]>
git.proxmox.com Git - mirror_edk2.git/blob - Vlv2DeviceRefCodePkg/ValleyView2Soc/NorthCluster/Include/VlvCommonDefinitions.h
4 Copyright (c) 1999 - 2014, Intel Corporation. All rights reserved
6 SPDX-License-Identifier: BSD-2-Clause-Patent
12 VlvCommonDefinitions.h
16 Macros to simplify and abstract the interface to PCI configuration.
21 /// PCI CONFIGURATION MAP REGISTER OFFSETS
24 #define PCI_VID 0x0000 ///< Vendor ID Register
25 #define PCI_DID 0x0002 ///< Device ID Register
26 #define PCI_CMD 0x0004 ///< PCI Command Register
27 #define PCI_STS 0x0006 ///< PCI Status Register
28 #define PCI_RID 0x0008 ///< Revision ID Register
29 #define PCI_IFT 0x0009 ///< Interface Type
30 #define PCI_SCC 0x000A ///< Sub Class Code Register
31 #define PCI_BCC 0x000B ///< Base Class Code Register
32 #define PCI_CLS 0x000C ///< Cache Line Size
33 #define PCI_PMLT 0x000D ///< Primary Master Latency Timer
34 #define PCI_HDR 0x000E ///< Header Type Register
35 #define PCI_BIST 0x000F ///< Built in Self Test Register
36 #define PCI_BAR0 0x0010 ///< Base Address Register 0
37 #define PCI_BAR1 0x0014 ///< Base Address Register 1
38 #define PCI_BAR2 0x0018 ///< Base Address Register 2
39 #define PCI_PBUS 0x0018 ///< Primary Bus Number Register
40 #define PCI_SBUS 0x0019 ///< Secondary Bus Number Register
41 #define PCI_SUBUS 0x001A ///< Subordinate Bus Number Register
42 #define PCI_SMLT 0x001B ///< Secondary Master Latency Timer
43 #define PCI_BAR3 0x001C ///< Base Address Register 3
44 #define PCI_IOBASE 0x001C ///< I/O base Register
45 #define PCI_IOLIMIT 0x001D ///< I/O Limit Register
46 #define PCI_SECSTATUS 0x001E ///< Secondary Status Register
47 #define PCI_BAR4 0x0020 ///< Base Address Register 4
48 #define PCI_MEMBASE 0x0020 ///< Memory Base Register
49 #define PCI_MEMLIMIT 0x0022 ///< Memory Limit Register
50 #define PCI_BAR5 0x0024 ///< Base Address Register 5
51 #define PCI_PRE_MEMBASE 0x0024 ///< Prefetchable memory Base register
52 #define PCI_PRE_MEMLIMIT 0x0026 ///< Prefetchable memory Limit register
53 #define PCI_PRE_MEMBASE_U 0x0028 ///< Prefetchable memory base upper 32 bits
54 #define PCI_PRE_MEMLIMIT_U 0x002C ///< Prefetchable memory limit upper 32 bits
55 #define PCI_SVID 0x002C ///< Subsystem Vendor ID
56 #define PCI_SID 0x002E ///< Subsystem ID
57 #define PCI_IOBASE_U 0x0030 ///< I/O base Upper Register
58 #define PCI_IOLIMIT_U 0x0032 ///< I/O Limit Upper Register
59 #define PCI_CAPP 0x0034 ///< Capabilities Pointer
60 #define PCI_EROM 0x0038 ///< Expansion ROM Base Address
61 #define PCI_INTLINE 0x003C ///< Interrupt Line Register
62 #define PCI_INTPIN 0x003D ///< Interrupt Pin Register
63 #define PCI_MAXGNT 0x003E ///< Max Grant Register
64 #define PCI_BRIDGE_CNTL 0x003E ///< Bridge Control Register
65 #define PCI_MAXLAT 0x003F ///< Max Latency Register
87 #define BIT16 0x00010000
88 #define BIT17 0x00020000
89 #define BIT18 0x00040000
90 #define BIT19 0x00080000
91 #define BIT20 0x00100000
92 #define BIT21 0x00200000
93 #define BIT22 0x00400000
94 #define BIT23 0x00800000
95 #define BIT24 0x01000000
96 #define BIT25 0x02000000
97 #define BIT26 0x04000000
98 #define BIT27 0x08000000
99 #define BIT28 0x10000000
100 #define BIT29 0x20000000
101 #define BIT30 0x40000000
102 #define BIT31 0x80000000
105 #ifndef _PCIACCESS_H_INCLUDED_
106 #define _PCIACCESS_H_INCLUDED_
107 #ifndef PCI_EXPRESS_BASE_ADDRESS
108 #define PCI_EXPRESS_BASE_ADDRESS 0xE0000000
112 #define MmPciAddress( Segment, Bus, Device, Function, Register ) \
113 ( (UINTN)PCI_EXPRESS_BASE_ADDRESS + \
114 (UINTN)(Bus << 20) + \
115 (UINTN)(Device << 15) + \
116 (UINTN)(Function << 12) + \
124 #define MmPci64Ptr( Segment, Bus, Device, Function, Register ) \
125 ( (volatile UINT64 *)MmPciAddress( Segment, Bus, Device, Function, Register ) )
127 #define MmPci64( Segment, Bus, Device, Function, Register ) \
128 *MmPci64Ptr( Segment, Bus, Device, Function, Register )
130 #define MmPci64Or( Segment, Bus, Device, Function, Register, OrData ) \
131 MmPci64( Segment, Bus, Device, Function, Register ) = \
133 MmPci64( Segment, Bus, Device, Function, Register ) | \
137 #define MmPci64And( Segment, Bus, Device, Function, Register, AndData ) \
138 MmPci64( Segment, Bus, Device, Function, Register ) = \
140 MmPci64( Segment, Bus, Device, Function, Register ) & \
144 #define MmPci64AndThenOr( Segment, Bus, Device, Function, Register, AndData, OrData ) \
145 MmPci64( Segment, Bus, Device, Function, Register ) = \
147 ( MmPci64( Segment, Bus, Device, Function, Register ) & \
157 #define MmPci32Ptr( Segment, Bus, Device, Function, Register ) \
158 ( (volatile UINT32 *) MmPciAddress( Segment, Bus, Device, Function, Register ) )
160 #define MmPci32( Segment, Bus, Device, Function, Register ) \
161 *MmPci32Ptr( Segment, Bus, Device, Function, Register )
163 #define MmPci32Or( Segment, Bus, Device, Function, Register, OrData ) \
164 MmPci32( Segment, Bus, Device, Function, Register ) = \
166 MmPci32( Segment, Bus, Device, Function, Register ) | \
170 #define MmPci32And( Segment, Bus, Device, Function, Register, AndData ) \
171 MmPci32( Segment, Bus, Device, Function, Register ) = \
173 MmPci32( Segment, Bus, Device, Function, Register ) & \
177 #define MmPci32AndThenOr( Segment, Bus, Device, Function, Register, AndData, OrData ) \
178 MmPci32( Segment, Bus, Device, Function, Register ) = \
180 ( MmPci32( Segment, Bus, Device, Function, Register ) & \
190 #define MmPci16Ptr( Segment, Bus, Device, Function, Register ) \
191 ( (volatile UINT16 *)MmPciAddress( Segment, Bus, Device, Function, Register ) )
193 #define MmPci16( Segment, Bus, Device, Function, Register ) \
194 *MmPci16Ptr( Segment, Bus, Device, Function, Register )
196 #define MmPci16Or( Segment, Bus, Device, Function, Register, OrData ) \
197 MmPci16( Segment, Bus, Device, Function, Register ) = \
199 MmPci16( Segment, Bus, Device, Function, Register ) | \
203 #define MmPci16And( Segment, Bus, Device, Function, Register, AndData ) \
204 MmPci16( Segment, Bus, Device, Function, Register ) = \
206 MmPci16( Segment, Bus, Device, Function, Register ) & \
210 #define MmPci16AndThenOr( Segment, Bus, Device, Function, Register, AndData, OrData ) \
211 MmPci16( Segment, Bus, Device, Function, Register ) = \
213 ( MmPci16( Segment, Bus, Device, Function, Register ) & \
223 #define MmPci8Ptr( Segment, Bus, Device, Function, Register ) \
224 ( (volatile UINT8 *)MmPciAddress( Segment, Bus, Device, Function, Register ) )
226 #define MmPci8( Segment, Bus, Device, Function, Register ) \
227 *MmPci8Ptr( Segment, Bus, Device, Function, Register )
229 #define MmPci8Or( Segment, Bus, Device, Function, Register, OrData ) \
230 MmPci8( Segment, Bus, Device, Function, Register ) = \
232 MmPci8( Segment, Bus, Device, Function, Register ) | \
236 #define MmPci8And( Segment, Bus, Device, Function, Register, AndData ) \
237 MmPci8( Segment, Bus, Device, Function, Register ) = \
239 MmPci8( Segment, Bus, Device, Function, Register ) & \
243 #define MmPci8AndThenOr( Segment, Bus, Device, Function, Register, AndData, OrData ) \
244 MmPci8( Segment, Bus, Device, Function, Register ) = \
246 ( MmPci8( Segment, Bus, Device, Function, Register ) & \