我有以下的汇编代码:是否有可能强制内联汇编代码中的特定寄存器?
__asm__ __volatile__ (
"1: subi %0, 1" "\n\t"
"brne 1b"
: "=d" (__count)
: "M" (__count));
这将导致以下编译器ouptut
ce: 81 50 subi r24, 0x01 ; 1
d0: f1 f7 brne .-4 ; 0xce <main>
d2: 80 e0 ldi r24, 0x00 ; 0
d4: 90 e0 ldi r25, 0x00 ; 0
如何能够做到以下几点:
ce: 81 50 subi r16, 0x01 ; 1
d0: f1 f7 brne .-4 ; 0xce <main>
d2: 80 e0 ldi r16, 0x00 ; 0
它甚至有可能告诉编译器使用r16而不是r24:r25?这样我可以减少ldi r25,0x00行使用的循环次数1。
感谢 杰克