[英]How to understand this GNU C inline assembly macro for PowerPC stwbrx
[英]How to use a macro in linux C inline assembly
我想调用由其他配置结果确定的地址。 该调用是内联汇编中的。
当前,就像这样,并已手动对其进行了修改:
asm volatile ("call 0xc0200c20\n\t");
我的问题是我可以这样写吗?
#define CALL_ADDR 0xC0200c20
asm volatile ("call CALL_ADDR\n\t");
谢谢!
只需普通的字符串连接就可以解决问题,它使用两个包装宏来创建值的字符串化版本:
#define QUAUX(X) #X
#define QU(X) QUAUX(X)
asm volatile ("call " QU(CALL_ADDR) "\n\t");
将我的评论提升为答案:
gcc的内联汇编操作数的P
修饰符可阻止编译器在生成的汇编代码中发出“常量指示前缀”。 请参阅链接的参考,以获得更详细的解释,并引用Linus。
如果您尝试过:
#define CALL_ADDR 12345678
asm volatile("call %0\n\t" :: "i"(CALL_ADDR));
您注意到从汇编程序中收到错误,因为生成的代码显示call $12345678
,这不是有效的汇编语法。 相反,使用%P0
可使编译器在开始时不发出$
,这很好。
此处不需要使用预处理程序字符串串联-缺点是,正如您所发现的,需要“嵌套”(两级宏),以便在完成串联之前扩展CALL_ADDR
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.