在使用扩展汇编(asm volatile)语法的C++中,使用btr重置整数中的位的正确实现是什么?我需要在重置之前返回位中的值。
这是我的实现,对于16位整数,这是正确的吗?
std::uint16_t reset(std::uint16_t& integer, std::uint32_t bit) {
auto success = false;
asm volatile("lock btrw %1, (%2); setnc %0"
: "=r"(success)
: "i"(bit), "r"(&integer)
: "memory", "flags");
return !success;
}这个实现正确吗?我漏掉了什么细节吗?我对asm()语法或x86程序集不是很熟悉。
发布于 2018-08-29 07:52:43
这里有一个版本,它用适当的读写操作数替换了memory占位器,而不是传入寄存器中的地址,并且还去掉了setnc (需要gcc 6+)。添加了r以覆盖在编译时bit未知的情况。已将success更改为具有bool类型的可读性更强的was_set。注如果你想让它是原子的,你还需要添加一个lock前缀。对于编译器内存屏障,您可能需要放回memory约束。
bool reset(std::uint16_t& integer, std::uint32_t bit) {
bool was_set;
asm volatile("btrw %w2, %1"
: "=@ccc"(was_set), "+mr"(integer)
: "ri"(bit)
: "cc");
return was_set;
}原子版本可能如下所示:
bool reset(std::uint16_t& integer, std::uint32_t bit) {
bool was_set;
asm volatile("lock btrw %w2, %1"
: "=@ccc"(was_set), "+m"(integer)
: "ri"(bit)
: "cc", "memory");
return was_set;
}https://stackoverflow.com/questions/52067307
复制相似问题