📄 lc_bcb_69.txt
字号:
I/O端口读写的实现
I/O 端 口 读 写 的
实 现
细 心 的 读 者 会
发现,C++ Builder 不 再 支 持 如inportb()、outportb() 一 类I/O 端
口 读 写指 令 了。 准 确 地 说, 在Windows 环 境 下,Borland
C++ 仅 支 持16 位应 用 程 序 的 端 口 操 作, 对32 位 应 用
程 序 的 端 口 操 作 不 再 支持, 而C++ Builder 开 发 出 来 的
程 序 是32 位 的。 我 个 人 以 为, 这是C++ Builder 设 计 者
的 败 笔。 因 为PC 机 中,I/O 地 址 空 间 与 内存 地 址 空
间 从 来 都 是 各 自 独 立 的。 看 看Delphi, 不 就 通 过Port
数 组 实 现 了 对I/O 端 口 的 访 问 了 吗? 搞 不 清 楚 为
什 么C++ Builder 就 没 有 提 供 类 似 的 机 制 ? 下 面 这 几
个 函 数 是 笔 者 从 网 上淘 下 来 的, 经 过 验 证, 在Windows95
环 境 下, 的 确 可 实 现 对I/O 端 口 的 读 写。 读 者 可 以
借 鉴 使 用。
void outportb(unsigned short int port, unsigned char value)
{
// mov edx, *(&port);
__emit__(0x8b, 0x95, &port);
// mov al, *(&value);
__emit__(0x8a, 0x85, &value);
// out dx, al;
__emit__(0x66, 0xee);
}
void outportw(unsigned short int port, unsigned short int value)
{
// mov edx, *(&port);
__emit__(0x8b, 0x95, &port);
// mov ax, *(&value);
__emit__(0x66, 0x8b, 0x85, &value);
// out dx, ax;
__emit__(0xef);
}
unsigned char inportb(unsigned short int port)
{
unsigned char value;
// mov edx, *(&port);
__emit__(0x8b, 0x95, &port);
// in al, dx;
__emit__(0x66, 0xec);
// mov *(&value), al;
__emit__(0x88, 0x85, &value);
return value;
}
unsigned short int inportw(unsigned short int port)
{
unsigned short int value;
// mov edx, *(&port);
__emit__(0x8b, 0x95, &port);
// in ax, dx
__emit__(0xed);
// mov *(&value), ax
__emit__(0x66, 0x89, 0x85, &value);
return value;
}