xref: /openbmc/linux/drivers/i2c/busses/i2c-i801.c (revision e983940270f10fe8551baf0098be76ea478294a3)
1 /*
2     Copyright (c) 1998 - 2002  Frodo Looijaard <frodol@dds.nl>,
3     Philip Edelbrock <phil@netroedge.com>, and Mark D. Studebaker
4     <mdsxyz123@yahoo.com>
5     Copyright (C) 2007 - 2014  Jean Delvare <jdelvare@suse.de>
6     Copyright (C) 2010         Intel Corporation,
7                                David Woodhouse <dwmw2@infradead.org>
8 
9     This program is free software; you can redistribute it and/or modify
10     it under the terms of the GNU General Public License as published by
11     the Free Software Foundation; either version 2 of the License, or
12     (at your option) any later version.
13 
14     This program is distributed in the hope that it will be useful,
15     but WITHOUT ANY WARRANTY; without even the implied warranty of
16     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17     GNU General Public License for more details.
18 */
19 
20 /*
21  * Supports the following Intel I/O Controller Hubs (ICH):
22  *
23  *					I/O			Block	I2C
24  *					region	SMBus	Block	proc.	block
25  * Chip name			PCI ID	size	PEC	buffer	call	read
26  * ---------------------------------------------------------------------------
27  * 82801AA (ICH)		0x2413	16	no	no	no	no
28  * 82801AB (ICH0)		0x2423	16	no	no	no	no
29  * 82801BA (ICH2)		0x2443	16	no	no	no	no
30  * 82801CA (ICH3)		0x2483	32	soft	no	no	no
31  * 82801DB (ICH4)		0x24c3	32	hard	yes	no	no
32  * 82801E (ICH5)		0x24d3	32	hard	yes	yes	yes
33  * 6300ESB			0x25a4	32	hard	yes	yes	yes
34  * 82801F (ICH6)		0x266a	32	hard	yes	yes	yes
35  * 6310ESB/6320ESB		0x269b	32	hard	yes	yes	yes
36  * 82801G (ICH7)		0x27da	32	hard	yes	yes	yes
37  * 82801H (ICH8)		0x283e	32	hard	yes	yes	yes
38  * 82801I (ICH9)		0x2930	32	hard	yes	yes	yes
39  * EP80579 (Tolapai)		0x5032	32	hard	yes	yes	yes
40  * ICH10			0x3a30	32	hard	yes	yes	yes
41  * ICH10			0x3a60	32	hard	yes	yes	yes
42  * 5/3400 Series (PCH)		0x3b30	32	hard	yes	yes	yes
43  * 6 Series (PCH)		0x1c22	32	hard	yes	yes	yes
44  * Patsburg (PCH)		0x1d22	32	hard	yes	yes	yes
45  * Patsburg (PCH) IDF		0x1d70	32	hard	yes	yes	yes
46  * Patsburg (PCH) IDF		0x1d71	32	hard	yes	yes	yes
47  * Patsburg (PCH) IDF		0x1d72	32	hard	yes	yes	yes
48  * DH89xxCC (PCH)		0x2330	32	hard	yes	yes	yes
49  * Panther Point (PCH)		0x1e22	32	hard	yes	yes	yes
50  * Lynx Point (PCH)		0x8c22	32	hard	yes	yes	yes
51  * Lynx Point-LP (PCH)		0x9c22	32	hard	yes	yes	yes
52  * Avoton (SOC)			0x1f3c	32	hard	yes	yes	yes
53  * Wellsburg (PCH)		0x8d22	32	hard	yes	yes	yes
54  * Wellsburg (PCH) MS		0x8d7d	32	hard	yes	yes	yes
55  * Wellsburg (PCH) MS		0x8d7e	32	hard	yes	yes	yes
56  * Wellsburg (PCH) MS		0x8d7f	32	hard	yes	yes	yes
57  * Coleto Creek (PCH)		0x23b0	32	hard	yes	yes	yes
58  * Wildcat Point (PCH)		0x8ca2	32	hard	yes	yes	yes
59  * Wildcat Point-LP (PCH)	0x9ca2	32	hard	yes	yes	yes
60  * BayTrail (SOC)		0x0f12	32	hard	yes	yes	yes
61  * Sunrise Point-H (PCH) 	0xa123  32	hard	yes	yes	yes
62  * Sunrise Point-LP (PCH)	0x9d23	32	hard	yes	yes	yes
63  * DNV (SOC)			0x19df	32	hard	yes	yes	yes
64  * Broxton (SOC)		0x5ad4	32	hard	yes	yes	yes
65  * Lewisburg (PCH)		0xa1a3	32	hard	yes	yes	yes
66  * Lewisburg Supersku (PCH)	0xa223	32	hard	yes	yes	yes
67  * Kaby Lake PCH-H (PCH)	0xa2a3	32	hard	yes	yes	yes
68  *
69  * Features supported by this driver:
70  * Software PEC				no
71  * Hardware PEC				yes
72  * Block buffer				yes
73  * Block process call transaction	no
74  * I2C block read transaction		yes (doesn't use the block buffer)
75  * Slave mode				no
76  * SMBus Host Notify			yes
77  * Interrupt processing			yes
78  *
79  * See the file Documentation/i2c/busses/i2c-i801 for details.
80  */
81 
82 #include <linux/interrupt.h>
83 #include <linux/module.h>
84 #include <linux/pci.h>
85 #include <linux/kernel.h>
86 #include <linux/stddef.h>
87 #include <linux/delay.h>
88 #include <linux/ioport.h>
89 #include <linux/init.h>
90 #include <linux/i2c.h>
91 #include <linux/i2c-smbus.h>
92 #include <linux/acpi.h>
93 #include <linux/io.h>
94 #include <linux/dmi.h>
95 #include <linux/slab.h>
96 #include <linux/wait.h>
97 #include <linux/err.h>
98 #include <linux/platform_device.h>
99 #include <linux/platform_data/itco_wdt.h>
100 #include <linux/pm_runtime.h>
101 
102 #if IS_ENABLED(CONFIG_I2C_MUX_GPIO) && defined CONFIG_DMI
103 #include <linux/gpio.h>
104 #include <linux/i2c-mux-gpio.h>
105 #endif
106 
107 /* I801 SMBus address offsets */
108 #define SMBHSTSTS(p)	(0 + (p)->smba)
109 #define SMBHSTCNT(p)	(2 + (p)->smba)
110 #define SMBHSTCMD(p)	(3 + (p)->smba)
111 #define SMBHSTADD(p)	(4 + (p)->smba)
112 #define SMBHSTDAT0(p)	(5 + (p)->smba)
113 #define SMBHSTDAT1(p)	(6 + (p)->smba)
114 #define SMBBLKDAT(p)	(7 + (p)->smba)
115 #define SMBPEC(p)	(8 + (p)->smba)		/* ICH3 and later */
116 #define SMBAUXSTS(p)	(12 + (p)->smba)	/* ICH4 and later */
117 #define SMBAUXCTL(p)	(13 + (p)->smba)	/* ICH4 and later */
118 #define SMBSLVSTS(p)	(16 + (p)->smba)	/* ICH3 and later */
119 #define SMBSLVCMD(p)	(17 + (p)->smba)	/* ICH3 and later */
120 #define SMBNTFDADD(p)	(20 + (p)->smba)	/* ICH3 and later */
121 #define SMBNTFDDAT(p)	(22 + (p)->smba)	/* ICH3 and later */
122 
123 /* PCI Address Constants */
124 #define SMBBAR		4
125 #define SMBPCICTL	0x004
126 #define SMBPCISTS	0x006
127 #define SMBHSTCFG	0x040
128 #define TCOBASE		0x050
129 #define TCOCTL		0x054
130 
131 #define ACPIBASE		0x040
132 #define ACPIBASE_SMI_OFF	0x030
133 #define ACPICTRL		0x044
134 #define ACPICTRL_EN		0x080
135 
136 #define SBREG_BAR		0x10
137 #define SBREG_SMBCTRL		0xc6000c
138 
139 /* Host status bits for SMBPCISTS */
140 #define SMBPCISTS_INTS		0x08
141 
142 /* Control bits for SMBPCICTL */
143 #define SMBPCICTL_INTDIS	0x0400
144 
145 /* Host configuration bits for SMBHSTCFG */
146 #define SMBHSTCFG_HST_EN	1
147 #define SMBHSTCFG_SMB_SMI_EN	2
148 #define SMBHSTCFG_I2C_EN	4
149 
150 /* TCO configuration bits for TCOCTL */
151 #define TCOCTL_EN		0x0100
152 
153 /* Auxiliary status register bits, ICH4+ only */
154 #define SMBAUXSTS_CRCE		1
155 #define SMBAUXSTS_STCO		2
156 
157 /* Auxiliary control register bits, ICH4+ only */
158 #define SMBAUXCTL_CRC		1
159 #define SMBAUXCTL_E32B		2
160 
161 /* Other settings */
162 #define MAX_RETRIES		400
163 
164 /* I801 command constants */
165 #define I801_QUICK		0x00
166 #define I801_BYTE		0x04
167 #define I801_BYTE_DATA		0x08
168 #define I801_WORD_DATA		0x0C
169 #define I801_PROC_CALL		0x10	/* unimplemented */
170 #define I801_BLOCK_DATA		0x14
171 #define I801_I2C_BLOCK_DATA	0x18	/* ICH5 and later */
172 
173 /* I801 Host Control register bits */
174 #define SMBHSTCNT_INTREN	0x01
175 #define SMBHSTCNT_KILL		0x02
176 #define SMBHSTCNT_LAST_BYTE	0x20
177 #define SMBHSTCNT_START		0x40
178 #define SMBHSTCNT_PEC_EN	0x80	/* ICH3 and later */
179 
180 /* I801 Hosts Status register bits */
181 #define SMBHSTSTS_BYTE_DONE	0x80
182 #define SMBHSTSTS_INUSE_STS	0x40
183 #define SMBHSTSTS_SMBALERT_STS	0x20
184 #define SMBHSTSTS_FAILED	0x10
185 #define SMBHSTSTS_BUS_ERR	0x08
186 #define SMBHSTSTS_DEV_ERR	0x04
187 #define SMBHSTSTS_INTR		0x02
188 #define SMBHSTSTS_HOST_BUSY	0x01
189 
190 /* Host Notify Status registers bits */
191 #define SMBSLVSTS_HST_NTFY_STS	1
192 
193 /* Host Notify Command registers bits */
194 #define SMBSLVCMD_HST_NTFY_INTREN	0x01
195 
196 #define STATUS_ERROR_FLAGS	(SMBHSTSTS_FAILED | SMBHSTSTS_BUS_ERR | \
197 				 SMBHSTSTS_DEV_ERR)
198 
199 #define STATUS_FLAGS		(SMBHSTSTS_BYTE_DONE | SMBHSTSTS_INTR | \
200 				 STATUS_ERROR_FLAGS)
201 
202 /* Older devices have their ID defined in <linux/pci_ids.h> */
203 #define PCI_DEVICE_ID_INTEL_BAYTRAIL_SMBUS		0x0f12
204 #define PCI_DEVICE_ID_INTEL_DNV_SMBUS			0x19df
205 #define PCI_DEVICE_ID_INTEL_COUGARPOINT_SMBUS		0x1c22
206 #define PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS		0x1d22
207 /* Patsburg also has three 'Integrated Device Function' SMBus controllers */
208 #define PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF0		0x1d70
209 #define PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF1		0x1d71
210 #define PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF2		0x1d72
211 #define PCI_DEVICE_ID_INTEL_PANTHERPOINT_SMBUS		0x1e22
212 #define PCI_DEVICE_ID_INTEL_AVOTON_SMBUS		0x1f3c
213 #define PCI_DEVICE_ID_INTEL_BRASWELL_SMBUS		0x2292
214 #define PCI_DEVICE_ID_INTEL_DH89XXCC_SMBUS		0x2330
215 #define PCI_DEVICE_ID_INTEL_COLETOCREEK_SMBUS		0x23b0
216 #define PCI_DEVICE_ID_INTEL_5_3400_SERIES_SMBUS		0x3b30
217 #define PCI_DEVICE_ID_INTEL_BROXTON_SMBUS		0x5ad4
218 #define PCI_DEVICE_ID_INTEL_LYNXPOINT_SMBUS		0x8c22
219 #define PCI_DEVICE_ID_INTEL_WILDCATPOINT_SMBUS		0x8ca2
220 #define PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS		0x8d22
221 #define PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS0		0x8d7d
222 #define PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS1		0x8d7e
223 #define PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS2		0x8d7f
224 #define PCI_DEVICE_ID_INTEL_LYNXPOINT_LP_SMBUS		0x9c22
225 #define PCI_DEVICE_ID_INTEL_WILDCATPOINT_LP_SMBUS	0x9ca2
226 #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_SMBUS	0x9d23
227 #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_H_SMBUS	0xa123
228 #define PCI_DEVICE_ID_INTEL_LEWISBURG_SMBUS		0xa1a3
229 #define PCI_DEVICE_ID_INTEL_LEWISBURG_SSKU_SMBUS	0xa223
230 #define PCI_DEVICE_ID_INTEL_KABYLAKE_PCH_H_SMBUS	0xa2a3
231 
232 struct i801_mux_config {
233 	char *gpio_chip;
234 	unsigned values[3];
235 	int n_values;
236 	unsigned classes[3];
237 	unsigned gpios[2];		/* Relative to gpio_chip->base */
238 	int n_gpios;
239 };
240 
241 struct i801_priv {
242 	struct i2c_adapter adapter;
243 	unsigned long smba;
244 	unsigned char original_hstcfg;
245 	struct pci_dev *pci_dev;
246 	unsigned int features;
247 
248 	/* isr processing */
249 	wait_queue_head_t waitq;
250 	u8 status;
251 
252 	/* Command state used by isr for byte-by-byte block transactions */
253 	u8 cmd;
254 	bool is_read;
255 	int count;
256 	int len;
257 	u8 *data;
258 
259 #if IS_ENABLED(CONFIG_I2C_MUX_GPIO) && defined CONFIG_DMI
260 	const struct i801_mux_config *mux_drvdata;
261 	struct platform_device *mux_pdev;
262 #endif
263 	struct platform_device *tco_pdev;
264 
265 	/*
266 	 * If set to true the host controller registers are reserved for
267 	 * ACPI AML use. Protected by acpi_lock.
268 	 */
269 	bool acpi_reserved;
270 	struct mutex acpi_lock;
271 	struct smbus_host_notify *host_notify;
272 };
273 
274 #define SMBHSTNTFY_SIZE		8
275 
276 #define FEATURE_SMBUS_PEC	(1 << 0)
277 #define FEATURE_BLOCK_BUFFER	(1 << 1)
278 #define FEATURE_BLOCK_PROC	(1 << 2)
279 #define FEATURE_I2C_BLOCK_READ	(1 << 3)
280 #define FEATURE_IRQ		(1 << 4)
281 #define FEATURE_HOST_NOTIFY	(1 << 5)
282 /* Not really a feature, but it's convenient to handle it as such */
283 #define FEATURE_IDF		(1 << 15)
284 #define FEATURE_TCO		(1 << 16)
285 
286 static const char *i801_feature_names[] = {
287 	"SMBus PEC",
288 	"Block buffer",
289 	"Block process call",
290 	"I2C block read",
291 	"Interrupt",
292 	"SMBus Host Notify",
293 };
294 
295 static unsigned int disable_features;
296 module_param(disable_features, uint, S_IRUGO | S_IWUSR);
297 MODULE_PARM_DESC(disable_features, "Disable selected driver features:\n"
298 	"\t\t  0x01  disable SMBus PEC\n"
299 	"\t\t  0x02  disable the block buffer\n"
300 	"\t\t  0x08  disable the I2C block read functionality\n"
301 	"\t\t  0x10  don't use interrupts\n"
302 	"\t\t  0x20  disable SMBus Host Notify ");
303 
304 /* Make sure the SMBus host is ready to start transmitting.
305    Return 0 if it is, -EBUSY if it is not. */
306 static int i801_check_pre(struct i801_priv *priv)
307 {
308 	int status;
309 
310 	status = inb_p(SMBHSTSTS(priv));
311 	if (status & SMBHSTSTS_HOST_BUSY) {
312 		dev_err(&priv->pci_dev->dev, "SMBus is busy, can't use it!\n");
313 		return -EBUSY;
314 	}
315 
316 	status &= STATUS_FLAGS;
317 	if (status) {
318 		dev_dbg(&priv->pci_dev->dev, "Clearing status flags (%02x)\n",
319 			status);
320 		outb_p(status, SMBHSTSTS(priv));
321 		status = inb_p(SMBHSTSTS(priv)) & STATUS_FLAGS;
322 		if (status) {
323 			dev_err(&priv->pci_dev->dev,
324 				"Failed clearing status flags (%02x)\n",
325 				status);
326 			return -EBUSY;
327 		}
328 	}
329 
330 	/*
331 	 * Clear CRC status if needed.
332 	 * During normal operation, i801_check_post() takes care
333 	 * of it after every operation.  We do it here only in case
334 	 * the hardware was already in this state when the driver
335 	 * started.
336 	 */
337 	if (priv->features & FEATURE_SMBUS_PEC) {
338 		status = inb_p(SMBAUXSTS(priv)) & SMBAUXSTS_CRCE;
339 		if (status) {
340 			dev_dbg(&priv->pci_dev->dev,
341 				"Clearing aux status flags (%02x)\n", status);
342 			outb_p(status, SMBAUXSTS(priv));
343 			status = inb_p(SMBAUXSTS(priv)) & SMBAUXSTS_CRCE;
344 			if (status) {
345 				dev_err(&priv->pci_dev->dev,
346 					"Failed clearing aux status flags (%02x)\n",
347 					status);
348 				return -EBUSY;
349 			}
350 		}
351 	}
352 
353 	return 0;
354 }
355 
356 /*
357  * Convert the status register to an error code, and clear it.
358  * Note that status only contains the bits we want to clear, not the
359  * actual register value.
360  */
361 static int i801_check_post(struct i801_priv *priv, int status)
362 {
363 	int result = 0;
364 
365 	/*
366 	 * If the SMBus is still busy, we give up
367 	 * Note: This timeout condition only happens when using polling
368 	 * transactions.  For interrupt operation, NAK/timeout is indicated by
369 	 * DEV_ERR.
370 	 */
371 	if (unlikely(status < 0)) {
372 		dev_err(&priv->pci_dev->dev, "Transaction timeout\n");
373 		/* try to stop the current command */
374 		dev_dbg(&priv->pci_dev->dev, "Terminating the current operation\n");
375 		outb_p(inb_p(SMBHSTCNT(priv)) | SMBHSTCNT_KILL,
376 		       SMBHSTCNT(priv));
377 		usleep_range(1000, 2000);
378 		outb_p(inb_p(SMBHSTCNT(priv)) & (~SMBHSTCNT_KILL),
379 		       SMBHSTCNT(priv));
380 
381 		/* Check if it worked */
382 		status = inb_p(SMBHSTSTS(priv));
383 		if ((status & SMBHSTSTS_HOST_BUSY) ||
384 		    !(status & SMBHSTSTS_FAILED))
385 			dev_err(&priv->pci_dev->dev,
386 				"Failed terminating the transaction\n");
387 		outb_p(STATUS_FLAGS, SMBHSTSTS(priv));
388 		return -ETIMEDOUT;
389 	}
390 
391 	if (status & SMBHSTSTS_FAILED) {
392 		result = -EIO;
393 		dev_err(&priv->pci_dev->dev, "Transaction failed\n");
394 	}
395 	if (status & SMBHSTSTS_DEV_ERR) {
396 		/*
397 		 * This may be a PEC error, check and clear it.
398 		 *
399 		 * AUXSTS is handled differently from HSTSTS.
400 		 * For HSTSTS, i801_isr() or i801_wait_intr()
401 		 * has already cleared the error bits in hardware,
402 		 * and we are passed a copy of the original value
403 		 * in "status".
404 		 * For AUXSTS, the hardware register is left
405 		 * for us to handle here.
406 		 * This is asymmetric, slightly iffy, but safe,
407 		 * since all this code is serialized and the CRCE
408 		 * bit is harmless as long as it's cleared before
409 		 * the next operation.
410 		 */
411 		if ((priv->features & FEATURE_SMBUS_PEC) &&
412 		    (inb_p(SMBAUXSTS(priv)) & SMBAUXSTS_CRCE)) {
413 			outb_p(SMBAUXSTS_CRCE, SMBAUXSTS(priv));
414 			result = -EBADMSG;
415 			dev_dbg(&priv->pci_dev->dev, "PEC error\n");
416 		} else {
417 			result = -ENXIO;
418 			dev_dbg(&priv->pci_dev->dev, "No response\n");
419 		}
420 	}
421 	if (status & SMBHSTSTS_BUS_ERR) {
422 		result = -EAGAIN;
423 		dev_dbg(&priv->pci_dev->dev, "Lost arbitration\n");
424 	}
425 
426 	/* Clear status flags except BYTE_DONE, to be cleared by caller */
427 	outb_p(status, SMBHSTSTS(priv));
428 
429 	return result;
430 }
431 
432 /* Wait for BUSY being cleared and either INTR or an error flag being set */
433 static int i801_wait_intr(struct i801_priv *priv)
434 {
435 	int timeout = 0;
436 	int status;
437 
438 	/* We will always wait for a fraction of a second! */
439 	do {
440 		usleep_range(250, 500);
441 		status = inb_p(SMBHSTSTS(priv));
442 	} while (((status & SMBHSTSTS_HOST_BUSY) ||
443 		  !(status & (STATUS_ERROR_FLAGS | SMBHSTSTS_INTR))) &&
444 		 (timeout++ < MAX_RETRIES));
445 
446 	if (timeout > MAX_RETRIES) {
447 		dev_dbg(&priv->pci_dev->dev, "INTR Timeout!\n");
448 		return -ETIMEDOUT;
449 	}
450 	return status & (STATUS_ERROR_FLAGS | SMBHSTSTS_INTR);
451 }
452 
453 /* Wait for either BYTE_DONE or an error flag being set */
454 static int i801_wait_byte_done(struct i801_priv *priv)
455 {
456 	int timeout = 0;
457 	int status;
458 
459 	/* We will always wait for a fraction of a second! */
460 	do {
461 		usleep_range(250, 500);
462 		status = inb_p(SMBHSTSTS(priv));
463 	} while (!(status & (STATUS_ERROR_FLAGS | SMBHSTSTS_BYTE_DONE)) &&
464 		 (timeout++ < MAX_RETRIES));
465 
466 	if (timeout > MAX_RETRIES) {
467 		dev_dbg(&priv->pci_dev->dev, "BYTE_DONE Timeout!\n");
468 		return -ETIMEDOUT;
469 	}
470 	return status & STATUS_ERROR_FLAGS;
471 }
472 
473 static int i801_transaction(struct i801_priv *priv, int xact)
474 {
475 	int status;
476 	int result;
477 	const struct i2c_adapter *adap = &priv->adapter;
478 
479 	result = i801_check_pre(priv);
480 	if (result < 0)
481 		return result;
482 
483 	if (priv->features & FEATURE_IRQ) {
484 		outb_p(xact | SMBHSTCNT_INTREN | SMBHSTCNT_START,
485 		       SMBHSTCNT(priv));
486 		result = wait_event_timeout(priv->waitq,
487 					    (status = priv->status),
488 					    adap->timeout);
489 		if (!result) {
490 			status = -ETIMEDOUT;
491 			dev_warn(&priv->pci_dev->dev,
492 				 "Timeout waiting for interrupt!\n");
493 		}
494 		priv->status = 0;
495 		return i801_check_post(priv, status);
496 	}
497 
498 	/* the current contents of SMBHSTCNT can be overwritten, since PEC,
499 	 * SMBSCMD are passed in xact */
500 	outb_p(xact | SMBHSTCNT_START, SMBHSTCNT(priv));
501 
502 	status = i801_wait_intr(priv);
503 	return i801_check_post(priv, status);
504 }
505 
506 static int i801_block_transaction_by_block(struct i801_priv *priv,
507 					   union i2c_smbus_data *data,
508 					   char read_write, int hwpec)
509 {
510 	int i, len;
511 	int status;
512 
513 	inb_p(SMBHSTCNT(priv)); /* reset the data buffer index */
514 
515 	/* Use 32-byte buffer to process this transaction */
516 	if (read_write == I2C_SMBUS_WRITE) {
517 		len = data->block[0];
518 		outb_p(len, SMBHSTDAT0(priv));
519 		for (i = 0; i < len; i++)
520 			outb_p(data->block[i+1], SMBBLKDAT(priv));
521 	}
522 
523 	status = i801_transaction(priv, I801_BLOCK_DATA |
524 				  (hwpec ? SMBHSTCNT_PEC_EN : 0));
525 	if (status)
526 		return status;
527 
528 	if (read_write == I2C_SMBUS_READ) {
529 		len = inb_p(SMBHSTDAT0(priv));
530 		if (len < 1 || len > I2C_SMBUS_BLOCK_MAX)
531 			return -EPROTO;
532 
533 		data->block[0] = len;
534 		for (i = 0; i < len; i++)
535 			data->block[i + 1] = inb_p(SMBBLKDAT(priv));
536 	}
537 	return 0;
538 }
539 
540 static void i801_isr_byte_done(struct i801_priv *priv)
541 {
542 	if (priv->is_read) {
543 		/* For SMBus block reads, length is received with first byte */
544 		if (((priv->cmd & 0x1c) == I801_BLOCK_DATA) &&
545 		    (priv->count == 0)) {
546 			priv->len = inb_p(SMBHSTDAT0(priv));
547 			if (priv->len < 1 || priv->len > I2C_SMBUS_BLOCK_MAX) {
548 				dev_err(&priv->pci_dev->dev,
549 					"Illegal SMBus block read size %d\n",
550 					priv->len);
551 				/* FIXME: Recover */
552 				priv->len = I2C_SMBUS_BLOCK_MAX;
553 			} else {
554 				dev_dbg(&priv->pci_dev->dev,
555 					"SMBus block read size is %d\n",
556 					priv->len);
557 			}
558 			priv->data[-1] = priv->len;
559 		}
560 
561 		/* Read next byte */
562 		if (priv->count < priv->len)
563 			priv->data[priv->count++] = inb(SMBBLKDAT(priv));
564 		else
565 			dev_dbg(&priv->pci_dev->dev,
566 				"Discarding extra byte on block read\n");
567 
568 		/* Set LAST_BYTE for last byte of read transaction */
569 		if (priv->count == priv->len - 1)
570 			outb_p(priv->cmd | SMBHSTCNT_LAST_BYTE,
571 			       SMBHSTCNT(priv));
572 	} else if (priv->count < priv->len - 1) {
573 		/* Write next byte, except for IRQ after last byte */
574 		outb_p(priv->data[++priv->count], SMBBLKDAT(priv));
575 	}
576 
577 	/* Clear BYTE_DONE to continue with next byte */
578 	outb_p(SMBHSTSTS_BYTE_DONE, SMBHSTSTS(priv));
579 }
580 
581 static irqreturn_t i801_host_notify_isr(struct i801_priv *priv)
582 {
583 	unsigned short addr;
584 	unsigned int data;
585 
586 	addr = inb_p(SMBNTFDADD(priv)) >> 1;
587 	data = inw_p(SMBNTFDDAT(priv));
588 
589 	i2c_handle_smbus_host_notify(priv->host_notify, addr, data);
590 
591 	/* clear Host Notify bit and return */
592 	outb_p(SMBSLVSTS_HST_NTFY_STS, SMBSLVSTS(priv));
593 	return IRQ_HANDLED;
594 }
595 
596 /*
597  * There are three kinds of interrupts:
598  *
599  * 1) i801 signals transaction completion with one of these interrupts:
600  *      INTR - Success
601  *      DEV_ERR - Invalid command, NAK or communication timeout
602  *      BUS_ERR - SMI# transaction collision
603  *      FAILED - transaction was canceled due to a KILL request
604  *    When any of these occur, update ->status and wake up the waitq.
605  *    ->status must be cleared before kicking off the next transaction.
606  *
607  * 2) For byte-by-byte (I2C read/write) transactions, one BYTE_DONE interrupt
608  *    occurs for each byte of a byte-by-byte to prepare the next byte.
609  *
610  * 3) Host Notify interrupts
611  */
612 static irqreturn_t i801_isr(int irq, void *dev_id)
613 {
614 	struct i801_priv *priv = dev_id;
615 	u16 pcists;
616 	u8 status;
617 
618 	/* Confirm this is our interrupt */
619 	pci_read_config_word(priv->pci_dev, SMBPCISTS, &pcists);
620 	if (!(pcists & SMBPCISTS_INTS))
621 		return IRQ_NONE;
622 
623 	if (priv->features & FEATURE_HOST_NOTIFY) {
624 		status = inb_p(SMBSLVSTS(priv));
625 		if (status & SMBSLVSTS_HST_NTFY_STS)
626 			return i801_host_notify_isr(priv);
627 	}
628 
629 	status = inb_p(SMBHSTSTS(priv));
630 	if (status & SMBHSTSTS_BYTE_DONE)
631 		i801_isr_byte_done(priv);
632 
633 	/*
634 	 * Clear irq sources and report transaction result.
635 	 * ->status must be cleared before the next transaction is started.
636 	 */
637 	status &= SMBHSTSTS_INTR | STATUS_ERROR_FLAGS;
638 	if (status) {
639 		outb_p(status, SMBHSTSTS(priv));
640 		priv->status = status;
641 		wake_up(&priv->waitq);
642 	}
643 
644 	return IRQ_HANDLED;
645 }
646 
647 /*
648  * For "byte-by-byte" block transactions:
649  *   I2C write uses cmd=I801_BLOCK_DATA, I2C_EN=1
650  *   I2C read uses cmd=I801_I2C_BLOCK_DATA
651  */
652 static int i801_block_transaction_byte_by_byte(struct i801_priv *priv,
653 					       union i2c_smbus_data *data,
654 					       char read_write, int command,
655 					       int hwpec)
656 {
657 	int i, len;
658 	int smbcmd;
659 	int status;
660 	int result;
661 	const struct i2c_adapter *adap = &priv->adapter;
662 
663 	result = i801_check_pre(priv);
664 	if (result < 0)
665 		return result;
666 
667 	len = data->block[0];
668 
669 	if (read_write == I2C_SMBUS_WRITE) {
670 		outb_p(len, SMBHSTDAT0(priv));
671 		outb_p(data->block[1], SMBBLKDAT(priv));
672 	}
673 
674 	if (command == I2C_SMBUS_I2C_BLOCK_DATA &&
675 	    read_write == I2C_SMBUS_READ)
676 		smbcmd = I801_I2C_BLOCK_DATA;
677 	else
678 		smbcmd = I801_BLOCK_DATA;
679 
680 	if (priv->features & FEATURE_IRQ) {
681 		priv->is_read = (read_write == I2C_SMBUS_READ);
682 		if (len == 1 && priv->is_read)
683 			smbcmd |= SMBHSTCNT_LAST_BYTE;
684 		priv->cmd = smbcmd | SMBHSTCNT_INTREN;
685 		priv->len = len;
686 		priv->count = 0;
687 		priv->data = &data->block[1];
688 
689 		outb_p(priv->cmd | SMBHSTCNT_START, SMBHSTCNT(priv));
690 		result = wait_event_timeout(priv->waitq,
691 					    (status = priv->status),
692 					    adap->timeout);
693 		if (!result) {
694 			status = -ETIMEDOUT;
695 			dev_warn(&priv->pci_dev->dev,
696 				 "Timeout waiting for interrupt!\n");
697 		}
698 		priv->status = 0;
699 		return i801_check_post(priv, status);
700 	}
701 
702 	for (i = 1; i <= len; i++) {
703 		if (i == len && read_write == I2C_SMBUS_READ)
704 			smbcmd |= SMBHSTCNT_LAST_BYTE;
705 		outb_p(smbcmd, SMBHSTCNT(priv));
706 
707 		if (i == 1)
708 			outb_p(inb(SMBHSTCNT(priv)) | SMBHSTCNT_START,
709 			       SMBHSTCNT(priv));
710 
711 		status = i801_wait_byte_done(priv);
712 		if (status)
713 			goto exit;
714 
715 		if (i == 1 && read_write == I2C_SMBUS_READ
716 		 && command != I2C_SMBUS_I2C_BLOCK_DATA) {
717 			len = inb_p(SMBHSTDAT0(priv));
718 			if (len < 1 || len > I2C_SMBUS_BLOCK_MAX) {
719 				dev_err(&priv->pci_dev->dev,
720 					"Illegal SMBus block read size %d\n",
721 					len);
722 				/* Recover */
723 				while (inb_p(SMBHSTSTS(priv)) &
724 				       SMBHSTSTS_HOST_BUSY)
725 					outb_p(SMBHSTSTS_BYTE_DONE,
726 					       SMBHSTSTS(priv));
727 				outb_p(SMBHSTSTS_INTR, SMBHSTSTS(priv));
728 				return -EPROTO;
729 			}
730 			data->block[0] = len;
731 		}
732 
733 		/* Retrieve/store value in SMBBLKDAT */
734 		if (read_write == I2C_SMBUS_READ)
735 			data->block[i] = inb_p(SMBBLKDAT(priv));
736 		if (read_write == I2C_SMBUS_WRITE && i+1 <= len)
737 			outb_p(data->block[i+1], SMBBLKDAT(priv));
738 
739 		/* signals SMBBLKDAT ready */
740 		outb_p(SMBHSTSTS_BYTE_DONE, SMBHSTSTS(priv));
741 	}
742 
743 	status = i801_wait_intr(priv);
744 exit:
745 	return i801_check_post(priv, status);
746 }
747 
748 static int i801_set_block_buffer_mode(struct i801_priv *priv)
749 {
750 	outb_p(inb_p(SMBAUXCTL(priv)) | SMBAUXCTL_E32B, SMBAUXCTL(priv));
751 	if ((inb_p(SMBAUXCTL(priv)) & SMBAUXCTL_E32B) == 0)
752 		return -EIO;
753 	return 0;
754 }
755 
756 /* Block transaction function */
757 static int i801_block_transaction(struct i801_priv *priv,
758 				  union i2c_smbus_data *data, char read_write,
759 				  int command, int hwpec)
760 {
761 	int result = 0;
762 	unsigned char hostc;
763 
764 	if (command == I2C_SMBUS_I2C_BLOCK_DATA) {
765 		if (read_write == I2C_SMBUS_WRITE) {
766 			/* set I2C_EN bit in configuration register */
767 			pci_read_config_byte(priv->pci_dev, SMBHSTCFG, &hostc);
768 			pci_write_config_byte(priv->pci_dev, SMBHSTCFG,
769 					      hostc | SMBHSTCFG_I2C_EN);
770 		} else if (!(priv->features & FEATURE_I2C_BLOCK_READ)) {
771 			dev_err(&priv->pci_dev->dev,
772 				"I2C block read is unsupported!\n");
773 			return -EOPNOTSUPP;
774 		}
775 	}
776 
777 	if (read_write == I2C_SMBUS_WRITE
778 	 || command == I2C_SMBUS_I2C_BLOCK_DATA) {
779 		if (data->block[0] < 1)
780 			data->block[0] = 1;
781 		if (data->block[0] > I2C_SMBUS_BLOCK_MAX)
782 			data->block[0] = I2C_SMBUS_BLOCK_MAX;
783 	} else {
784 		data->block[0] = 32;	/* max for SMBus block reads */
785 	}
786 
787 	/* Experience has shown that the block buffer can only be used for
788 	   SMBus (not I2C) block transactions, even though the datasheet
789 	   doesn't mention this limitation. */
790 	if ((priv->features & FEATURE_BLOCK_BUFFER)
791 	 && command != I2C_SMBUS_I2C_BLOCK_DATA
792 	 && i801_set_block_buffer_mode(priv) == 0)
793 		result = i801_block_transaction_by_block(priv, data,
794 							 read_write, hwpec);
795 	else
796 		result = i801_block_transaction_byte_by_byte(priv, data,
797 							     read_write,
798 							     command, hwpec);
799 
800 	if (command == I2C_SMBUS_I2C_BLOCK_DATA
801 	 && read_write == I2C_SMBUS_WRITE) {
802 		/* restore saved configuration register value */
803 		pci_write_config_byte(priv->pci_dev, SMBHSTCFG, hostc);
804 	}
805 	return result;
806 }
807 
808 /* Return negative errno on error. */
809 static s32 i801_access(struct i2c_adapter *adap, u16 addr,
810 		       unsigned short flags, char read_write, u8 command,
811 		       int size, union i2c_smbus_data *data)
812 {
813 	int hwpec;
814 	int block = 0;
815 	int ret = 0, xact = 0;
816 	struct i801_priv *priv = i2c_get_adapdata(adap);
817 
818 	mutex_lock(&priv->acpi_lock);
819 	if (priv->acpi_reserved) {
820 		mutex_unlock(&priv->acpi_lock);
821 		return -EBUSY;
822 	}
823 
824 	pm_runtime_get_sync(&priv->pci_dev->dev);
825 
826 	hwpec = (priv->features & FEATURE_SMBUS_PEC) && (flags & I2C_CLIENT_PEC)
827 		&& size != I2C_SMBUS_QUICK
828 		&& size != I2C_SMBUS_I2C_BLOCK_DATA;
829 
830 	switch (size) {
831 	case I2C_SMBUS_QUICK:
832 		outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
833 		       SMBHSTADD(priv));
834 		xact = I801_QUICK;
835 		break;
836 	case I2C_SMBUS_BYTE:
837 		outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
838 		       SMBHSTADD(priv));
839 		if (read_write == I2C_SMBUS_WRITE)
840 			outb_p(command, SMBHSTCMD(priv));
841 		xact = I801_BYTE;
842 		break;
843 	case I2C_SMBUS_BYTE_DATA:
844 		outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
845 		       SMBHSTADD(priv));
846 		outb_p(command, SMBHSTCMD(priv));
847 		if (read_write == I2C_SMBUS_WRITE)
848 			outb_p(data->byte, SMBHSTDAT0(priv));
849 		xact = I801_BYTE_DATA;
850 		break;
851 	case I2C_SMBUS_WORD_DATA:
852 		outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
853 		       SMBHSTADD(priv));
854 		outb_p(command, SMBHSTCMD(priv));
855 		if (read_write == I2C_SMBUS_WRITE) {
856 			outb_p(data->word & 0xff, SMBHSTDAT0(priv));
857 			outb_p((data->word & 0xff00) >> 8, SMBHSTDAT1(priv));
858 		}
859 		xact = I801_WORD_DATA;
860 		break;
861 	case I2C_SMBUS_BLOCK_DATA:
862 		outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
863 		       SMBHSTADD(priv));
864 		outb_p(command, SMBHSTCMD(priv));
865 		block = 1;
866 		break;
867 	case I2C_SMBUS_I2C_BLOCK_DATA:
868 		/* NB: page 240 of ICH5 datasheet shows that the R/#W
869 		 * bit should be cleared here, even when reading */
870 		outb_p((addr & 0x7f) << 1, SMBHSTADD(priv));
871 		if (read_write == I2C_SMBUS_READ) {
872 			/* NB: page 240 of ICH5 datasheet also shows
873 			 * that DATA1 is the cmd field when reading */
874 			outb_p(command, SMBHSTDAT1(priv));
875 		} else
876 			outb_p(command, SMBHSTCMD(priv));
877 		block = 1;
878 		break;
879 	default:
880 		dev_err(&priv->pci_dev->dev, "Unsupported transaction %d\n",
881 			size);
882 		ret = -EOPNOTSUPP;
883 		goto out;
884 	}
885 
886 	if (hwpec)	/* enable/disable hardware PEC */
887 		outb_p(inb_p(SMBAUXCTL(priv)) | SMBAUXCTL_CRC, SMBAUXCTL(priv));
888 	else
889 		outb_p(inb_p(SMBAUXCTL(priv)) & (~SMBAUXCTL_CRC),
890 		       SMBAUXCTL(priv));
891 
892 	if (block)
893 		ret = i801_block_transaction(priv, data, read_write, size,
894 					     hwpec);
895 	else
896 		ret = i801_transaction(priv, xact);
897 
898 	/* Some BIOSes don't like it when PEC is enabled at reboot or resume
899 	   time, so we forcibly disable it after every transaction. Turn off
900 	   E32B for the same reason. */
901 	if (hwpec || block)
902 		outb_p(inb_p(SMBAUXCTL(priv)) &
903 		       ~(SMBAUXCTL_CRC | SMBAUXCTL_E32B), SMBAUXCTL(priv));
904 
905 	if (block)
906 		goto out;
907 	if (ret)
908 		goto out;
909 	if ((read_write == I2C_SMBUS_WRITE) || (xact == I801_QUICK))
910 		goto out;
911 
912 	switch (xact & 0x7f) {
913 	case I801_BYTE:	/* Result put in SMBHSTDAT0 */
914 	case I801_BYTE_DATA:
915 		data->byte = inb_p(SMBHSTDAT0(priv));
916 		break;
917 	case I801_WORD_DATA:
918 		data->word = inb_p(SMBHSTDAT0(priv)) +
919 			     (inb_p(SMBHSTDAT1(priv)) << 8);
920 		break;
921 	}
922 
923 out:
924 	pm_runtime_mark_last_busy(&priv->pci_dev->dev);
925 	pm_runtime_put_autosuspend(&priv->pci_dev->dev);
926 	mutex_unlock(&priv->acpi_lock);
927 	return ret;
928 }
929 
930 
931 static u32 i801_func(struct i2c_adapter *adapter)
932 {
933 	struct i801_priv *priv = i2c_get_adapdata(adapter);
934 
935 	return I2C_FUNC_SMBUS_QUICK | I2C_FUNC_SMBUS_BYTE |
936 	       I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA |
937 	       I2C_FUNC_SMBUS_BLOCK_DATA | I2C_FUNC_SMBUS_WRITE_I2C_BLOCK |
938 	       ((priv->features & FEATURE_SMBUS_PEC) ? I2C_FUNC_SMBUS_PEC : 0) |
939 	       ((priv->features & FEATURE_I2C_BLOCK_READ) ?
940 		I2C_FUNC_SMBUS_READ_I2C_BLOCK : 0) |
941 	       ((priv->features & FEATURE_HOST_NOTIFY) ?
942 		I2C_FUNC_SMBUS_HOST_NOTIFY : 0);
943 }
944 
945 static int i801_enable_host_notify(struct i2c_adapter *adapter)
946 {
947 	struct i801_priv *priv = i2c_get_adapdata(adapter);
948 
949 	if (!(priv->features & FEATURE_HOST_NOTIFY))
950 		return -ENOTSUPP;
951 
952 	if (!priv->host_notify)
953 		priv->host_notify = i2c_setup_smbus_host_notify(adapter);
954 	if (!priv->host_notify)
955 		return -ENOMEM;
956 
957 	outb_p(SMBSLVCMD_HST_NTFY_INTREN, SMBSLVCMD(priv));
958 	/* clear Host Notify bit to allow a new notification */
959 	outb_p(SMBSLVSTS_HST_NTFY_STS, SMBSLVSTS(priv));
960 
961 	return 0;
962 }
963 
964 static const struct i2c_algorithm smbus_algorithm = {
965 	.smbus_xfer	= i801_access,
966 	.functionality	= i801_func,
967 };
968 
969 static const struct pci_device_id i801_ids[] = {
970 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801AA_3) },
971 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801AB_3) },
972 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801BA_2) },
973 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_3) },
974 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801DB_3) },
975 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801EB_3) },
976 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB_4) },
977 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH6_16) },
978 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH7_17) },
979 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB2_17) },
980 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH8_5) },
981 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH9_6) },
982 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_EP80579_1) },
983 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH10_4) },
984 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH10_5) },
985 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_5_3400_SERIES_SMBUS) },
986 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_COUGARPOINT_SMBUS) },
987 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS) },
988 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF0) },
989 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF1) },
990 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF2) },
991 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_DH89XXCC_SMBUS) },
992 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_PANTHERPOINT_SMBUS) },
993 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_LYNXPOINT_SMBUS) },
994 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_LYNXPOINT_LP_SMBUS) },
995 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_AVOTON_SMBUS) },
996 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS) },
997 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS0) },
998 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS1) },
999 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS2) },
1000 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_COLETOCREEK_SMBUS) },
1001 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_WILDCATPOINT_SMBUS) },
1002 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_WILDCATPOINT_LP_SMBUS) },
1003 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_BAYTRAIL_SMBUS) },
1004 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_BRASWELL_SMBUS) },
1005 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_SUNRISEPOINT_H_SMBUS) },
1006 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_SMBUS) },
1007 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_DNV_SMBUS) },
1008 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_BROXTON_SMBUS) },
1009 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_LEWISBURG_SMBUS) },
1010 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_LEWISBURG_SSKU_SMBUS) },
1011 	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_KABYLAKE_PCH_H_SMBUS) },
1012 	{ 0, }
1013 };
1014 
1015 MODULE_DEVICE_TABLE(pci, i801_ids);
1016 
1017 #if defined CONFIG_X86 && defined CONFIG_DMI
1018 static unsigned char apanel_addr;
1019 
1020 /* Scan the system ROM for the signature "FJKEYINF" */
1021 static __init const void __iomem *bios_signature(const void __iomem *bios)
1022 {
1023 	ssize_t offset;
1024 	const unsigned char signature[] = "FJKEYINF";
1025 
1026 	for (offset = 0; offset < 0x10000; offset += 0x10) {
1027 		if (check_signature(bios + offset, signature,
1028 				    sizeof(signature)-1))
1029 			return bios + offset;
1030 	}
1031 	return NULL;
1032 }
1033 
1034 static void __init input_apanel_init(void)
1035 {
1036 	void __iomem *bios;
1037 	const void __iomem *p;
1038 
1039 	bios = ioremap(0xF0000, 0x10000); /* Can't fail */
1040 	p = bios_signature(bios);
1041 	if (p) {
1042 		/* just use the first address */
1043 		apanel_addr = readb(p + 8 + 3) >> 1;
1044 	}
1045 	iounmap(bios);
1046 }
1047 
1048 struct dmi_onboard_device_info {
1049 	const char *name;
1050 	u8 type;
1051 	unsigned short i2c_addr;
1052 	const char *i2c_type;
1053 };
1054 
1055 static const struct dmi_onboard_device_info dmi_devices[] = {
1056 	{ "Syleus", DMI_DEV_TYPE_OTHER, 0x73, "fscsyl" },
1057 	{ "Hermes", DMI_DEV_TYPE_OTHER, 0x73, "fscher" },
1058 	{ "Hades",  DMI_DEV_TYPE_OTHER, 0x73, "fschds" },
1059 };
1060 
1061 static void dmi_check_onboard_device(u8 type, const char *name,
1062 				     struct i2c_adapter *adap)
1063 {
1064 	int i;
1065 	struct i2c_board_info info;
1066 
1067 	for (i = 0; i < ARRAY_SIZE(dmi_devices); i++) {
1068 		/* & ~0x80, ignore enabled/disabled bit */
1069 		if ((type & ~0x80) != dmi_devices[i].type)
1070 			continue;
1071 		if (strcasecmp(name, dmi_devices[i].name))
1072 			continue;
1073 
1074 		memset(&info, 0, sizeof(struct i2c_board_info));
1075 		info.addr = dmi_devices[i].i2c_addr;
1076 		strlcpy(info.type, dmi_devices[i].i2c_type, I2C_NAME_SIZE);
1077 		i2c_new_device(adap, &info);
1078 		break;
1079 	}
1080 }
1081 
1082 /* We use our own function to check for onboard devices instead of
1083    dmi_find_device() as some buggy BIOS's have the devices we are interested
1084    in marked as disabled */
1085 static void dmi_check_onboard_devices(const struct dmi_header *dm, void *adap)
1086 {
1087 	int i, count;
1088 
1089 	if (dm->type != 10)
1090 		return;
1091 
1092 	count = (dm->length - sizeof(struct dmi_header)) / 2;
1093 	for (i = 0; i < count; i++) {
1094 		const u8 *d = (char *)(dm + 1) + (i * 2);
1095 		const char *name = ((char *) dm) + dm->length;
1096 		u8 type = d[0];
1097 		u8 s = d[1];
1098 
1099 		if (!s)
1100 			continue;
1101 		s--;
1102 		while (s > 0 && name[0]) {
1103 			name += strlen(name) + 1;
1104 			s--;
1105 		}
1106 		if (name[0] == 0) /* Bogus string reference */
1107 			continue;
1108 
1109 		dmi_check_onboard_device(type, name, adap);
1110 	}
1111 }
1112 
1113 /* Register optional slaves */
1114 static void i801_probe_optional_slaves(struct i801_priv *priv)
1115 {
1116 	/* Only register slaves on main SMBus channel */
1117 	if (priv->features & FEATURE_IDF)
1118 		return;
1119 
1120 	if (apanel_addr) {
1121 		struct i2c_board_info info;
1122 
1123 		memset(&info, 0, sizeof(struct i2c_board_info));
1124 		info.addr = apanel_addr;
1125 		strlcpy(info.type, "fujitsu_apanel", I2C_NAME_SIZE);
1126 		i2c_new_device(&priv->adapter, &info);
1127 	}
1128 
1129 	if (dmi_name_in_vendors("FUJITSU"))
1130 		dmi_walk(dmi_check_onboard_devices, &priv->adapter);
1131 }
1132 #else
1133 static void __init input_apanel_init(void) {}
1134 static void i801_probe_optional_slaves(struct i801_priv *priv) {}
1135 #endif	/* CONFIG_X86 && CONFIG_DMI */
1136 
1137 #if IS_ENABLED(CONFIG_I2C_MUX_GPIO) && defined CONFIG_DMI
1138 static struct i801_mux_config i801_mux_config_asus_z8_d12 = {
1139 	.gpio_chip = "gpio_ich",
1140 	.values = { 0x02, 0x03 },
1141 	.n_values = 2,
1142 	.classes = { I2C_CLASS_SPD, I2C_CLASS_SPD },
1143 	.gpios = { 52, 53 },
1144 	.n_gpios = 2,
1145 };
1146 
1147 static struct i801_mux_config i801_mux_config_asus_z8_d18 = {
1148 	.gpio_chip = "gpio_ich",
1149 	.values = { 0x02, 0x03, 0x01 },
1150 	.n_values = 3,
1151 	.classes = { I2C_CLASS_SPD, I2C_CLASS_SPD, I2C_CLASS_SPD },
1152 	.gpios = { 52, 53 },
1153 	.n_gpios = 2,
1154 };
1155 
1156 static const struct dmi_system_id mux_dmi_table[] = {
1157 	{
1158 		.matches = {
1159 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1160 			DMI_MATCH(DMI_BOARD_NAME, "Z8NA-D6(C)"),
1161 		},
1162 		.driver_data = &i801_mux_config_asus_z8_d12,
1163 	},
1164 	{
1165 		.matches = {
1166 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1167 			DMI_MATCH(DMI_BOARD_NAME, "Z8P(N)E-D12(X)"),
1168 		},
1169 		.driver_data = &i801_mux_config_asus_z8_d12,
1170 	},
1171 	{
1172 		.matches = {
1173 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1174 			DMI_MATCH(DMI_BOARD_NAME, "Z8NH-D12"),
1175 		},
1176 		.driver_data = &i801_mux_config_asus_z8_d12,
1177 	},
1178 	{
1179 		.matches = {
1180 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1181 			DMI_MATCH(DMI_BOARD_NAME, "Z8PH-D12/IFB"),
1182 		},
1183 		.driver_data = &i801_mux_config_asus_z8_d12,
1184 	},
1185 	{
1186 		.matches = {
1187 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1188 			DMI_MATCH(DMI_BOARD_NAME, "Z8NR-D12"),
1189 		},
1190 		.driver_data = &i801_mux_config_asus_z8_d12,
1191 	},
1192 	{
1193 		.matches = {
1194 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1195 			DMI_MATCH(DMI_BOARD_NAME, "Z8P(N)H-D12"),
1196 		},
1197 		.driver_data = &i801_mux_config_asus_z8_d12,
1198 	},
1199 	{
1200 		.matches = {
1201 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1202 			DMI_MATCH(DMI_BOARD_NAME, "Z8PG-D18"),
1203 		},
1204 		.driver_data = &i801_mux_config_asus_z8_d18,
1205 	},
1206 	{
1207 		.matches = {
1208 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1209 			DMI_MATCH(DMI_BOARD_NAME, "Z8PE-D18"),
1210 		},
1211 		.driver_data = &i801_mux_config_asus_z8_d18,
1212 	},
1213 	{
1214 		.matches = {
1215 			DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
1216 			DMI_MATCH(DMI_BOARD_NAME, "Z8PS-D12"),
1217 		},
1218 		.driver_data = &i801_mux_config_asus_z8_d12,
1219 	},
1220 	{ }
1221 };
1222 
1223 /* Setup multiplexing if needed */
1224 static int i801_add_mux(struct i801_priv *priv)
1225 {
1226 	struct device *dev = &priv->adapter.dev;
1227 	const struct i801_mux_config *mux_config;
1228 	struct i2c_mux_gpio_platform_data gpio_data;
1229 	int err;
1230 
1231 	if (!priv->mux_drvdata)
1232 		return 0;
1233 	mux_config = priv->mux_drvdata;
1234 
1235 	/* Prepare the platform data */
1236 	memset(&gpio_data, 0, sizeof(struct i2c_mux_gpio_platform_data));
1237 	gpio_data.parent = priv->adapter.nr;
1238 	gpio_data.values = mux_config->values;
1239 	gpio_data.n_values = mux_config->n_values;
1240 	gpio_data.classes = mux_config->classes;
1241 	gpio_data.gpio_chip = mux_config->gpio_chip;
1242 	gpio_data.gpios = mux_config->gpios;
1243 	gpio_data.n_gpios = mux_config->n_gpios;
1244 	gpio_data.idle = I2C_MUX_GPIO_NO_IDLE;
1245 
1246 	/* Register the mux device */
1247 	priv->mux_pdev = platform_device_register_data(dev, "i2c-mux-gpio",
1248 				PLATFORM_DEVID_AUTO, &gpio_data,
1249 				sizeof(struct i2c_mux_gpio_platform_data));
1250 	if (IS_ERR(priv->mux_pdev)) {
1251 		err = PTR_ERR(priv->mux_pdev);
1252 		priv->mux_pdev = NULL;
1253 		dev_err(dev, "Failed to register i2c-mux-gpio device\n");
1254 		return err;
1255 	}
1256 
1257 	return 0;
1258 }
1259 
1260 static void i801_del_mux(struct i801_priv *priv)
1261 {
1262 	if (priv->mux_pdev)
1263 		platform_device_unregister(priv->mux_pdev);
1264 }
1265 
1266 static unsigned int i801_get_adapter_class(struct i801_priv *priv)
1267 {
1268 	const struct dmi_system_id *id;
1269 	const struct i801_mux_config *mux_config;
1270 	unsigned int class = I2C_CLASS_HWMON | I2C_CLASS_SPD;
1271 	int i;
1272 
1273 	id = dmi_first_match(mux_dmi_table);
1274 	if (id) {
1275 		/* Remove branch classes from trunk */
1276 		mux_config = id->driver_data;
1277 		for (i = 0; i < mux_config->n_values; i++)
1278 			class &= ~mux_config->classes[i];
1279 
1280 		/* Remember for later */
1281 		priv->mux_drvdata = mux_config;
1282 	}
1283 
1284 	return class;
1285 }
1286 #else
1287 static inline int i801_add_mux(struct i801_priv *priv) { return 0; }
1288 static inline void i801_del_mux(struct i801_priv *priv) { }
1289 
1290 static inline unsigned int i801_get_adapter_class(struct i801_priv *priv)
1291 {
1292 	return I2C_CLASS_HWMON | I2C_CLASS_SPD;
1293 }
1294 #endif
1295 
1296 static const struct itco_wdt_platform_data tco_platform_data = {
1297 	.name = "Intel PCH",
1298 	.version = 4,
1299 };
1300 
1301 static DEFINE_SPINLOCK(p2sb_spinlock);
1302 
1303 static void i801_add_tco(struct i801_priv *priv)
1304 {
1305 	struct pci_dev *pci_dev = priv->pci_dev;
1306 	struct resource tco_res[3], *res;
1307 	struct platform_device *pdev;
1308 	unsigned int devfn;
1309 	u32 tco_base, tco_ctl;
1310 	u32 base_addr, ctrl_val;
1311 	u64 base64_addr;
1312 
1313 	if (!(priv->features & FEATURE_TCO))
1314 		return;
1315 
1316 	pci_read_config_dword(pci_dev, TCOBASE, &tco_base);
1317 	pci_read_config_dword(pci_dev, TCOCTL, &tco_ctl);
1318 	if (!(tco_ctl & TCOCTL_EN))
1319 		return;
1320 
1321 	memset(tco_res, 0, sizeof(tco_res));
1322 
1323 	res = &tco_res[ICH_RES_IO_TCO];
1324 	res->start = tco_base & ~1;
1325 	res->end = res->start + 32 - 1;
1326 	res->flags = IORESOURCE_IO;
1327 
1328 	/*
1329 	 * Power Management registers.
1330 	 */
1331 	devfn = PCI_DEVFN(PCI_SLOT(pci_dev->devfn), 2);
1332 	pci_bus_read_config_dword(pci_dev->bus, devfn, ACPIBASE, &base_addr);
1333 
1334 	res = &tco_res[ICH_RES_IO_SMI];
1335 	res->start = (base_addr & ~1) + ACPIBASE_SMI_OFF;
1336 	res->end = res->start + 3;
1337 	res->flags = IORESOURCE_IO;
1338 
1339 	/*
1340 	 * Enable the ACPI I/O space.
1341 	 */
1342 	pci_bus_read_config_dword(pci_dev->bus, devfn, ACPICTRL, &ctrl_val);
1343 	ctrl_val |= ACPICTRL_EN;
1344 	pci_bus_write_config_dword(pci_dev->bus, devfn, ACPICTRL, ctrl_val);
1345 
1346 	/*
1347 	 * We must access the NO_REBOOT bit over the Primary to Sideband
1348 	 * bridge (P2SB). The BIOS prevents the P2SB device from being
1349 	 * enumerated by the PCI subsystem, so we need to unhide/hide it
1350 	 * to lookup the P2SB BAR.
1351 	 */
1352 	spin_lock(&p2sb_spinlock);
1353 
1354 	devfn = PCI_DEVFN(PCI_SLOT(pci_dev->devfn), 1);
1355 
1356 	/* Unhide the P2SB device */
1357 	pci_bus_write_config_byte(pci_dev->bus, devfn, 0xe1, 0x0);
1358 
1359 	pci_bus_read_config_dword(pci_dev->bus, devfn, SBREG_BAR, &base_addr);
1360 	base64_addr = base_addr & 0xfffffff0;
1361 
1362 	pci_bus_read_config_dword(pci_dev->bus, devfn, SBREG_BAR + 0x4, &base_addr);
1363 	base64_addr |= (u64)base_addr << 32;
1364 
1365 	/* Hide the P2SB device */
1366 	pci_bus_write_config_byte(pci_dev->bus, devfn, 0xe1, 0x1);
1367 	spin_unlock(&p2sb_spinlock);
1368 
1369 	res = &tco_res[ICH_RES_MEM_OFF];
1370 	res->start = (resource_size_t)base64_addr + SBREG_SMBCTRL;
1371 	res->end = res->start + 3;
1372 	res->flags = IORESOURCE_MEM;
1373 
1374 	pdev = platform_device_register_resndata(&pci_dev->dev, "iTCO_wdt", -1,
1375 						 tco_res, 3, &tco_platform_data,
1376 						 sizeof(tco_platform_data));
1377 	if (IS_ERR(pdev)) {
1378 		dev_warn(&pci_dev->dev, "failed to create iTCO device\n");
1379 		return;
1380 	}
1381 
1382 	priv->tco_pdev = pdev;
1383 }
1384 
1385 #ifdef CONFIG_ACPI
1386 static acpi_status
1387 i801_acpi_io_handler(u32 function, acpi_physical_address address, u32 bits,
1388 		     u64 *value, void *handler_context, void *region_context)
1389 {
1390 	struct i801_priv *priv = handler_context;
1391 	struct pci_dev *pdev = priv->pci_dev;
1392 	acpi_status status;
1393 
1394 	/*
1395 	 * Once BIOS AML code touches the OpRegion we warn and inhibit any
1396 	 * further access from the driver itself. This device is now owned
1397 	 * by the system firmware.
1398 	 */
1399 	mutex_lock(&priv->acpi_lock);
1400 
1401 	if (!priv->acpi_reserved) {
1402 		priv->acpi_reserved = true;
1403 
1404 		dev_warn(&pdev->dev, "BIOS is accessing SMBus registers\n");
1405 		dev_warn(&pdev->dev, "Driver SMBus register access inhibited\n");
1406 
1407 		/*
1408 		 * BIOS is accessing the host controller so prevent it from
1409 		 * suspending automatically from now on.
1410 		 */
1411 		pm_runtime_get_sync(&pdev->dev);
1412 	}
1413 
1414 	if ((function & ACPI_IO_MASK) == ACPI_READ)
1415 		status = acpi_os_read_port(address, (u32 *)value, bits);
1416 	else
1417 		status = acpi_os_write_port(address, (u32)*value, bits);
1418 
1419 	mutex_unlock(&priv->acpi_lock);
1420 
1421 	return status;
1422 }
1423 
1424 static int i801_acpi_probe(struct i801_priv *priv)
1425 {
1426 	struct acpi_device *adev;
1427 	acpi_status status;
1428 
1429 	adev = ACPI_COMPANION(&priv->pci_dev->dev);
1430 	if (adev) {
1431 		status = acpi_install_address_space_handler(adev->handle,
1432 				ACPI_ADR_SPACE_SYSTEM_IO, i801_acpi_io_handler,
1433 				NULL, priv);
1434 		if (ACPI_SUCCESS(status))
1435 			return 0;
1436 	}
1437 
1438 	return acpi_check_resource_conflict(&priv->pci_dev->resource[SMBBAR]);
1439 }
1440 
1441 static void i801_acpi_remove(struct i801_priv *priv)
1442 {
1443 	struct acpi_device *adev;
1444 
1445 	adev = ACPI_COMPANION(&priv->pci_dev->dev);
1446 	if (!adev)
1447 		return;
1448 
1449 	acpi_remove_address_space_handler(adev->handle,
1450 		ACPI_ADR_SPACE_SYSTEM_IO, i801_acpi_io_handler);
1451 
1452 	mutex_lock(&priv->acpi_lock);
1453 	if (priv->acpi_reserved)
1454 		pm_runtime_put(&priv->pci_dev->dev);
1455 	mutex_unlock(&priv->acpi_lock);
1456 }
1457 #else
1458 static inline int i801_acpi_probe(struct i801_priv *priv) { return 0; }
1459 static inline void i801_acpi_remove(struct i801_priv *priv) { }
1460 #endif
1461 
1462 static int i801_probe(struct pci_dev *dev, const struct pci_device_id *id)
1463 {
1464 	unsigned char temp;
1465 	int err, i;
1466 	struct i801_priv *priv;
1467 
1468 	priv = devm_kzalloc(&dev->dev, sizeof(*priv), GFP_KERNEL);
1469 	if (!priv)
1470 		return -ENOMEM;
1471 
1472 	i2c_set_adapdata(&priv->adapter, priv);
1473 	priv->adapter.owner = THIS_MODULE;
1474 	priv->adapter.class = i801_get_adapter_class(priv);
1475 	priv->adapter.algo = &smbus_algorithm;
1476 	priv->adapter.dev.parent = &dev->dev;
1477 	ACPI_COMPANION_SET(&priv->adapter.dev, ACPI_COMPANION(&dev->dev));
1478 	priv->adapter.retries = 3;
1479 	mutex_init(&priv->acpi_lock);
1480 
1481 	priv->pci_dev = dev;
1482 	switch (dev->device) {
1483 	case PCI_DEVICE_ID_INTEL_SUNRISEPOINT_H_SMBUS:
1484 	case PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_SMBUS:
1485 	case PCI_DEVICE_ID_INTEL_LEWISBURG_SMBUS:
1486 	case PCI_DEVICE_ID_INTEL_LEWISBURG_SSKU_SMBUS:
1487 	case PCI_DEVICE_ID_INTEL_DNV_SMBUS:
1488 	case PCI_DEVICE_ID_INTEL_KABYLAKE_PCH_H_SMBUS:
1489 		priv->features |= FEATURE_I2C_BLOCK_READ;
1490 		priv->features |= FEATURE_IRQ;
1491 		priv->features |= FEATURE_SMBUS_PEC;
1492 		priv->features |= FEATURE_BLOCK_BUFFER;
1493 		/* If we have ACPI based watchdog use that instead */
1494 		if (!acpi_has_watchdog())
1495 			priv->features |= FEATURE_TCO;
1496 		priv->features |= FEATURE_HOST_NOTIFY;
1497 		break;
1498 
1499 	case PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF0:
1500 	case PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF1:
1501 	case PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF2:
1502 	case PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS0:
1503 	case PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS1:
1504 	case PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS2:
1505 		priv->features |= FEATURE_IDF;
1506 		/* fall through */
1507 	default:
1508 		priv->features |= FEATURE_I2C_BLOCK_READ;
1509 		priv->features |= FEATURE_IRQ;
1510 		/* fall through */
1511 	case PCI_DEVICE_ID_INTEL_82801DB_3:
1512 		priv->features |= FEATURE_SMBUS_PEC;
1513 		priv->features |= FEATURE_BLOCK_BUFFER;
1514 		/* fall through */
1515 	case PCI_DEVICE_ID_INTEL_82801CA_3:
1516 		priv->features |= FEATURE_HOST_NOTIFY;
1517 		/* fall through */
1518 	case PCI_DEVICE_ID_INTEL_82801BA_2:
1519 	case PCI_DEVICE_ID_INTEL_82801AB_3:
1520 	case PCI_DEVICE_ID_INTEL_82801AA_3:
1521 		break;
1522 	}
1523 
1524 	/* Disable features on user request */
1525 	for (i = 0; i < ARRAY_SIZE(i801_feature_names); i++) {
1526 		if (priv->features & disable_features & (1 << i))
1527 			dev_notice(&dev->dev, "%s disabled by user\n",
1528 				   i801_feature_names[i]);
1529 	}
1530 	priv->features &= ~disable_features;
1531 
1532 	err = pcim_enable_device(dev);
1533 	if (err) {
1534 		dev_err(&dev->dev, "Failed to enable SMBus PCI device (%d)\n",
1535 			err);
1536 		return err;
1537 	}
1538 	pcim_pin_device(dev);
1539 
1540 	/* Determine the address of the SMBus area */
1541 	priv->smba = pci_resource_start(dev, SMBBAR);
1542 	if (!priv->smba) {
1543 		dev_err(&dev->dev,
1544 			"SMBus base address uninitialized, upgrade BIOS\n");
1545 		return -ENODEV;
1546 	}
1547 
1548 	if (i801_acpi_probe(priv))
1549 		return -ENODEV;
1550 
1551 	err = pcim_iomap_regions(dev, 1 << SMBBAR,
1552 				 dev_driver_string(&dev->dev));
1553 	if (err) {
1554 		dev_err(&dev->dev,
1555 			"Failed to request SMBus region 0x%lx-0x%Lx\n",
1556 			priv->smba,
1557 			(unsigned long long)pci_resource_end(dev, SMBBAR));
1558 		i801_acpi_remove(priv);
1559 		return err;
1560 	}
1561 
1562 	pci_read_config_byte(priv->pci_dev, SMBHSTCFG, &temp);
1563 	priv->original_hstcfg = temp;
1564 	temp &= ~SMBHSTCFG_I2C_EN;	/* SMBus timing */
1565 	if (!(temp & SMBHSTCFG_HST_EN)) {
1566 		dev_info(&dev->dev, "Enabling SMBus device\n");
1567 		temp |= SMBHSTCFG_HST_EN;
1568 	}
1569 	pci_write_config_byte(priv->pci_dev, SMBHSTCFG, temp);
1570 
1571 	if (temp & SMBHSTCFG_SMB_SMI_EN) {
1572 		dev_dbg(&dev->dev, "SMBus using interrupt SMI#\n");
1573 		/* Disable SMBus interrupt feature if SMBus using SMI# */
1574 		priv->features &= ~FEATURE_IRQ;
1575 	}
1576 
1577 	/* Clear special mode bits */
1578 	if (priv->features & (FEATURE_SMBUS_PEC | FEATURE_BLOCK_BUFFER))
1579 		outb_p(inb_p(SMBAUXCTL(priv)) &
1580 		       ~(SMBAUXCTL_CRC | SMBAUXCTL_E32B), SMBAUXCTL(priv));
1581 
1582 	/* Default timeout in interrupt mode: 200 ms */
1583 	priv->adapter.timeout = HZ / 5;
1584 
1585 	if (priv->features & FEATURE_IRQ) {
1586 		u16 pcictl, pcists;
1587 
1588 		/* Complain if an interrupt is already pending */
1589 		pci_read_config_word(priv->pci_dev, SMBPCISTS, &pcists);
1590 		if (pcists & SMBPCISTS_INTS)
1591 			dev_warn(&dev->dev, "An interrupt is pending!\n");
1592 
1593 		/* Check if interrupts have been disabled */
1594 		pci_read_config_word(priv->pci_dev, SMBPCICTL, &pcictl);
1595 		if (pcictl & SMBPCICTL_INTDIS) {
1596 			dev_info(&dev->dev, "Interrupts are disabled\n");
1597 			priv->features &= ~FEATURE_IRQ;
1598 		}
1599 	}
1600 
1601 	if (priv->features & FEATURE_IRQ) {
1602 		init_waitqueue_head(&priv->waitq);
1603 
1604 		err = devm_request_irq(&dev->dev, dev->irq, i801_isr,
1605 				       IRQF_SHARED,
1606 				       dev_driver_string(&dev->dev), priv);
1607 		if (err) {
1608 			dev_err(&dev->dev, "Failed to allocate irq %d: %d\n",
1609 				dev->irq, err);
1610 			priv->features &= ~FEATURE_IRQ;
1611 		}
1612 	}
1613 	dev_info(&dev->dev, "SMBus using %s\n",
1614 		 priv->features & FEATURE_IRQ ? "PCI interrupt" : "polling");
1615 
1616 	i801_add_tco(priv);
1617 
1618 	snprintf(priv->adapter.name, sizeof(priv->adapter.name),
1619 		"SMBus I801 adapter at %04lx", priv->smba);
1620 	err = i2c_add_adapter(&priv->adapter);
1621 	if (err) {
1622 		i801_acpi_remove(priv);
1623 		return err;
1624 	}
1625 
1626 	/*
1627 	 * Enable Host Notify for chips that supports it.
1628 	 * It is done after i2c_add_adapter() so that we are sure the work queue
1629 	 * is not used if i2c_add_adapter() fails.
1630 	 */
1631 	err = i801_enable_host_notify(&priv->adapter);
1632 	if (err && err != -ENOTSUPP)
1633 		dev_warn(&dev->dev, "Unable to enable SMBus Host Notify\n");
1634 
1635 	i801_probe_optional_slaves(priv);
1636 	/* We ignore errors - multiplexing is optional */
1637 	i801_add_mux(priv);
1638 
1639 	pci_set_drvdata(dev, priv);
1640 
1641 	pm_runtime_set_autosuspend_delay(&dev->dev, 1000);
1642 	pm_runtime_use_autosuspend(&dev->dev);
1643 	pm_runtime_put_autosuspend(&dev->dev);
1644 	pm_runtime_allow(&dev->dev);
1645 
1646 	return 0;
1647 }
1648 
1649 static void i801_remove(struct pci_dev *dev)
1650 {
1651 	struct i801_priv *priv = pci_get_drvdata(dev);
1652 
1653 	pm_runtime_forbid(&dev->dev);
1654 	pm_runtime_get_noresume(&dev->dev);
1655 
1656 	i801_del_mux(priv);
1657 	i2c_del_adapter(&priv->adapter);
1658 	i801_acpi_remove(priv);
1659 	pci_write_config_byte(dev, SMBHSTCFG, priv->original_hstcfg);
1660 
1661 	platform_device_unregister(priv->tco_pdev);
1662 
1663 	/*
1664 	 * do not call pci_disable_device(dev) since it can cause hard hangs on
1665 	 * some systems during power-off (eg. Fujitsu-Siemens Lifebook E8010)
1666 	 */
1667 }
1668 
1669 #ifdef CONFIG_PM
1670 static int i801_suspend(struct device *dev)
1671 {
1672 	struct pci_dev *pci_dev = to_pci_dev(dev);
1673 	struct i801_priv *priv = pci_get_drvdata(pci_dev);
1674 
1675 	pci_write_config_byte(pci_dev, SMBHSTCFG, priv->original_hstcfg);
1676 	return 0;
1677 }
1678 
1679 static int i801_resume(struct device *dev)
1680 {
1681 	struct pci_dev *pci_dev = to_pci_dev(dev);
1682 	struct i801_priv *priv = pci_get_drvdata(pci_dev);
1683 	int err;
1684 
1685 	err = i801_enable_host_notify(&priv->adapter);
1686 	if (err && err != -ENOTSUPP)
1687 		dev_warn(dev, "Unable to enable SMBus Host Notify\n");
1688 
1689 	return 0;
1690 }
1691 #endif
1692 
1693 static UNIVERSAL_DEV_PM_OPS(i801_pm_ops, i801_suspend,
1694 			    i801_resume, NULL);
1695 
1696 static struct pci_driver i801_driver = {
1697 	.name		= "i801_smbus",
1698 	.id_table	= i801_ids,
1699 	.probe		= i801_probe,
1700 	.remove		= i801_remove,
1701 	.driver		= {
1702 		.pm	= &i801_pm_ops,
1703 	},
1704 };
1705 
1706 static int __init i2c_i801_init(void)
1707 {
1708 	if (dmi_name_in_vendors("FUJITSU"))
1709 		input_apanel_init();
1710 	return pci_register_driver(&i801_driver);
1711 }
1712 
1713 static void __exit i2c_i801_exit(void)
1714 {
1715 	pci_unregister_driver(&i801_driver);
1716 }
1717 
1718 MODULE_AUTHOR("Mark D. Studebaker <mdsxyz123@yahoo.com>, Jean Delvare <jdelvare@suse.de>");
1719 MODULE_DESCRIPTION("I801 SMBus driver");
1720 MODULE_LICENSE("GPL");
1721 
1722 module_init(i2c_i801_init);
1723 module_exit(i2c_i801_exit);
1724