打字猴:1.700414027e+09
1700414027
1700414028 OUT (2),A
1700414029
1700414030 LD A,255
1700414031
1700414032 OUT (2),A
1700414033
1700414034 这里的207和255是连续向Z80 PIO的端口A控制寄存器(对应该I/O的地址编号为2)写入的两个数据。虽然使用OUT指令可以向I/O写入数据,但不能直接把207和255这样的数字作为OUT指令的操作数,操作数必须是已存储在CPU寄存器中的数字,这是汇编语言的规定。
1700414035
1700414036 于是,先通过指令LD A 207把数字207读入到寄存器A中,再通过指令OUT (2),A把寄存器A中的数据写入到I/O地址所对应的寄存器中。像(2)这样用括号括起来的数字,表示的地址编号,端口A控制寄存器的I/O地址是2号
1700414037
1700414038 一旦把207写入到端口A控制寄存器,Z80 PIO就明白了“哦,想要设定端口A的输入输出模式啊!”而通过接下来写入的255,Z80 PIO就知道“要把端口A设定为输入模式”
1700414039
1700414040 同样地,通过下面的程序可以将端口B设定为输出模式
1700414041
1700414042 LD A,207
1700414043
1700414044 OUT (3),A
1700414045
1700414046 LD A,0
1700414047
1700414048 OUT (3),A
1700414049
1700414050 先把207写入端口B控制寄存器(对应的I/O地址为3号)然后写入0,这个0表示要把端口B设定为输出模式,应该使用什么样的数字设定端口,在Z80 PIO的资料上有说明。用207,255,0这样的数字表示功能设定参数,这也是为了适应计算机的处理方式
1700414051
1700414052 完成了Z80 PIO的设定后,就进入了一段死循环处理,用于把由指拨开关输入的数据输出到LED。为了完成这个功能,需要如下的代码:
1700414053
1700414054 LOOP:   IN A,(0)
1700414055
1700414056 OUT (1),A
1700414057
1700414058 JP LOOP
1700414059
1700414060 IN A,(0)的作用是把数据由端口A数据寄存器(连接在指拨开关上,对应的I/O地址为0号)输入到CPU的寄存器A
1700414061
1700414062 OUT (1),A的作用是把寄存器A的值输出到端口B数据寄存器上(连接在LED上,对应的I/O地址为1号)
1700414063
1700414064 JP LOOP的作用是使程序的流程跳转到LOOP(标签名)标签所标识的指令上。JP是Jump的缩写
1700414065
1700414066 IN A,(0)所在行的开头有一个标签LOOP:,代表着这一行的内存地址。正如刚才所讲的那样,在用汇编语言编程时,如果老想着“这一行对应的内存地址是什么?“就会很不方便,所以就要用LOOP:这样的标签代替内存地址。当把标签作为JP指令的操作数时,标签名的结尾不需要冒号,但在设定标签时,标签名的结尾需要加一个冒号,这一点请注意
1700414067
1700414068
1700414069
1700414070
1700414071 计算机是怎样跑起来的 [:1700412639]
1700414072 计算机是怎样跑起来的 3.4 追踪程序的运行过程
1700414073
1700414074 用汇编语言编写的程序是不能直接运行的,必须先转换成机器语言。机器语言是唯一一种CPU能直接理解的编程语言。从汇编语言到机器语言的转换方法稍后介绍,这里先看一下代码清单3.3,里面列出了事先转换出来的机器语言以及对应的汇编语言。1条汇编语言的指令所对应的机器语言由多个字节构成。而且,同样的汇编语言中的1条指令,有的指令对应1个字节的机器语言,有的指令则对应多个字节的机器语言。汇编语言中的1条指令能转换成多少条机器语言取决于指令的种类及操作数的个数。代码清单3.3中第一个内存地址是00000000(0号地址),下一个地址是00000010(2号地址)中间隔了2个地址,这说明如果从0号地址开始存储一条2字节的机器语言,那么下一条机器语言就从2号地址开始存储
1700414075
1700414076 下面就一边看代码清单3.3,一边跟随着CPU解释、执行机器语言程序吧。在这里,我们假设机器语言的程序是像代码清单3.3那样被存储在内存中的
[ 上一页 ]  [ :1.700414027e+09 ]  [ 下一页 ]