2 * MCP23S08 SPI/I2C GPIO gpio expander driver
4 * The inputs and outputs of the mcp23s08, mcp23s17, mcp23008 and mcp23017 are
6 * For the I2C versions of the chips (mcp23008 and mcp23017) generation of
7 * interrupts is also supported.
8 * The hardware of the SPI versions of the chips (mcp23s08 and mcp23s17) is
9 * also capable of generating interrupts, but the linux driver does not
13 #include <linux/kernel.h>
14 #include <linux/device.h>
15 #include <linux/mutex.h>
16 #include <linux/module.h>
17 #include <linux/gpio.h>
18 #include <linux/i2c.h>
19 #include <linux/spi/spi.h>
20 #include <linux/spi/mcp23s08.h>
21 #include <linux/slab.h>
22 #include <asm/byteorder.h>
23 #include <linux/interrupt.h>
24 #include <linux/of_irq.h>
25 #include <linux/of_device.h>
28 * MCP types supported by driver
30 #define MCP_TYPE_S08 0
31 #define MCP_TYPE_S17 1
32 #define MCP_TYPE_008 2
33 #define MCP_TYPE_017 3
34 #define MCP_TYPE_S18 4
36 /* Registers are all 8 bits wide.
38 * The mcp23s17 has twice as many bits, and can be configured to work
39 * with either 16 bit registers or with two adjacent 8 bit banks.
41 #define MCP_IODIR 0x00 /* init/reset: all ones */
43 #define MCP_GPINTEN 0x02
44 #define MCP_DEFVAL 0x03
45 #define MCP_INTCON 0x04
46 #define MCP_IOCON 0x05
47 # define IOCON_MIRROR (1 << 6)
48 # define IOCON_SEQOP (1 << 5)
49 # define IOCON_HAEN (1 << 3)
50 # define IOCON_ODR (1 << 2)
51 # define IOCON_INTPOL (1 << 1)
52 # define IOCON_INTCC (1)
55 #define MCP_INTCAP 0x08
62 int (*read
)(struct mcp23s08
*mcp
, unsigned reg
);
63 int (*write
)(struct mcp23s08
*mcp
, unsigned reg
, unsigned val
);
64 int (*read_regs
)(struct mcp23s08
*mcp
, unsigned reg
,
65 u16
*vals
, unsigned n
);
77 /* lock protects the cached values */
79 struct mutex irq_lock
;
81 struct gpio_chip chip
;
83 const struct mcp23s08_ops
*ops
;
84 void *data
; /* ops specific data */
87 /* A given spi_device can represent up to eight mcp23sxx chips
88 * sharing the same chipselect but using different addresses
89 * (e.g. chips #0 and #3 might be populated, but not #1 or $2).
90 * Driver data holds all the per-chip data.
92 struct mcp23s08_driver_data
{
94 struct mcp23s08
*mcp
[8];
95 struct mcp23s08 chip
[];
98 /*----------------------------------------------------------------------*/
100 #if IS_ENABLED(CONFIG_I2C)
102 static int mcp23008_read(struct mcp23s08
*mcp
, unsigned reg
)
104 return i2c_smbus_read_byte_data(mcp
->data
, reg
);
107 static int mcp23008_write(struct mcp23s08
*mcp
, unsigned reg
, unsigned val
)
109 return i2c_smbus_write_byte_data(mcp
->data
, reg
, val
);
113 mcp23008_read_regs(struct mcp23s08
*mcp
, unsigned reg
, u16
*vals
, unsigned n
)
116 int ret
= mcp23008_read(mcp
, reg
++);
125 static int mcp23017_read(struct mcp23s08
*mcp
, unsigned reg
)
127 return i2c_smbus_read_word_data(mcp
->data
, reg
<< 1);
130 static int mcp23017_write(struct mcp23s08
*mcp
, unsigned reg
, unsigned val
)
132 return i2c_smbus_write_word_data(mcp
->data
, reg
<< 1, val
);
136 mcp23017_read_regs(struct mcp23s08
*mcp
, unsigned reg
, u16
*vals
, unsigned n
)
139 int ret
= mcp23017_read(mcp
, reg
++);
148 static const struct mcp23s08_ops mcp23008_ops
= {
149 .read
= mcp23008_read
,
150 .write
= mcp23008_write
,
151 .read_regs
= mcp23008_read_regs
,
154 static const struct mcp23s08_ops mcp23017_ops
= {
155 .read
= mcp23017_read
,
156 .write
= mcp23017_write
,
157 .read_regs
= mcp23017_read_regs
,
160 #endif /* CONFIG_I2C */
162 /*----------------------------------------------------------------------*/
164 #ifdef CONFIG_SPI_MASTER
166 static int mcp23s08_read(struct mcp23s08
*mcp
, unsigned reg
)
171 tx
[0] = mcp
->addr
| 0x01;
173 status
= spi_write_then_read(mcp
->data
, tx
, sizeof(tx
), rx
, sizeof(rx
));
174 return (status
< 0) ? status
: rx
[0];
177 static int mcp23s08_write(struct mcp23s08
*mcp
, unsigned reg
, unsigned val
)
184 return spi_write_then_read(mcp
->data
, tx
, sizeof(tx
), NULL
, 0);
188 mcp23s08_read_regs(struct mcp23s08
*mcp
, unsigned reg
, u16
*vals
, unsigned n
)
193 if ((n
+ reg
) > sizeof(mcp
->cache
))
195 tx
[0] = mcp
->addr
| 0x01;
199 status
= spi_write_then_read(mcp
->data
, tx
, sizeof(tx
), tmp
, n
);
202 vals
[n
] = tmp
[n
]; /* expand to 16bit */
207 static int mcp23s17_read(struct mcp23s08
*mcp
, unsigned reg
)
212 tx
[0] = mcp
->addr
| 0x01;
214 status
= spi_write_then_read(mcp
->data
, tx
, sizeof(tx
), rx
, sizeof(rx
));
215 return (status
< 0) ? status
: (rx
[0] | (rx
[1] << 8));
218 static int mcp23s17_write(struct mcp23s08
*mcp
, unsigned reg
, unsigned val
)
226 return spi_write_then_read(mcp
->data
, tx
, sizeof(tx
), NULL
, 0);
230 mcp23s17_read_regs(struct mcp23s08
*mcp
, unsigned reg
, u16
*vals
, unsigned n
)
235 if ((n
+ reg
) > sizeof(mcp
->cache
))
237 tx
[0] = mcp
->addr
| 0x01;
240 status
= spi_write_then_read(mcp
->data
, tx
, sizeof(tx
),
244 vals
[n
] = __le16_to_cpu((__le16
)vals
[n
]);
250 static const struct mcp23s08_ops mcp23s08_ops
= {
251 .read
= mcp23s08_read
,
252 .write
= mcp23s08_write
,
253 .read_regs
= mcp23s08_read_regs
,
256 static const struct mcp23s08_ops mcp23s17_ops
= {
257 .read
= mcp23s17_read
,
258 .write
= mcp23s17_write
,
259 .read_regs
= mcp23s17_read_regs
,
262 #endif /* CONFIG_SPI_MASTER */
264 /*----------------------------------------------------------------------*/
266 static int mcp23s08_direction_input(struct gpio_chip
*chip
, unsigned offset
)
268 struct mcp23s08
*mcp
= gpiochip_get_data(chip
);
271 mutex_lock(&mcp
->lock
);
272 mcp
->cache
[MCP_IODIR
] |= (1 << offset
);
273 status
= mcp
->ops
->write(mcp
, MCP_IODIR
, mcp
->cache
[MCP_IODIR
]);
274 mutex_unlock(&mcp
->lock
);
278 static int mcp23s08_get(struct gpio_chip
*chip
, unsigned offset
)
280 struct mcp23s08
*mcp
= gpiochip_get_data(chip
);
283 mutex_lock(&mcp
->lock
);
285 /* REVISIT reading this clears any IRQ ... */
286 status
= mcp
->ops
->read(mcp
, MCP_GPIO
);
290 mcp
->cache
[MCP_GPIO
] = status
;
291 status
= !!(status
& (1 << offset
));
293 mutex_unlock(&mcp
->lock
);
297 static int __mcp23s08_set(struct mcp23s08
*mcp
, unsigned mask
, int value
)
299 unsigned olat
= mcp
->cache
[MCP_OLAT
];
305 mcp
->cache
[MCP_OLAT
] = olat
;
306 return mcp
->ops
->write(mcp
, MCP_OLAT
, olat
);
309 static void mcp23s08_set(struct gpio_chip
*chip
, unsigned offset
, int value
)
311 struct mcp23s08
*mcp
= gpiochip_get_data(chip
);
312 unsigned mask
= 1 << offset
;
314 mutex_lock(&mcp
->lock
);
315 __mcp23s08_set(mcp
, mask
, value
);
316 mutex_unlock(&mcp
->lock
);
320 mcp23s08_direction_output(struct gpio_chip
*chip
, unsigned offset
, int value
)
322 struct mcp23s08
*mcp
= gpiochip_get_data(chip
);
323 unsigned mask
= 1 << offset
;
326 mutex_lock(&mcp
->lock
);
327 status
= __mcp23s08_set(mcp
, mask
, value
);
329 mcp
->cache
[MCP_IODIR
] &= ~mask
;
330 status
= mcp
->ops
->write(mcp
, MCP_IODIR
, mcp
->cache
[MCP_IODIR
]);
332 mutex_unlock(&mcp
->lock
);
336 /*----------------------------------------------------------------------*/
337 static irqreturn_t
mcp23s08_irq(int irq
, void *data
)
339 struct mcp23s08
*mcp
= data
;
341 unsigned int child_irq
;
343 mutex_lock(&mcp
->lock
);
344 intf
= mcp
->ops
->read(mcp
, MCP_INTF
);
346 mutex_unlock(&mcp
->lock
);
350 mcp
->cache
[MCP_INTF
] = intf
;
352 intcap
= mcp
->ops
->read(mcp
, MCP_INTCAP
);
354 mutex_unlock(&mcp
->lock
);
358 mcp
->cache
[MCP_INTCAP
] = intcap
;
359 mutex_unlock(&mcp
->lock
);
362 for (i
= 0; i
< mcp
->chip
.ngpio
; i
++) {
363 if ((BIT(i
) & mcp
->cache
[MCP_INTF
]) &&
364 ((BIT(i
) & intcap
& mcp
->irq_rise
) ||
365 (mcp
->irq_fall
& ~intcap
& BIT(i
)) ||
366 (BIT(i
) & mcp
->cache
[MCP_INTCON
]))) {
367 child_irq
= irq_find_mapping(mcp
->chip
.irqdomain
, i
);
368 handle_nested_irq(child_irq
);
375 static void mcp23s08_irq_mask(struct irq_data
*data
)
377 struct gpio_chip
*gc
= irq_data_get_irq_chip_data(data
);
378 struct mcp23s08
*mcp
= gpiochip_get_data(gc
);
379 unsigned int pos
= data
->hwirq
;
381 mcp
->cache
[MCP_GPINTEN
] &= ~BIT(pos
);
384 static void mcp23s08_irq_unmask(struct irq_data
*data
)
386 struct gpio_chip
*gc
= irq_data_get_irq_chip_data(data
);
387 struct mcp23s08
*mcp
= gpiochip_get_data(gc
);
388 unsigned int pos
= data
->hwirq
;
390 mcp
->cache
[MCP_GPINTEN
] |= BIT(pos
);
393 static int mcp23s08_irq_set_type(struct irq_data
*data
, unsigned int type
)
395 struct gpio_chip
*gc
= irq_data_get_irq_chip_data(data
);
396 struct mcp23s08
*mcp
= gpiochip_get_data(gc
);
397 unsigned int pos
= data
->hwirq
;
400 if ((type
& IRQ_TYPE_EDGE_BOTH
) == IRQ_TYPE_EDGE_BOTH
) {
401 mcp
->cache
[MCP_INTCON
] &= ~BIT(pos
);
402 mcp
->irq_rise
|= BIT(pos
);
403 mcp
->irq_fall
|= BIT(pos
);
404 } else if (type
& IRQ_TYPE_EDGE_RISING
) {
405 mcp
->cache
[MCP_INTCON
] &= ~BIT(pos
);
406 mcp
->irq_rise
|= BIT(pos
);
407 mcp
->irq_fall
&= ~BIT(pos
);
408 } else if (type
& IRQ_TYPE_EDGE_FALLING
) {
409 mcp
->cache
[MCP_INTCON
] &= ~BIT(pos
);
410 mcp
->irq_rise
&= ~BIT(pos
);
411 mcp
->irq_fall
|= BIT(pos
);
412 } else if (type
& IRQ_TYPE_LEVEL_HIGH
) {
413 mcp
->cache
[MCP_INTCON
] |= BIT(pos
);
414 mcp
->cache
[MCP_DEFVAL
] &= ~BIT(pos
);
415 } else if (type
& IRQ_TYPE_LEVEL_LOW
) {
416 mcp
->cache
[MCP_INTCON
] |= BIT(pos
);
417 mcp
->cache
[MCP_DEFVAL
] |= BIT(pos
);
424 static void mcp23s08_irq_bus_lock(struct irq_data
*data
)
426 struct gpio_chip
*gc
= irq_data_get_irq_chip_data(data
);
427 struct mcp23s08
*mcp
= gpiochip_get_data(gc
);
429 mutex_lock(&mcp
->irq_lock
);
432 static void mcp23s08_irq_bus_unlock(struct irq_data
*data
)
434 struct gpio_chip
*gc
= irq_data_get_irq_chip_data(data
);
435 struct mcp23s08
*mcp
= gpiochip_get_data(gc
);
437 mutex_lock(&mcp
->lock
);
438 mcp
->ops
->write(mcp
, MCP_GPINTEN
, mcp
->cache
[MCP_GPINTEN
]);
439 mcp
->ops
->write(mcp
, MCP_DEFVAL
, mcp
->cache
[MCP_DEFVAL
]);
440 mcp
->ops
->write(mcp
, MCP_INTCON
, mcp
->cache
[MCP_INTCON
]);
441 mutex_unlock(&mcp
->lock
);
442 mutex_unlock(&mcp
->irq_lock
);
445 static struct irq_chip mcp23s08_irq_chip
= {
446 .name
= "gpio-mcp23xxx",
447 .irq_mask
= mcp23s08_irq_mask
,
448 .irq_unmask
= mcp23s08_irq_unmask
,
449 .irq_set_type
= mcp23s08_irq_set_type
,
450 .irq_bus_lock
= mcp23s08_irq_bus_lock
,
451 .irq_bus_sync_unlock
= mcp23s08_irq_bus_unlock
,
454 static int mcp23s08_irq_setup(struct mcp23s08
*mcp
)
456 struct gpio_chip
*chip
= &mcp
->chip
;
458 unsigned long irqflags
= IRQF_ONESHOT
| IRQF_SHARED
;
460 mutex_init(&mcp
->irq_lock
);
462 if (mcp
->irq_active_high
)
463 irqflags
|= IRQF_TRIGGER_HIGH
;
465 irqflags
|= IRQF_TRIGGER_LOW
;
467 err
= devm_request_threaded_irq(chip
->parent
, mcp
->irq
, NULL
,
469 irqflags
, dev_name(chip
->parent
), mcp
);
471 dev_err(chip
->parent
, "unable to request IRQ#%d: %d\n",
476 err
= gpiochip_irqchip_add_nested(chip
,
482 dev_err(chip
->parent
,
483 "could not connect irqchip to gpiochip: %d\n", err
);
487 gpiochip_set_nested_irqchip(chip
,
494 /*----------------------------------------------------------------------*/
496 #ifdef CONFIG_DEBUG_FS
498 #include <linux/seq_file.h>
501 * This shows more info than the generic gpio dump code:
502 * pullups, deglitching, open drain drive.
504 static void mcp23s08_dbg_show(struct seq_file
*s
, struct gpio_chip
*chip
)
506 struct mcp23s08
*mcp
;
511 mcp
= gpiochip_get_data(chip
);
513 /* NOTE: we only handle one bank for now ... */
514 bank
= '0' + ((mcp
->addr
>> 1) & 0x7);
516 mutex_lock(&mcp
->lock
);
517 t
= mcp
->ops
->read_regs(mcp
, 0, mcp
->cache
, ARRAY_SIZE(mcp
->cache
));
519 seq_printf(s
, " I/O ERROR %d\n", t
);
523 for (t
= 0, mask
= 1; t
< chip
->ngpio
; t
++, mask
<<= 1) {
526 label
= gpiochip_is_requested(chip
, t
);
530 seq_printf(s
, " gpio-%-3d P%c.%d (%-12s) %s %s %s",
531 chip
->base
+ t
, bank
, t
, label
,
532 (mcp
->cache
[MCP_IODIR
] & mask
) ? "in " : "out",
533 (mcp
->cache
[MCP_GPIO
] & mask
) ? "hi" : "lo",
534 (mcp
->cache
[MCP_GPPU
] & mask
) ? "up" : " ");
535 /* NOTE: ignoring the irq-related registers */
539 mutex_unlock(&mcp
->lock
);
543 #define mcp23s08_dbg_show NULL
546 /*----------------------------------------------------------------------*/
548 static int mcp23s08_probe_one(struct mcp23s08
*mcp
, struct device
*dev
,
549 void *data
, unsigned addr
, unsigned type
,
550 struct mcp23s08_platform_data
*pdata
, int cs
)
555 mutex_init(&mcp
->lock
);
559 mcp
->irq_active_high
= false;
561 mcp
->chip
.direction_input
= mcp23s08_direction_input
;
562 mcp
->chip
.get
= mcp23s08_get
;
563 mcp
->chip
.direction_output
= mcp23s08_direction_output
;
564 mcp
->chip
.set
= mcp23s08_set
;
565 mcp
->chip
.dbg_show
= mcp23s08_dbg_show
;
566 #ifdef CONFIG_OF_GPIO
567 mcp
->chip
.of_gpio_n_cells
= 2;
568 mcp
->chip
.of_node
= dev
->of_node
;
572 #ifdef CONFIG_SPI_MASTER
574 mcp
->ops
= &mcp23s08_ops
;
576 mcp
->chip
.label
= "mcp23s08";
580 mcp
->ops
= &mcp23s17_ops
;
581 mcp
->chip
.ngpio
= 16;
582 mcp
->chip
.label
= "mcp23s17";
586 mcp
->ops
= &mcp23s17_ops
;
587 mcp
->chip
.ngpio
= 16;
588 mcp
->chip
.label
= "mcp23s18";
590 #endif /* CONFIG_SPI_MASTER */
592 #if IS_ENABLED(CONFIG_I2C)
594 mcp
->ops
= &mcp23008_ops
;
596 mcp
->chip
.label
= "mcp23008";
600 mcp
->ops
= &mcp23017_ops
;
601 mcp
->chip
.ngpio
= 16;
602 mcp
->chip
.label
= "mcp23017";
604 #endif /* CONFIG_I2C */
607 dev_err(dev
, "invalid device type (%d)\n", type
);
611 mcp
->chip
.base
= pdata
->base
;
612 mcp
->chip
.can_sleep
= true;
613 mcp
->chip
.parent
= dev
;
614 mcp
->chip
.owner
= THIS_MODULE
;
616 /* verify MCP_IOCON.SEQOP = 0, so sequential reads work,
617 * and MCP_IOCON.HAEN = 1, so we work with all chips.
620 status
= mcp
->ops
->read(mcp
, MCP_IOCON
);
624 mcp
->irq_controller
= pdata
->irq_controller
;
625 if (mcp
->irq
&& mcp
->irq_controller
) {
626 mcp
->irq_active_high
=
627 of_property_read_bool(mcp
->chip
.parent
->of_node
,
628 "microchip,irq-active-high");
630 mirror
= pdata
->mirror
;
633 if ((status
& IOCON_SEQOP
) || !(status
& IOCON_HAEN
) || mirror
||
634 mcp
->irq_active_high
) {
635 /* mcp23s17 has IOCON twice, make sure they are in sync */
636 status
&= ~(IOCON_SEQOP
| (IOCON_SEQOP
<< 8));
637 status
|= IOCON_HAEN
| (IOCON_HAEN
<< 8);
638 if (mcp
->irq_active_high
)
639 status
|= IOCON_INTPOL
| (IOCON_INTPOL
<< 8);
641 status
&= ~(IOCON_INTPOL
| (IOCON_INTPOL
<< 8));
644 status
|= IOCON_MIRROR
| (IOCON_MIRROR
<< 8);
646 if (type
== MCP_TYPE_S18
)
647 status
|= IOCON_INTCC
| (IOCON_INTCC
<< 8);
649 status
= mcp
->ops
->write(mcp
, MCP_IOCON
, status
);
654 /* configure ~100K pullups */
655 status
= mcp
->ops
->write(mcp
, MCP_GPPU
, pdata
->chip
[cs
].pullups
);
659 status
= mcp
->ops
->read_regs(mcp
, 0, mcp
->cache
, ARRAY_SIZE(mcp
->cache
));
663 /* disable inverter on input */
664 if (mcp
->cache
[MCP_IPOL
] != 0) {
665 mcp
->cache
[MCP_IPOL
] = 0;
666 status
= mcp
->ops
->write(mcp
, MCP_IPOL
, 0);
672 if (mcp
->cache
[MCP_GPINTEN
] != 0) {
673 mcp
->cache
[MCP_GPINTEN
] = 0;
674 status
= mcp
->ops
->write(mcp
, MCP_GPINTEN
, 0);
679 status
= gpiochip_add_data(&mcp
->chip
, mcp
);
683 if (mcp
->irq
&& mcp
->irq_controller
) {
684 status
= mcp23s08_irq_setup(mcp
);
691 dev_dbg(dev
, "can't setup chip %d, --> %d\n",
696 /*----------------------------------------------------------------------*/
699 #ifdef CONFIG_SPI_MASTER
700 static const struct of_device_id mcp23s08_spi_of_match
[] = {
702 .compatible
= "microchip,mcp23s08",
703 .data
= (void *) MCP_TYPE_S08
,
706 .compatible
= "microchip,mcp23s17",
707 .data
= (void *) MCP_TYPE_S17
,
710 .compatible
= "microchip,mcp23s18",
711 .data
= (void *) MCP_TYPE_S18
,
713 /* NOTE: The use of the mcp prefix is deprecated and will be removed. */
715 .compatible
= "mcp,mcp23s08",
716 .data
= (void *) MCP_TYPE_S08
,
719 .compatible
= "mcp,mcp23s17",
720 .data
= (void *) MCP_TYPE_S17
,
724 MODULE_DEVICE_TABLE(of
, mcp23s08_spi_of_match
);
727 #if IS_ENABLED(CONFIG_I2C)
728 static const struct of_device_id mcp23s08_i2c_of_match
[] = {
730 .compatible
= "microchip,mcp23008",
731 .data
= (void *) MCP_TYPE_008
,
734 .compatible
= "microchip,mcp23017",
735 .data
= (void *) MCP_TYPE_017
,
737 /* NOTE: The use of the mcp prefix is deprecated and will be removed. */
739 .compatible
= "mcp,mcp23008",
740 .data
= (void *) MCP_TYPE_008
,
743 .compatible
= "mcp,mcp23017",
744 .data
= (void *) MCP_TYPE_017
,
748 MODULE_DEVICE_TABLE(of
, mcp23s08_i2c_of_match
);
750 #endif /* CONFIG_OF */
753 #if IS_ENABLED(CONFIG_I2C)
755 static int mcp230xx_probe(struct i2c_client
*client
,
756 const struct i2c_device_id
*id
)
758 struct mcp23s08_platform_data
*pdata
, local_pdata
;
759 struct mcp23s08
*mcp
;
761 const struct of_device_id
*match
;
763 match
= of_match_device(of_match_ptr(mcp23s08_i2c_of_match
),
766 pdata
= &local_pdata
;
768 pdata
->chip
[0].pullups
= 0;
769 pdata
->irq_controller
= of_property_read_bool(
771 "interrupt-controller");
772 pdata
->mirror
= of_property_read_bool(client
->dev
.of_node
,
773 "microchip,irq-mirror");
774 client
->irq
= irq_of_parse_and_map(client
->dev
.of_node
, 0);
776 pdata
= dev_get_platdata(&client
->dev
);
778 pdata
= devm_kzalloc(&client
->dev
,
779 sizeof(struct mcp23s08_platform_data
),
787 mcp
= kzalloc(sizeof(*mcp
), GFP_KERNEL
);
791 mcp
->irq
= client
->irq
;
792 status
= mcp23s08_probe_one(mcp
, &client
->dev
, client
, client
->addr
,
793 id
->driver_data
, pdata
, 0);
797 i2c_set_clientdata(client
, mcp
);
807 static int mcp230xx_remove(struct i2c_client
*client
)
809 struct mcp23s08
*mcp
= i2c_get_clientdata(client
);
811 gpiochip_remove(&mcp
->chip
);
817 static const struct i2c_device_id mcp230xx_id
[] = {
818 { "mcp23008", MCP_TYPE_008
},
819 { "mcp23017", MCP_TYPE_017
},
822 MODULE_DEVICE_TABLE(i2c
, mcp230xx_id
);
824 static struct i2c_driver mcp230xx_driver
= {
827 .of_match_table
= of_match_ptr(mcp23s08_i2c_of_match
),
829 .probe
= mcp230xx_probe
,
830 .remove
= mcp230xx_remove
,
831 .id_table
= mcp230xx_id
,
834 static int __init
mcp23s08_i2c_init(void)
836 return i2c_add_driver(&mcp230xx_driver
);
839 static void mcp23s08_i2c_exit(void)
841 i2c_del_driver(&mcp230xx_driver
);
846 static int __init
mcp23s08_i2c_init(void) { return 0; }
847 static void mcp23s08_i2c_exit(void) { }
849 #endif /* CONFIG_I2C */
851 /*----------------------------------------------------------------------*/
853 #ifdef CONFIG_SPI_MASTER
855 static int mcp23s08_probe(struct spi_device
*spi
)
857 struct mcp23s08_platform_data
*pdata
, local_pdata
;
860 struct mcp23s08_driver_data
*data
;
863 const struct of_device_id
*match
;
864 u32 spi_present_mask
= 0;
866 match
= of_match_device(of_match_ptr(mcp23s08_spi_of_match
), &spi
->dev
);
868 type
= (int)(uintptr_t)match
->data
;
869 status
= of_property_read_u32(spi
->dev
.of_node
,
870 "microchip,spi-present-mask", &spi_present_mask
);
872 status
= of_property_read_u32(spi
->dev
.of_node
,
873 "mcp,spi-present-mask", &spi_present_mask
);
876 "DT has no spi-present-mask\n");
880 if ((spi_present_mask
<= 0) || (spi_present_mask
>= 256)) {
881 dev_err(&spi
->dev
, "invalid spi-present-mask\n");
885 pdata
= &local_pdata
;
887 for (addr
= 0; addr
< ARRAY_SIZE(pdata
->chip
); addr
++) {
888 pdata
->chip
[addr
].pullups
= 0;
889 if (spi_present_mask
& (1 << addr
))
892 pdata
->irq_controller
= of_property_read_bool(
894 "interrupt-controller");
895 pdata
->mirror
= of_property_read_bool(spi
->dev
.of_node
,
896 "microchip,irq-mirror");
898 type
= spi_get_device_id(spi
)->driver_data
;
899 pdata
= dev_get_platdata(&spi
->dev
);
901 pdata
= devm_kzalloc(&spi
->dev
,
902 sizeof(struct mcp23s08_platform_data
),
907 for (addr
= 0; addr
< ARRAY_SIZE(pdata
->chip
); addr
++) {
908 if (!pdata
->chip
[addr
].is_present
)
911 if ((type
== MCP_TYPE_S08
) && (addr
> 3)) {
913 "mcp23s08 only supports address 0..3\n");
916 spi_present_mask
|= 1 << addr
;
923 data
= devm_kzalloc(&spi
->dev
,
924 sizeof(*data
) + chips
* sizeof(struct mcp23s08
),
929 spi_set_drvdata(spi
, data
);
931 spi
->irq
= irq_of_parse_and_map(spi
->dev
.of_node
, 0);
933 for (addr
= 0; addr
< ARRAY_SIZE(pdata
->chip
); addr
++) {
934 if (!(spi_present_mask
& (1 << addr
)))
937 data
->mcp
[addr
] = &data
->chip
[chips
];
938 data
->mcp
[addr
]->irq
= spi
->irq
;
939 status
= mcp23s08_probe_one(data
->mcp
[addr
], &spi
->dev
, spi
,
940 0x40 | (addr
<< 1), type
, pdata
,
945 if (pdata
->base
!= -1)
946 pdata
->base
+= data
->mcp
[addr
]->chip
.ngpio
;
947 ngpio
+= data
->mcp
[addr
]->chip
.ngpio
;
951 /* NOTE: these chips have a relatively sane IRQ framework, with
952 * per-signal masking and level/edge triggering. It's not yet
959 for (addr
= 0; addr
< ARRAY_SIZE(data
->mcp
); addr
++) {
961 if (!data
->mcp
[addr
])
963 gpiochip_remove(&data
->mcp
[addr
]->chip
);
968 static int mcp23s08_remove(struct spi_device
*spi
)
970 struct mcp23s08_driver_data
*data
= spi_get_drvdata(spi
);
973 for (addr
= 0; addr
< ARRAY_SIZE(data
->mcp
); addr
++) {
975 if (!data
->mcp
[addr
])
978 gpiochip_remove(&data
->mcp
[addr
]->chip
);
984 static const struct spi_device_id mcp23s08_ids
[] = {
985 { "mcp23s08", MCP_TYPE_S08
},
986 { "mcp23s17", MCP_TYPE_S17
},
987 { "mcp23s18", MCP_TYPE_S18
},
990 MODULE_DEVICE_TABLE(spi
, mcp23s08_ids
);
992 static struct spi_driver mcp23s08_driver
= {
993 .probe
= mcp23s08_probe
,
994 .remove
= mcp23s08_remove
,
995 .id_table
= mcp23s08_ids
,
998 .of_match_table
= of_match_ptr(mcp23s08_spi_of_match
),
1002 static int __init
mcp23s08_spi_init(void)
1004 return spi_register_driver(&mcp23s08_driver
);
1007 static void mcp23s08_spi_exit(void)
1009 spi_unregister_driver(&mcp23s08_driver
);
1014 static int __init
mcp23s08_spi_init(void) { return 0; }
1015 static void mcp23s08_spi_exit(void) { }
1017 #endif /* CONFIG_SPI_MASTER */
1019 /*----------------------------------------------------------------------*/
1021 static int __init
mcp23s08_init(void)
1025 ret
= mcp23s08_spi_init();
1029 ret
= mcp23s08_i2c_init();
1036 mcp23s08_spi_exit();
1040 /* register after spi/i2c postcore initcall and before
1041 * subsys initcalls that may rely on these GPIOs
1043 subsys_initcall(mcp23s08_init
);
1045 static void __exit
mcp23s08_exit(void)
1047 mcp23s08_spi_exit();
1048 mcp23s08_i2c_exit();
1050 module_exit(mcp23s08_exit
);
1052 MODULE_LICENSE("GPL");