端口
和CPU通过总线相连的芯片除了各种存储器外,还有一些其他的芯片,例如网卡显卡等。从CPU的角度,将这些寄存器都当作端口,对它们进行统一编址,从而建立了一个统一的端口地址空间,每一个端口的地址空间都有一个地址。
端口的读写
在访问端口的时候,CPU通过端口地址来定位端口。因为端口所在的芯片和CPU通过总线相连,所以,端口地址和内存地址是一样的,都是通过地址总线相连传输数据的。
介绍in指令
in al,60h ;
从60h号端口读入一个字节到内存
执行时与总线相关操作
- cpu通过地址线将地址信息60h发出
- cpu通过控制线发出端口读命令,选中存储芯片,并通知它,将要从中读取数据
- 端口所在的芯片将60h端口中的数据通过数据线送入cpu中
介绍out指令
out 60h,al
从内存读出一个字节到60h号端口
执行时与总线相关操作和in指令相似
在in 和out 指令中, 只能使用al或ax来存放从端口中读入的数据或要发送到端口中的数据
shl和shr指令
shl和shr是逻辑移位指令
shl是逻辑左移指令
功能:
- 将一个寄存器或内存单元中的数据向左移位
- 将最后移出的移位写入CF中
- 最低位用0 补充
mov al, 01001000b
shl al, 1 ;将 al中数据左移一位
执行后 (al) = 10010000b, CF=0
shr是逻辑右移指令
功能:
- 将一个寄存器或内存单元中的数据向右移位
- 将最后移出的移位写入CF中
- 最高位用0 补充
mov al, 01001000b
shr al, 1 ;将 al中数据右移一位
执行后 (al) = 00100100b, CF=