3 #ifndef SOUTHBRIDGE_INTEL_I82801IX_I82801IX_H
4 #define SOUTHBRIDGE_INTEL_I82801IX_I82801IX_H
6 #define DEFAULT_TBAR ((u8 *)0xfed1b000)
10 #if CONFIG(BOARD_EMULATION_QEMU_X86_Q35)
16 # define DEFAULT_PMBASE 0x00000600
18 # define DEFAULT_PMBASE 0x00000500
20 #define DEFAULT_TCOBASE (DEFAULT_PMBASE + 0x60)
21 #define DEFAULT_GPIOBASE 0x00000580
25 #define GP_IO_USE_SEL 0x00
26 #define GP_IO_SEL 0x04
28 #define GPO_BLINK 0x18
30 #define GP_IO_USE_SEL2 0x30
31 #define GP_IO_SEL2 0x34
34 #define DEBUG_PERIODIC_SMIS 0
36 #define MAINBOARD_POWER_OFF 0
37 #define MAINBOARD_POWER_ON 1
38 #define MAINBOARD_POWER_KEEP 2
41 #define D31F0_ACPI_CNTL 0x44
42 #define D31F0_GPIO_BASE 0x48
43 #define D31F0_GPIO_CNTL 0x4c
44 #define D31F0_PIRQA_ROUT 0x60
45 #define D31F0_PIRQB_ROUT 0x61
46 #define D31F0_PIRQC_ROUT 0x62
47 #define D31F0_PIRQD_ROUT 0x63
48 #define D31F0_SERIRQ_CNTL 0x64
49 #define D31F0_PIRQE_ROUT 0x68
50 #define D31F0_PIRQF_ROUT 0x69
51 #define D31F0_PIRQG_ROUT 0x6a
52 #define D31F0_PIRQH_ROUT 0x6b
53 #define D31F0_LPC_IODEC 0x80
54 #define D31F0_LPC_EN 0x82
55 #define CNF2_LPC_EN (1 << 13)
56 #define CNF1_LPC_EN (1 << 12)
57 #define MC_LPC_EN (1 << 11)
58 #define KBC_LPC_EN (1 << 10)
59 #define GAMEH_LPC_EN (1 << 9)
60 #define GAMEL_LPC_EN (1 << 8)
61 #define FDD_LPC_EN (1 << 3)
62 #define LPT_LPC_EN (1 << 2)
63 #define COMB_LPC_EN (1 << 1)
64 #define COMA_LPC_EN (1 << 0)
65 #define D31F0_GEN1_DEC 0x84
66 #define D31F0_GEN2_DEC 0x88
67 #define D31F0_GEN3_DEC 0x8c
68 #define D31F0_GEN4_DEC 0x90
69 #define D31F0_C5_EXIT_TIMING 0xa8
70 #define D31F0_CxSTATE_CNF 0xa9
71 #define D31F0_C4TIMING_CNT 0xaa
74 #define D31F2_IDE_TIM_PRI 0x40
75 #define D31F2_IDE_TIM_SEC 0x42
76 #define D31F2_SIDX 0xa0
77 #define D31F2_SDAT 0xa4
80 #define D30F0_SMLT 0x1b
83 #define D28Fx_XCAP 0x42
84 #define D28Fx_SLCAP 0x54
91 #define I2C_EN (1 << 2)
92 #define SMB_SMI_EN (1 << 1)
93 #define HST_EN (1 << 0)
95 #define RCBA_V0CTL 0x0014
96 #define RCBA_V1CAP 0x001c
97 #define RCBA_V1CTL 0x0020
98 #define RCBA_V1STS 0x0026
99 #define RCBA_PAT 0x0030
100 #define RCBA_CIR1 0x0088
101 #define RCBA_ESD 0x0104
102 #define RCBA_ULD 0x0110
103 #define RCBA_ULBA 0x0118
104 #define RCBA_LCAP 0x01a4
105 #define RCBA_LCTL 0x01a8
106 #define RCBA_LSTS 0x01aa
107 #define RCBA_CIR2 0x01f4
108 #define RCBA_CIR3 0x01fc
109 #define RCBA_BCR 0x0220
110 #define RCBA_DMIC 0x0234
111 #define RCBA_RPFN 0x0238
112 #define RCBA_CIR13 0x0f20
113 #define RCBA_CIR5 0x1d40
114 #define RCBA_DMC 0x2010
115 #define RCBA_CIR6 0x2024
116 #define RCBA_CIR7 0x2034
117 #define RCBA_HPTC 0x3404
119 #define RCBA_BUC 0x3414
120 #define RCBA_FD 0x3418
121 #define RCBA_CG 0x341c
122 #define RCBA_FDSW 0x3420
123 #define RCBA_CIR8 0x3430
124 #define RCBA_CIR9 0x350c
125 #define RCBA_CIR10 0x352c
126 #define RCBA_MAP 0x35f0
128 #define BUC_LAND (1 << 5)
129 #define FD_SAD2 (1 << 25)
130 #define FD_TTD (1 << 24)
131 #define FD_PE6D (1 << 21)
132 #define FD_PE5D (1 << 20)
133 #define FD_PE4D (1 << 19)
134 #define FD_PE3D (1 << 18)
135 #define FD_PE2D (1 << 17)
136 #define FD_PE1D (1 << 16)
137 #define FD_EHCI1D (1 << 15)
138 #define FD_LBD (1 << 14)
139 #define FD_EHCI2D (1 << 13)
140 #define FD_U5D (1 << 12)
141 #define FD_U4D (1 << 11)
142 #define FD_U3D (1 << 10)
143 #define FD_U2D (1 << 9)
144 #define FD_U1D (1 << 8)
145 #define FD_U6D (1 << 7)
146 #define FD_HDAD (1 << 4)
147 #define FD_SD (1 << 3)
148 #define FD_SAD1 (1 << 2)
151 #ifndef __ASSEMBLER__
157 return (devid == 0x2917) || (devid == 0x2919);
159 #define LPC_IS_MOBILE(dev) lpc_is_mobile(pci_read_config16(dev, PCI_DEVICE_ID))
void i82801ix_dmi_setup(void)
void i82801ix_early_init(void)
void i82801ix_lpc_setup(void)
void i82801ix_dmi_poll_vc1(void)
static int lpc_is_mobile(const u16 devid)