4

(这是“让 GCC 优化手动组装”的后续内容)

我一直试图让 GCC (3.3.6-m68hc1x-20060122) 使用索引寻址来发出bsetbclr汇编指令,但我使用的任何约束似乎都不起作用。

asm: _

#define bset(base, offset, mask) { \
volatile unsigned char *__base = base; \
const unsigned char __offset = offset; \
const char __mask = mask; \
asm volatile ("bset %0 %1" : "=o" (__base[__offset]) : "X" (__mask),
  "x" (__base)); }

C:

inline void spi_init()
{
  bset(_io_ports, M6811_DDRD, 0x38);
  bset(_io_ports, M6811_PORTD, 0x20);
  bset(_io_ports, M6811_SPCR, (M6811_SPE | M6811_DWOM | M6811_MSTR));
}

汇编代码结果:

spi_init:
        ldx     #_io_ports
; Begin inline assembler code
#APP
        bset _io_ports+9 #56
        bset _io_ports+8 #32
        bset _io_ports+40 #112
; End of inline assembler code
#NO_APP
        rts

现在这真的非常接近。但不幸的是,它完全无效。它必须如下所示:

spi_init:
        ldx     #_io_ports
; Begin inline assembler code
#APP
        bset 9,x #56
        bset 8,x #32
        bset 40,x #112
; End of inline assembler code
#NO_APP
        rts

我必须使用哪些约束来指示 GCC 发出该汇编代码?

GCC 3.3.6 扩展汇编文档
GCC 3.3.6 约束文档

4

0 回答 0