汇编语言(王爽)-端口


各种存储器都和CPU的地址线、数据线、控制线相连。CPU在操控它们的时候,把它们都当作内存来对待,把它们总的看作一个由若干存储单元组成的逻辑存储器,这个逻辑存储器称为内存地址空间

PC机系统中,和CPU通过总线相连的芯片除各种存储器外,还有以下3种芯片:

  1. 各种接口卡(网卡、显卡等)上的接口芯片,用于控制接口卡进行工作

  2. 主板上的接口芯片,CPU通过其对部分外设进行访问

  3. 其他芯片,用来存储相关的系统信息,或进行相关的输入输出处理

在这些芯片中,都有一组可以由CPU读写的寄存器。这些寄存器,它们物理上可能处于不同的芯片种,但它们在以下两点以上相同

  1. 都与CPU的总线相连

  2. CPU对它们进行读或写时都通过控制线向它们所在的芯片发出端口读写的命令

CPU的角度,将这些寄存器都当作端口,对它们进行统一编址,从而建立了一个统一的端口地址空间。每一个端口在地址空间中都有一个地址

CPU可以直接读写3个地方的数据:

  1. CPU内部的寄存器

  2. 内存单元

  3. 端口


端口的读写

在访问端口时,CPU通过端口地址来定位端口

端口地址和内存地址一样,通过地址总线来传送

PC系统中,CPU最多可以定位64KB个不同的端口,则端口地址的范围是0-65535

端口的读写指令只有两条:

  1. in,从端口读取数据

  2. out,往端口写入数据

访问内存时的总线信息

1
mov ax,ds:[8]

执行时与总线相关的操作:

  1. CPU通过地址线将地址信息8发出

  2. CPU通过控制线发出内存读命令,选中存储器芯片,并通知它,将要从中读取数据

  3. 存储器将8号单元中的数据通过数据线送入CPU

访问端口时的总线信息

1
in al,60h		;从60h号端口读入一个字节

执行时与总线相关的操作:

  1. CPU通过地址线将地址信息60h发出

  2. CPU通过控制线发出端口读命令,选中端口所在的芯片,并通知它,将要从中读取数据

  3. 端口所在的芯片将60h端口中的数据通过数据线送入CPU

inout指令中,只能使用axal来存放从端口中读入的数据或要发送到端口中的数据。访问8位端口时用al,访问16位端口时用ax

对0-255以内的端口进行读写时:

1
2
in al,20h		;从20h端口读入一个字节
out 20h,al ;往20h端口写入一个字节

对256-65535的端口进行读写时,端口号放在dx中:

1
2
3
mov dx,3f8h		;将端口号3f8h送入dx
in al,dx ;从3f8h端口读入一个字节
out dx,al ;向3f8h端口写入一个字节

CMOS RAM芯片

CMOS芯片是一种低耗电存储器,其主要作用是用来存放BIOS中的设置信息以及系统时间日期。

此芯片的特征:

  1. 包含一个实时钟和一个有128个存储单元的RAM存储器(早期计算机为64个字节)

  2. 该芯片靠电池供电,关机后其内部的实时钟仍可工作,RAM中信息不丢失

  3. 128个字节的RAM中,内部实时钟占用0-0dh单元来保存时间信息,其余大部分单元用于保存系统配置信息,供系统启动时BIOS程序读取。BIOS也提供了相关的程序,使我们可以在开机的时候配置CMOS RAM中的系统信息

  4. 该芯片内部有两个端口,端口地址为70h71hCPU通过这两个端口来读写CMOS RAM

  5. 70h为地址端口,存放要访问的CMOS RAM单元的地址;71h为数据端口,存放从选定的CMOS RAM单元中读取的数据,或要写入到其中的数据

    CPUCMOS RAM的读写分两步进行

例:读CMOS RAM的2号单元

  1. 将2送入端口70h

  2. 从端口71h读出2号单元的内容


shl和shr指令

逻辑移位指令

shl指令

逻辑左移指令

功能:

  1. 将一个寄存器或内存单元中的数据向左移位

  2. 将最后移出的一位写入CF

  3. 最低位用0补充

例:

1
2
mov al,01001000b
shl al,1 ;将al中的数据左移一位

执行后(al)=10010000bCF=0

如果移动位数大于1时,必须将移动位数放在cl

1
2
3
mov al,01010001b
mov cl,3
shl al,cl

执行后(al)=10001000bCF=0

即,X逻辑左移一位,相当于执行X=X*2

shr指令

逻辑右移指令

功能:

  1. 将一个寄存器或内存单元中的数据向右移位

  2. 将最后移出的一位写入CF

  3. 最高位用0补充

例:

1
2
mov al,10000001b
shr al,1 ;将al中的数据右移一位

执行后(al)=01000000bCF=1

如果移动位数大于1时,必须将移动位数放在cl

X逻辑右移一位,相当于执行X=X/2


CMOS RAM中存储的时间信息

CMOS RAM中,存放着当前的时间:年、月、日、时、分、秒,每个信息长度1个字节

存放单元为:

0 2 4 7 8 9

这些数据以BCD码(以4位二进制数表示十进制数码的编码方法)的方式存放:

1.png

一个字节可以表示两个BCD

CMOS RAM存储时间信息的单元中,存储了用两个BCD码表示的两位十进制数,高4位的BCD码表示十位,低4位的BCD码表示个位。例:00010100b表示14

编程,在屏幕中间显示当前的月份

两部分工作:

  1. CMOS RAM的8号单元读出当前月份的BCD

  2. 将用BCD码表示的月份以十进制的形式显示到屏幕上

    BCD码值=十进制数码值,则BCD码值+30h=十进制数对应的ASCII

    1. CMOS RAM的8号单元中读出的一个字节,分为两个表示BCD码值的数据

    2. 显示十位和个位BCD码值+30h对应的ASCII码字符

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
assume cs:code
code segment

start: mov al,8
out 70h,al ;访问CMOS RAM的8号单元
in al,71h ;读出CMOS RAM8号单元的数据

mov ah,al
mov cl,4
shr ah,cl ;ah中为月份的十位数码值
and al,00001111b ;al中为月份的个位数码值

add ah,30h
add al,30h ;转换为对应的十进制数的ASCII码值

mov bx,0b800h
mov es,bx
mov byte ptr es:[160*12+40*2],ah ;显示月份的十位数码
mov byte ptr es:[160*12+40*2+2],al ;显示月份的个位数码

mov ax,4c00h
int 21h

code ends
end start
---------------The End---------------
0%