| 1 | 
 /* | 
 
 
 
 
 
 | 2 | 
  * ioaccess.h | 
 
 
 
 
 
 | 3 | 
  * | 
 
 
 
 
 
 | 4 | 
  * Windows Device Driver Kit | 
 
 
 
 
 
 | 5 | 
  * | 
 
 
 
 
 
 | 6 | 
  * This file is part of the w32api package. | 
 
 
 
 
 
 | 7 | 
  * | 
 
 
 
 
 
 | 8 | 
  * THIS SOFTWARE IS NOT COPYRIGHTED | 
 
 
 
 
 
 | 9 | 
  * | 
 
 
 
 
 
 | 10 | 
  * This source code is offered for use in the public domain. You may | 
 
 
 
 
 
 | 11 | 
  * use, modify or distribute it freely. | 
 
 
 
 
 
 | 12 | 
  * | 
 
 
 
 
 
 | 13 | 
  * This code is distributed in the hope that it will be useful but | 
 
 
 
 
 
 | 14 | 
  * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY | 
 
 
 
 
 
 | 15 | 
  * DISCLAIMED. This includes but is not limited to warranties of | 
 
 
 
 
 
 | 16 | 
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | 
 
 
 
 
 
 | 17 | 
  * | 
 
 
 
 
 
 | 18 | 
  */ | 
 
 
 
 
 
 | 19 | 
 #ifndef __IOACCESS_H | 
 
 
 
 
 
 | 20 | 
 #define __IOACCESS_H | 
 
 
 
 
 
 | 21 | 
  | 
 
 
 
 
 
 | 22 | 
 #ifdef __cplusplus | 
 
 
 
 
 
 | 23 | 
 extern "C" { | 
 
 
 
 
 
 | 24 | 
 #endif | 
 
 
 
 
 
 | 25 | 
  | 
 
 
 
 
 
 | 26 | 
 #define H2I(p) PtrToUshort(p) | 
 
 
 
 
 
 | 27 | 
  | 
 
 
 
 
 
 | 28 | 
 #ifndef NO_PORT_MACROS | 
 
 
 
 
 
 | 29 | 
  | 
 
 
 
 
 
 | 30 | 
 #if defined(_X86_) || defined(_M_AMD64) | 
 
 
 
 
 
 | 31 | 
 #define READ_REGISTER_UCHAR(r) (*(volatile UCHAR *)(r)) | 
 
 
 
 
 
 | 32 | 
 #define READ_REGISTER_USHORT(r) (*(volatile USHORT *)(r)) | 
 
 
 
 
 
 | 33 | 
 #define READ_REGISTER_ULONG(r) (*(volatile ULONG *)(r)) | 
 
 
 
 
 
 | 34 | 
 #define WRITE_REGISTER_UCHAR(r, v) (*(volatile UCHAR *)(r) = (v)) | 
 
 
 
 
 
 | 35 | 
 #define WRITE_REGISTER_USHORT(r, v) (*(volatile USHORT *)(r) = (v)) | 
 
 
 
 
 
 | 36 | 
 #define WRITE_REGISTER_ULONG(r, v) (*(volatile ULONG *)(r) = (v)) | 
 
 
 
 
 
 | 37 | 
 #define READ_PORT_UCHAR(p) (UCHAR)(__inbyte (H2I(p))) | 
 
 
 
 
 
 | 38 | 
 #define READ_PORT_USHORT(p) (USHORT)(__inword (H2I(p))) | 
 
 
 
 
 
 | 39 | 
 #define READ_PORT_ULONG(p) (ULONG)(__indword (H2I(p))) | 
 
 
 
 
 
 | 40 | 
 #define WRITE_PORT_UCHAR(p, v) __outbyte (H2I(p), (v)) | 
 
 
 
 
 
 | 41 | 
 #define WRITE_PORT_USHORT(p, v) __outword (H2I(p), (v)) | 
 
 
 
 
 
 | 42 | 
 #define WRITE_PORT_ULONG(p, v) __outdword (H2I(p), (v)) | 
 
 
 
 
 
 | 43 | 
  | 
 
 
 
 
 
 | 44 | 
 #define MEMORY_BARRIER() | 
 
 
 
 
 
 | 45 | 
  | 
 
 
 
 
 
 | 46 | 
 #elif defined(_PPC_) || defined(_MIPS_) || defined(_ARM_) | 
 
 
 
 
 
 | 47 | 
  | 
 
 
 
 
 
 | 48 | 
 #define READ_REGISTER_UCHAR(r)      (*(volatile UCHAR * const)(r)) | 
 
 
 
 
 
 | 49 | 
 #define READ_REGISTER_USHORT(r)     (*(volatile USHORT * const)(r)) | 
 
 
 
 
 
 | 50 | 
 #define READ_REGISTER_ULONG(r)      (*(volatile ULONG * const)(r)) | 
 
 
 
 
 
 | 51 | 
 #define WRITE_REGISTER_UCHAR(r, v)  (*(volatile UCHAR * const)(r) = (v)) | 
 
 
 
 
 
 | 52 | 
 #define WRITE_REGISTER_USHORT(r, v) (*(volatile USHORT * const)(r) = (v)) | 
 
 
 
 
 
 | 53 | 
 #define WRITE_REGISTER_ULONG(r, v)  (*(volatile ULONG * const)(r) = (v)) | 
 
 
 
 
 
 | 54 | 
 #define READ_PORT_UCHAR(r)          READ_REGISTER_UCHAR(r) | 
 
 
 
 
 
 | 55 | 
 #define READ_PORT_USHORT(r)         READ_REGISTER_USHORT(r) | 
 
 
 
 
 
 | 56 | 
 #define READ_PORT_ULONG(r)          READ_REGISTER_ULONG(r) | 
 
 
 
 
 
 | 57 | 
 #define WRITE_PORT_UCHAR(p, v)      WRITE_REGISTER_UCHAR(p, (UCHAR) (v)) | 
 
 
 
 
 
 | 58 | 
 #define WRITE_PORT_USHORT(p, v)     WRITE_REGISTER_USHORT(p, (USHORT) (v)) | 
 
 
 
 
 
 | 59 | 
 #define WRITE_PORT_ULONG(p, v)      WRITE_REGISTER_ULONG(p, (ULONG) (v)) | 
 
 
 
 
 
 | 60 | 
  | 
 
 
 
 
 
 | 61 | 
 #else | 
 
 
 
 
 
 | 62 | 
  | 
 
 
 
 
 
 | 63 | 
 #error Unsupported architecture | 
 
 
 
 
 
 | 64 | 
  | 
 
 
 
 
 
 | 65 | 
 #endif | 
 
 
 
 
 
 | 66 | 
  | 
 
 
 
 
 
 | 67 | 
 #endif /* NO_PORT_MACROS */ | 
 
 
 
 
 
 | 68 | 
  | 
 
 
 
 
 
 | 69 | 
 #ifdef __cplusplus | 
 
 
 
 
 
 | 70 | 
 } | 
 
 
 
 
 
 | 71 | 
 #endif | 
 
 
 
 
 
 | 72 | 
  | 
 
 
 
 
 
 | 73 | 
 #endif /* __IOACCESS_H */ |