/* $NetBSD: mcp23xxxgpiovar.h,v 1.2 2022/01/17 19:36:54 thorpej Exp $ */ /*- * Copyright (c) 2014, 2022 The NetBSD Foundation, Inc. * All rights reserved. * * This code is derived from software contributed to The NetBSD Foundation * by Frank Kardel, and by Jason R. Thorpe. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #ifndef _DEV_IC_MCP23xxxGPIOVAR_H_ #define _DEV_IC_MCP23xxxGPIOVAR_H_ /* * Driver for Microchip serial I/O expansers: * * MCP23008 8-bit, I2C interface * MCP23S08 8-bit, SPI interface * MCP23017 16-bit, I2C interface * MCP23S17 16-bit, SPI interface * MCP23018 16-bit (open-drain outputs), I2C interface * MCP23S18 16-bit (open-drain outputs), SPI interface * * Data sheet: * * https://ww1.microchip.com/downloads/en/DeviceDoc/20001952C.pdf */ #include <sys/gpio.h> #include <dev/gpio/gpiovar.h> struct mcpgpio_softc; typedef enum { MCPGPIO_TYPE_23x08 = 0, MCPGPIO_TYPE_23x17 = 1, MCPGPIO_TYPE_23x18 = 2, } mcpgpio_type; struct mcpgpio_variant { const char *name; mcpgpio_type type; }; struct mcpgpio_accessops { int (*lock)(struct mcpgpio_softc *); void (*unlock)(struct mcpgpio_softc *); int (*read)(struct mcpgpio_softc *, unsigned int, uint8_t, uint8_t *); int (*write)(struct mcpgpio_softc *, unsigned int, uint8_t, uint8_t); }; struct mcpgpio_softc { device_t sc_dev; const struct mcpgpio_variant *sc_variant; struct gpio_chipset_tag sc_gpio_gc; gpio_pin_t *sc_gpio_pins; unsigned int sc_npins; uint8_t sc_iocon; /* I/O configuration */ /* Bus-specific access functions. */ const struct mcpgpio_accessops *sc_accessops; }; void mcpgpio_attach(struct mcpgpio_softc *); #endif /* _DEV_IC_MCP23xxxGPIOVAR_H_ */ |