push,pop格式可以是如下的:
1.push 寄存器
2.pop 寄存器
3.push 段寄存器
4.pop 段寄存器
5.push 内存单元
6.pop 内存单元
当push,pop指令中只能给出内存单元的偏移地址,段地址在执行指令时,CPU从ds中取得
push,pop指令同mov指令不同,CPU执行mov指令只需一步操作,就是传送,而执行push,pop指令却需要两步操作。执行push时,CPU的两步操作是:先改变SP,后向SS:SP处传送。执行POP时,CPU的两步操作是:先读取SS:SP处的数据,后改变SP
段我们可以分为数据段,代码段,栈段。
对于数据段,将它的段地址放在DS中,用mov,add,sub,等访问内存单元的时候,CPU就将我们定义的数据段中的内容当做数据来访问。
对于代码段,将他的段地址放在CS中,将段中第一条指令的偏移地址放在IP中,这样CPU就将执行我们定义的代码段的指令。
对于栈段,将它的段地址放在SS中,将栈顶单元的偏移地址放在SP中,这样CPU在需要进行栈操作的时候,比如执行push,pop指令等,就将我们定义的栈段当做栈空间来使用。