xref: /aosp_15_r20/external/pciutils/lib/internal.h (revision c2e0c6b56a71da9abe8df5c8348fb3eb5c2c9251)
1*c2e0c6b5SAndroid Build Coastguard Worker /*
2*c2e0c6b5SAndroid Build Coastguard Worker  *	The PCI Library -- Internal Stuff
3*c2e0c6b5SAndroid Build Coastguard Worker  *
4*c2e0c6b5SAndroid Build Coastguard Worker  *	Copyright (c) 1997--2022 Martin Mares <[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 #ifndef _INTERNAL_H
12*c2e0c6b5SAndroid Build Coastguard Worker #define _INTERNAL_H
13*c2e0c6b5SAndroid Build Coastguard Worker 
14*c2e0c6b5SAndroid Build Coastguard Worker #include "config.h"
15*c2e0c6b5SAndroid Build Coastguard Worker 
16*c2e0c6b5SAndroid Build Coastguard Worker #ifdef PCI_SHARED_LIB
17*c2e0c6b5SAndroid Build Coastguard Worker #define PCI_ABI __attribute__((visibility("default")))
18*c2e0c6b5SAndroid Build Coastguard Worker // Functions, which are bound to externally visible symbols by the versioning
19*c2e0c6b5SAndroid Build Coastguard Worker // mechanism, have to be declared as VERSIONED. Otherwise, GCC with global
20*c2e0c6b5SAndroid Build Coastguard Worker // optimizations is happy to optimize them away, leading to linker failures.
21*c2e0c6b5SAndroid Build Coastguard Worker #define VERSIONED_ABI __attribute__((used)) PCI_ABI
22*c2e0c6b5SAndroid Build Coastguard Worker #ifdef __APPLE__
23*c2e0c6b5SAndroid Build Coastguard Worker #define STATIC_ALIAS(_decl, _for) VERSIONED_ABI _decl { return _for; }
24*c2e0c6b5SAndroid Build Coastguard Worker #define DEFINE_ALIAS(_decl, _for)
25*c2e0c6b5SAndroid Build Coastguard Worker #define SYMBOL_VERSION(_int, _ext)
26*c2e0c6b5SAndroid Build Coastguard Worker #else
27*c2e0c6b5SAndroid Build Coastguard Worker #define DEFINE_ALIAS(_decl, _for) extern _decl __attribute__((alias(#_for))) VERSIONED_ABI
28*c2e0c6b5SAndroid Build Coastguard Worker #ifdef _WIN32
29*c2e0c6b5SAndroid Build Coastguard Worker #define STATIC_ALIAS(_decl, _for) VERSIONED_ABI _decl { return _for; }
30*c2e0c6b5SAndroid Build Coastguard Worker /* GCC does not support asm .symver directive for Windows targets, so define new external global function symbol as alias to internal symbol */
31*c2e0c6b5SAndroid Build Coastguard Worker #define SYMBOL_VERSION(_int, _ext) asm(".globl\t" PCI_STRINGIFY(__MINGW_USYMBOL(_ext)) "\n\t" \
32*c2e0c6b5SAndroid Build Coastguard Worker                                        ".def\t"   PCI_STRINGIFY(__MINGW_USYMBOL(_ext)) ";\t.scl\t2;\t.type\t32;\t.endef\n\t" \
33*c2e0c6b5SAndroid Build Coastguard Worker                                        ".set\t"   PCI_STRINGIFY(__MINGW_USYMBOL(_ext)) "," PCI_STRINGIFY(__MINGW_USYMBOL(_int)))
34*c2e0c6b5SAndroid Build Coastguard Worker #else
35*c2e0c6b5SAndroid Build Coastguard Worker #define STATIC_ALIAS(_decl, _for)
36*c2e0c6b5SAndroid Build Coastguard Worker #define SYMBOL_VERSION(_int, _ext) asm(".symver " #_int "," #_ext)
37*c2e0c6b5SAndroid Build Coastguard Worker #endif
38*c2e0c6b5SAndroid Build Coastguard Worker #endif
39*c2e0c6b5SAndroid Build Coastguard Worker #else
40*c2e0c6b5SAndroid Build Coastguard Worker #define VERSIONED_ABI
41*c2e0c6b5SAndroid Build Coastguard Worker #define STATIC_ALIAS(_decl, _for) _decl { return _for; }
42*c2e0c6b5SAndroid Build Coastguard Worker #define DEFINE_ALIAS(_decl, _for)
43*c2e0c6b5SAndroid Build Coastguard Worker #define SYMBOL_VERSION(_int, _ext)
44*c2e0c6b5SAndroid Build Coastguard Worker #endif
45*c2e0c6b5SAndroid Build Coastguard Worker 
46*c2e0c6b5SAndroid Build Coastguard Worker #include "pci.h"
47*c2e0c6b5SAndroid Build Coastguard Worker #include "sysdep.h"
48*c2e0c6b5SAndroid Build Coastguard Worker 
49*c2e0c6b5SAndroid Build Coastguard Worker /* Old 32-bit-only versions of MinGW32 do not define __MINGW_USYMBOL macro */
50*c2e0c6b5SAndroid Build Coastguard Worker #ifdef __MINGW32__
51*c2e0c6b5SAndroid Build Coastguard Worker #ifndef __MINGW_USYMBOL
52*c2e0c6b5SAndroid Build Coastguard Worker #define __MINGW_USYMBOL(sym) _##sym
53*c2e0c6b5SAndroid Build Coastguard Worker #endif
54*c2e0c6b5SAndroid Build Coastguard Worker #endif
55*c2e0c6b5SAndroid Build Coastguard Worker 
56*c2e0c6b5SAndroid Build Coastguard Worker #define _PCI_STRINGIFY(x) #x
57*c2e0c6b5SAndroid Build Coastguard Worker #define PCI_STRINGIFY(x) _PCI_STRINGIFY(x)
58*c2e0c6b5SAndroid Build Coastguard Worker 
59*c2e0c6b5SAndroid Build Coastguard Worker struct pci_methods {
60*c2e0c6b5SAndroid Build Coastguard Worker   char *name;
61*c2e0c6b5SAndroid Build Coastguard Worker   char *help;
62*c2e0c6b5SAndroid Build Coastguard Worker   void (*config)(struct pci_access *);
63*c2e0c6b5SAndroid Build Coastguard Worker   int (*detect)(struct pci_access *);
64*c2e0c6b5SAndroid Build Coastguard Worker   void (*init)(struct pci_access *);
65*c2e0c6b5SAndroid Build Coastguard Worker   void (*cleanup)(struct pci_access *);
66*c2e0c6b5SAndroid Build Coastguard Worker   void (*scan)(struct pci_access *);
67*c2e0c6b5SAndroid Build Coastguard Worker   void (*fill_info)(struct pci_dev *, unsigned int flags);
68*c2e0c6b5SAndroid Build Coastguard Worker   int (*read)(struct pci_dev *, int pos, byte *buf, int len);
69*c2e0c6b5SAndroid Build Coastguard Worker   int (*write)(struct pci_dev *, int pos, byte *buf, int len);
70*c2e0c6b5SAndroid Build Coastguard Worker   int (*read_vpd)(struct pci_dev *, int pos, byte *buf, int len);
71*c2e0c6b5SAndroid Build Coastguard Worker   void (*init_dev)(struct pci_dev *);
72*c2e0c6b5SAndroid Build Coastguard Worker   void (*cleanup_dev)(struct pci_dev *);
73*c2e0c6b5SAndroid Build Coastguard Worker };
74*c2e0c6b5SAndroid Build Coastguard Worker 
75*c2e0c6b5SAndroid Build Coastguard Worker /* generic.c */
76*c2e0c6b5SAndroid Build Coastguard Worker void pci_generic_scan_bus(struct pci_access *, byte *busmap, int domain, int bus);
77*c2e0c6b5SAndroid Build Coastguard Worker void pci_generic_scan_domain(struct pci_access *, int domain);
78*c2e0c6b5SAndroid Build Coastguard Worker void pci_generic_scan(struct pci_access *);
79*c2e0c6b5SAndroid Build Coastguard Worker void pci_generic_fill_info(struct pci_dev *, unsigned int flags);
80*c2e0c6b5SAndroid Build Coastguard Worker int pci_generic_block_read(struct pci_dev *, int pos, byte *buf, int len);
81*c2e0c6b5SAndroid Build Coastguard Worker int pci_generic_block_write(struct pci_dev *, int pos, byte *buf, int len);
82*c2e0c6b5SAndroid Build Coastguard Worker 
83*c2e0c6b5SAndroid Build Coastguard Worker /* emulated.c */
84*c2e0c6b5SAndroid Build Coastguard Worker int pci_emulated_read(struct pci_dev *d, int pos, byte *buf, int len);
85*c2e0c6b5SAndroid Build Coastguard Worker 
86*c2e0c6b5SAndroid Build Coastguard Worker /* init.c */
87*c2e0c6b5SAndroid Build Coastguard Worker void *pci_malloc(struct pci_access *, int);
88*c2e0c6b5SAndroid Build Coastguard Worker void pci_mfree(void *);
89*c2e0c6b5SAndroid Build Coastguard Worker char *pci_strdup(struct pci_access *a, const char *s);
90*c2e0c6b5SAndroid Build Coastguard Worker struct pci_access *pci_clone_access(struct pci_access *a);
91*c2e0c6b5SAndroid Build Coastguard Worker int pci_init_internal(struct pci_access *a, int skip_method);
92*c2e0c6b5SAndroid Build Coastguard Worker 
93*c2e0c6b5SAndroid Build Coastguard Worker void pci_init_v30(struct pci_access *a) VERSIONED_ABI;
94*c2e0c6b5SAndroid Build Coastguard Worker void pci_init_v35(struct pci_access *a) VERSIONED_ABI;
95*c2e0c6b5SAndroid Build Coastguard Worker 
96*c2e0c6b5SAndroid Build Coastguard Worker /* access.c */
97*c2e0c6b5SAndroid Build Coastguard Worker struct pci_dev *pci_alloc_dev(struct pci_access *);
98*c2e0c6b5SAndroid Build Coastguard Worker int pci_link_dev(struct pci_access *, struct pci_dev *);
99*c2e0c6b5SAndroid Build Coastguard Worker 
100*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v30(struct pci_dev *, int flags) VERSIONED_ABI;
101*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v31(struct pci_dev *, int flags) VERSIONED_ABI;
102*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v32(struct pci_dev *, int flags) VERSIONED_ABI;
103*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v33(struct pci_dev *, int flags) VERSIONED_ABI;
104*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v34(struct pci_dev *, int flags) VERSIONED_ABI;
105*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v35(struct pci_dev *, int flags) VERSIONED_ABI;
106*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v38(struct pci_dev *, int flags) VERSIONED_ABI;
107*c2e0c6b5SAndroid Build Coastguard Worker int pci_fill_info_v313(struct pci_dev *, int flags) VERSIONED_ABI;
108*c2e0c6b5SAndroid Build Coastguard Worker 
want_fill(struct pci_dev * d,unsigned want_fields,unsigned int try_fields)109*c2e0c6b5SAndroid Build Coastguard Worker static inline int want_fill(struct pci_dev *d, unsigned want_fields, unsigned int try_fields)
110*c2e0c6b5SAndroid Build Coastguard Worker {
111*c2e0c6b5SAndroid Build Coastguard Worker   want_fields &= try_fields;
112*c2e0c6b5SAndroid Build Coastguard Worker   if ((d->known_fields & want_fields) == want_fields)
113*c2e0c6b5SAndroid Build Coastguard Worker     return 0;
114*c2e0c6b5SAndroid Build Coastguard Worker   else
115*c2e0c6b5SAndroid Build Coastguard Worker     {
116*c2e0c6b5SAndroid Build Coastguard Worker       d->known_fields |= try_fields;
117*c2e0c6b5SAndroid Build Coastguard Worker       return 1;
118*c2e0c6b5SAndroid Build Coastguard Worker     }
119*c2e0c6b5SAndroid Build Coastguard Worker }
120*c2e0c6b5SAndroid Build Coastguard Worker 
clear_fill(struct pci_dev * d,unsigned clear_fields)121*c2e0c6b5SAndroid Build Coastguard Worker static inline void clear_fill(struct pci_dev *d, unsigned clear_fields)
122*c2e0c6b5SAndroid Build Coastguard Worker {
123*c2e0c6b5SAndroid Build Coastguard Worker   d->known_fields &= ~clear_fields;
124*c2e0c6b5SAndroid Build Coastguard Worker }
125*c2e0c6b5SAndroid Build Coastguard Worker 
126*c2e0c6b5SAndroid Build Coastguard Worker struct pci_property {
127*c2e0c6b5SAndroid Build Coastguard Worker   struct pci_property *next;
128*c2e0c6b5SAndroid Build Coastguard Worker   u32 key;
129*c2e0c6b5SAndroid Build Coastguard Worker   char value[1];
130*c2e0c6b5SAndroid Build Coastguard Worker };
131*c2e0c6b5SAndroid Build Coastguard Worker 
132*c2e0c6b5SAndroid Build Coastguard Worker char *pci_set_property(struct pci_dev *d, u32 key, char *value);
133*c2e0c6b5SAndroid Build Coastguard Worker 
134*c2e0c6b5SAndroid Build Coastguard Worker /* params.c */
135*c2e0c6b5SAndroid Build Coastguard Worker struct pci_param *pci_define_param(struct pci_access *acc, char *param, char *val, char *help);
136*c2e0c6b5SAndroid Build Coastguard Worker int pci_set_param_internal(struct pci_access *acc, char *param, char *val, int copy);
137*c2e0c6b5SAndroid Build Coastguard Worker void pci_free_params(struct pci_access *acc);
138*c2e0c6b5SAndroid Build Coastguard Worker 
139*c2e0c6b5SAndroid Build Coastguard Worker /* caps.c */
140*c2e0c6b5SAndroid Build Coastguard Worker void pci_scan_caps(struct pci_dev *, unsigned int want_fields);
141*c2e0c6b5SAndroid Build Coastguard Worker void pci_free_caps(struct pci_dev *);
142*c2e0c6b5SAndroid Build Coastguard Worker 
143*c2e0c6b5SAndroid Build Coastguard Worker extern struct pci_methods pm_intel_conf1, pm_intel_conf2, pm_linux_proc,
144*c2e0c6b5SAndroid Build Coastguard Worker 	pm_fbsd_device, pm_aix_device, pm_nbsd_libpci, pm_obsd_device,
145*c2e0c6b5SAndroid Build Coastguard Worker 	pm_dump, pm_linux_sysfs, pm_darwin, pm_sylixos_device, pm_hurd,
146*c2e0c6b5SAndroid Build Coastguard Worker 	pm_mmio_conf1, pm_mmio_conf1_ext, pm_ecam,
147*c2e0c6b5SAndroid Build Coastguard Worker 	pm_win32_cfgmgr32, pm_win32_kldbg, pm_win32_sysdbg, pm_aos_expansion;
148*c2e0c6b5SAndroid Build Coastguard Worker 
149*c2e0c6b5SAndroid Build Coastguard Worker #endif
150