完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我正在使用LSM9DS1。
我想用中断读取加速度计数据。问题是,当我启用'数据就绪中断'(INT_DRDY_XL)并读取和打印STATUS_REG时,要查看是否已生成一个或多个中断,它会返回0b00000101。但它应该是0b10000101,因为应该生成一个新的中断。 我的传感器寄存器是: void init_accel_interrupt(void){ uint8_t reg_value = 0; reg_value = 0x07&lt;&lt; 3; //启用x,y,z轴 WRITE_REG(CTRL_REG5_XL,reg_value); reg_value = 0; reg_value =(0x06&lt;&lt; 5); // 952 Hz odr reg_value | =(0x02&lt;&lt; 3); // + -4g reg_value | =(0x01&lt;&lt; 2); // bw根据bw [1:0]选择 reg_value | =(0x00&lt;&lt; 0); // 408 hz bw WRITE_REG(CTRL_REG6_XL,reg_value); reg_value = 0; reg_value =(0x01&lt;&lt; 7); //高分辨率 reg_value | =(0x03&lt;&lt; 5); // cutofffrequency odr / 50 = 0 odr / 100 = 1 odr / 400 = 3 reg_value | =(0x01&lt;&lt; 2); //已启用过滤器 WRITE_REG(CTRL_REG7_XL,reg_value); reg_value =(0x01&lt;&lt; 0); WRITE_REG(INT1_CTRL,reg_value); //数据就绪中断int1 reg_value =(0x01&lt;&lt; 0); WRITE_REG(INT2_CTRL,reg_value); //数据就绪中断int2 reg_value =(0x01&lt;&lt; 4)| (0x01&lt;&lt; 5); //开漏,低电平有效 WRITE_REG(CTRL_REG8,reg_value); reg_value =(0x01&lt;&lt; 3); //数据可用计时器已启用 WRITE_REG(CTRL_REG9,reg_value); 我的循环是: 而(1){ rv = read_reg(STATUS_REG_0); // printf_P(PSTR('%i n'),rv); rv = read_reg(STATUS_REG_1); // printf_P(PSTR('%i n'),rv); rv = read_reg(INT_GEN_SRC_XL); // printf_P(PSTR('%i n'),rv); _delay_ms(1);输出为:5 五 0 以上来自于谷歌翻译 以下为原文 i am working with the LSM9DS1. I want to read the accelerometer data using interrupts. The problem is that, when i enable the 'data ready interrupt'(INT_DRDY_XL) and read and printf STATUS_REG, to see whether one or more interrupts have been generated, it gives me back 0b00000101 . But it should be 0b10000101 because a new interrupt should have been generated. my sensor register are: void init_accel_interrupt(void){ uint8_t reg_value =0; reg_value = 0x07 << 3; // x,y,z axis enabled write_reg(CTRL_REG5_XL,reg_value); reg_value = 0; reg_value = (0x06 << 5); // 952 Hz odr reg_value|= (0x02 << 3); // +-4g reg_value|= (0x01 << 2); // bw select according to bw[1:0] reg_value|= (0x00 << 0); //408 hz bw write_reg(CTRL_REG6_XL,reg_value); reg_value = 0; reg_value = (0x01 << 7);// high resolution reg_value|= (0x03 << 5); // cutofffrequency odr/50= 0 odr/100 =1 odr/400=3 reg_value|= (0x01 << 2); // filter enabled write_reg(CTRL_REG7_XL,reg_value); reg_value = (0x01 << 0); write_reg(INT1_CTRL,reg_value); // data ready interrupt int1 reg_value = (0x01 << 0); write_reg(INT2_CTRL,reg_value); // data ready interrupt int2 reg_value = (0x01 << 4) | (0x01 << 5) ;// open drain, active low write_reg(CTRL_REG8,reg_value); reg_value = (0x01 << 3); // data available timer enabled write_reg(CTRL_REG9,reg_value); }and my loop is: while (1){ rv = read_reg(STATUS_REG_0);// printf_P(PSTR('%i n'),rv); rv = read_reg(STATUS_REG_1);// printf_P(PSTR('%i n'),rv); rv = read_reg(INT_GEN_SRC_XL);// printf_P(PSTR('%i n'),rv); _delay_ms(1);output is : 5 5 0 |
|
相关推荐
1个回答
|
|
STATUS_REG中的IG_XL位不会被设置
数据准备好了加速度计数据就绪信号控制XLDA位。 IG_XL位将由来自INT_GEN_CFG_XL寄存器中配置的中断发生器的中断设置,您不使用该中断。 以上来自于谷歌翻译 以下为原文 The bit IG_XL in the STATUS_REG will not be set by data ready. Accelerometer data ready signal controls the XLDA bit. The IG_XL bit would be set by interrupt from interrupt generator configured in INT_GEN_CFG_XL register which you don't use. |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2738 浏览 1 评论
3241 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1810 浏览 1 评论
3650 浏览 6 评论
6039 浏览 21 评论
1339浏览 4评论
201浏览 3评论
对H747I-DISCO写程序时将CN2的st-link复用为usart1,再次烧录时无法检测到stlink怎么解决?
353浏览 2评论
STM32G474RE芯片只是串口发个数据就发烫严重是怎么回事?
444浏览 2评论
STM32处理增量式编码器Z信号如何判断中断是正转的还是反向转的?
275浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-25 09:17 , Processed in 1.055335 second(s), Total 80, Slave 63 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号