main.lua 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. -- LuaTools需要PROJECT和VERSION这两个信息
  2. PROJECT = "sfuddemo"
  3. VERSION = "1.0.0"
  4. log.info("main", PROJECT, VERSION)
  5. sys = require("sys")
  6. --添加硬狗防止程序卡死
  7. if wdt then
  8. wdt.init(9000)--初始化watchdog设置为9s
  9. sys.timerLoopStart(wdt.feed, 3000)--3s喂一次狗
  10. end
  11. -- spi_id,pin_cs
  12. local function sfud_spi_pin()
  13. local rtos_bsp = rtos.bsp()
  14. if rtos_bsp == "AIR101" then
  15. return 0,pin.PB04
  16. elseif rtos_bsp == "AIR103" then
  17. return 0,pin.PB04
  18. elseif rtos_bsp == "AIR105" then
  19. return 5,pin.PC14
  20. elseif rtos_bsp == "ESP32C3" then
  21. return 2,7
  22. elseif rtos_bsp == "ESP32S3" then
  23. return 2,14
  24. elseif rtos_bsp == "EC618" then
  25. return 0,8
  26. elseif string.find(rtos_bsp,"EC718") then
  27. return 0,8
  28. else
  29. log.info("main", "bsp not support")
  30. return
  31. end
  32. end
  33. sys.taskInit(function()
  34. -- log.info("等5秒")
  35. sys.wait(1000)
  36. local spi_id,pin_cs = sfud_spi_pin()
  37. if not spi_id then
  38. while 1 do
  39. sys.wait(1000)
  40. log.info("main", "bsp not support yet")
  41. end
  42. end
  43. log.info("sfud", "SPI", spi_id, "CS PIN", pin_cs)
  44. spi_flash = spi.deviceSetup(spi_id,pin_cs,0,0,8,20*1000*1000,spi.MSB,1,0)
  45. log.info("sfud", "spi_flash", spi_flash)
  46. local ret = sfud.init(spi_flash)
  47. if ret then
  48. log.info("sfud.init ok")
  49. else
  50. log.info("sfud.init Error")
  51. return
  52. end
  53. log.info("sfud.getDeviceNum",sfud.getDeviceNum())
  54. local sfud_device = sfud.getDeviceTable()
  55. if sfud.getInfo then
  56. log.info("sfud.getInfo", sfud.getInfo(sfud_device))
  57. end
  58. local test_sfud_raw = false
  59. local test_sfud_mount = true
  60. if test_sfud_raw then
  61. log.info("sfud.eraseWrite",sfud.eraseWrite(sfud_device,1024,"luatos-sfud1234567890123456789012345678901234567890"))
  62. log.info("sfud.read",sfud.read(sfud_device,1024,4))
  63. end
  64. if test_sfud_mount then
  65. local ret = sfud.mount(sfud_device,"/sfud")
  66. log.info("sfud.mount", ret)
  67. if ret then
  68. log.info("sfud", "挂载成功")
  69. log.info("fsstat", fs.fsstat("/sfud"))
  70. -- 挂载成功后,可以像操作文件一样操作
  71. local f = io.open("/sfud/test", "w")
  72. f:write(os.date())
  73. f:close()
  74. log.info("sfud", io.readFile("/sfud/test"))
  75. -- 文件追加
  76. os.remove("/sfud/test2")
  77. io.writeFile("/sfud/test2", "LuatOS")
  78. local f = io.open("/sfud/test2", "a+")
  79. f:write(" - " .. os.date())
  80. f:close()
  81. log.info("sfud", io.readFile("/sfud/test2"))
  82. else
  83. log.info("sfud", "挂载失败")
  84. end
  85. end
  86. end)
  87. -- 用户代码已结束---------------------------------------------
  88. -- 结尾总是这一句
  89. sys.run()
  90. -- sys.run()之后后面不要加任何语句!!!!!