xref: /aosp_15_r20/external/pciutils/lib/i386-io-access.h (revision c2e0c6b56a71da9abe8df5c8348fb3eb5c2c9251)
1*c2e0c6b5SAndroid Build Coastguard Worker /*
2*c2e0c6b5SAndroid Build Coastguard Worker  *	The PCI Library -- Compiler-specific wrappers around x86 I/O port access instructions
3*c2e0c6b5SAndroid Build Coastguard Worker  *
4*c2e0c6b5SAndroid Build Coastguard Worker  *	Copyright (c) 2023 Pali Rohár <[email protected]>
5*c2e0c6b5SAndroid Build Coastguard Worker  *
6*c2e0c6b5SAndroid Build Coastguard Worker  *	Can be freely distributed and used under the terms of the GNU GPL v2+
7*c2e0c6b5SAndroid Build Coastguard Worker  *
8*c2e0c6b5SAndroid Build Coastguard Worker  *	SPDX-License-Identifier: GPL-2.0-or-later
9*c2e0c6b5SAndroid Build Coastguard Worker  */
10*c2e0c6b5SAndroid Build Coastguard Worker 
11*c2e0c6b5SAndroid Build Coastguard Worker #if defined(__GNUC__)
12*c2e0c6b5SAndroid Build Coastguard Worker 
13*c2e0c6b5SAndroid Build Coastguard Worker static inline unsigned char
intel_inb(unsigned short int port)14*c2e0c6b5SAndroid Build Coastguard Worker intel_inb(unsigned short int port)
15*c2e0c6b5SAndroid Build Coastguard Worker {
16*c2e0c6b5SAndroid Build Coastguard Worker   unsigned char value;
17*c2e0c6b5SAndroid Build Coastguard Worker   asm volatile ("inb %w1, %0" : "=a" (value) : "Nd" (port));
18*c2e0c6b5SAndroid Build Coastguard Worker   return value;
19*c2e0c6b5SAndroid Build Coastguard Worker }
20*c2e0c6b5SAndroid Build Coastguard Worker 
21*c2e0c6b5SAndroid Build Coastguard Worker static inline unsigned short int
intel_inw(unsigned short int port)22*c2e0c6b5SAndroid Build Coastguard Worker intel_inw(unsigned short int port)
23*c2e0c6b5SAndroid Build Coastguard Worker {
24*c2e0c6b5SAndroid Build Coastguard Worker   unsigned short value;
25*c2e0c6b5SAndroid Build Coastguard Worker   asm volatile ("inw %w1, %0" : "=a" (value) : "Nd" (port));
26*c2e0c6b5SAndroid Build Coastguard Worker   return value;
27*c2e0c6b5SAndroid Build Coastguard Worker }
28*c2e0c6b5SAndroid Build Coastguard Worker 
29*c2e0c6b5SAndroid Build Coastguard Worker static inline unsigned int
intel_inl(unsigned short int port)30*c2e0c6b5SAndroid Build Coastguard Worker intel_inl(unsigned short int port)
31*c2e0c6b5SAndroid Build Coastguard Worker {
32*c2e0c6b5SAndroid Build Coastguard Worker   u32 value;
33*c2e0c6b5SAndroid Build Coastguard Worker   asm volatile ("inl %w1, %0" : "=a" (value) : "Nd" (port));
34*c2e0c6b5SAndroid Build Coastguard Worker   return value;
35*c2e0c6b5SAndroid Build Coastguard Worker }
36*c2e0c6b5SAndroid Build Coastguard Worker 
37*c2e0c6b5SAndroid Build Coastguard Worker static inline void
intel_outb(unsigned char value,unsigned short int port)38*c2e0c6b5SAndroid Build Coastguard Worker intel_outb(unsigned char value, unsigned short int port)
39*c2e0c6b5SAndroid Build Coastguard Worker {
40*c2e0c6b5SAndroid Build Coastguard Worker   asm volatile ("outb %b0, %w1" : : "a" (value), "Nd" (port));
41*c2e0c6b5SAndroid Build Coastguard Worker }
42*c2e0c6b5SAndroid Build Coastguard Worker 
43*c2e0c6b5SAndroid Build Coastguard Worker static inline void
intel_outw(unsigned short int value,unsigned short int port)44*c2e0c6b5SAndroid Build Coastguard Worker intel_outw(unsigned short int value, unsigned short int port)
45*c2e0c6b5SAndroid Build Coastguard Worker {
46*c2e0c6b5SAndroid Build Coastguard Worker   asm volatile ("outw %w0, %w1" : : "a" (value), "Nd" (port));
47*c2e0c6b5SAndroid Build Coastguard Worker }
48*c2e0c6b5SAndroid Build Coastguard Worker 
49*c2e0c6b5SAndroid Build Coastguard Worker static inline void
intel_outl(u32 value,unsigned short int port)50*c2e0c6b5SAndroid Build Coastguard Worker intel_outl(u32 value, unsigned short int port)
51*c2e0c6b5SAndroid Build Coastguard Worker {
52*c2e0c6b5SAndroid Build Coastguard Worker   asm volatile ("outl %0, %w1" : : "a" (value), "Nd" (port));
53*c2e0c6b5SAndroid Build Coastguard Worker }
54*c2e0c6b5SAndroid Build Coastguard Worker 
55*c2e0c6b5SAndroid Build Coastguard Worker #elif defined(_MSC_VER)
56*c2e0c6b5SAndroid Build Coastguard Worker 
57*c2e0c6b5SAndroid Build Coastguard Worker #pragma intrinsic(_outp)
58*c2e0c6b5SAndroid Build Coastguard Worker #pragma intrinsic(_outpw)
59*c2e0c6b5SAndroid Build Coastguard Worker #pragma intrinsic(_outpd)
60*c2e0c6b5SAndroid Build Coastguard Worker #pragma intrinsic(_inp)
61*c2e0c6b5SAndroid Build Coastguard Worker #pragma intrinsic(_inpw)
62*c2e0c6b5SAndroid Build Coastguard Worker #pragma intrinsic(_inpd)
63*c2e0c6b5SAndroid Build Coastguard Worker 
64*c2e0c6b5SAndroid Build Coastguard Worker #define intel_outb(x, y) _outp(y, x)
65*c2e0c6b5SAndroid Build Coastguard Worker #define intel_outw(x, y) _outpw(y, x)
66*c2e0c6b5SAndroid Build Coastguard Worker #define intel_outl(x, y) _outpd(y, x)
67*c2e0c6b5SAndroid Build Coastguard Worker #define intel_inb(x) _inp(x)
68*c2e0c6b5SAndroid Build Coastguard Worker #define intel_inw(x) _inpw(x)
69*c2e0c6b5SAndroid Build Coastguard Worker #define intel_inl(x) _inpd(x)
70*c2e0c6b5SAndroid Build Coastguard Worker 
71*c2e0c6b5SAndroid Build Coastguard Worker #else
72*c2e0c6b5SAndroid Build Coastguard Worker 
73*c2e0c6b5SAndroid Build Coastguard Worker #error Do not know how to access I/O ports on this compiler
74*c2e0c6b5SAndroid Build Coastguard Worker 
75*c2e0c6b5SAndroid Build Coastguard Worker #endif
76