本帖最后由 lymzzyh 于 2018-9-19 17:27 编辑
3 m; z0 H4 q# v. Q4 a6 V9 I( P* ^7 U# `6 W% m# K
库版本V1.7.2 文件 stm32f4xx_hal_sd.c
' X# o* D8 E. s$ u1 }/ K- `* x- V" ?3 _行数 503
) E9 u: d% t$ ~' B代码节选:
' y+ d- K6 x4 E+ I/ \% `1 {6 t- HAL_StatusTypeDef HAL_SD_ReadBlocks(SD_HandleTypeDef *hsd, uint8_t *pData, uint32_t BlockAdd, uint32_t NumberOfBlocks, uint32_t Timeout), y6 K: H- d x4 I6 E
- {$ i( D4 |0 U+ ~1 K$ q) D
- SDIO_DataInitTypeDef config;6 N. C/ X* T1 s) p. |+ w8 a- M
- uint32_t errorstate = HAL_SD_ERROR_NONE;( [0 D! ?' a6 k* W( G% O$ B: b1 C( b
- uint32_t tickstart = HAL_GetTick();
) R' f/ w( r6 |+ E0 z) C - uint32_t count = 0U, *tempbuff = (uint32_t *)pData;
9 F6 O2 j* F1 w - /* ......... */
; e! g* B: C( V+ }% z+ j& c2 V - *tempbuff = SDIO_ReadFIFO(hsd->Instance);
: c0 C0 g0 d, c - /* ......... */7 R4 n/ C# L' b
- }
7 J, [, n; a/ [* b
复制代码 bug1: 此处pData 为u8 指针 强转 32位 编译后使用STM指令当pData未4字节对齐时将造成非对齐访问异常。
$ ^' S0 U7 ^9 x6 |1 A5 b+ I9 Abug2: 若pData未4字节对齐,使用DMA模式时会强行向低地址进行4字节对齐造成向低地址的内存越界。
# {" _9 {3 U' H- a$ Z5 F5 L注:其中图示代码为bug1所出现的bug点,修复建议:检测对齐,发现未对齐时使用一个32位变量进行数据搬运。& Z) \6 }1 ?9 C9 P$ L" ?6 K
bug2未进行查找错误点 望ST工程师自行查找。
; U- k6 J6 @' P0 d+ X3 f1 r/ n1 |
8 K& ? v5 q; J5 [ ]$ R9 B/ b& z另:对于未知的字节流数据进行非数据等长指针的强制类型转换的这种低级错误发生的ST身上令我等非常失望,希望相关人员(大学生临时工)尽快修复
( x& v- x* C5 d2 J9 g3 G |
不关编译器的事情 指针强转是编译器无法预判是否对齐的 所以只能用STM指令去处理
回答三连:是这样的,暴露接口不对,该改
不过作为一个库,也确实应该考虑完善一些。
评分
查看全部评分
淡定一点,骚年
不不不 这是防喷手段 我已经帮喷子 喷过我自己了
评分
查看全部评分
到现在都没有FAE现身说法呢