第8章

操作码代码

位锁存器的结果应作为加法器的进位输入。

nand01

下载

世界ศ范围内的即时通信我们已经很熟悉,但它是当今新า技

这些只是一个多职业生涯者的足迹。摩尔斯最着名的贡献

要回到先前的程序,并使用a、b、c中ณ原有的值。

当然,你能做的工作只是简单地把寄存器a、b、c中的值保存到存储器中ณ的不同位置,

以后再把这些位置的值装载到寄存器中,但这样做需要保存值被保存的位置。一个显然的方แ

法是把寄存器压入堆栈:

pushaທ

pushb

pushc

一会儿再解释这些指令的作用。现在,我们只需要知道它们以某种方式把寄存器的内容

保存在一个后进先出的存储器中。一旦这些语句执行了,你的程序就可以毫无຀顾虑地利用这

些寄存器来做其他工作。为ฦ了得到原来的值,只需简单地按与压入堆栈相反的顺序把它们从

堆栈中弹出即可,如下所示ิ:

1้98编码的奥秘

下载

popc

popb

popa

记住是后进先出。如果用错了pop语句的顺序,就会引起错误。

堆栈机制的一个好处在于一个ฐ程序的不同部分都可以使用堆栈而不会出现问题。例如,

在把a、b、c压入堆栈中后,程序的其他部分还可能需要把寄存器c、d、e的内容压入堆栈:

pushcນ

pushd

pushe

接着,这一部分程序所要做的就是在第一部分弹出c、b和a之ใ前,用下述方法恢复寄存

器的值:

pope

popd

popc

堆栈是怎样实现的呢?先,堆栈只是不被别的东西使用的正常的ram的一部分。808๖0

微处理器包含一个特殊的16๔位寄存器来对这一部分存储器进行寻址,这个ฐ16位寄存器叫作堆

栈指针。

这里举的压入和弹出寄存器的例子对于80่80来说不太准确。8080的push指令实际上是存

储1้6๔位的值到堆栈,pop指令用来恢复它们。因此8080不用像pushc和popc这样的指令,

它有下述8条指令:

操作码指令操作码指令

cນ9

d5pushded1popde

e5pushhle1pophl

f5pushp9f1popp9๗

pushbcນ指令把寄存器b和cນ的内容保存到เ堆栈中,popbcນ指令恢复它们。最后一行的

缩写ps9指的是程序状态字,前面讲过,它是包含有标志位的8位寄存器。最后一行的两条指

令实际上是把累加器和ps9都压入和弹出堆栈。如果你想保存所有寄存器和标志位的内容,

可以使用:

pushp9

pushbຘc

pushde

pushhl

当以后想恢复这些寄存器的内容时,按相反的顺序使用pop指令:

pophl

popde

popbcນ

popp9

堆栈是怎样工作的呢?假设堆栈指针ฤ为8๖000h,pushbc指令将引起下面这些情况生:

堆栈指针ฤ减1至7fffh

寄存器bຘ的内容保存在堆栈指针ฤ所指的地址处,即7fffh处

第19章两种典型的微处理器199

下载

堆栈指针减1至7ffeh

寄存器cນ的内容保存在堆栈指针所指的地址处,即7ffeh处

当堆栈指针仍然为7ffeh时,popbc指令执行,用来反向执行每一步:

从堆栈指针所指的地址即7ffeh处装载数据到寄存器c中

堆栈指针ฤ增1至7fffh

从堆栈指针所指的地址即7๕fffh处装ณ载数据到เ寄存器bຘ中

堆栈指针增1至8๖000h

对每个push指令,堆栈都会增加2个字节,这可能导致程序出现小毛病—堆栈可能会

变得很大以致会覆盖掉程序所需的一些代码和数据。这就是堆栈上溢问题。同样,过多的

pop指令会过早用光堆栈内容,这就是堆栈下溢问题。

如果8080่同一个64kb的存储器连接,你可能想把初始堆栈指针置为00่00h。第一条push

指令使地址减1变为ffffh,这时堆栈占用了存储器的最高地址。如果你的程序放在从0000h

处开始的存储器区域,则它和堆栈离的就太远了。

对堆栈寄存器进行赋值的指令是lxi,即loadextendedimmediate装载扩展的立即数。

下面这些操作码后的指令也๣是把两个字节装载到16位寄存器:

操作码指令

01lxibcນ,xxxx