在ARM處理器(HT32F1655),寄存器的特定部分需要字訪問。從用戶手冊:力GCC與詞語訪問結構
請注意,AHB總線中的所有外設寄存器都只支持字訪問。
但是GCC正在產生一些ldrb
(負載字節)和strb
(存儲字節)在填充結構的說明。該結構是這個樣子:
typedef union {
struct {
uint32_t CKOUTSRC : 3; //!< CKOUT Clock Source Selection
uint32_t : 5;
uint32_t PLLSRC : 1; //!< PLL Clock Source Selection
uint32_t : 2;
uint32_t CKREFPRE : 5; //!< CK_REF Clock Prescaler Selection
uint32_t : 4;
uint32_t URPRE : 2; //!< USART Clock Prescaler Selection
uint32_t USBPRE : 2; //!< USB Clock Prescaler Selection
uint32_t : 5;
uint32_t LPMOD : 3; //!< Lower Power Mode Status
} __attribute__((packed)) __attribute__ ((aligned(4)));
uint32_t word;
} reg;
用法示例:
(*(volatile uint32_t*)0x40088000)->CKOUTSRC = 1;
生成類似的東西:
ldrb r2, [r1]
orr r2, r2, #1
strb r2, [r1]
當我需要:
ldr r2, [r1]
orr r2, r2, #1
str r2, [r1]
有什麼強制gcc只有g的方法嵌入指令可以訪問整個單詞嗎?某些選項(-mno-unaligned-access
)讓GCC生成字訪問,但只有當一個字節是不是4字對齊。
有一個-mslow-bytes
應該做正確的事情,但它似乎選項臂無 - EABI - 海合會不存在。
理想的情況下,會有辦法迫使這個僅在受影響的結構。
請,沒有「不使用位域」的答案。我知道這些缺點,但我有能力在這裏控制使用的編譯器,所以我不擔心可移植性。
將「打包位圖覆蓋到設備寄存器上」的代碼會使此更好更清晰。 – chux
只需決定一組好的函數來提供所需的訪問權限,並在需要時使用內聯彙編編寫代碼。 –
@DavidSchwartz這些寄存器映射的數量不是很重要。映射的結構很好地工作,除了這個問題之外,所以我認爲值得花一點點努力試圖在轉向不同的解決方案之前完成這項工作。 – Shade