68cec6128ac04f388bc36f3f7fa93ce6c066e575
[cascardo/linux.git] / drivers / i2c / busses / i2c-i801.c
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  *
68  * Features supported by this driver:
69  * Software PEC                         no
70  * Hardware PEC                         yes
71  * Block buffer                         yes
72  * Block process call transaction       no
73  * I2C block read transaction           yes (doesn't use the block buffer)
74  * Slave mode                           no
75  * SMBus Host Notify                    yes
76  * Interrupt processing                 yes
77  *
78  * See the file Documentation/i2c/busses/i2c-i801 for details.
79  */
80
81 #include <linux/interrupt.h>
82 #include <linux/module.h>
83 #include <linux/pci.h>
84 #include <linux/kernel.h>
85 #include <linux/stddef.h>
86 #include <linux/delay.h>
87 #include <linux/ioport.h>
88 #include <linux/init.h>
89 #include <linux/i2c.h>
90 #include <linux/i2c-smbus.h>
91 #include <linux/acpi.h>
92 #include <linux/io.h>
93 #include <linux/dmi.h>
94 #include <linux/slab.h>
95 #include <linux/wait.h>
96 #include <linux/err.h>
97 #include <linux/platform_device.h>
98 #include <linux/platform_data/itco_wdt.h>
99 #include <linux/pm_runtime.h>
100
101 #if (defined CONFIG_I2C_MUX_GPIO || defined CONFIG_I2C_MUX_GPIO_MODULE) && \
102                 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
231 struct i801_mux_config {
232         char *gpio_chip;
233         unsigned values[3];
234         int n_values;
235         unsigned classes[3];
236         unsigned gpios[2];              /* Relative to gpio_chip->base */
237         int n_gpios;
238 };
239
240 struct i801_priv {
241         struct i2c_adapter adapter;
242         unsigned long smba;
243         unsigned char original_hstcfg;
244         struct pci_dev *pci_dev;
245         unsigned int features;
246
247         /* isr processing */
248         wait_queue_head_t waitq;
249         u8 status;
250
251         /* Command state used by isr for byte-by-byte block transactions */
252         u8 cmd;
253         bool is_read;
254         int count;
255         int len;
256         u8 *data;
257
258 #if (defined CONFIG_I2C_MUX_GPIO || defined CONFIG_I2C_MUX_GPIO_MODULE) && \
259                 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         { 0, }
1012 };
1013
1014 MODULE_DEVICE_TABLE(pci, i801_ids);
1015
1016 #if defined CONFIG_X86 && defined CONFIG_DMI
1017 static unsigned char apanel_addr;
1018
1019 /* Scan the system ROM for the signature "FJKEYINF" */
1020 static __init const void __iomem *bios_signature(const void __iomem *bios)
1021 {
1022         ssize_t offset;
1023         const unsigned char signature[] = "FJKEYINF";
1024
1025         for (offset = 0; offset < 0x10000; offset += 0x10) {
1026                 if (check_signature(bios + offset, signature,
1027                                     sizeof(signature)-1))
1028                         return bios + offset;
1029         }
1030         return NULL;
1031 }
1032
1033 static void __init input_apanel_init(void)
1034 {
1035         void __iomem *bios;
1036         const void __iomem *p;
1037
1038         bios = ioremap(0xF0000, 0x10000); /* Can't fail */
1039         p = bios_signature(bios);
1040         if (p) {
1041                 /* just use the first address */
1042                 apanel_addr = readb(p + 8 + 3) >> 1;
1043         }
1044         iounmap(bios);
1045 }
1046
1047 struct dmi_onboard_device_info {
1048         const char *name;
1049         u8 type;
1050         unsigned short i2c_addr;
1051         const char *i2c_type;
1052 };
1053
1054 static const struct dmi_onboard_device_info dmi_devices[] = {
1055         { "Syleus", DMI_DEV_TYPE_OTHER, 0x73, "fscsyl" },
1056         { "Hermes", DMI_DEV_TYPE_OTHER, 0x73, "fscher" },
1057         { "Hades",  DMI_DEV_TYPE_OTHER, 0x73, "fschds" },
1058 };
1059
1060 static void dmi_check_onboard_device(u8 type, const char *name,
1061                                      struct i2c_adapter *adap)
1062 {
1063         int i;
1064         struct i2c_board_info info;
1065
1066         for (i = 0; i < ARRAY_SIZE(dmi_devices); i++) {
1067                 /* & ~0x80, ignore enabled/disabled bit */
1068                 if ((type & ~0x80) != dmi_devices[i].type)
1069                         continue;
1070                 if (strcasecmp(name, dmi_devices[i].name))
1071                         continue;
1072
1073                 memset(&info, 0, sizeof(struct i2c_board_info));
1074                 info.addr = dmi_devices[i].i2c_addr;
1075                 strlcpy(info.type, dmi_devices[i].i2c_type, I2C_NAME_SIZE);
1076                 i2c_new_device(adap, &info);
1077                 break;
1078         }
1079 }
1080
1081 /* We use our own function to check for onboard devices instead of
1082    dmi_find_device() as some buggy BIOS's have the devices we are interested
1083    in marked as disabled */
1084 static void dmi_check_onboard_devices(const struct dmi_header *dm, void *adap)
1085 {
1086         int i, count;
1087
1088         if (dm->type != 10)
1089                 return;
1090
1091         count = (dm->length - sizeof(struct dmi_header)) / 2;
1092         for (i = 0; i < count; i++) {
1093                 const u8 *d = (char *)(dm + 1) + (i * 2);
1094                 const char *name = ((char *) dm) + dm->length;
1095                 u8 type = d[0];
1096                 u8 s = d[1];
1097
1098                 if (!s)
1099                         continue;
1100                 s--;
1101                 while (s > 0 && name[0]) {
1102                         name += strlen(name) + 1;
1103                         s--;
1104                 }
1105                 if (name[0] == 0) /* Bogus string reference */
1106                         continue;
1107
1108                 dmi_check_onboard_device(type, name, adap);
1109         }
1110 }
1111
1112 /* Register optional slaves */
1113 static void i801_probe_optional_slaves(struct i801_priv *priv)
1114 {
1115         /* Only register slaves on main SMBus channel */
1116         if (priv->features & FEATURE_IDF)
1117                 return;
1118
1119         if (apanel_addr) {
1120                 struct i2c_board_info info;
1121
1122                 memset(&info, 0, sizeof(struct i2c_board_info));
1123                 info.addr = apanel_addr;
1124                 strlcpy(info.type, "fujitsu_apanel", I2C_NAME_SIZE);
1125                 i2c_new_device(&priv->adapter, &info);
1126         }
1127
1128         if (dmi_name_in_vendors("FUJITSU"))
1129                 dmi_walk(dmi_check_onboard_devices, &priv->adapter);
1130 }
1131 #else
1132 static void __init input_apanel_init(void) {}
1133 static void i801_probe_optional_slaves(struct i801_priv *priv) {}
1134 #endif  /* CONFIG_X86 && CONFIG_DMI */
1135
1136 #if (defined CONFIG_I2C_MUX_GPIO || defined CONFIG_I2C_MUX_GPIO_MODULE) && \
1137                 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                 priv->features |= FEATURE_I2C_BLOCK_READ;
1489                 priv->features |= FEATURE_IRQ;
1490                 priv->features |= FEATURE_SMBUS_PEC;
1491                 priv->features |= FEATURE_BLOCK_BUFFER;
1492                 priv->features |= FEATURE_TCO;
1493                 priv->features |= FEATURE_HOST_NOTIFY;
1494                 break;
1495
1496         case PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF0:
1497         case PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF1:
1498         case PCI_DEVICE_ID_INTEL_PATSBURG_SMBUS_IDF2:
1499         case PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS0:
1500         case PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS1:
1501         case PCI_DEVICE_ID_INTEL_WELLSBURG_SMBUS_MS2:
1502                 priv->features |= FEATURE_IDF;
1503                 /* fall through */
1504         default:
1505                 priv->features |= FEATURE_I2C_BLOCK_READ;
1506                 priv->features |= FEATURE_IRQ;
1507                 /* fall through */
1508         case PCI_DEVICE_ID_INTEL_82801DB_3:
1509                 priv->features |= FEATURE_SMBUS_PEC;
1510                 priv->features |= FEATURE_BLOCK_BUFFER;
1511                 /* fall through */
1512         case PCI_DEVICE_ID_INTEL_82801CA_3:
1513                 priv->features |= FEATURE_HOST_NOTIFY;
1514                 /* fall through */
1515         case PCI_DEVICE_ID_INTEL_82801BA_2:
1516         case PCI_DEVICE_ID_INTEL_82801AB_3:
1517         case PCI_DEVICE_ID_INTEL_82801AA_3:
1518                 break;
1519         }
1520
1521         /* Disable features on user request */
1522         for (i = 0; i < ARRAY_SIZE(i801_feature_names); i++) {
1523                 if (priv->features & disable_features & (1 << i))
1524                         dev_notice(&dev->dev, "%s disabled by user\n",
1525                                    i801_feature_names[i]);
1526         }
1527         priv->features &= ~disable_features;
1528
1529         err = pcim_enable_device(dev);
1530         if (err) {
1531                 dev_err(&dev->dev, "Failed to enable SMBus PCI device (%d)\n",
1532                         err);
1533                 return err;
1534         }
1535         pcim_pin_device(dev);
1536
1537         /* Determine the address of the SMBus area */
1538         priv->smba = pci_resource_start(dev, SMBBAR);
1539         if (!priv->smba) {
1540                 dev_err(&dev->dev,
1541                         "SMBus base address uninitialized, upgrade BIOS\n");
1542                 return -ENODEV;
1543         }
1544
1545         if (i801_acpi_probe(priv))
1546                 return -ENODEV;
1547
1548         err = pcim_iomap_regions(dev, 1 << SMBBAR,
1549                                  dev_driver_string(&dev->dev));
1550         if (err) {
1551                 dev_err(&dev->dev,
1552                         "Failed to request SMBus region 0x%lx-0x%Lx\n",
1553                         priv->smba,
1554                         (unsigned long long)pci_resource_end(dev, SMBBAR));
1555                 i801_acpi_remove(priv);
1556                 return err;
1557         }
1558
1559         pci_read_config_byte(priv->pci_dev, SMBHSTCFG, &temp);
1560         priv->original_hstcfg = temp;
1561         temp &= ~SMBHSTCFG_I2C_EN;      /* SMBus timing */
1562         if (!(temp & SMBHSTCFG_HST_EN)) {
1563                 dev_info(&dev->dev, "Enabling SMBus device\n");
1564                 temp |= SMBHSTCFG_HST_EN;
1565         }
1566         pci_write_config_byte(priv->pci_dev, SMBHSTCFG, temp);
1567
1568         if (temp & SMBHSTCFG_SMB_SMI_EN) {
1569                 dev_dbg(&dev->dev, "SMBus using interrupt SMI#\n");
1570                 /* Disable SMBus interrupt feature if SMBus using SMI# */
1571                 priv->features &= ~FEATURE_IRQ;
1572         }
1573
1574         /* Clear special mode bits */
1575         if (priv->features & (FEATURE_SMBUS_PEC | FEATURE_BLOCK_BUFFER))
1576                 outb_p(inb_p(SMBAUXCTL(priv)) &
1577                        ~(SMBAUXCTL_CRC | SMBAUXCTL_E32B), SMBAUXCTL(priv));
1578
1579         /* Default timeout in interrupt mode: 200 ms */
1580         priv->adapter.timeout = HZ / 5;
1581
1582         if (priv->features & FEATURE_IRQ) {
1583                 u16 pcictl, pcists;
1584
1585                 /* Complain if an interrupt is already pending */
1586                 pci_read_config_word(priv->pci_dev, SMBPCISTS, &pcists);
1587                 if (pcists & SMBPCISTS_INTS)
1588                         dev_warn(&dev->dev, "An interrupt is pending!\n");
1589
1590                 /* Check if interrupts have been disabled */
1591                 pci_read_config_word(priv->pci_dev, SMBPCICTL, &pcictl);
1592                 if (pcictl & SMBPCICTL_INTDIS) {
1593                         dev_info(&dev->dev, "Interrupts are disabled\n");
1594                         priv->features &= ~FEATURE_IRQ;
1595                 }
1596         }
1597
1598         if (priv->features & FEATURE_IRQ) {
1599                 init_waitqueue_head(&priv->waitq);
1600
1601                 err = devm_request_irq(&dev->dev, dev->irq, i801_isr,
1602                                        IRQF_SHARED,
1603                                        dev_driver_string(&dev->dev), priv);
1604                 if (err) {
1605                         dev_err(&dev->dev, "Failed to allocate irq %d: %d\n",
1606                                 dev->irq, err);
1607                         priv->features &= ~FEATURE_IRQ;
1608                 }
1609         }
1610         dev_info(&dev->dev, "SMBus using %s\n",
1611                  priv->features & FEATURE_IRQ ? "PCI interrupt" : "polling");
1612
1613         i801_add_tco(priv);
1614
1615         snprintf(priv->adapter.name, sizeof(priv->adapter.name),
1616                 "SMBus I801 adapter at %04lx", priv->smba);
1617         err = i2c_add_adapter(&priv->adapter);
1618         if (err) {
1619                 dev_err(&dev->dev, "Failed to add SMBus adapter\n");
1620                 i801_acpi_remove(priv);
1621                 return err;
1622         }
1623
1624         /*
1625          * Enable Host Notify for chips that supports it.
1626          * It is done after i2c_add_adapter() so that we are sure the work queue
1627          * is not used if i2c_add_adapter() fails.
1628          */
1629         err = i801_enable_host_notify(&priv->adapter);
1630         if (err && err != -ENOTSUPP)
1631                 dev_warn(&dev->dev, "Unable to enable SMBus Host Notify\n");
1632
1633         i801_probe_optional_slaves(priv);
1634         /* We ignore errors - multiplexing is optional */
1635         i801_add_mux(priv);
1636
1637         pci_set_drvdata(dev, priv);
1638
1639         pm_runtime_set_autosuspend_delay(&dev->dev, 1000);
1640         pm_runtime_use_autosuspend(&dev->dev);
1641         pm_runtime_put_autosuspend(&dev->dev);
1642         pm_runtime_allow(&dev->dev);
1643
1644         return 0;
1645 }
1646
1647 static void i801_remove(struct pci_dev *dev)
1648 {
1649         struct i801_priv *priv = pci_get_drvdata(dev);
1650
1651         pm_runtime_forbid(&dev->dev);
1652         pm_runtime_get_noresume(&dev->dev);
1653
1654         i801_del_mux(priv);
1655         i2c_del_adapter(&priv->adapter);
1656         i801_acpi_remove(priv);
1657         pci_write_config_byte(dev, SMBHSTCFG, priv->original_hstcfg);
1658
1659         platform_device_unregister(priv->tco_pdev);
1660
1661         /*
1662          * do not call pci_disable_device(dev) since it can cause hard hangs on
1663          * some systems during power-off (eg. Fujitsu-Siemens Lifebook E8010)
1664          */
1665 }
1666
1667 #ifdef CONFIG_PM
1668 static int i801_suspend(struct device *dev)
1669 {
1670         struct pci_dev *pci_dev = to_pci_dev(dev);
1671         struct i801_priv *priv = pci_get_drvdata(pci_dev);
1672
1673         pci_write_config_byte(pci_dev, SMBHSTCFG, priv->original_hstcfg);
1674         return 0;
1675 }
1676
1677 static int i801_resume(struct device *dev)
1678 {
1679         struct pci_dev *pci_dev = to_pci_dev(dev);
1680         struct i801_priv *priv = pci_get_drvdata(pci_dev);
1681         int err;
1682
1683         err = i801_enable_host_notify(&priv->adapter);
1684         if (err && err != -ENOTSUPP)
1685                 dev_warn(dev, "Unable to enable SMBus Host Notify\n");
1686
1687         return 0;
1688 }
1689 #endif
1690
1691 static UNIVERSAL_DEV_PM_OPS(i801_pm_ops, i801_suspend,
1692                             i801_resume, NULL);
1693
1694 static struct pci_driver i801_driver = {
1695         .name           = "i801_smbus",
1696         .id_table       = i801_ids,
1697         .probe          = i801_probe,
1698         .remove         = i801_remove,
1699         .driver         = {
1700                 .pm     = &i801_pm_ops,
1701         },
1702 };
1703
1704 static int __init i2c_i801_init(void)
1705 {
1706         if (dmi_name_in_vendors("FUJITSU"))
1707                 input_apanel_init();
1708         return pci_register_driver(&i801_driver);
1709 }
1710
1711 static void __exit i2c_i801_exit(void)
1712 {
1713         pci_unregister_driver(&i801_driver);
1714 }
1715
1716 MODULE_AUTHOR("Mark D. Studebaker <mdsxyz123@yahoo.com>, Jean Delvare <jdelvare@suse.de>");
1717 MODULE_DESCRIPTION("I801 SMBus driver");
1718 MODULE_LICENSE("GPL");
1719
1720 module_init(i2c_i801_init);
1721 module_exit(i2c_i801_exit);