完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
在我的项目中,我使用了 LIS3DH 芯片。大部分时间处理器处于休眠状态。
处理器按时唤醒并超过冲击阈值。 在冲击阈值唤醒的情况下,我需要从唤醒信号之前的 FIFO 缓冲区(32 次测量)中读取数据 以及醒来后的一系列测量 (600-32)。 我怎么能这样做? 现在我正在读取测量值,同时等待 ZYXDA 寄存器就绪位 STATUS_REG(27h) 设置。FIFO 在 Stream 模式下始终启用。 但是当读取测量的 FIFO 部分时,此方法可能不起作用。从 FIFO 读取数据时是否应该更改读取算法? 我认为这是算法: 1. 通过观察 FIFO_SRC_REG(2Fh) 寄存器的 EMPTY 位读取唤醒时的 FIFO 32 测量值 2. 通过重置 FIFO_EN 寄存器 CTRL_REG5(24h) 来禁用 FIFO 3. 读取 600 - 32 测量等待 ZYXDA 位 STATUS_REG(27h) 还是有可能以某种方式更容易? 在 DocID17530 Rev 2 和 AN3308 文档中,我没有找到有关读取 FIFO 时 STATUS_REG (27h) 寄存器的 ZYXDA 位如何表现的问题的答案 |
|
相关推荐
1个回答
|
|
感谢你的回答。是的,该示例读取 FIFO 级别,然后读取相同数量的测量值。在我看来,我做得更简单——我在将 FIFO EMPTY 位设置为真正的位之前读取 FIFO(ํ 不参与与 FIFO 的交换。事实上,位 ZYXDA 不参与与 FIFO 的交换。
|
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2644 浏览 1 评论
3209 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1784 浏览 1 评论
3613 浏览 6 评论
5990 浏览 21 评论
940浏览 4评论
1317浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
585浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1304浏览 3评论
1362浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-25 13:06 , Processed in 1.169418 second(s), Total 78, Slave 61 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号