/* FIXME driver should be able to handle IRQs... */ struct mcp23s08_chip_info { bool is_present; /* true iff populated */ u8 pullups; /* BIT(x) means enable pullup x */ }; struct mcp23s08_platform_data { /* Four slaves (numbered 0..3) can share one SPI chipselect, and * will provide 8..32 GPIOs using 1..4 gpio_chip instances. */ struct mcp23s08_chip_info chip[4]; /* "base" is the number of the first GPIO. Dynamic assignment is * not currently supported, and even if there are gaps in chip * addressing the GPIO numbers are sequential .. so for example * if only slaves 0 and 3 are present, their GPIOs range from * base to base+15. */ unsigned base; void *context; /* param to setup/teardown */ int (*setup)(struct spi_device *spi, int gpio, unsigned ngpio, void *context); int (*teardown)(struct spi_device *spi, int gpio, unsigned ngpio, void *context); };