欢迎来到天天文库
浏览记录
ID:42696121
大小:103.00 KB
页数:18页
时间:2019-09-20
《珍藏版WinIo中文说明文档》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、[winio的使用] WinIO程序库允许在32位的Windows应用程序中直接对I/O端口和物理内存进行存取操作。通过使用一种内核模式的设备驱动器和其它几种底层编程技巧,它绕过了Windows系统的保护机制。 WinNT/2000/XP下,WinIO函数库只允许被具有管理者权限的应用程序调用。如果使用者不是以管理者的身份进入的,则WinIO.DLL不能够被安装,也不能激活WinIO驱动器。通过在管理者权限下安装驱动器软件就可以克服这种限制。然而,在这种情况下,ShutdownWinIo函数不能在应用程序结
2、束之前被调用,因为该函数将WinIO驱动程序从系统注册表中删除。 该函数库提供8个函数功能调用: bool_stdcallInitializeWinIo(); 本函数初始化WioIO函数库。 必须在调用所有其它功能函数之前调用本函数。 如果函数调用成功,返回值为非零值。 如果调用失败,则返回值为0。 void_stdcallShutdownWinIo(); 本函数在内存中清除WinIO库 本函数必须在中止应用函数之前或者不再需要WinIO库时调用, bool_stdcallGetPortVa
3、l(WORDwPortAddr,PDWORDpdwPortVal,BYTEbSize); 使用此函数从一个输入或输出端口读取一个字节/字/双字数据。 参数: wPortAddr–输入输出端口地址 pdwPortVal–指向双字变量的指针,接收从端口得到的数据。 bSize–需要读的字节数,可以是1(BYTE),2(WORD)or4(DWORD). 如果调用成功,则返回非零值。 如果函数调用失败,则函数返回值为零。 bool_stdcallSetPortVal(WORDwPortAddr,DWOR
4、DdwPortVal,BYTEbSize); 使用本函数将一个字节/字/双字的数据写入输入或输出接口。 参数: wPortAddr–输入输出口地址 dwPortVal–要写入口的数据 bSize–要写的数据个数,可以是1(BYTE),2(WORD)or4(DWORD). 如果调用成功,则返回非零值。 如果函数调用失败,则函数返回值为零。 PBYTE_stdcallMapPhysToLin(PBYTEpbPhysAddr,DWORDdwPhysSize,HANDLE*pPhysicalMemory
5、Handle) 使用此函数将物理内存的一部分映射到一个32位应用程序的线性地址空间。 下面是一个例子: PBYTEpbLinAddr; HANDLEPhysicalMemoryHandle; pbLinAddr=MapPhysToLin(0xA0000,65536,&PhysicalMemoryHandle); 该函数将把物理地址范围为0xA0000-0xAFFFF的地址空间映射到与应用程序对应的线性地址空间。返回值为一个与物理地址0xA0000相关的线性地址。如果出现错误,则返回值为NULL。
6、参数: pbPhysAddr–指向物理地址的指针 dwPhysSize–需要映射的字节数 pPhysicalMemoryHandle–变量指针,如果调用成功,负责接收物理内存句柄。随后本句柄在调用UnmapPhysicalMemory函数时作为其第一个参数。 bool_stdcallUnmapPhysicalMemory(HANDLEPhysicalMemoryHandle,PBYTE pbLinAddr) 使用本函数解除原先使用MapPhysToLin函数映射的一段线性物理内存区域,该区域被映射到
7、应用程序所属的线性地址空间。 Windows9x应用程序不需要调用此函数。 参数: PhysicalMemoryHandle–物理内存区域所属的句柄,此参数由对MapPhysToLin函数的调用返回。 pbLinAddr–MapPhysToLin函数调用返回的线性地址。 bool_stdcallGetPhysLong(PBYTEpbPhysAddr,PDWORDpdwPhysVal); 从指定的物理地址读取一个双字数据。 参数: pbPhysAddr–指向物理地址的指针。 pdwPhysVal
8、–指向一个双字变量的指针,接收从物理内存中传来的数据。 如果此函数调用成功,返回一个非零值。 如果函数调用失败,则返回一个零值。 bool_stdcallSetPhysLong(PBYTEpbPhysAddr,DWORDdwPhysVal); 将一个双字型数据写入指定的物理地址。 参数: pbPhysAddr–指向物理地址的指针。 pdwPhysVal–指定待写入物理内存
此文档下载收益归作者所有