X86指令:NOP指令

NOP指令的作用

通常NOP用于对齐指令的地址。
NOP指令的特性:

  • 因为NOP是X86指令中最短的,只有1byte
  • 处理器执行NOP指令时,不进行任何的操作,不会影响系统的状态

NOP也有其他的用途:

1)编程时如果使用了支持lable标记的编译器,如果使用JXX someLabel1(JXX是条件跳转),编译器将会将someLabel替换为Label对应的地址。然而如果我们手动修改了汇编代码,那么指令的长度就会发生了变化,Label的地址也会发生变化,因此可以使用NOP来将Label的地址恢复到之前的地址

2)NOP sled 如果我们想跳转到某条具体的指令,但是却不知道指令的地址,那么可以在目标指令前加入足够数量的NOP指令。跳转的地址设置到NOP的范围内,那么执行完毕跳转之后,就会持续的执行NOP指令,直到最终跳转到期望的目标指令

3)NOP也可以进行代码替换,比如想非法的避开软件的写保护操作,原来的软件代码是if(genuineCopy),会进行自动的拷贝,我们可以通过将genuineCopy这样的检查条件替换为NOP,这样就不会在if中进行任何有效地操作,从而非法的改动代码。

欢迎关注我的公众号《处理器与AI芯片》

你可能感兴趣的:(Microarchiture)