
利用STM32MP1和STM32MP2为嵌入式Linux提供有效的安全措施:供当今决策者参考的3条宝贵经验
有奖直播 | STM32MP2x 资源隔离架构 (RIF) 介绍与使用
白皮书下载|边缘 AI 变革:MCU集成 NPU 的破局与领航
OpenSTLinux:为STM32 MPU生态系统带来超强助力
【STM32MP257】轻松搭建A35 Linux编译及调试环境
【STM32MP257】🥳STM32MP257-DK-开发板开箱体验
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【STM32MPU 安全启动】 TF-A BL2 TrustedBoot原理学习
《STM32MPU安全启动》学**结
《STM32MPU安全启动》学习心得
这里有错字
谢谢,我就是个白字布袋。
如果是spi方式推荐你看看这里:http://hom.hackpad.com/SmartIMU-E9zzbSI7QyK。文件可以在这里下载:http://github.com/Hom-Wang/SmartIMU 我暂时没有试过它的算法。但是我看过他的调试记录,个人觉得,这朋友还是挺严谨的,应该可以读取。我可能忙完算法和测试之后,试试添加SPI。
但问题是I2C融合之后的更新的速率能够达到200hz这还不够吗?当然有时候有利用使用SPI的。
个人之见:SPI读取并不难,对于姿态传感器最难的是算法.5 O- x+ I; r) i; ?5 }) a V
; Y% e7 n$ v7 M' k0 J5 z6 E- b+ M
还有朋友,我才不是什么大师,我其实也只能算是beginner。我的帖子有问题你直接指正,谢谢、
你好,这个我已经参考过了,同样没法读取磁力计的数据!( \' b+ D2 U$ n% W$ V- P
虽然I2C可以完成,但是如果有SPI的方式,我觉得是SPI更好,毕竟读取
速度比I2C要快。9 Z3 M" x8 i6 X! k1 n% u4 a& K
200hz是可以,不过如果通过SPI来加快单次的通信速率就更好了!
# |5 }5 ]& b, g) f" W; o( {
但是在代码里面看,也确实是转成了这种模式,7 E' _: A. Q4 L8 [
这个是写入到off set 寄存器里面去,但是如果是把这个偏移值带入到dmp中去,也就是 n! a2 f8 u8 T E) x! M
dmp_set_gyro_bias(gyro_bias);dmp_set_accel_bias(accel_bias); 的时候,我看到的一个' v. q. b# n. s6 Z
别的代码是
int result;
long gyro_bias[3], accel_bias[3]; , q C: v- f- q7 D& k
result = mpu_run_self_test(gyro_bias, accel_bias); & U, n" O/ O: ?7 G/ q+ M. a
if (result == 0x07)
{2 y8 L% T9 n* Y# v$ T
/* Test passed. We can trust the gyro data here, so let's push it down to the DMP.*/ Y4 Q; \/ j, o
float gyro_sens;5 j* f( y- b' J! C' f: B2 F0 v6 L; t
unsigned short accel_sens;
mpu_get_gyro_sens(&gyro_sens);
+ g; ^7 ?+ P( h- C$ A( Q
gyro_bias[0] = (long)(gyro_bias[0] * gyro_sens);( o$ ?% ]* v# _
gyro_bias[1] = (long)(gyro_bias[1] * gyro_sens);
gyro_bias[2] = (long)(gyro_bias[2] * gyro_sens);" B5 b9 h. A' h& A- c
dmp_set_gyro_bias(gyro_bias); 0 Y$ k7 ~ O s
mpu_get_accel_sens(&accel_sens); @" T! o N/ c+ I# n, O- Y
accel_bias[0] *= accel_sens;
accel_bias[1] *= accel_sens;
accel_bias[2] *= accel_sens;$ K8 \2 r3 |3 l8 \: b
dmp_set_accel_bias(accel_bias);
2 w3 I& A3 ~* i" i! ^. I' R# w
return 0;
}
else) }4 R5 d' U3 z! l6 K7 B
return 1;7 j4 r7 |2 i3 Y ]- S
! H# c# x* h& [5 ?/ z& k3 q' N
我比较愚笨,我反复比较了这个函数,在mpu_run_self_test(gyro_bias, accel_bias); 中获得的gyro_bias, accel_bias是q16格式的,然后那个& y4 ], q: q. A' P4 G% W
dmp_set_gyro_bias(gyro_bias);dmp_set_accel_bias(accel_bias); 要求输入的参数也是q16,而且我实在想不明白那里获得偏移的时候,获得的q16格式的数,乘以一个范围值做什么用,费解这里,,还是说人家这里就是错的,,上面的代码是原子的开发板里面的一段截取的代码,我没用,给注释掉了,换成把偏移存进去off set寄存器里面了,
我没有测试过hom的方案,但是我记忆中他的硬件连接的的确是SPI。我又看了一般片子的PS,MPU9250内部集成的是AK8963。AK8963是I2C的,但是不知道Invensense在封装的时候是怎么处理的。" ~8 C; l f, y M4 ^$ Q
但是请看下面的图,它让我似乎明白了些东西。但还需要实验验证。
注意看图中ACC和Gyro与compass的区别。Got it?
实际上访问Acc和Gyro读取的直接是内部寄存器,用SPI和I2C都行。但是Compass却不是。它使用的I2C的辅助接口来连接的。在SPI当作通讯接口时,MPU内部实际上是通过I2C来和Compass通讯的。但是是否是自动的呐?读取的数据写到了哪里呐?必须再深入了解。今天有些累了,先这样。回头在看文档做实验。
我也看过,官方库i2c是读取了地磁数据的,地磁数据是通过bypass模式,把ak8xxx磁力计直接当作另一个器件,通过它的地址来读取的,而使用spi模式 只能通过内部i2c matster模块来读取,我试过无数方法,从来没有读过正常值,唯一有一次只能读到了ID号,其他数据都不行
那我回头试试,按道理SPI比I2C更容易读取。先读一下生数据试试。hom wang的就是通过SPI读取的。
我参考过他的做过一版PCB,因为这个问题没解决,我换用了MPU6500+HMC5983,后来陀螺仪和加表我改用了MAX21105,正在打样