我正在尝试通过azeria-labs.com的指南学习汇编
我有一个关于在非叶函数和叶函数的结语中使用LR寄存器和PC寄存器的问题。
在下面的代码片段中,它们显示了这些函数中的尾声的差异。
如果我用C语言编写一个程序,在GDB中查看,它总是使用"pop {r11,pc}表示非叶函数,"pop {r11};bx lr“表示叶函数。有人能告诉我为什么吗?
当我在叶函数中时。例如,如果我使用"bx lr“或"pop pc”返回父函数,会有什么不同吗?
/* An epilogue of a leaf function */
pop {r11}
bx lr
/* An epilogue of a non-leaf function */
pop {r11, pc}发布于 2019-08-17 00:59:15
在叶函数中,没有其他函数调用会修改链接寄存器lr。
对于非叶函数,必须保留lr,在这里通过将其推送到堆栈(在函数前面未显示的位置)。
非叶函数的结尾可以重写:
pop {r11, lr}
bx lr然而,这是多一条指令,因此它的效率略低。
https://stackoverflow.com/questions/57528457
复制相似问题