|
|
|
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 端 口 的 读 写。 读 者 可 以
借 鉴 使 用。 { // 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;
} |