main.lua 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. -- LuaTools需要PROJECT和VERSION这两个信息
  2. PROJECT = "test"
  3. VERSION = "1.0.0"
  4. -- sys库是标配
  5. _G.sys = require("sys")
  6. sys.taskInit(function()
  7. local _,tick_us = mcu.tick64()
  8. local hw_timer_id = 1
  9. local capture_pin = pin.PD06
  10. local out_pin = pin.PD07
  11. local buff1 = zbuff.create(100)
  12. local buff2 = zbuff.create(100)
  13. local cnt1,cnt2,i,lastTick,bit1Tick,nowTick,j,bit
  14. mcu.setXTAL(true) --为了测试更准确,调整到外部时钟
  15. bit1Tick = 100 * tick_us
  16. while 1 do
  17. --测试单总线DHT11
  18. ioqueue.stop(hw_timer_id) --确保硬件定时器1是空闲的
  19. ioqueue.init(hw_timer_id,100,1) --io队列设置100个命令,重复1次,实际上用不到那么多命令
  20. ioqueue.setgpio(hw_timer_id, capture_pin, true, gpio.PULLUP) --数据线拉高,上拉输入
  21. ioqueue.setdelay(hw_timer_id, 10000, 0, false) --单次延迟10ms
  22. ioqueue.setgpio(hw_timer_id, capture_pin, false, 0, 0) --数据线拉低
  23. ioqueue.setdelay(hw_timer_id, 18000, 0, false) --单次延迟18ms
  24. ioqueue.set_cap(hw_timer_id, capture_pin, gpio.PULLUP, gpio.FALLING, 100000 * tick_us) --设置成下降沿中断捕获,最大计时100000us, 上拉输入,这里已经代替了输出20~40us高电平
  25. for i = 1,42,1 do
  26. ioqueue.capture(hw_timer_id) --捕获42次外部中断发生时的tick值,2个start信号+40bit数据
  27. end
  28. ioqueue.cap_done(hw_timer_id, capture_pin) --停止捕获
  29. ioqueue.setgpio(hw_timer_id, capture_pin, true, gpio.PULLUP) --数据线拉高,上拉输入
  30. ioqueue.start(hw_timer_id)
  31. sys.waitUntil("IO_QUEUE_DONE_"..hw_timer_id)
  32. ioqueue.stop(hw_timer_id)
  33. --开始解析捕获的数据
  34. cnt1,cnt2 = ioqueue.get(hw_timer_id, buff1, buff2)
  35. if cnt2 ~= 42 then
  36. log.info('test fail')
  37. goto TEST_OUT
  38. end
  39. lastTick = buff2:query(6 + 2, 4, false) --以第二次中断的tick作为起始tick,第一次的tick没有用
  40. j = 0
  41. bit = 8
  42. buff1[0] = 0
  43. for i = 2,41,1 do
  44. --检查一下是不是对应pin的下降沿中断,不过也不太需要
  45. if buff2[i * 6 + 0] ~= capture_pin or buff2[i * 6 + 1] ~= 0 then
  46. log.error("capture", buff2[i * 6 + 0], buff2[i * 6 + 1])
  47. end
  48. --通过计算tick差值来确定是bit1还是bit0
  49. nowTick = buff2:query(i * 6 + 2, 4, false)
  50. buff1[j] = buff1[j] << 1
  51. if (nowTick - lastTick) > bit1Tick then
  52. buff1[j] = buff1[j] + 1
  53. end
  54. bit = bit - 1
  55. if bit == 0 then
  56. j = j + 1
  57. bit = 8
  58. end
  59. lastTick = nowTick
  60. end
  61. buff1[5] = buff1[0] + buff1[1] + buff1[2] + buff1[3]
  62. if buff1[4] ~= buff1[5] then
  63. log.info('check fail', buff1[4], buff1[5])
  64. else
  65. log.info("湿度", buff1[0] .. '.' .. buff1[1], "温度", buff1[2] .. '.' .. buff1[3])
  66. end
  67. ::TEST_OUT::
  68. ioqueue.release(hw_timer_id)
  69. --测试高精度固定间隔定时输出,1us间隔翻转电平
  70. ioqueue.init(hw_timer_id, 100, 100)
  71. ioqueue.setgpio(hw_timer_id, out_pin, false,0,1) --设置成输出口,电平1
  72. ioqueue.setdelay(hw_timer_id, 0, 45, true) --设置成连续延时,每次1个us,如果不准,对time_tick微调,延时开始
  73. for i = 0,40,1 do
  74. ioqueue.output(hw_timer_id, out_pin, 0)
  75. ioqueue.delay(hw_timer_id) --连续延时1次
  76. ioqueue.output(hw_timer_id, out_pin, 1)
  77. ioqueue.delay(hw_timer_id) --连续延时1次
  78. end
  79. ioqueue.start(hw_timer_id)
  80. sys.waitUntil("IO_QUEUE_DONE_"..hw_timer_id)
  81. log.info('output 1 done')
  82. ioqueue.stop(hw_timer_id)
  83. ioqueue.release(hw_timer_id)
  84. sys.wait(500)
  85. --测试高精度可变间隔定时输出
  86. ioqueue.init(hw_timer_id, 100, 100)
  87. ioqueue.setgpio(hw_timer_id, out_pin, false,0,1) --设置成输出口,电平1
  88. ioqueue.setdelay(hw_timer_id, 0, 45) --单次延迟1us,如果不准,对time_tick微调
  89. ioqueue.output(hw_timer_id, out_pin, 0) --低电平
  90. ioqueue.setdelay(hw_timer_id, 1, 45) --单次延迟2us
  91. ioqueue.output(hw_timer_id, out_pin, 1) --高电平
  92. ioqueue.setdelay(hw_timer_id, 2, 45) --单次延迟3us
  93. ioqueue.output(hw_timer_id, out_pin, 0) --低电平
  94. ioqueue.setdelay(hw_timer_id, 3, 45) --单次延迟4us
  95. ioqueue.output(hw_timer_id, out_pin, 1) --高电平
  96. ioqueue.setdelay(hw_timer_id, 4, 45) --单次延迟5us
  97. ioqueue.output(hw_timer_id, out_pin, 0) --低电平
  98. ioqueue.setdelay(hw_timer_id, 5, 45) --单次延迟6us
  99. ioqueue.output(hw_timer_id, out_pin, 1) --高电平
  100. ioqueue.start(hw_timer_id)
  101. sys.waitUntil("IO_QUEUE_DONE_"..hw_timer_id)
  102. log.info('output 2 done')
  103. ioqueue.stop(hw_timer_id)
  104. ioqueue.release(hw_timer_id)
  105. sys.wait(500)
  106. end
  107. end)
  108. -- 用户代码已结束---------------------------------------------
  109. -- 结尾总是这一句
  110. sys.run()
  111. -- sys.run()之后后面不要加任何语句!!!!!