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

端口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完全一样。

posted @ 2022-05-30 16:51  肖肖凯  阅读(266)  评论(1)    收藏  举报