如果是 w800 做 SPI 主机, 就参考 demo 目录下 wm_master_spi_demo. c.
如果是 w800 做 SPI 主机, 就参考 demo 目录下 wm_master_spi_demo. c.
tick 最小改到 1000, 不能再小了. 关于延时, 如果延时时间大于 tick 值, 可以用 tls_os_time_delay (N * tick) 来实现, 如果想延时更小的时间, 可以自己写个 for 循环调用__NOP () ; 接口来延时, 具体循环多少次可以用个 IOpin 拉高拉低, 用示波器或者逻辑分析仪来测量延时时间长短.
tls_os_time_delay (1 * HZ) ;
w800 做 softap 时不会去连接路由器, 它的作用并不是网络覆盖范围变大, 而是某些情况下需要起一个热点创造一个局域网环境来通信.
g_crypto_ctx. gpsec_lock 定义的是一个互斥锁, 在 SDK 的初始化时有调用 tls_crypto_init, 在这里创建了该信号量, 初始值是 1, 所以在没有其他地方用到该模块时, 调用 tls_os_sem_acquire (g_crypto_ctx. gpsec_lock, 0) ; 会立即返回接着往下执行. 如果有其他地方调用了就会等待, 直到能获取到信号量才能接着往下执行, 起到一个互斥锁的功能. 调用 tls_os_sem_acquire 获取, 信号量的个数会减一, 调用 tls_os_sem_release 释放, 信号量的个数会加一, 这两个接口是成对使用的. 在使用信号量实现互斥锁的功能时, 创建信号量时初始值会设置为 1, 这样有一个地方获取了锁的使用权后, 其他地方就需要等待这里释放了才能获取, 起到防止出现同一个模块或者变量或者接口被同时操作的情况. 并不是一个物理信号.
可以看下技术文档下面的 "WM_W800_SDK_DEMO 使用指导_V1. 5. pdf" , 需要先打开联网和 mqtt 的 demo 宏, 编译固件, 然后需要先发送联网的命令, 联网成功后再发送 mqtt 的命令. 但是 demo 中的服务器是不可用的, 需要换成自己的服务器地址, 端口号, client id 等相关的参数. 或者用 mqtt. isme. fun: 1883 试下. https: //www. winnermicro. com/html/1/156/158/558. html
为什么用 w800 给自己的串口发送 AT 指令的? AT 指令是上位机通过串口控制 W800 工作的, 如果是用代码, 那就是在 W800 上做二次开发, 直接调用相关的接口来实现功能就可以了, 不需要用到 AT 指令. 如果用自己的 APP 蓝牙配网, 可以参考官网的 APP 代码把蓝牙配网的功能加到自己的 APP 中, 这样就不需要改动 W800 的代码了. 也可以开发自己的配网协议, 只是需要在 W800 端配套实现对应的协议.
旋转编码器就是 2~3 个普通的 IO 口, 用 W800 的 GPIO 设置为输入模式连接就可以. 剩下的就是读 GPIO 的状态, 然后根据旋转编码器的时序来判断旋转方向.
联网成功后, 调用 gethostbyname 接口来获取域名对应的 IP 地址.
SDK 的 doc 目录下有 w800_apis. chm 文件, 里面有各个模块的接口. 具体使用 demo 目录下都有相关的 demo 参考.
DNS server 是 W801 做 softap 模式时用到的, 而且只是把 dnsname 和自己的 IP 地址对应, 对于应用层来说, 一般不会用到这里的接口.
WIFI 协议这部分是封在库里面的, 没有对外开放. 按你的描述应该是需要改动库里面的代码才能实现的. 目前是没有支持私有协商协议的方式的.
SPI DEMO 里有 DMA 的使用.
新建文件夹. rar
更新下这两个文件的改动试下, 然后初始化的时候 hpmu. ClkSource 选 PMU_CR_32KRCBYPASS, 这种情况下 32K 时钟是从 40M 分出来的, 会比较准确, 在 sleep 模式下可以用作时钟源, 而 PMU_CLKSOURCE_32RC 是用的 32K 震荡产生的, 会有误差.
我现在手头没有工程了, 就改那几个地方就行, 你目前的问题是卡在哪一步了, 具体描述下
问 w800 如何通过 SPI 连接光传感器