RISC-V系列MCU不支持非对齐访问?
// static const uint32_t s_keys[32];
// uint8_t rseq[16];
f->key[4] = s_keys[((keyid + 1) & 0x0000001F)] ^ (*(uint32_t *)&hdr->rseq[1]);

如上面代码,rseq是16字节数据。运行上面代码的时候,直接就是mcause = 4的hardfault,即非对齐load address错误。网上搜了一下,好像说RISC-V还是像CORTEX-M系列那样,能访问,只是速度一样会很慢。但是现在直接hardfault了。不允许非对齐访问不是ARM7年代的问题了?现在移植代码,有不少这些非对齐访问。非常麻烦。是不是编译器参数修改一下就可以非对齐范围?

您好,内核不支持非对齐访问,但编译器会按照字节访问依次访问hdr->rseq[1],hdr->rseq[2],hdr->rseq[3],hdr->rseq[4]后组成一个字返回。附件为测试例程,你可以看一下。

icon_rar.gifCH32V307 Test.zip

image.png


image.png

image.png

这是我的程序编译出来的汇编代码,在0x632那行hardfault了。


您好,若方便,可将工程程序发过来看一下(lzs@wch.cn),这边结合程序整体看一下


只有登录才能回复,可以选择微信账号登录