newlibc memcpy 存在问题

背景

sdk 中发现 memcpy 函数没有达到预期,执行后,目的地址与源地址中的内容不一致。

复现方法

通过单步调试 memcpy 汇编代码,发现使用了 ldrh 指令,该指令在对 uncacheable memory 同时该 memory 非对齐的情况下,并不会按照预期执行(从内存 load 两字节到目标寄存器),如下汇编代码。

复制代码
.text
.global my_memcpy
.type my_memcpy, %function
my_memcpy:
    push    {r10,lr}
    ldrh    r10, [r1]  # 如果 r1 不对齐且为 uncacheble,并不会 load 2 字节到 r10
    strh    r10, [r0]
    pop     {r10, pc}

.size my_memcpy, .-my_memcpy

关闭了非对齐访问检查,所以不会产生 fault

该指令执行结果,如图:

实锤

newlibc 中 memcpy 存在非对齐访问,某些 cpu (cortex-a5 与 cortex-a9)非对齐访问时,行为不一致,可参考 ARM ArchitectureReference Manual ARMv7-A and ARMv7-R edition.pdf 第 109 页。

对于非对齐访问(cpu 使能非对齐访问,SCTLR 寄存器的 bit1),会产生不可预测行为。

相关推荐
梁洪飞6 小时前
kernel 内存知识
linux·arm开发·嵌入式硬件·arm
梁洪飞16 小时前
clk学习
linux·arm开发·嵌入式硬件·arm
乙酸氧铍1 天前
【imx6ul 学习笔记】Docker 运行百问网 imx6ul_qemu
linux·docker·arm·qemu·imx6ul
皮蛋sol周1 天前
嵌入式学习数据结构(二)双向链表 内核链表
linux·数据结构·学习·嵌入式·arm·双向链表
梁洪飞2 天前
pmu+power控制+pmic
arm开发·嵌入式硬件·arm
TroubleBoy丶3 天前
麒麟V10-ARM架构Docker启动报错
运维·docker·容器·arm·麒麟v10
梁洪飞4 天前
使用uboot学习I2C
嵌入式硬件·arm
suyong_yq6 天前
RUHMI & RA8P1 教程 Part4 - 使用 RUHMI 转换 AI 模型文件
人工智能·ai·嵌入式·arm
KeLin&7 天前
讯为iTOP4412-Qt5.7环境搭建
开发语言·arm开发·qt·arm
一池秋_9 天前
HK1 box飞牛os
arm