2 * Copyright (C) 2007-2010 ST-Ericsson
3 * License terms: GNU General Public License (GPL) version 2
4 * Low-level core for exclusive access to the AB3550 IC on the I2C bus
5 * and some basic chip-configuration.
6 * Author: Bengt Jonsson <bengt.g.jonsson@stericsson.com>
7 * Author: Mattias Nilsson <mattias.i.nilsson@stericsson.com>
8 * Author: Mattias Wallin <mattias.wallin@stericsson.com>
9 * Author: Rickard Andersson <rickard.andersson@stericsson.com>
12 #include <linux/i2c.h>
13 #include <linux/mutex.h>
14 #include <linux/err.h>
15 #include <linux/platform_device.h>
16 #include <linux/slab.h>
17 #include <linux/device.h>
18 #include <linux/irq.h>
19 #include <linux/interrupt.h>
20 #include <linux/random.h>
21 #include <linux/workqueue.h>
22 #include <linux/debugfs.h>
23 #include <linux/seq_file.h>
24 #include <linux/uaccess.h>
25 #include <linux/mfd/abx500.h>
26 #include <linux/list.h>
27 #include <linux/bitops.h>
28 #include <linux/spinlock.h>
29 #include <linux/mfd/core.h>
31 #define AB3550_NAME_STRING "ab3550"
32 #define AB3550_ID_FORMAT_STRING "AB3550 %s"
33 #define AB3550_NUM_BANKS 2
34 #define AB3550_NUM_EVENT_REG 5
36 /* These are the only registers inside AB3550 used in this main file */
38 /* Chip ID register */
39 #define AB3550_CID_REG 0x20
41 /* Interrupt event registers */
42 #define AB3550_EVENT_BANK 0
43 #define AB3550_EVENT_REG 0x22
45 /* Read/write operation values. */
46 #define AB3550_PERM_RD (0x01)
47 #define AB3550_PERM_WR (0x02)
49 /* Read/write permissions. */
50 #define AB3550_PERM_RO (AB3550_PERM_RD)
51 #define AB3550_PERM_RW (AB3550_PERM_RD | AB3550_PERM_WR)
55 * @access_mutex: lock out concurrent accesses to the AB registers
56 * @i2c_client: I2C client for this chip
57 * @chip_name: name of this chip variant
58 * @chip_id: 8 bit chip ID for this chip variant
59 * @mask_work: a worker for writing to mask registers
60 * @event_lock: a lock to protect the event_mask
61 * @event_mask: a local copy of the mask event registers
62 * @startup_events: a copy of the first reading of the event registers
63 * @startup_events_read: whether the first events have been read
66 struct mutex access_mutex
;
67 struct i2c_client
*i2c_client
[AB3550_NUM_BANKS
];
70 struct work_struct mask_work
;
71 spinlock_t event_lock
;
72 u8 event_mask
[AB3550_NUM_EVENT_REG
];
73 u8 startup_events
[AB3550_NUM_EVENT_REG
];
74 bool startup_events_read
;
75 #ifdef CONFIG_DEBUG_FS
76 unsigned int debug_bank
;
77 unsigned int debug_address
;
82 * struct ab3550_reg_range
83 * @first: the first address of the range
84 * @last: the last address of the range
85 * @perm: access permissions for the range
87 struct ab3550_reg_range
{
94 * struct ab3550_reg_ranges
95 * @count: the number of ranges in the list
96 * @range: the list of register ranges
98 struct ab3550_reg_ranges
{
100 const struct ab3550_reg_range
*range
;
104 * Permissible register ranges for reading and writing per device and bank.
106 * The ranges must be listed in increasing address order, and no overlaps are
107 * allowed. It is assumed that write permission implies read permission
108 * (i.e. only RO and RW permissions should be used). Ranges with write
109 * permission must not be split up.
112 #define NO_RANGE {.count = 0, .range = NULL,}
115 ab3550_reg_ranges ab3550_reg_ranges
[AB3550_NUM_DEVICES
][AB3550_NUM_BANKS
] = {
116 [AB3550_DEVID_DAC
] = {
120 .range
= (struct ab3550_reg_range
[]) {
124 .perm
= AB3550_PERM_RW
,
129 .perm
= AB3550_PERM_RW
,
134 [AB3550_DEVID_LEDS
] = {
138 .range
= (struct ab3550_reg_range
[]) {
142 .perm
= AB3550_PERM_RW
,
147 .perm
= AB3550_PERM_RW
,
152 [AB3550_DEVID_POWER
] = {
155 .range
= (struct ab3550_reg_range
[]) {
159 .perm
= AB3550_PERM_RO
,
165 [AB3550_DEVID_REGULATORS
] = {
168 .range
= (struct ab3550_reg_range
[]) {
172 .perm
= AB3550_PERM_RW
,
178 .range
= (struct ab3550_reg_range
[]) {
182 .perm
= AB3550_PERM_RW
,
187 [AB3550_DEVID_SIM
] = {
190 .range
= (struct ab3550_reg_range
[]) {
194 .perm
= AB3550_PERM_RO
,
200 .range
= (struct ab3550_reg_range
[]) {
204 .perm
= AB3550_PERM_RW
,
210 [AB3550_DEVID_UART
] = {
214 [AB3550_DEVID_RTC
] = {
217 .range
= (struct ab3550_reg_range
[]) {
221 .perm
= AB3550_PERM_RW
,
227 [AB3550_DEVID_CHARGER
] = {
230 .range
= (struct ab3550_reg_range
[]) {
234 .perm
= AB3550_PERM_RW
,
239 .perm
= AB3550_PERM_RO
,
245 [AB3550_DEVID_ADC
] = {
249 .range
= (struct ab3550_reg_range
[]) {
253 .perm
= AB3550_PERM_RW
,
259 [AB3550_DEVID_FUELGAUGE
] = {
262 .range
= (struct ab3550_reg_range
[]) {
266 .perm
= AB3550_PERM_RO
,
272 .range
= (struct ab3550_reg_range
[]) {
276 .perm
= AB3550_PERM_RW
,
281 [AB3550_DEVID_VIBRATOR
] = {
285 .range
= (struct ab3550_reg_range
[]) {
289 .perm
= AB3550_PERM_RW
,
295 [AB3550_DEVID_CODEC
] = {
298 .range
= (struct ab3550_reg_range
[]) {
302 .perm
= AB3550_PERM_RW
,
307 .perm
= AB3550_PERM_RW
,
315 static struct mfd_cell ab3550_devs
[AB3550_NUM_DEVICES
] = {
316 [AB3550_DEVID_DAC
] = {
317 .name
= "ab3550-dac",
318 .id
= AB3550_DEVID_DAC
,
321 [AB3550_DEVID_LEDS
] = {
322 .name
= "ab3550-leds",
323 .id
= AB3550_DEVID_LEDS
,
325 [AB3550_DEVID_POWER
] = {
326 .name
= "ab3550-power",
327 .id
= AB3550_DEVID_POWER
,
329 [AB3550_DEVID_REGULATORS
] = {
330 .name
= "ab3550-regulators",
331 .id
= AB3550_DEVID_REGULATORS
,
333 [AB3550_DEVID_SIM
] = {
334 .name
= "ab3550-sim",
335 .id
= AB3550_DEVID_SIM
,
337 [AB3550_DEVID_UART
] = {
338 .name
= "ab3550-uart",
339 .id
= AB3550_DEVID_UART
,
341 [AB3550_DEVID_RTC
] = {
342 .name
= "ab3550-rtc",
343 .id
= AB3550_DEVID_RTC
,
345 [AB3550_DEVID_CHARGER
] = {
346 .name
= "ab3550-charger",
347 .id
= AB3550_DEVID_CHARGER
,
349 [AB3550_DEVID_ADC
] = {
350 .name
= "ab3550-adc",
351 .id
= AB3550_DEVID_ADC
,
353 .resources
= (struct resource
[]) {
356 .flags
= IORESOURCE_IRQ
,
362 .flags
= IORESOURCE_IRQ
,
368 .flags
= IORESOURCE_IRQ
,
374 .flags
= IORESOURCE_IRQ
,
380 .flags
= IORESOURCE_IRQ
,
386 .flags
= IORESOURCE_IRQ
,
392 .flags
= IORESOURCE_IRQ
,
398 .flags
= IORESOURCE_IRQ
,
403 .name
= "TRIGGER-VBAT-TXON",
404 .flags
= IORESOURCE_IRQ
,
409 .name
= "TRIGGER-VBAT",
410 .flags
= IORESOURCE_IRQ
,
416 [AB3550_DEVID_FUELGAUGE
] = {
417 .name
= "ab3550-fuelgauge",
418 .id
= AB3550_DEVID_FUELGAUGE
,
420 [AB3550_DEVID_VIBRATOR
] = {
421 .name
= "ab3550-vibrator",
422 .id
= AB3550_DEVID_VIBRATOR
,
424 [AB3550_DEVID_CODEC
] = {
425 .name
= "ab3550-codec",
426 .id
= AB3550_DEVID_CODEC
,
431 * I2C transactions with error messages.
433 static int ab3550_i2c_master_send(struct ab3550
*ab
, u8 bank
, u8
*data
,
438 err
= i2c_master_send(ab
->i2c_client
[bank
], data
, count
);
440 dev_err(&ab
->i2c_client
[0]->dev
, "send error: %d\n", err
);
446 static int ab3550_i2c_master_recv(struct ab3550
*ab
, u8 bank
, u8
*data
,
451 err
= i2c_master_recv(ab
->i2c_client
[bank
], data
, count
);
453 dev_err(&ab
->i2c_client
[0]->dev
, "receive error: %d\n", err
);
460 * Functionality for getting/setting register values.
462 static int get_register_interruptible(struct ab3550
*ab
, u8 bank
, u8 reg
,
467 err
= mutex_lock_interruptible(&ab
->access_mutex
);
471 err
= ab3550_i2c_master_send(ab
, bank
, ®
, 1);
473 err
= ab3550_i2c_master_recv(ab
, bank
, value
, 1);
475 mutex_unlock(&ab
->access_mutex
);
479 static int get_register_page_interruptible(struct ab3550
*ab
, u8 bank
,
480 u8 first_reg
, u8
*regvals
, u8 numregs
)
484 err
= mutex_lock_interruptible(&ab
->access_mutex
);
488 err
= ab3550_i2c_master_send(ab
, bank
, &first_reg
, 1);
490 err
= ab3550_i2c_master_recv(ab
, bank
, regvals
, numregs
);
492 mutex_unlock(&ab
->access_mutex
);
496 static int mask_and_set_register_interruptible(struct ab3550
*ab
, u8 bank
,
497 u8 reg
, u8 bitmask
, u8 bitvalues
)
501 if (likely(bitmask
)) {
502 u8 reg_bits
[2] = {reg
, 0};
504 err
= mutex_lock_interruptible(&ab
->access_mutex
);
508 if (bitmask
== 0xFF) /* No need to read in this case. */
509 reg_bits
[1] = bitvalues
;
510 else { /* Read and modify the register value. */
513 err
= ab3550_i2c_master_send(ab
, bank
, ®
, 1);
515 goto unlock_and_return
;
516 err
= ab3550_i2c_master_recv(ab
, bank
, &bits
, 1);
518 goto unlock_and_return
;
519 reg_bits
[1] = ((~bitmask
& bits
) |
520 (bitmask
& bitvalues
));
522 /* Write the new value. */
523 err
= ab3550_i2c_master_send(ab
, bank
, reg_bits
, 2);
525 mutex_unlock(&ab
->access_mutex
);
531 * Read/write permission checking functions.
533 static bool page_write_allowed(const struct ab3550_reg_ranges
*ranges
,
534 u8 first_reg
, u8 last_reg
)
538 if (last_reg
< first_reg
)
541 for (i
= 0; i
< ranges
->count
; i
++) {
542 if (first_reg
< ranges
->range
[i
].first
)
544 if ((last_reg
<= ranges
->range
[i
].last
) &&
545 (ranges
->range
[i
].perm
& AB3550_PERM_WR
))
551 static bool reg_write_allowed(const struct ab3550_reg_ranges
*ranges
, u8 reg
)
553 return page_write_allowed(ranges
, reg
, reg
);
556 static bool page_read_allowed(const struct ab3550_reg_ranges
*ranges
,
557 u8 first_reg
, u8 last_reg
)
561 if (last_reg
< first_reg
)
563 /* Find the range (if it exists in the list) that includes first_reg. */
564 for (i
= 0; i
< ranges
->count
; i
++) {
565 if (first_reg
< ranges
->range
[i
].first
)
567 if (first_reg
<= ranges
->range
[i
].last
)
570 /* Make sure that the entire range up to and including last_reg is
571 * readable. This may span several of the ranges in the list.
573 while ((i
< ranges
->count
) &&
574 (ranges
->range
[i
].perm
& AB3550_PERM_RD
)) {
575 if (last_reg
<= ranges
->range
[i
].last
)
577 if ((++i
>= ranges
->count
) ||
578 (ranges
->range
[i
].first
!=
579 (ranges
->range
[i
- 1].last
+ 1))) {
586 static bool reg_read_allowed(const struct ab3550_reg_ranges
*ranges
, u8 reg
)
588 return page_read_allowed(ranges
, reg
, reg
);
592 * The exported register access functionality.
594 int ab3550_get_chip_id(struct device
*dev
)
596 struct ab3550
*ab
= dev_get_drvdata(dev
->parent
);
597 return (int)ab
->chip_id
;
600 int ab3550_mask_and_set_register_interruptible(struct device
*dev
, u8 bank
,
601 u8 reg
, u8 bitmask
, u8 bitvalues
)
604 struct platform_device
*pdev
= to_platform_device(dev
);
606 if ((AB3550_NUM_BANKS
<= bank
) ||
607 !reg_write_allowed(&ab3550_reg_ranges
[pdev
->id
][bank
], reg
))
610 ab
= dev_get_drvdata(dev
->parent
);
611 return mask_and_set_register_interruptible(ab
, bank
, reg
,
615 int ab3550_set_register_interruptible(struct device
*dev
, u8 bank
, u8 reg
,
618 return ab3550_mask_and_set_register_interruptible(dev
, bank
, reg
, 0xFF,
622 int ab3550_get_register_interruptible(struct device
*dev
, u8 bank
, u8 reg
,
626 struct platform_device
*pdev
= to_platform_device(dev
);
628 if ((AB3550_NUM_BANKS
<= bank
) ||
629 !reg_read_allowed(&ab3550_reg_ranges
[pdev
->id
][bank
], reg
))
632 ab
= dev_get_drvdata(dev
->parent
);
633 return get_register_interruptible(ab
, bank
, reg
, value
);
636 int ab3550_get_register_page_interruptible(struct device
*dev
, u8 bank
,
637 u8 first_reg
, u8
*regvals
, u8 numregs
)
640 struct platform_device
*pdev
= to_platform_device(dev
);
642 if ((AB3550_NUM_BANKS
<= bank
) ||
643 !page_read_allowed(&ab3550_reg_ranges
[pdev
->id
][bank
],
644 first_reg
, (first_reg
+ numregs
- 1)))
647 ab
= dev_get_drvdata(dev
->parent
);
648 return get_register_page_interruptible(ab
, bank
, first_reg
, regvals
,
652 int ab3550_event_registers_startup_state_get(struct device
*dev
, u8
*event
)
656 ab
= dev_get_drvdata(dev
->parent
);
657 if (!ab
->startup_events_read
)
658 return -EAGAIN
; /* Try again later */
660 memcpy(event
, ab
->startup_events
, AB3550_NUM_EVENT_REG
);
664 int ab3550_startup_irq_enabled(struct device
*dev
, unsigned int irq
)
667 struct ab3550_platform_data
*plf_data
;
670 ab
= get_irq_chip_data(irq
);
671 plf_data
= ab
->i2c_client
[0]->dev
.platform_data
;
672 irq
-= plf_data
->irq
.base
;
673 val
= ((ab
->startup_events
[irq
/ 8] & BIT(irq
% 8)) != 0);
678 static struct abx500_ops ab3550_ops
= {
679 .get_chip_id
= ab3550_get_chip_id
,
680 .get_register
= ab3550_get_register_interruptible
,
681 .set_register
= ab3550_set_register_interruptible
,
682 .get_register_page
= ab3550_get_register_page_interruptible
,
683 .set_register_page
= NULL
,
684 .mask_and_set_register
= ab3550_mask_and_set_register_interruptible
,
685 .event_registers_startup_state_get
=
686 ab3550_event_registers_startup_state_get
,
687 .startup_irq_enabled
= ab3550_startup_irq_enabled
,
690 static irqreturn_t
ab3550_irq_handler(int irq
, void *data
)
692 struct ab3550
*ab
= data
;
695 u8 e
[AB3550_NUM_EVENT_REG
];
699 events
= (ab
->startup_events_read
? e
: ab
->startup_events
);
701 err
= get_register_page_interruptible(ab
, AB3550_EVENT_BANK
,
702 AB3550_EVENT_REG
, events
, AB3550_NUM_EVENT_REG
);
706 if (!ab
->startup_events_read
) {
707 dev_info(&ab
->i2c_client
[0]->dev
,
708 "startup events 0x%x,0x%x,0x%x,0x%x,0x%x\n",
709 ab
->startup_events
[0], ab
->startup_events
[1],
710 ab
->startup_events
[2], ab
->startup_events
[3],
711 ab
->startup_events
[4]);
712 ab
->startup_events_read
= true;
716 /* The two highest bits in event[4] are not used. */
719 spin_lock_irqsave(&ab
->event_lock
, flags
);
720 for (i
= 0; i
< AB3550_NUM_EVENT_REG
; i
++)
721 events
[i
] &= ~ab
->event_mask
[i
];
722 spin_unlock_irqrestore(&ab
->event_lock
, flags
);
724 for (i
= 0; i
< AB3550_NUM_EVENT_REG
; i
++) {
728 dev_dbg(&ab
->i2c_client
[0]->dev
, "IRQ Event[%d]: 0x%2x\n",
731 event_reg
= events
[i
];
732 for (bit
= 0; event_reg
; bit
++, event_reg
/= 2) {
735 struct ab3550_platform_data
*plf_data
;
737 plf_data
= ab
->i2c_client
[0]->dev
.platform_data
;
738 irq
= plf_data
->irq
.base
+ (i
* 8) + bit
;
739 handle_nested_irq(irq
);
747 dev_dbg(&ab
->i2c_client
[0]->dev
, "error reading event registers\n");
751 #ifdef CONFIG_DEBUG_FS
752 static struct ab3550_reg_ranges debug_ranges
[AB3550_NUM_BANKS
] = {
755 .range
= (struct ab3550_reg_range
[]) {
784 .range
= (struct ab3550_reg_range
[]) {
821 static int ab3550_registers_print(struct seq_file
*s
, void *p
)
823 struct ab3550
*ab
= s
->private;
826 seq_printf(s
, AB3550_NAME_STRING
" register values:\n");
828 for (bank
= 0; bank
< AB3550_NUM_BANKS
; bank
++) {
831 seq_printf(s
, " bank %d:\n", bank
);
832 for (i
= 0; i
< debug_ranges
[bank
].count
; i
++) {
835 for (reg
= debug_ranges
[bank
].range
[i
].first
;
836 reg
<= debug_ranges
[bank
].range
[i
].last
;
840 get_register_interruptible(ab
, bank
, reg
,
842 seq_printf(s
, " [%d/0x%02X]: 0x%02X\n", bank
,
850 static int ab3550_registers_open(struct inode
*inode
, struct file
*file
)
852 return single_open(file
, ab3550_registers_print
, inode
->i_private
);
855 static const struct file_operations ab3550_registers_fops
= {
856 .open
= ab3550_registers_open
,
859 .release
= single_release
,
860 .owner
= THIS_MODULE
,
863 static int ab3550_bank_print(struct seq_file
*s
, void *p
)
865 struct ab3550
*ab
= s
->private;
867 seq_printf(s
, "%d\n", ab
->debug_bank
);
871 static int ab3550_bank_open(struct inode
*inode
, struct file
*file
)
873 return single_open(file
, ab3550_bank_print
, inode
->i_private
);
876 static ssize_t
ab3550_bank_write(struct file
*file
,
877 const char __user
*user_buf
,
878 size_t count
, loff_t
*ppos
)
880 struct ab3550
*ab
= ((struct seq_file
*)(file
->private_data
))->private;
883 unsigned long user_bank
;
886 /* Get userspace string and assure termination */
887 buf_size
= min(count
, (sizeof(buf
) - 1));
888 if (copy_from_user(buf
, user_buf
, buf_size
))
892 err
= strict_strtoul(buf
, 0, &user_bank
);
896 if (user_bank
>= AB3550_NUM_BANKS
) {
897 dev_err(&ab
->i2c_client
[0]->dev
,
898 "debugfs error input > number of banks\n");
902 ab
->debug_bank
= user_bank
;
907 static int ab3550_address_print(struct seq_file
*s
, void *p
)
909 struct ab3550
*ab
= s
->private;
911 seq_printf(s
, "0x%02X\n", ab
->debug_address
);
915 static int ab3550_address_open(struct inode
*inode
, struct file
*file
)
917 return single_open(file
, ab3550_address_print
, inode
->i_private
);
920 static ssize_t
ab3550_address_write(struct file
*file
,
921 const char __user
*user_buf
,
922 size_t count
, loff_t
*ppos
)
924 struct ab3550
*ab
= ((struct seq_file
*)(file
->private_data
))->private;
927 unsigned long user_address
;
930 /* Get userspace string and assure termination */
931 buf_size
= min(count
, (sizeof(buf
) - 1));
932 if (copy_from_user(buf
, user_buf
, buf_size
))
936 err
= strict_strtoul(buf
, 0, &user_address
);
939 if (user_address
> 0xff) {
940 dev_err(&ab
->i2c_client
[0]->dev
,
941 "debugfs error input > 0xff\n");
944 ab
->debug_address
= user_address
;
948 static int ab3550_val_print(struct seq_file
*s
, void *p
)
950 struct ab3550
*ab
= s
->private;
954 err
= get_register_interruptible(ab
, (u8
)ab
->debug_bank
,
955 (u8
)ab
->debug_address
, ®value
);
958 seq_printf(s
, "0x%02X\n", regvalue
);
963 static int ab3550_val_open(struct inode
*inode
, struct file
*file
)
965 return single_open(file
, ab3550_val_print
, inode
->i_private
);
968 static ssize_t
ab3550_val_write(struct file
*file
,
969 const char __user
*user_buf
,
970 size_t count
, loff_t
*ppos
)
972 struct ab3550
*ab
= ((struct seq_file
*)(file
->private_data
))->private;
975 unsigned long user_val
;
979 /* Get userspace string and assure termination */
980 buf_size
= min(count
, (sizeof(buf
)-1));
981 if (copy_from_user(buf
, user_buf
, buf_size
))
985 err
= strict_strtoul(buf
, 0, &user_val
);
988 if (user_val
> 0xff) {
989 dev_err(&ab
->i2c_client
[0]->dev
,
990 "debugfs error input > 0xff\n");
993 err
= mask_and_set_register_interruptible(
994 ab
, (u8
)ab
->debug_bank
,
995 (u8
)ab
->debug_address
, 0xFF, (u8
)user_val
);
999 get_register_interruptible(ab
, (u8
)ab
->debug_bank
,
1000 (u8
)ab
->debug_address
, ®value
);
1007 static const struct file_operations ab3550_bank_fops
= {
1008 .open
= ab3550_bank_open
,
1009 .write
= ab3550_bank_write
,
1011 .llseek
= seq_lseek
,
1012 .release
= single_release
,
1013 .owner
= THIS_MODULE
,
1016 static const struct file_operations ab3550_address_fops
= {
1017 .open
= ab3550_address_open
,
1018 .write
= ab3550_address_write
,
1020 .llseek
= seq_lseek
,
1021 .release
= single_release
,
1022 .owner
= THIS_MODULE
,
1025 static const struct file_operations ab3550_val_fops
= {
1026 .open
= ab3550_val_open
,
1027 .write
= ab3550_val_write
,
1029 .llseek
= seq_lseek
,
1030 .release
= single_release
,
1031 .owner
= THIS_MODULE
,
1034 static struct dentry
*ab3550_dir
;
1035 static struct dentry
*ab3550_reg_file
;
1036 static struct dentry
*ab3550_bank_file
;
1037 static struct dentry
*ab3550_address_file
;
1038 static struct dentry
*ab3550_val_file
;
1040 static inline void ab3550_setup_debugfs(struct ab3550
*ab
)
1043 ab
->debug_address
= 0x00;
1045 ab3550_dir
= debugfs_create_dir(AB3550_NAME_STRING
, NULL
);
1047 goto exit_no_debugfs
;
1049 ab3550_reg_file
= debugfs_create_file("all-registers",
1050 S_IRUGO
, ab3550_dir
, ab
, &ab3550_registers_fops
);
1051 if (!ab3550_reg_file
)
1052 goto exit_destroy_dir
;
1054 ab3550_bank_file
= debugfs_create_file("register-bank",
1055 (S_IRUGO
| S_IWUGO
), ab3550_dir
, ab
, &ab3550_bank_fops
);
1056 if (!ab3550_bank_file
)
1057 goto exit_destroy_reg
;
1059 ab3550_address_file
= debugfs_create_file("register-address",
1060 (S_IRUGO
| S_IWUGO
), ab3550_dir
, ab
, &ab3550_address_fops
);
1061 if (!ab3550_address_file
)
1062 goto exit_destroy_bank
;
1064 ab3550_val_file
= debugfs_create_file("register-value",
1065 (S_IRUGO
| S_IWUGO
), ab3550_dir
, ab
, &ab3550_val_fops
);
1066 if (!ab3550_val_file
)
1067 goto exit_destroy_address
;
1071 exit_destroy_address
:
1072 debugfs_remove(ab3550_address_file
);
1074 debugfs_remove(ab3550_bank_file
);
1076 debugfs_remove(ab3550_reg_file
);
1078 debugfs_remove(ab3550_dir
);
1080 dev_err(&ab
->i2c_client
[0]->dev
, "failed to create debugfs entries.\n");
1084 static inline void ab3550_remove_debugfs(void)
1086 debugfs_remove(ab3550_val_file
);
1087 debugfs_remove(ab3550_address_file
);
1088 debugfs_remove(ab3550_bank_file
);
1089 debugfs_remove(ab3550_reg_file
);
1090 debugfs_remove(ab3550_dir
);
1093 #else /* !CONFIG_DEBUG_FS */
1094 static inline void ab3550_setup_debugfs(struct ab3550
*ab
)
1097 static inline void ab3550_remove_debugfs(void)
1103 * Basic set-up, datastructure creation/destruction and I2C interface.
1104 * This sets up a default config in the AB3550 chip so that it
1105 * will work as expected.
1107 static int __init
ab3550_setup(struct ab3550
*ab
)
1111 struct ab3550_platform_data
*plf_data
;
1112 struct abx500_init_settings
*settings
;
1114 plf_data
= ab
->i2c_client
[0]->dev
.platform_data
;
1115 settings
= plf_data
->init_settings
;
1117 for (i
= 0; i
< plf_data
->init_settings_sz
; i
++) {
1118 err
= mask_and_set_register_interruptible(ab
,
1121 0xFF, settings
[i
].setting
);
1125 /* If event mask register update the event mask in ab3550 */
1126 if ((settings
[i
].bank
== 0) &&
1127 (AB3550_IMR1
<= settings
[i
].reg
) &&
1128 (settings
[i
].reg
<= AB3550_IMR5
)) {
1129 ab
->event_mask
[settings
[i
].reg
- AB3550_IMR1
] =
1130 settings
[i
].setting
;
1137 static void ab3550_mask_work(struct work_struct
*work
)
1139 struct ab3550
*ab
= container_of(work
, struct ab3550
, mask_work
);
1141 unsigned long flags
;
1142 u8 mask
[AB3550_NUM_EVENT_REG
];
1144 spin_lock_irqsave(&ab
->event_lock
, flags
);
1145 for (i
= 0; i
< AB3550_NUM_EVENT_REG
; i
++)
1146 mask
[i
] = ab
->event_mask
[i
];
1147 spin_unlock_irqrestore(&ab
->event_lock
, flags
);
1149 for (i
= 0; i
< AB3550_NUM_EVENT_REG
; i
++) {
1152 err
= mask_and_set_register_interruptible(ab
, 0,
1153 (AB3550_IMR1
+ i
), ~0, mask
[i
]);
1155 dev_err(&ab
->i2c_client
[0]->dev
,
1156 "ab3550_mask_work failed 0x%x,0x%x\n",
1157 (AB3550_IMR1
+ i
), mask
[i
]);
1161 static void ab3550_mask(unsigned int irq
)
1163 unsigned long flags
;
1165 struct ab3550_platform_data
*plf_data
;
1167 ab
= get_irq_chip_data(irq
);
1168 plf_data
= ab
->i2c_client
[0]->dev
.platform_data
;
1169 irq
-= plf_data
->irq
.base
;
1171 spin_lock_irqsave(&ab
->event_lock
, flags
);
1172 ab
->event_mask
[irq
/ 8] |= BIT(irq
% 8);
1173 spin_unlock_irqrestore(&ab
->event_lock
, flags
);
1175 schedule_work(&ab
->mask_work
);
1178 static void ab3550_unmask(unsigned int irq
)
1180 unsigned long flags
;
1182 struct ab3550_platform_data
*plf_data
;
1184 ab
= get_irq_chip_data(irq
);
1185 plf_data
= ab
->i2c_client
[0]->dev
.platform_data
;
1186 irq
-= plf_data
->irq
.base
;
1188 spin_lock_irqsave(&ab
->event_lock
, flags
);
1189 ab
->event_mask
[irq
/ 8] &= ~BIT(irq
% 8);
1190 spin_unlock_irqrestore(&ab
->event_lock
, flags
);
1192 schedule_work(&ab
->mask_work
);
1195 static void noop(unsigned int irq
)
1199 static struct irq_chip ab3550_irq_chip
= {
1200 .name
= "ab3550-core", /* Keep the same name as the request */
1201 .startup
= NULL
, /* defaults to enable */
1202 .shutdown
= NULL
, /* defaults to disable */
1203 .enable
= NULL
, /* defaults to unmask */
1204 .disable
= ab3550_mask
, /* No default to mask in chip.c */
1206 .mask
= ab3550_mask
,
1207 .unmask
= ab3550_unmask
,
1211 struct ab_family_id
{
1216 static const struct ab_family_id ids
[] __initdata
= {
1228 static int __init
ab3550_probe(struct i2c_client
*client
,
1229 const struct i2c_device_id
*id
)
1232 struct ab3550_platform_data
*ab3550_plf_data
=
1233 client
->dev
.platform_data
;
1236 int num_i2c_clients
= 0;
1238 ab
= kzalloc(sizeof(struct ab3550
), GFP_KERNEL
);
1240 dev_err(&client
->dev
,
1241 "could not allocate " AB3550_NAME_STRING
" device\n");
1245 /* Initialize data structure */
1246 mutex_init(&ab
->access_mutex
);
1247 spin_lock_init(&ab
->event_lock
);
1248 ab
->i2c_client
[0] = client
;
1250 i2c_set_clientdata(client
, ab
);
1252 /* Read chip ID register */
1253 err
= get_register_interruptible(ab
, 0, AB3550_CID_REG
, &ab
->chip_id
);
1255 dev_err(&client
->dev
, "could not communicate with the analog "
1257 goto exit_no_detect
;
1260 for (i
= 0; ids
[i
].id
!= 0x0; i
++) {
1261 if (ids
[i
].id
== ab
->chip_id
) {
1262 snprintf(&ab
->chip_name
[0], sizeof(ab
->chip_name
) - 1,
1263 AB3550_ID_FORMAT_STRING
, ids
[i
].name
);
1268 if (ids
[i
].id
== 0x0) {
1269 dev_err(&client
->dev
, "unknown analog baseband chip id: 0x%x\n",
1271 dev_err(&client
->dev
, "driver not started!\n");
1272 goto exit_no_detect
;
1275 dev_info(&client
->dev
, "detected AB chip: %s\n", &ab
->chip_name
[0]);
1277 /* Attach other dummy I2C clients. */
1278 while (++num_i2c_clients
< AB3550_NUM_BANKS
) {
1279 ab
->i2c_client
[num_i2c_clients
] =
1280 i2c_new_dummy(client
->adapter
,
1281 (client
->addr
+ num_i2c_clients
));
1282 if (!ab
->i2c_client
[num_i2c_clients
]) {
1284 goto exit_no_dummy_client
;
1286 strlcpy(ab
->i2c_client
[num_i2c_clients
]->name
, id
->name
,
1287 sizeof(ab
->i2c_client
[num_i2c_clients
]->name
));
1290 err
= ab3550_setup(ab
);
1294 INIT_WORK(&ab
->mask_work
, ab3550_mask_work
);
1296 for (i
= 0; i
< ab3550_plf_data
->irq
.count
; i
++) {
1299 irq
= ab3550_plf_data
->irq
.base
+ i
;
1300 set_irq_chip_data(irq
, ab
);
1301 set_irq_chip_and_handler(irq
, &ab3550_irq_chip
,
1303 set_irq_nested_thread(irq
, 1);
1305 set_irq_flags(irq
, IRQF_VALID
);
1307 set_irq_noprobe(irq
);
1311 err
= request_threaded_irq(client
->irq
, NULL
, ab3550_irq_handler
,
1312 IRQF_ONESHOT
, "ab3550-core", ab
);
1313 /* This real unpredictable IRQ is of course sampled for entropy */
1314 rand_initialize_irq(client
->irq
);
1319 err
= abx500_register_ops(&client
->dev
, &ab3550_ops
);
1323 /* Set up and register the platform devices. */
1324 for (i
= 0; i
< AB3550_NUM_DEVICES
; i
++) {
1325 ab3550_devs
[i
].platform_data
= ab3550_plf_data
->dev_data
[i
];
1326 ab3550_devs
[i
].data_size
= ab3550_plf_data
->dev_data_sz
[i
];
1329 err
= mfd_add_devices(&client
->dev
, 0, ab3550_devs
,
1330 ARRAY_SIZE(ab3550_devs
), NULL
,
1331 ab3550_plf_data
->irq
.base
);
1333 ab3550_setup_debugfs(ab
);
1340 exit_no_dummy_client
:
1341 /* Unregister the dummy i2c clients. */
1342 while (--num_i2c_clients
)
1343 i2c_unregister_device(ab
->i2c_client
[num_i2c_clients
]);
1349 static int __exit
ab3550_remove(struct i2c_client
*client
)
1351 struct ab3550
*ab
= i2c_get_clientdata(client
);
1352 int num_i2c_clients
= AB3550_NUM_BANKS
;
1354 mfd_remove_devices(&client
->dev
);
1355 ab3550_remove_debugfs();
1357 while (--num_i2c_clients
)
1358 i2c_unregister_device(ab
->i2c_client
[num_i2c_clients
]);
1361 * At this point, all subscribers should have unregistered
1362 * their notifiers so deactivate IRQ
1364 free_irq(client
->irq
, ab
);
1369 static const struct i2c_device_id ab3550_id
[] = {
1370 {AB3550_NAME_STRING
, 0},
1373 MODULE_DEVICE_TABLE(i2c
, ab3550_id
);
1375 static struct i2c_driver ab3550_driver
= {
1377 .name
= AB3550_NAME_STRING
,
1378 .owner
= THIS_MODULE
,
1380 .id_table
= ab3550_id
,
1381 .probe
= ab3550_probe
,
1382 .remove
= __exit_p(ab3550_remove
),
1385 static int __init
ab3550_i2c_init(void)
1387 return i2c_add_driver(&ab3550_driver
);
1390 static void __exit
ab3550_i2c_exit(void)
1392 i2c_del_driver(&ab3550_driver
);
1395 subsys_initcall(ab3550_i2c_init
);
1396 module_exit(ab3550_i2c_exit
);
1398 MODULE_AUTHOR("Mattias Wallin <mattias.wallin@stericsson.com>");
1399 MODULE_DESCRIPTION("AB3550 core driver");
1400 MODULE_LICENSE("GPL");