
利用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安全启动》学习心得
的确磁力的数据有时能读上来,有时读不上来。我暂时不能做实验找到问题的根源。你找出来可以告诉我。
可能是因为打开了自动排除干扰模式,在检测到干扰很大的时候就把磁力计甩掉。
但是这只是我的推测,好久没有玩了。不好意思
是吗,这部分的更改我没有印象。时间有点久了,我暂时试不了。真不好意思
你还需要原版吗,给我邮箱我发给你。我抽空又下了一遍
你贴的代码是不是偶尔也可以读出磁力计...
多谢!我的邮箱 lzm1019@hotmail.com
====
题外话,Invensense的代码结构,没有对应的文档说明,读起来极不习惯,颇费周折去厘清其关系。找到您的帖子,方便许多。$ P( `; R" a, l7 Y4 R {0 D
我是新手,刚学习EMD6.12,想移植到STM32F411;无意对比了下,发现invensense_adv.h中的变更,所以请教下。
Sorry,刚理解错了,以为您有新的代码,提供了邮箱。
========0 @8 j4 G/ k, e& ~( R
关于emd6.12的源码,我能下载;之前是应#38楼 rushidao 的需要,分享baidupan链接。
ok,很抱歉没能帮到你。祝你成功
另外建议你看一下飞兆半导体的传感器FIS1100,或者ST的iNemo-M1。这两者都有比较好的库。前者的硬件因为电压问题不方便STM32使用。后者的算法似乎有些问题,校准部分不太好。如果你刚好调试过,能否交流一下经验。
Fairchild的没用过;
目前用的是MPU9250和ST的LSM9DS1;原计划同步开展的。但实际因经验不足(或者说全无经验),先从MPU9250开始。
这两天,基于您共享的移植文件在学习;我用的是STM32F411CEU6,按您的简单移植说明,处理后,编译ok;但是download板子上,串口没有任何输出。
调试情况:
1)在板上调试,debug卡在启动文件中的SystemInit,意思是还没有进入main();随后将setsysclk()注释掉,再仿真,最终发现停滞在Gyro的INT_PIN_CFG配置中。% M7 H9 t0 x* c+ H( R
----------
if (i2c_write(st.hw->addr, st.reg->int_pin_cfg, 1, &tmp))1 ?- ]; `- c. q6 Z- F
return -1;2 w! R& N! F7 @- V: o
-------------
, W9 R: }5 I* l" v8 K* [ z
2)模拟仿真,不带板的情况,则停滞在USART的发送循环中;0 `) Z# M' A% c: t0 ^
-------------------
//* Loop until the end of transmission
while (USART_GetFlagStatus(USARTx, USART_FLAG_TC) == RESET)
{}4 V R$ e' I9 l& A2 h0 X. W
-----------------1 O: D( X- c0 k: L5 E6 y; x2 k; b5 z
我的理解,无板时,USART发送接收无效,导致死循环。( c! i6 r3 J" m
# `, ]9 L3 B3 z6 i, H
后面,用最笨的方法,直接以LED来指示,确定代码停滞在mpu_set_bypass()中;但原因不明。: Z! F7 ^0 f5 Y
再麻烦您一下。
之前您提到的STM32F411的移植代码,还能找到吗?可否提供我参考下。多谢!0 {/ M8 W, |( S' v; D2 ^5 D x" ?
===============: R+ [+ r$ t9 u D7 g
手头没有STM32F4-Discovery的板子,没法验证原始工程是否能正常输出9轴数据。看您之前的记录,移植后是正常输出了的,具体情形如何呢?我之前基于您的F401KeilPorting的代码,编译OK,运行后串口无输出。# n1 X# A! U- F* i+ X
----------------
另,刚尝试安装Invensense的AppNote1,安装Python环境,运行eMPL-Client.py,闪退;报错如下:
--------------
c:\Python27>python eMPL612\eMPL-client.py 6
Traceback (most recent call last):
File "eMPL612\eMPL-client.py", line 273, in <module>
def four_bytes(d1, d2, d3, d4):
File "eMPL612\eMPL-client.py", line 12, in __init__
File "c:\Python27\lib\site-packages\serial\serialwin32.py", line 31, in __init__. `; A+ {4 h( w+ U) T3 I7 }7 V
SerialBase.__init__(self, *args, **kwargs)# d T6 R' C! ]9 F2 ]& R
File "c:\Python27\lib\site-packages\serial\serialutil.py", line 180, in __init__
self.open()1 S8 T+ K* A& W/ W; b- I9 c7 q, K
File "c:\Python27\lib\site-packages\serial\serialwin32.py", line 47, in open
if port.upper().startswith('COM') and int(port[3:]) > 8:# w, |1 G8 Q8 \3 d
AttributeError: 'int' object has no attribute 'upper'4 t2 l! k q( d# I: I' [
---------------------
请务必注意stack和heap的尺寸。因为库中用到了malloc来分配内存,所以stack用到了很多。除此之外,接线如果用的是杜邦线之类的临时连线,请确保连线稳定。如果有必要的话换一组线,甚至传感器来做相同的实验。411的程序理论上是一致的。但是我最近在外面用一台老笔记本,之前的资料保存在家里的台式机上。但是我尽量基于401的还原一份411的稍后给你。但是这份我不确定是否能用。另外建议你最好从追踪代码开始,如果压根就没有进到main函数里面,这很可能是工程或者硬件的问题。
关于python的问题,我觉得是串口驱动的问题。如果没记错的话,需要安装pyserial和game两个插件。这样才能正常运行。
所以我觉得是你硬件连接或者时钟设置的问题,请先确保这里没问题。SystemInit如果都不能正常进入那说明这里你没有修改好。如果你从官方的代码直接移植的话,时钟这个问题必须要注意的。因为F407的最大时钟时168MHZ而401是84M,411是100M。所以这里注意一下。" `- O6 G+ D2 `# H
另外确保你的MPU连线正确,单我估计这里没问题。
多谢!
关于物理连线,确认过多次,应该没有问题。
昨天调试,发现无法跳转main(),实际应操作失误。但具体是怎么回事,也高不清楚。
将SetSysClock()注释取消后,今天在线调试,可一路运行至最终发现停滞在Gyro的INT_PIN_CFG配置中。
----------
if (i2c_write(st.hw->addr, st.reg->int_pin_cfg, 1, &tmp))
return -1;# V9 V) C c# [! J
-------------
关于Gyro的int_pin_cfg,查证其对应寄存器,在上述代码前一行,已配置
-----------------------------------( A9 g w8 e1 d* f% x
tmp |= BIT_LATCH_EN | BIT_ANY_RD_CLR; 8 ~. t+ r5 H6 x Z4 x) f
-----------------------------------
比较费解为什么配置setup_compass() -> mpu_set_bypass(1)执行到i2c_write()导致跑飞?
至于时钟:4 i& [( v0 s9 ~, P+ F+ N
1)您提到的3种芯片的最大时钟的区别,之前已了解;但如何变更,尚不清楚;+ Q# s0 X$ L7 S# t. o5 y+ v
2)查看SystemInit(),其默认就是设置系统时钟为HSI(16MHz);4 D) W# N* a, k+ j
3)另仔细读了一遍SetSysClock()函数,根据主芯片型号STM32F411CE,其配置代码主要是配置PLL;并未开启HSE_ON,因此我理解,系统时钟依然是HSI(16MHz)。
4)SetSysClock()中有两处开启HSE_ON,但分别被条件编译#if defined(xxx)和#if defined(USE_HSE_BYPASS)限定。前者肯定不对;后者,因为我使用的是无源晶体,没有使能USE_HSE_BYPASS。0 ^8 z; j; u* T, m. X9 F) h
若要求配置系统时钟为HSE,是否在别的地方有配置HSE_ON呢?麻烦指点,多谢!
# j2 t% v; y( S g* R- A6 \, l a, p
首先你不能选择SetSysClock,这样时钟的配置应该会除了问题。之前你的程序卡在这里,就是因为时钟设置的问题。如果你用的是nucleo,那么主芯片的时钟是从另一个片子的MCO来得,是8MHZ。我记得之前观察程序发现使用的是外部时钟。时钟的配置需要做一些修改,怎么修改呐。在main函数的开头,有boardInit的部分,这里面的开始就是配置了一下系统时钟,然后是systick。你而SystemCoreClock是系统的宏定义,在原始代码中是168000000。而411则不是这个数值,这个数值与你最终配置的有关。但是这里你是直接追踪不到时钟配置的,时钟的配置是在SystemInit里面执行的,起初会使用HSI时钟,然后再通过SetSysClock()来是能PLL时钟。但是这部分的具体工作你最好查一下网络。