drivers/gpio/gpio-regmap.c
Source file repositories/reference/linux-study-clean/drivers/gpio/gpio-regmap.c
File Facts
- System
- Linux kernel
- Corpus path
drivers/gpio/gpio-regmap.c- Extension
.c- Size
- 12567 bytes
- Lines
- 487
- Domain
- Driver Families
- Bucket
- drivers/gpio
- Inferred role
- Driver Families: exported/initcall integration point
- Status
- integration implementation candidate
Why This File Exists
Repeatable hardware-adapter layer. Deep compatibility for every driver is out of scope; this atlas records patterns, probe lifecycles, bus glue, IRQ/DMA usage, and links back to core abstractions.
- Repeatable hardware-adapter layer. Deep compatibility for every driver is out of scope; this atlas records patterns, probe lifecycles, bus glue, IRQ/DMA usage, and links back to core abstractions.
- Exports symbols or registers init work; inspect boot/module ordering and who consumes the exported contract.
- Allocates kernel memory; connect allocation flags and lifetime to context constraints.
- Defines or uses C structs; map object ownership, embedded links, reference counts, and lock ownership.
Dependency Surface
linux/bits.hlinux/device.hlinux/err.hlinux/io.hlinux/module.hlinux/regmap.hlinux/slab.hlinux/types.hlinux/gpio/driver.hlinux/gpio/regmap.hgpiolib.h
Detected Declarations
struct gpio_regmapfunction gpio_regmap_addrfunction gpio_regmap_simple_xlatefunction gpio_regmap_getfunction gpio_regmap_setfunction gpio_regmap_set_with_clearfunction gpio_regmap_fixed_directionfunction gpio_regmap_get_directionfunction gpio_regmap_try_direction_fixedfunction gpio_regmap_set_directionfunction gpio_regmap_direction_inputfunction gpio_regmap_direction_outputfunction gpio_regmap_registerfunction gpio_regmap_unregisterfunction devm_gpio_regmap_unregisterfunction devm_gpio_regmap_registerexport gpio_regmap_get_drvdataexport gpio_regmap_registerexport gpio_regmap_unregisterexport devm_gpio_regmap_register
Annotated Snippet
struct gpio_regmap {
struct device *parent;
struct regmap *regmap;
struct gpio_chip gpio_chip;
int reg_stride;
int ngpio_per_reg;
unsigned int reg_dat_base;
unsigned int reg_set_base;
unsigned int reg_clr_base;
unsigned int reg_dir_in_base;
unsigned int reg_dir_out_base;
unsigned long *fixed_direction_mask;
unsigned long *fixed_direction_output;
#ifdef CONFIG_REGMAP_IRQ
int regmap_irq_line;
struct regmap_irq_chip_data *irq_chip_data;
#endif
int (*reg_mask_xlate)(struct gpio_regmap *gpio, unsigned int base,
unsigned int offset, unsigned int *reg,
unsigned int *mask);
void *driver_data;
};
static unsigned int gpio_regmap_addr(unsigned int addr)
{
if (addr == GPIO_REGMAP_ADDR_ZERO)
return 0;
return addr;
}
static int gpio_regmap_simple_xlate(struct gpio_regmap *gpio,
unsigned int base, unsigned int offset,
unsigned int *reg, unsigned int *mask)
{
unsigned int line = offset % gpio->ngpio_per_reg;
unsigned int stride = offset / gpio->ngpio_per_reg;
*reg = base + stride * gpio->reg_stride;
*mask = BIT(line);
return 0;
}
static int gpio_regmap_get(struct gpio_chip *chip, unsigned int offset)
{
struct gpio_regmap *gpio = gpiochip_get_data(chip);
unsigned int base, val, reg, mask;
int ret;
/* we might not have an output register if we are input only */
if (gpio->reg_dat_base)
base = gpio_regmap_addr(gpio->reg_dat_base);
else
base = gpio_regmap_addr(gpio->reg_set_base);
ret = gpio->reg_mask_xlate(gpio, base, offset, ®, &mask);
if (ret)
return ret;
/* ensure we don't spoil any register cache with pin input values */
if (gpio->reg_dat_base == gpio->reg_set_base)
ret = regmap_read_bypassed(gpio->regmap, reg, &val);
else
ret = regmap_read(gpio->regmap, reg, &val);
if (ret)
return ret;
return !!(val & mask);
}
static int gpio_regmap_set(struct gpio_chip *chip, unsigned int offset,
int val)
{
struct gpio_regmap *gpio = gpiochip_get_data(chip);
unsigned int base = gpio_regmap_addr(gpio->reg_set_base);
unsigned int reg, mask, mask_val;
int ret;
ret = gpio->reg_mask_xlate(gpio, base, offset, ®, &mask);
if (ret)
return ret;
if (val)
mask_val = mask;
else
Annotation
- Immediate include surface: `linux/bits.h`, `linux/device.h`, `linux/err.h`, `linux/io.h`, `linux/module.h`, `linux/regmap.h`, `linux/slab.h`, `linux/types.h`.
- Detected declarations: `struct gpio_regmap`, `function gpio_regmap_addr`, `function gpio_regmap_simple_xlate`, `function gpio_regmap_get`, `function gpio_regmap_set`, `function gpio_regmap_set_with_clear`, `function gpio_regmap_fixed_direction`, `function gpio_regmap_get_direction`, `function gpio_regmap_try_direction_fixed`, `function gpio_regmap_set_direction`.
- Atlas domain: Driver Families / drivers/gpio.
- Implementation status: integration implementation candidate.
Implementation Notes
- This generated page is the file-by-file coverage layer; curated subsystem chapters should link here when they synthesize a multi-file control flow.
- Core OS pages should be promoted from atlas-only to deep-reviewed when they explain data structures, invariants, locking, lifecycle, and C implementation snippets.
- Driver-family pages are intentionally pattern-oriented unless they are part of the selected PCIe/NVMe representative device path.