blob: da466563fb19f62845f8c487ebdcaf267da07bfd [file] [log] [blame]
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001/* Copyright (c) 2010-2011, Code Aurora Forum. All rights reserved.
2 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 */
12
13#include <linux/interrupt.h>
14#include <linux/i2c.h>
15#include <linux/slab.h>
16#include <linux/ratelimit.h>
17#include <linux/mfd/core.h>
18#include <linux/mfd/pmic8901.h>
19#include <linux/platform_device.h>
20#include <linux/debugfs.h>
21
22/* PMIC8901 Revision */
23#define SSBI_REG_REV 0x002 /* PMIC4 revision */
24
25/* PMIC8901 IRQ */
26#define SSBI_REG_ADDR_IRQ_BASE 0xD5
27
28#define SSBI_REG_ADDR_IRQ_ROOT (SSBI_REG_ADDR_IRQ_BASE + 0)
29#define SSBI_REG_ADDR_IRQ_M_STATUS1 (SSBI_REG_ADDR_IRQ_BASE + 1)
30#define SSBI_REG_ADDR_IRQ_M_STATUS2 (SSBI_REG_ADDR_IRQ_BASE + 2)
31#define SSBI_REG_ADDR_IRQ_M_STATUS3 (SSBI_REG_ADDR_IRQ_BASE + 3)
32#define SSBI_REG_ADDR_IRQ_M_STATUS4 (SSBI_REG_ADDR_IRQ_BASE + 4)
33#define SSBI_REG_ADDR_IRQ_BLK_SEL (SSBI_REG_ADDR_IRQ_BASE + 5)
34#define SSBI_REG_ADDR_IRQ_IT_STATUS (SSBI_REG_ADDR_IRQ_BASE + 6)
35#define SSBI_REG_ADDR_IRQ_CONFIG (SSBI_REG_ADDR_IRQ_BASE + 7)
36#define SSBI_REG_ADDR_IRQ_RT_STATUS (SSBI_REG_ADDR_IRQ_BASE + 8)
37
38#define PM8901_IRQF_LVL_SEL 0x01 /* level select */
39#define PM8901_IRQF_MASK_FE 0x02 /* mask falling edge */
40#define PM8901_IRQF_MASK_RE 0x04 /* mask rising edge */
41#define PM8901_IRQF_CLR 0x08 /* clear interrupt */
42#define PM8901_IRQF_BITS_MASK 0x70
43#define PM8901_IRQF_BITS_SHIFT 4
44#define PM8901_IRQF_WRITE 0x80
45
46#define PM8901_IRQF_MASK_ALL (PM8901_IRQF_MASK_FE | \
47 PM8901_IRQF_MASK_RE)
48#define PM8901_IRQF_W_C_M (PM8901_IRQF_WRITE | \
49 PM8901_IRQF_CLR | \
50 PM8901_IRQF_MASK_ALL)
51
52#define MAX_PM_IRQ 72
53#define MAX_PM_BLOCKS (MAX_PM_IRQ / 8 + 1)
54#define MAX_PM_MASTERS (MAX_PM_BLOCKS / 8 + 1)
55
56#define MPP_IRQ_BLOCK 1
57
58/* FTS regulator PMR registers */
59#define SSBI_REG_ADDR_S1_PMR (0xA7)
60#define SSBI_REG_ADDR_S2_PMR (0xA8)
61#define SSBI_REG_ADDR_S3_PMR (0xA9)
62#define SSBI_REG_ADDR_S4_PMR (0xAA)
63
64#define REGULATOR_PMR_STATE_MASK 0x60
65#define REGULATOR_PMR_STATE_OFF 0x20
66
67struct pm8901_chip {
68 struct pm8901_platform_data pdata;
69
70 struct i2c_client *dev;
71
72 u8 irqs_allowed[MAX_PM_BLOCKS];
73 u8 blocks_allowed[MAX_PM_MASTERS];
74 u8 masters_allowed;
75 int pm_max_irq;
76 int pm_max_blocks;
77 int pm_max_masters;
78
79 u8 config[MAX_PM_IRQ];
80 u8 wake_enable[MAX_PM_IRQ];
81 u16 count_wakeable;
82
83 u8 revision;
84
85 spinlock_t pm_lock;
86};
87
88#if defined(CONFIG_DEBUG_FS)
89struct pm8901_dbg_device {
90 struct mutex dbg_mutex;
91 struct pm8901_chip *pm_chip;
92 struct dentry *dent;
93 int addr;
94};
95
96static struct pm8901_dbg_device *pmic_dbg_device;
97#endif
98
99static struct pm8901_chip *pmic_chip;
100
101/* Helper Functions */
102DEFINE_RATELIMIT_STATE(pm8901_msg_ratelimit, 60 * HZ, 10);
103
104static inline int pm8901_can_print(void)
105{
106 return __ratelimit(&pm8901_msg_ratelimit);
107}
108
109static inline int
110ssbi_write(struct i2c_client *client, u16 addr, const u8 *buf, size_t len)
111{
112 int rc;
113 struct i2c_msg msg = {
114 .addr = addr,
115 .flags = 0x0,
116 .buf = (u8 *)buf,
117 .len = len,
118 };
119
120 rc = i2c_transfer(client->adapter, &msg, 1);
121 return (rc == 1) ? 0 : rc;
122}
123
124static inline int
125ssbi_read(struct i2c_client *client, u16 addr, u8 *buf, size_t len)
126{
127 int rc;
128 struct i2c_msg msg = {
129 .addr = addr,
130 .flags = I2C_M_RD,
131 .buf = buf,
132 .len = len,
133 };
134
135 rc = i2c_transfer(client->adapter, &msg, 1);
136 return (rc == 1) ? 0 : rc;
137}
138
139/* External APIs */
140int pm8901_rev(struct pm8901_chip *chip)
141{
142 if (chip == NULL) {
143 if (pmic_chip != NULL)
144 return pmic_chip->revision;
145 else
146 return -EINVAL;
147 }
148
149 return chip->revision;
150}
151EXPORT_SYMBOL(pm8901_rev);
152
153int pm8901_read(struct pm8901_chip *chip, u16 addr, u8 *values,
154 unsigned int len)
155{
156 if (chip == NULL)
157 return -EINVAL;
158
159 return ssbi_read(chip->dev, addr, values, len);
160}
161EXPORT_SYMBOL(pm8901_read);
162
163int pm8901_write(struct pm8901_chip *chip, u16 addr, u8 *values,
164 unsigned int len)
165{
166 if (chip == NULL)
167 return -EINVAL;
168
169 return ssbi_write(chip->dev, addr, values, len);
170}
171EXPORT_SYMBOL(pm8901_write);
172
173int pm8901_irq_get_rt_status(struct pm8901_chip *chip, int irq)
174{
175 int rc;
176 u8 block, bits, bit;
177 unsigned long irqsave;
178
179 if (chip == NULL || irq < chip->pdata.irq_base ||
180 irq >= chip->pdata.irq_base + MAX_PM_IRQ)
181 return -EINVAL;
182
183 irq -= chip->pdata.irq_base;
184
185 block = irq / 8;
186 bit = irq % 8;
187
188 spin_lock_irqsave(&chip->pm_lock, irqsave);
189
190 rc = ssbi_write(chip->dev, SSBI_REG_ADDR_IRQ_BLK_SEL, &block, 1);
191 if (rc) {
192 pr_err("%s: FAIL ssbi_write(): rc=%d (Select Block)\n",
193 __func__, rc);
194 goto bail_out;
195 }
196
197 rc = ssbi_read(chip->dev, SSBI_REG_ADDR_IRQ_RT_STATUS, &bits, 1);
198 if (rc) {
199 pr_err("%s: FAIL ssbi_read(): rc=%d (Read RT Status)\n",
200 __func__, rc);
201 goto bail_out;
202 }
203
204 rc = (bits & (1 << bit)) ? 1 : 0;
205
206bail_out:
207 spin_unlock_irqrestore(&chip->pm_lock, irqsave);
208
209 return rc;
210}
211EXPORT_SYMBOL(pm8901_irq_get_rt_status);
212
213int pm8901_reset_pwr_off(int reset)
214{
215 int rc = 0, i;
216 u8 pmr;
217 u8 pmr_addr[4] = {
218 SSBI_REG_ADDR_S2_PMR,
219 SSBI_REG_ADDR_S3_PMR,
220 SSBI_REG_ADDR_S4_PMR,
221 SSBI_REG_ADDR_S1_PMR,
222 };
223
224 if (pmic_chip == NULL)
225 return -ENODEV;
226
227 /* Turn off regulators S1, S2, S3, S4 when shutting down. */
228 if (!reset) {
229 for (i = 0; i < 4; i++) {
230 rc = ssbi_read(pmic_chip->dev, pmr_addr[i], &pmr, 1);
231 if (rc) {
232 pr_err("%s: FAIL ssbi_read(0x%x): rc=%d\n",
233 __func__, pmr_addr[i], rc);
234 goto get_out;
235 }
236
237 pmr &= ~REGULATOR_PMR_STATE_MASK;
238 pmr |= REGULATOR_PMR_STATE_OFF;
239
240 rc = ssbi_write(pmic_chip->dev, pmr_addr[i], &pmr, 1);
241 if (rc) {
242 pr_err("%s: FAIL ssbi_write(0x%x)=0x%x: rc=%d"
243 "\n", __func__, pmr_addr[i], pmr, rc);
244 goto get_out;
245 }
246 }
247 }
248
249get_out:
250 return rc;
251}
252EXPORT_SYMBOL(pm8901_reset_pwr_off);
253
254/* Internal functions */
255static inline int
256pm8901_config_irq(struct pm8901_chip *chip, u8 *bp, u8 *cp)
257{
258 int rc;
259
260 rc = ssbi_write(chip->dev, SSBI_REG_ADDR_IRQ_BLK_SEL, bp, 1);
261 if (rc) {
262 pr_err("%s: ssbi_write: rc=%d (Select block)\n",
263 __func__, rc);
264 goto bail_out;
265 }
266
267 rc = ssbi_write(chip->dev, SSBI_REG_ADDR_IRQ_CONFIG, cp, 1);
268 if (rc)
269 pr_err("%s: ssbi_write: rc=%d (Configure IRQ)\n",
270 __func__, rc);
271
272bail_out:
273 return rc;
274}
275
276static void pm8901_irq_mask(struct irq_data *d)
277{
278 int master, irq_bit;
279 struct pm8901_chip *chip = irq_data_get_irq_handler_data(d);
280 u8 block, config;
281 unsigned int irq = d->irq;
282
283 irq -= chip->pdata.irq_base;
284 block = irq / 8;
285 master = block / 8;
286 irq_bit = irq % 8;
287
288 chip->irqs_allowed[block] &= ~(1 << irq_bit);
289 if (!chip->irqs_allowed[block]) {
290 chip->blocks_allowed[master] &= ~(1 << (block % 8));
291
292 if (!chip->blocks_allowed[master])
293 chip->masters_allowed &= ~(1 << master);
294 }
295
296 config = PM8901_IRQF_WRITE | chip->config[irq] |
297 PM8901_IRQF_MASK_FE | PM8901_IRQF_MASK_RE;
298 pm8901_config_irq(chip, &block, &config);
299}
300
301static void pm8901_irq_unmask(struct irq_data *d)
302{
303 int master, irq_bit;
304 struct pm8901_chip *chip = irq_data_get_irq_handler_data(d);
305 u8 block, config, old_irqs_allowed, old_blocks_allowed;
306 unsigned int irq = d->irq;
307
308 irq -= chip->pdata.irq_base;
309 block = irq / 8;
310 master = block / 8;
311 irq_bit = irq % 8;
312
313 old_irqs_allowed = chip->irqs_allowed[block];
314 chip->irqs_allowed[block] |= 1 << irq_bit;
315 if (!old_irqs_allowed) {
316 master = block / 8;
317
318 old_blocks_allowed = chip->blocks_allowed[master];
319 chip->blocks_allowed[master] |= 1 << (block % 8);
320
321 if (!old_blocks_allowed)
322 chip->masters_allowed |= 1 << master;
323 }
324
325 config = PM8901_IRQF_WRITE | chip->config[irq];
326 pm8901_config_irq(chip, &block, &config);
327}
328
329static void pm8901_irq_ack(struct irq_data *d)
330{
331 struct pm8901_chip *chip = irq_data_get_irq_handler_data(d);
332 u8 block, config;
333 unsigned int irq = d->irq;
334
335 irq -= chip->pdata.irq_base;
336 block = irq / 8;
337
338 config = PM8901_IRQF_WRITE | chip->config[irq] | PM8901_IRQF_CLR;
339 pm8901_config_irq(chip, &block, &config);
340}
341
342static int pm8901_irq_set_type(struct irq_data *d, unsigned int flow_type)
343{
344 int master, irq_bit;
345 struct pm8901_chip *chip = irq_data_get_irq_handler_data(d);
346 u8 block, config;
347 unsigned int irq = d->irq;
348
349 irq -= chip->pdata.irq_base;
350 if (irq > chip->pm_max_irq) {
351 chip->pm_max_irq = irq;
352 chip->pm_max_blocks =
353 chip->pm_max_irq / 8 + 1;
354 chip->pm_max_masters =
355 chip->pm_max_blocks / 8 + 1;
356 }
357 block = irq / 8;
358 master = block / 8;
359 irq_bit = irq % 8;
360
361 chip->config[irq] = (irq_bit << PM8901_IRQF_BITS_SHIFT) |
362 PM8901_IRQF_MASK_RE | PM8901_IRQF_MASK_FE;
363 if (flow_type & (IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING)) {
364 if (flow_type & IRQF_TRIGGER_RISING)
365 chip->config[irq] &= ~PM8901_IRQF_MASK_RE;
366 if (flow_type & IRQF_TRIGGER_FALLING)
367 chip->config[irq] &= ~PM8901_IRQF_MASK_FE;
368 } else {
369 chip->config[irq] |= PM8901_IRQF_LVL_SEL;
370
371 if (flow_type & IRQF_TRIGGER_HIGH)
372 chip->config[irq] &= ~PM8901_IRQF_MASK_RE;
373 else
374 chip->config[irq] &= ~PM8901_IRQF_MASK_FE;
375 }
376
377 config = PM8901_IRQF_WRITE | chip->config[irq] | PM8901_IRQF_CLR;
378 return pm8901_config_irq(chip, &block, &config);
379}
380
381static int pm8901_irq_set_wake(struct irq_data *d, unsigned int on)
382{
383 struct pm8901_chip *chip = irq_data_get_irq_handler_data(d);
384 unsigned int irq = d->irq;
385
386 irq -= chip->pdata.irq_base;
387 if (on) {
388 if (!chip->wake_enable[irq]) {
389 chip->wake_enable[irq] = 1;
390 chip->count_wakeable++;
391 }
392 } else {
393 if (chip->wake_enable[irq]) {
394 chip->wake_enable[irq] = 0;
395 chip->count_wakeable--;
396 }
397 }
398
399 return 0;
400}
401
402static inline int
403pm8901_read_root(struct pm8901_chip *chip, u8 *rp)
404{
405 int rc;
406
407 rc = ssbi_read(chip->dev, SSBI_REG_ADDR_IRQ_ROOT, rp, 1);
408 if (rc) {
409 pr_err("%s: FAIL ssbi_read(): rc=%d (Read Root)\n",
410 __func__, rc);
411 *rp = 0;
412 }
413
414 return rc;
415}
416
417static inline int
418pm8901_read_master(struct pm8901_chip *chip, u8 m, u8 *bp)
419{
420 int rc;
421
422 rc = ssbi_read(chip->dev, SSBI_REG_ADDR_IRQ_M_STATUS1 + m, bp, 1);
423 if (rc) {
424 pr_err("%s: FAIL ssbi_read(): rc=%d (Read Master)\n",
425 __func__, rc);
426 *bp = 0;
427 }
428
429 return rc;
430}
431
432static inline int
433pm8901_read_block(struct pm8901_chip *chip, u8 *bp, u8 *ip)
434{
435 int rc;
436
437 rc = ssbi_write(chip->dev, SSBI_REG_ADDR_IRQ_BLK_SEL, bp, 1);
438 if (rc) {
439 pr_err("%s: FAIL ssbi_write(): rc=%d (Select Block)\n",
440 __func__, rc);
441 *bp = 0;
442 goto bail_out;
443 }
444
445 rc = ssbi_read(chip->dev, SSBI_REG_ADDR_IRQ_IT_STATUS, ip, 1);
446 if (rc)
447 pr_err("%s: FAIL ssbi_read(): rc=%d (Read Status)\n",
448 __func__, rc);
449
450bail_out:
451 return rc;
452}
453
454static irqreturn_t pm8901_isr_thread(int irq_requested, void *data)
455{
456 struct pm8901_chip *chip = data;
457 int i, j, k;
458 u8 root, block, config, bits;
459 u8 blocks[MAX_PM_MASTERS];
460 int masters = 0, irq, handled = 0, spurious = 0;
461 u16 irqs_to_handle[MAX_PM_IRQ];
462 unsigned long irqsave;
463
464 spin_lock_irqsave(&chip->pm_lock, irqsave);
465
466 /* Read root for masters */
467 if (pm8901_read_root(chip, &root))
468 goto bail_out;
469
470 masters = root >> 1;
471
472 if (!(masters & chip->masters_allowed) ||
473 (masters & ~chip->masters_allowed)) {
474 spurious = 1000000;
475 }
476
477 /* Read allowed masters for blocks. */
478 for (i = 0; i < chip->pm_max_masters; i++) {
479 if (masters & (1 << i)) {
480 if (pm8901_read_master(chip, i, &blocks[i]))
481 goto bail_out;
482
483 if (!blocks[i]) {
484 if (pm8901_can_print())
485 pr_err("%s: Spurious master: %d "
486 "(blocks=0)", __func__, i);
487 spurious += 10000;
488 }
489 } else
490 blocks[i] = 0;
491 }
492
493 /* Select block, read status and call isr */
494 for (i = 0; i < chip->pm_max_masters; i++) {
495 if (!blocks[i])
496 continue;
497
498 for (j = 0; j < 8; j++) {
499 if (!(blocks[i] & (1 << j)))
500 continue;
501
502 block = i * 8 + j; /* block # */
503 if (pm8901_read_block(chip, &block, &bits))
504 goto bail_out;
505
506 if (!bits) {
507 if (pm8901_can_print())
508 pr_err("%s: Spurious block: "
509 "[master, block]=[%d, %d] "
510 "(bits=0)\n", __func__, i, j);
511 spurious += 100;
512 continue;
513 }
514
515 /* Check IRQ bits */
516 for (k = 0; k < 8; k++) {
517 if (!(bits & (1 << k)))
518 continue;
519
520 /* Check spurious interrupts */
521 if (((1 << i) & chip->masters_allowed) &&
522 (blocks[i] & chip->blocks_allowed[i]) &&
523 (bits & chip->irqs_allowed[block])) {
524
525 /* Found one */
526 irq = block * 8 + k;
527 irqs_to_handle[handled] = irq +
528 chip->pdata.irq_base;
529 handled++;
530 } else {
531 /* Clear and mask wrong one */
532 config = PM8901_IRQF_W_C_M |
533 (k < PM8901_IRQF_BITS_SHIFT);
534
535 pm8901_config_irq(chip,
536 &block, &config);
537
538 if (pm8901_can_print())
539 pr_err("%s: Spurious IRQ: "
540 "[master, block, bit]="
541 "[%d, %d (%d), %d]\n",
542 __func__,
543 i, j, block, k);
544 spurious++;
545 }
546 }
547 }
548
549 }
550
551bail_out:
552
553 spin_unlock_irqrestore(&chip->pm_lock, irqsave);
554
555 for (i = 0; i < handled; i++)
556 generic_handle_irq(irqs_to_handle[i]);
557
558 if (spurious) {
559 if (!pm8901_can_print())
560 return IRQ_HANDLED;
561
562 pr_err("%s: spurious = %d (handled = %d)\n",
563 __func__, spurious, handled);
564 pr_err(" root = 0x%x (masters_allowed<<1 = 0x%x)\n",
565 root, chip->masters_allowed << 1);
566 for (i = 0; i < chip->pm_max_masters; i++) {
567 if (masters & (1 << i))
568 pr_err(" blocks[%d]=0x%x, "
569 "allowed[%d]=0x%x\n",
570 i, blocks[i],
571 i, chip->blocks_allowed[i]);
572 }
573 }
574
575 return IRQ_HANDLED;
576}
577
578#if defined(CONFIG_DEBUG_FS)
579
580static int check_addr(int addr, const char *func_name)
581{
582 if (addr < 0 || addr > 0x3FF) {
583 pr_err("%s: PMIC 8901 register address is invalid: %d\n",
584 func_name, addr);
585 return -EINVAL;
586 }
587 return 0;
588}
589
590static int data_set(void *data, u64 val)
591{
592 struct pm8901_dbg_device *dbgdev = data;
593 u8 reg = val;
594 int rc;
595
596 mutex_lock(&dbgdev->dbg_mutex);
597
598 rc = check_addr(dbgdev->addr, __func__);
599 if (rc)
600 goto done;
601
602 rc = pm8901_write(dbgdev->pm_chip, dbgdev->addr, &reg, 1);
603
604 if (rc)
605 pr_err("%s: FAIL pm8901_write(0x%03X)=0x%02X: rc=%d\n",
606 __func__, dbgdev->addr, reg, rc);
607done:
608 mutex_unlock(&dbgdev->dbg_mutex);
609 return rc;
610}
611
612static int data_get(void *data, u64 *val)
613{
614 struct pm8901_dbg_device *dbgdev = data;
615 int rc;
616 u8 reg;
617
618 mutex_lock(&dbgdev->dbg_mutex);
619
620 rc = check_addr(dbgdev->addr, __func__);
621 if (rc)
622 goto done;
623
624 rc = pm8901_read(dbgdev->pm_chip, dbgdev->addr, &reg, 1);
625
626 if (rc) {
627 pr_err("%s: FAIL pm8901_read(0x%03X)=0x%02X: rc=%d\n",
628 __func__, dbgdev->addr, reg, rc);
629 goto done;
630 }
631
632 *val = reg;
633done:
634 mutex_unlock(&dbgdev->dbg_mutex);
635 return rc;
636}
637
638DEFINE_SIMPLE_ATTRIBUTE(dbg_data_fops, data_get, data_set, "0x%02llX\n");
639
640static int addr_set(void *data, u64 val)
641{
642 struct pm8901_dbg_device *dbgdev = data;
643 int rc;
644
645 rc = check_addr(val, __func__);
646 if (rc)
647 return rc;
648
649 mutex_lock(&dbgdev->dbg_mutex);
650 dbgdev->addr = val;
651 mutex_unlock(&dbgdev->dbg_mutex);
652
653 return 0;
654}
655
656static int addr_get(void *data, u64 *val)
657{
658 struct pm8901_dbg_device *dbgdev = data;
659 int rc;
660
661 mutex_lock(&dbgdev->dbg_mutex);
662
663 rc = check_addr(dbgdev->addr, __func__);
664 if (rc) {
665 mutex_unlock(&dbgdev->dbg_mutex);
666 return rc;
667 }
668 *val = dbgdev->addr;
669
670 mutex_unlock(&dbgdev->dbg_mutex);
671
672 return 0;
673}
674
675DEFINE_SIMPLE_ATTRIBUTE(dbg_addr_fops, addr_get, addr_set, "0x%03llX\n");
676
677static int __devinit pmic8901_dbg_probe(struct pm8901_chip *chip)
678{
679 struct pm8901_dbg_device *dbgdev;
680 struct dentry *dent;
681 struct dentry *temp;
682
683 if (chip == NULL) {
684 pr_err("%s: no parent data passed in.\n", __func__);
685 return -EINVAL;
686 }
687
688 dbgdev = kzalloc(sizeof *dbgdev, GFP_KERNEL);
689 if (dbgdev == NULL) {
690 pr_err("%s: kzalloc() failed.\n", __func__);
691 return -ENOMEM;
692 }
693
694 mutex_init(&dbgdev->dbg_mutex);
695
696 dbgdev->pm_chip = chip;
697 dbgdev->addr = -1;
698
699 dent = debugfs_create_dir("pm8901-dbg", NULL);
700 if (dent == NULL || IS_ERR(dent)) {
701 pr_err("%s: ERR debugfs_create_dir: dent=0x%X\n",
702 __func__, (unsigned)dent);
703 return -ENOMEM;
704 }
705
706 temp = debugfs_create_file("addr", S_IRUSR | S_IWUSR, dent,
707 dbgdev, &dbg_addr_fops);
708 if (temp == NULL || IS_ERR(temp)) {
709 pr_err("%s: ERR debugfs_create_file: dent=0x%X\n",
710 __func__, (unsigned)temp);
711 goto debug_error;
712 }
713
714 temp = debugfs_create_file("data", S_IRUSR | S_IWUSR, dent,
715 dbgdev, &dbg_data_fops);
716 if (temp == NULL || IS_ERR(temp)) {
717 pr_err("%s: ERR debugfs_create_file: dent=0x%X\n",
718 __func__, (unsigned)temp);
719 goto debug_error;
720 }
721
722 dbgdev->dent = dent;
723
724 pmic_dbg_device = dbgdev;
725
726 return 0;
727
728debug_error:
729 debugfs_remove_recursive(dent);
730 return -ENOMEM;
731}
732
733static int __devexit pmic8901_dbg_remove(void)
734{
735 if (pmic_dbg_device) {
736 debugfs_remove_recursive(pmic_dbg_device->dent);
737 kfree(pmic_dbg_device);
738 }
739 return 0;
740}
741
742#else
743
744static int __devinit pmic8901_dbg_probe(struct pm8901_chip *chip)
745{
746 return 0;
747}
748
749static int __devexit pmic8901_dbg_remove(void)
750{
751 return 0;
752}
753
754#endif
755
756static struct irq_chip pm8901_irq_chip = {
757 .name = "pm8901",
758 .irq_ack = pm8901_irq_ack,
759 .irq_mask = pm8901_irq_mask,
760 .irq_unmask = pm8901_irq_unmask,
761 .irq_set_type = pm8901_irq_set_type,
762 .irq_set_wake = pm8901_irq_set_wake,
763};
764
765static int pm8901_probe(struct i2c_client *client,
766 const struct i2c_device_id *id)
767{
768 int i, rc;
769 struct pm8901_platform_data *pdata = client->dev.platform_data;
770 struct pm8901_chip *chip;
771
772 if (pdata == NULL || !client->irq) {
773 pr_err("%s: No platform_data or IRQ.\n", __func__);
774 return -ENODEV;
775 }
776
777 if (i2c_check_functionality(client->adapter, I2C_FUNC_I2C) == 0) {
778 pr_err("%s: i2c_check_functionality failed.\n", __func__);
779 return -ENODEV;
780 }
781
782 chip = kzalloc(sizeof *chip, GFP_KERNEL);
783 if (chip == NULL) {
784 pr_err("%s: kzalloc() failed.\n", __func__);
785 return -ENOMEM;
786 }
787
788 chip->dev = client;
789
790 /* Read PMIC chip revision */
791 rc = ssbi_read(chip->dev, SSBI_REG_REV, &chip->revision, 1);
792 if (rc)
793 pr_err("%s: Failed on ssbi_read for revision: rc=%d.\n",
794 __func__, rc);
795 pr_info("%s: PMIC revision: %X\n", __func__, chip->revision);
796
797 (void) memcpy((void *)&chip->pdata, (const void *)pdata,
798 sizeof(chip->pdata));
799
800 irq_set_handler_data(chip->dev->irq, (void *)chip);
801 irq_set_irq_wake(chip->dev->irq, 1);
802
803 chip->pm_max_irq = 0;
804 chip->pm_max_blocks = 0;
805 chip->pm_max_masters = 0;
806
807 i2c_set_clientdata(client, chip);
808
809 pmic_chip = chip;
810 spin_lock_init(&chip->pm_lock);
811
812 /* Register for all reserved IRQs */
813 for (i = pdata->irq_base; i < (pdata->irq_base + MAX_PM_IRQ); i++) {
814 irq_set_chip(i, &pm8901_irq_chip);
815 irq_set_handler(i, handle_edge_irq);
816 set_irq_flags(i, IRQF_VALID);
817 irq_set_handler_data(i, (void *)chip);
818 }
819
820 rc = mfd_add_devices(&chip->dev->dev, 0, pdata->sub_devices,
821 pdata->num_subdevs, NULL, 0);
822 if (rc) {
823 pr_err("%s: could not add devices %d\n", __func__, rc);
824 return rc;
825 }
826
827 rc = request_threaded_irq(chip->dev->irq, NULL, pm8901_isr_thread,
828 IRQF_ONESHOT | IRQF_DISABLED | pdata->irq_trigger_flags,
829 "pm8901-irq", chip);
830 if (rc)
831 pr_err("%s: could not request irq %d: %d\n", __func__,
832 chip->dev->irq, rc);
833
834 rc = pmic8901_dbg_probe(chip);
835 if (rc < 0)
836 pr_err("%s: could not set up debugfs: %d\n", __func__, rc);
837
838 return rc;
839}
840
841static int __devexit pm8901_remove(struct i2c_client *client)
842{
843 struct pm8901_chip *chip;
844
845 chip = i2c_get_clientdata(client);
846 if (chip) {
847 if (chip->pm_max_irq) {
848 irq_set_irq_wake(chip->dev->irq, 0);
849 free_irq(chip->dev->irq, chip);
850 }
851
852 mfd_remove_devices(&chip->dev->dev);
853
854 chip->dev = NULL;
855
856 kfree(chip);
857 }
858
859 pmic8901_dbg_remove();
860
861 return 0;
862}
863
864#ifdef CONFIG_PM
865static int pm8901_suspend(struct i2c_client *client, pm_message_t mesg)
866{
867 struct pm8901_chip *chip;
868 int i;
869 unsigned long irqsave;
870
871 chip = i2c_get_clientdata(client);
872
873 for (i = 0; i < MAX_PM_IRQ; i++) {
874 spin_lock_irqsave(&chip->pm_lock, irqsave);
875 if (chip->config[i] && !chip->wake_enable[i]) {
876 if (!((chip->config[i] & PM8901_IRQF_MASK_ALL)
877 == PM8901_IRQF_MASK_ALL))
878 pm8901_irq_mask(irq_get_irq_data(i +
879 chip->pdata.irq_base));
880 }
881 spin_unlock_irqrestore(&chip->pm_lock, irqsave);
882 }
883
884 if (!chip->count_wakeable)
885 disable_irq(chip->dev->irq);
886
887 return 0;
888}
889
890static int pm8901_resume(struct i2c_client *client)
891{
892 struct pm8901_chip *chip;
893 int i;
894 unsigned long irqsave;
895
896 chip = i2c_get_clientdata(client);
897
898 for (i = 0; i < MAX_PM_IRQ; i++) {
899 spin_lock_irqsave(&chip->pm_lock, irqsave);
900 if (chip->config[i] && !chip->wake_enable[i]) {
901 if (!((chip->config[i] & PM8901_IRQF_MASK_ALL)
902 == PM8901_IRQF_MASK_ALL))
903 pm8901_irq_unmask(irq_get_irq_data(i +
904 chip->pdata.irq_base));
905 }
906 spin_unlock_irqrestore(&chip->pm_lock, irqsave);
907 }
908
909 if (!chip->count_wakeable)
910 enable_irq(chip->dev->irq);
911
912 return 0;
913}
914#else
915#define pm8901_suspend NULL
916#define pm8901_resume NULL
917#endif
918
919static const struct i2c_device_id pm8901_ids[] = {
920 { "pm8901-core", 0 },
921 { },
922};
923MODULE_DEVICE_TABLE(i2c, pm8901_ids);
924
925static struct i2c_driver pm8901_driver = {
926 .driver.name = "pm8901-core",
927 .id_table = pm8901_ids,
928 .probe = pm8901_probe,
929 .remove = __devexit_p(pm8901_remove),
930 .suspend = pm8901_suspend,
931 .resume = pm8901_resume,
932};
933
934static int __init pm8901_init(void)
935{
936 int rc = i2c_add_driver(&pm8901_driver);
937 pr_notice("%s: i2c_add_driver: rc = %d\n", __func__, rc);
938
939 return rc;
940}
941
942static void __exit pm8901_exit(void)
943{
944 i2c_del_driver(&pm8901_driver);
945}
946
947arch_initcall(pm8901_init);
948module_exit(pm8901_exit);
949
950MODULE_LICENSE("GPL v2");
951MODULE_DESCRIPTION("PMIC8901 core driver");
952MODULE_VERSION("1.0");
953MODULE_ALIAS("platform:pmic8901-core");