汇编语言程序设计(十四)端口

2022/5/31 1:24:05

本文主要是介绍汇编语言程序设计(十四)端口,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

目录
  • 端口port
  • 端口的读写
  • CMOS RAM 芯片
  • 逻辑左移执行shl和逻辑右移指令shr

端口port

  • 计算机与硬件或网络交互的接口。
  • CPU可以直接读取3个地方的数据:
    ** (1)CPU内部的寄存器
    ** (2)内存单元
    ** (3)端口,CPU通过端口才能读取硬件或网络的数据。

端口的读写

  • 对端口的读写不能用mov、push、pop等内存读写指令,端口读写执行只有两条,in和out。分别用于从端口读入数据和往端口写入数据。
  • 在in和out指令中,只能使用ax或al来存放从端口中读入的数据或要发到端口中的数据,访问8位端口时用al,访问16位端口时用ax。
  • 对0~255以内的端口进行读写:
  • 对256~65535的端口进行读写时,端口号要放在dx中,不能直接用立即数了:

CMOS RAM 芯片

  • CMOS RAM 存放着一些配置信息,以及时间信息,在主板上有一块小电池维持着时间信息的更新。
  • BIOS提供了相关的程序,使得程序员可以在开机时配置CMOS RAM中的系统信息。
  • CMOS RAM 芯片中有两个端口,端口地址为70h和71h,CPU可以通过这两个端口来读写CMOS RAM。
  • 70h为地址端口,存放要访问的CMOS RAM单元的地址。
  • 71为数据端口,存放要读取的数据,或者要写入的数据。
  • CPU对CMOS RAM的读写分两步进行。首先选定要读写的地址,然后读取或写入数据。

逻辑左移执行shl和逻辑右移指令shr

  • 逻辑左移一位就相当于十进制乘以2。

  • 如果左移一位在shl指令中可以直接用立即数1,如果移位位数大于1,则必须将移位位数放在寄存器cl中。

  • 并将移出的最后一位放在CF中。

  • 逻辑右移一位相当于除以2,用法跟左移shl完全一样。



这篇关于汇编语言程序设计(十四)端口的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程