main.lua 5.4 KB

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