Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/backbone.js/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Operating system xchg指令能保证内存顺序吗?_Operating System_X86_Cpu - Fatal编程技术网

Operating system xchg指令能保证内存顺序吗?

Operating system xchg指令能保证内存顺序吗?,operating-system,x86,cpu,Operating System,X86,Cpu,一些操作系统内核使用xchg指令来实现自旋锁。在其获取锁功能的实现中,它们通常在使用xchg指令获取锁之前禁用中断。那么,xchg指令能保证内存顺序吗?我的意思是xchg指令可以确保禁用中断不会在它之后被调用吗?没有xchg指令可以做到这一点。 在XCHG指令执行时,处理器的锁信号会自动断言,因此我们不需要额外的锁前缀来确保指令以原子方式执行。 XCHG始终以原子方式执行!并且没有必要禁用中断。没有XCHG指令不能做到这一点。 在XCHG指令执行时,处理器的锁信号会自动断言,因此我们不需要额外的

一些操作系统内核使用
xchg
指令来实现
自旋锁。在其获取锁功能的实现中,它们通常在使用
xchg
指令获取锁之前禁用中断。那么,
xchg
指令能保证内存顺序吗?我的意思是
xchg
指令可以确保禁用中断不会在它之后被调用吗?

没有xchg指令可以做到这一点。 在XCHG指令执行时,处理器的锁信号会自动断言,因此我们不需要额外的锁前缀来确保指令以原子方式执行。
XCHG始终以原子方式执行!并且没有必要禁用中断。

没有XCHG指令不能做到这一点。 在XCHG指令执行时,处理器的锁信号会自动断言,因此我们不需要额外的锁前缀来确保指令以原子方式执行。
XCHG始终以原子方式执行!而且不需要禁用中断。

是。XCHG指令可以做到这一点


我得到了一个更好的答案。

是的。XCHG指令可以做到这一点


我得到了一个更好的答案。

XCHG总是以原子方式执行。但只有当操作数是内存时,锁信号才是隐式的。当然,当所有操作数都是寄存器时,不需要锁信号。XCHG总是以原子方式执行。但只有当操作数是内存时,锁信号才是隐式的。当然,当所有操作数都是寄存器时,不需要锁信号。