cregit-Linux how code gets into the kernel

Release 4.7 drivers/gpio/gpio-mmio.c

Directory: drivers/gpio
/*
 * Generic driver for memory-mapped GPIO controllers.
 *
 * Copyright 2008 MontaVista Software, Inc.
 * Copyright 2008,2010 Anton Vorontsov <cbouatmailru@gmail.com>
 *
 * This program is free software; you can redistribute  it and/or modify it
 * under  the terms of  the GNU General  Public License as published by the
 * Free Software Foundation;  either version 2 of the  License, or (at your
 * option) any later version.
 *
 * ....``.```~~~~````.`.`.`.`.```````'',,,.........`````......`.......
 * ...``                                                         ```````..
 * ..The simplest form of a GPIO controller that the driver supports is``
 *  `.just a single "data" register, where GPIO state can be read and/or `
 *    `,..written. ,,..``~~~~ .....``.`.`.~~.```.`.........``````.```````
 *        `````````
                                    ___
_/~~|___/~|   . ```~~~~~~       ___/___\___     ,~.`.`.`.`````.~~...,,,,...
__________|~$@~~~        %~    /o*o*o*o*o*o\   .. Implementing such a GPIO .
o        `                     ~~~~\___/~~~~    ` controller in FPGA is ,.`
                                                 `....trivial..'~`.```.```
 *                                                    ```````
 *  .```````~~~~`..`.``.``.
 * .  The driver supports  `...       ,..```.`~~~```````````````....````.``,,
 * .   big-endian notation, just`.  .. A bit more sophisticated controllers ,
 *  . register the device with -be`. .with a pair of set/clear-bit registers ,
 *   `.. suffix.  ```~~`````....`.`   . affecting the data register and the .`
 *     ``.`.``...```                  ```.. output pins are also supported.`
 *                        ^^             `````.`````````.,``~``~``~~``````
 *                                                   .                  ^^
 *   ,..`.`.`...````````````......`.`.`.`.`.`..`.`.`..
 * .. The expectation is that in at least some cases .    ,-~~~-,
 *  .this will be used with roll-your-own ASIC/FPGA .`     \   /
 *  .logic in Verilog or VHDL. ~~~`````````..`````~~`       \ /
 *  ..````````......```````````                             \o_
 *                                                           |
 *                              ^^                          / \
 *
 *           ...`````~~`.....``.`..........``````.`.``.```........``.
 *            `  8, 16, 32 and 64 bits registers are supported, and``.
 *            . the number of GPIOs is determined by the width of   ~
 *             .. the registers. ,............```.`.`..`.`.~~~.`.`.`~
 *               `.......````.```
 */

#include <linux/init.h>
#include <linux/err.h>
#include <linux/bug.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/spinlock.h>
#include <linux/compiler.h>
#include <linux/types.h>
#include <linux/errno.h>
#include <linux/log2.h>
#include <linux/ioport.h>
#include <linux/io.h>
#include <linux/gpio/driver.h>
#include <linux/slab.h>
#include <linux/bitops.h>
#include <linux/platform_device.h>
#include <linux/mod_devicetable.h>


static void bgpio_write8(void __iomem *reg, unsigned long data) { writeb(data, reg); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles1986.36%266.67%
anton vorontsovanton vorontsov313.64%133.33%
Total22100.00%3100.00%


static unsigned long bgpio_read8(void __iomem *reg) { return readb(reg); }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov950.00%133.33%
jamie ilesjamie iles950.00%266.67%
Total18100.00%3100.00%


static void bgpio_write16(void __iomem *reg, unsigned long data) { writew(data, reg); }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov1986.36%133.33%
jamie ilesjamie iles313.64%266.67%
Total22100.00%3100.00%


static unsigned long bgpio_read16(void __iomem *reg) { return readw(reg); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles1583.33%266.67%
anton vorontsovanton vorontsov316.67%133.33%
Total18100.00%3100.00%


static void bgpio_write32(void __iomem *reg, unsigned long data) { writel(data, reg); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles1672.73%266.67%
anton vorontsovanton vorontsov627.27%133.33%
Total22100.00%3100.00%


static unsigned long bgpio_read32(void __iomem *reg) { return readl(reg); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles18100.00%2100.00%
Total18100.00%2100.00%

#if BITS_PER_LONG >= 64
static void bgpio_write64(void __iomem *reg, unsigned long data) { writeq(data, reg); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles1568.18%266.67%
anton vorontsovanton vorontsov731.82%133.33%
Total22100.00%3100.00%


static unsigned long bgpio_read64(void __iomem *reg) { return readq(reg); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles1794.44%266.67%
anton vorontsovanton vorontsov15.56%133.33%
Total18100.00%3100.00%

#endif /* BITS_PER_LONG >= 64 */
static void bgpio_write16be(void __iomem *reg, unsigned long data) { iowrite16be(data, reg); }

Contributors

PersonTokensPropCommitsCommitProp
andreas larssonandreas larsson22100.00%1100.00%
Total22100.00%1100.00%


static unsigned long bgpio_read16be(void __iomem *reg) { return ioread16be(reg); }

Contributors

PersonTokensPropCommitsCommitProp
andreas larssonandreas larsson18100.00%1100.00%
Total18100.00%1100.00%


static void bgpio_write32be(void __iomem *reg, unsigned long data) { iowrite32be(data, reg); }

Contributors

PersonTokensPropCommitsCommitProp
andreas larssonandreas larsson22100.00%1100.00%
Total22100.00%1100.00%


static unsigned long bgpio_read32be(void __iomem *reg) { return ioread32be(reg); }

Contributors

PersonTokensPropCommitsCommitProp
andreas larssonandreas larsson18100.00%1100.00%
Total18100.00%1100.00%


static unsigned long bgpio_pin2mask(struct gpio_chip *gc, unsigned int pin) { return BIT(pin); }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov1359.09%125.00%
linus walleijlinus walleij522.73%250.00%
jamie ilesjamie iles418.18%125.00%
Total22100.00%4100.00%


static unsigned long bgpio_pin2mask_be(struct gpio_chip *gc, unsigned int pin) { return BIT(gc->bgpio_bits - 1 - pin); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles1346.43%125.00%
anton vorontsovanton vorontsov828.57%125.00%
linus walleijlinus walleij725.00%250.00%
Total28100.00%4100.00%


static int bgpio_get_set(struct gpio_chip *gc, unsigned int gpio) { unsigned long pinmask = gc->pin2mask(gc, gpio); if (gc->bgpio_dir & pinmask) return !!(gc->read_reg(gc->reg_set) & pinmask); else return !!(gc->read_reg(gc->reg_dat) & pinmask); }

Contributors

PersonTokensPropCommitsCommitProp
vladimir zapolskiyvladimir zapolskiy5376.81%133.33%
linus walleijlinus walleij1623.19%266.67%
Total69100.00%3100.00%


static int bgpio_get(struct gpio_chip *gc, unsigned int gpio) { return !!(gc->read_reg(gc->reg_dat) & gc->pin2mask(gc, gpio)); }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov2463.16%125.00%
linus walleijlinus walleij821.05%250.00%
jamie ilesjamie iles615.79%125.00%
Total38100.00%4100.00%


static void bgpio_set_none(struct gpio_chip *gc, unsigned int gpio, int val) { }

Contributors

PersonTokensPropCommitsCommitProp
rabin vincentrabin vincent17100.00%1100.00%
Total17100.00%1100.00%


static void bgpio_set(struct gpio_chip *gc, unsigned int gpio, int val) { unsigned long mask = gc->pin2mask(gc, gpio); unsigned long flags; spin_lock_irqsave(&gc->bgpio_lock, flags); if (val) gc->bgpio_data |= mask; else gc->bgpio_data &= ~mask; gc->write_reg(gc->reg_dat, gc->bgpio_data); spin_unlock_irqrestore(&gc->bgpio_lock, flags); }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov6777.91%133.33%
linus walleijlinus walleij1416.28%133.33%
jamie ilesjamie iles55.81%133.33%
Total86100.00%3100.00%


static void bgpio_set_with_clear(struct gpio_chip *gc, unsigned int gpio, int val) { unsigned long mask = gc->pin2mask(gc, gpio); if (val) gc->write_reg(gc->reg_set, mask); else gc->write_reg(gc->reg_clr, mask); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles5289.66%150.00%
linus walleijlinus walleij610.34%150.00%
Total58100.00%2100.00%


static void bgpio_set_set(struct gpio_chip *gc, unsigned int gpio, int val) { unsigned long mask = gc->pin2mask(gc, gpio); unsigned long flags; spin_lock_irqsave(&gc->bgpio_lock, flags); if (val) gc->bgpio_data |= mask; else gc->bgpio_data &= ~mask; gc->write_reg(gc->reg_set, gc->bgpio_data); spin_unlock_irqrestore(&gc->bgpio_lock, flags); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles7283.72%150.00%
linus walleijlinus walleij1416.28%150.00%
Total86100.00%2100.00%


static void bgpio_multiple_get_masks(struct gpio_chip *gc, unsigned long *mask, unsigned long *bits, unsigned long *set_mask, unsigned long *clear_mask) { int i; *set_mask = 0; *clear_mask = 0; for (i = 0; i < gc->bgpio_bits; i++) { if (*mask == 0) break; if (__test_and_clear_bit(i, mask)) { if (test_bit(i, bits)) *set_mask |= gc->pin2mask(gc, i); else *clear_mask |= gc->pin2mask(gc, i); } } }

Contributors

PersonTokensPropCommitsCommitProp
rojhalat ibrahimrojhalat ibrahim10692.98%150.00%
linus walleijlinus walleij87.02%150.00%
Total114100.00%2100.00%


static void bgpio_set_multiple_single_reg(struct gpio_chip *gc, unsigned long *mask, unsigned long *bits, void __iomem *reg) { unsigned long flags; unsigned long set_mask, clear_mask; spin_lock_irqsave(&gc->bgpio_lock, flags); bgpio_multiple_get_masks(gc, mask, bits, &set_mask, &clear_mask); gc->bgpio_data |= set_mask; gc->bgpio_data &= ~clear_mask; gc->write_reg(reg, gc->bgpio_data); spin_unlock_irqrestore(&gc->bgpio_lock, flags); }

Contributors

PersonTokensPropCommitsCommitProp
rojhalat ibrahimrojhalat ibrahim8185.26%150.00%
linus walleijlinus walleij1414.74%150.00%
Total95100.00%2100.00%


static void bgpio_set_multiple(struct gpio_chip *gc, unsigned long *mask, unsigned long *bits) { bgpio_set_multiple_single_reg(gc, mask, bits, gc->reg_dat); }

Contributors

PersonTokensPropCommitsCommitProp
rojhalat ibrahimrojhalat ibrahim3294.12%150.00%
linus walleijlinus walleij25.88%150.00%
Total34100.00%2100.00%


static void bgpio_set_multiple_set(struct gpio_chip *gc, unsigned long *mask, unsigned long *bits) { bgpio_set_multiple_single_reg(gc, mask, bits, gc->reg_set); }

Contributors

PersonTokensPropCommitsCommitProp
rojhalat ibrahimrojhalat ibrahim3294.12%150.00%
linus walleijlinus walleij25.88%150.00%
Total34100.00%2100.00%


static void bgpio_set_multiple_with_clear(struct gpio_chip *gc, unsigned long *mask, unsigned long *bits) { unsigned long set_mask, clear_mask; bgpio_multiple_get_masks(gc, mask, bits, &set_mask, &clear_mask); if (set_mask) gc->write_reg(gc->reg_set, set_mask); if (clear_mask) gc->write_reg(gc->reg_clr, clear_mask); }

Contributors

PersonTokensPropCommitsCommitProp
rojhalat ibrahimrojhalat ibrahim6793.06%150.00%
linus walleijlinus walleij56.94%150.00%
Total72100.00%2100.00%


static int bgpio_simple_dir_in(struct gpio_chip *gc, unsigned int gpio) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov1794.44%150.00%
jamie ilesjamie iles15.56%150.00%
Total18100.00%2100.00%


static int bgpio_dir_out_err(struct gpio_chip *gc, unsigned int gpio, int val) { return -EINVAL; }

Contributors

PersonTokensPropCommitsCommitProp
rabin vincentrabin vincent22100.00%1100.00%
Total22100.00%1100.00%


static int bgpio_simple_dir_out(struct gpio_chip *gc, unsigned int gpio, int val) { gc->set(gc, gpio, val); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov2887.50%133.33%
jamie ilesjamie iles412.50%266.67%
Total32100.00%3100.00%


static int bgpio_dir_in(struct gpio_chip *gc, unsigned int gpio) { unsigned long flags; spin_lock_irqsave(&gc->bgpio_lock, flags); gc->bgpio_dir &= ~gc->pin2mask(gc, gpio); gc->write_reg(gc->reg_dir, gc->bgpio_dir); spin_unlock_irqrestore(&gc->bgpio_lock, flags); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles5782.61%266.67%
linus walleijlinus walleij1217.39%133.33%
Total69100.00%3100.00%


static int bgpio_get_dir(struct gpio_chip *gc, unsigned int gpio) { /* Return 0 if output, 1 of input */ return !(gc->read_reg(gc->reg_dir) & gc->pin2mask(gc, gpio)); }

Contributors

PersonTokensPropCommitsCommitProp
philipp zabelphilipp zabel3284.21%150.00%
linus walleijlinus walleij615.79%150.00%
Total38100.00%2100.00%


static int bgpio_dir_out(struct gpio_chip *gc, unsigned int gpio, int val) { unsigned long flags; gc->set(gc, gpio, val); spin_lock_irqsave(&gc->bgpio_lock, flags); gc->bgpio_dir |= gc->pin2mask(gc, gpio); gc->write_reg(gc->reg_dir, gc->bgpio_dir); spin_unlock_irqrestore(&gc->bgpio_lock, flags); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles6376.83%250.00%
linus walleijlinus walleij1214.63%125.00%
anton vorontsovanton vorontsov78.54%125.00%
Total82100.00%4100.00%


static int bgpio_dir_in_inv(struct gpio_chip *gc, unsigned int gpio) { unsigned long flags; spin_lock_irqsave(&gc->bgpio_lock, flags); gc->bgpio_dir |= gc->pin2mask(gc, gpio); gc->write_reg(gc->reg_dir, gc->bgpio_dir); spin_unlock_irqrestore(&gc->bgpio_lock, flags); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles5682.35%150.00%
linus walleijlinus walleij1217.65%150.00%
Total68100.00%2100.00%


static int bgpio_dir_out_inv(struct gpio_chip *gc, unsigned int gpio, int val) { unsigned long flags; gc->set(gc, gpio, val); spin_lock_irqsave(&gc->bgpio_lock, flags); gc->bgpio_dir &= ~gc->pin2mask(gc, gpio); gc->write_reg(gc->reg_dir, gc->bgpio_dir); spin_unlock_irqrestore(&gc->bgpio_lock, flags); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles7185.54%150.00%
linus walleijlinus walleij1214.46%150.00%
Total83100.00%2100.00%


static int bgpio_get_dir_inv(struct gpio_chip *gc, unsigned int gpio) { /* Return 0 if output, 1 if input */ return !!(gc->read_reg(gc->reg_dir) & gc->pin2mask(gc, gpio)); }

Contributors

PersonTokensPropCommitsCommitProp
philipp zabelphilipp zabel3282.05%150.00%
linus walleijlinus walleij717.95%150.00%
Total39100.00%2100.00%


static int bgpio_setup_accessors(struct device *dev, struct gpio_chip *gc, bool bit_be, bool byte_be) { switch (gc->bgpio_bits) { case 8: gc->read_reg = bgpio_read8; gc->write_reg = bgpio_write8; break; case 16: if (byte_be) { gc->read_reg = bgpio_read16be; gc->write_reg = bgpio_write16be; } else { gc->read_reg = bgpio_read16; gc->write_reg = bgpio_write16; } break; case 32: if (byte_be) { gc->read_reg = bgpio_read32be; gc->write_reg = bgpio_write32be; } else { gc->read_reg = bgpio_read32; gc->write_reg = bgpio_write32; } break; #if BITS_PER_LONG >= 64 case 64: if (byte_be) { dev_err(dev, "64 bit big endian byte order unsupported\n"); return -EINVAL; } else { gc->read_reg = bgpio_read64; gc->write_reg = bgpio_write64; } break; #endif /* BITS_PER_LONG >= 64 */ default: dev_err(dev, "unsupported data width %u bits\n", gc->bgpio_bits); return -EINVAL; } gc->pin2mask = bit_be ? bgpio_pin2mask_be : bgpio_pin2mask; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles11157.51%360.00%
andreas larssonandreas larsson6332.64%120.00%
linus walleijlinus walleij199.84%120.00%
Total193100.00%5100.00%

/* * Create the device and allocate the resources. For setting GPIO's there are * three supported configurations: * * - single input/output register resource (named "dat"). * - set/clear pair (named "set" and "clr"). * - single output register resource and single input resource ("set" and * dat"). * * For the single output register, this drives a 1 by setting a bit and a zero * by clearing a bit. For the set clr pair, this drives a 1 by setting a bit * in the set register and clears it by setting a bit in the clear register. * The configuration is detected by which resources are present. * * For setting the GPIO direction, there are three supported configurations: * * - simple bidirection GPIO that requires no configuration. * - an output direction register (named "dirout") where a 1 bit * indicates the GPIO is an output. * - an input direction register (named "dirin") where a 1 bit indicates * the GPIO is an input. */
static int bgpio_setup_io(struct gpio_chip *gc, void __iomem *dat, void __iomem *set, void __iomem *clr, unsigned long flags) { gc->reg_dat = dat; if (!gc->reg_dat) return -EINVAL; if (set && clr) { gc->reg_set = set; gc->reg_clr = clr; gc->set = bgpio_set_with_clear; gc->set_multiple = bgpio_set_multiple_with_clear; } else if (set && !clr) { gc->reg_set = set; gc->set = bgpio_set_set; gc->set_multiple = bgpio_set_multiple_set; } else if (flags & BGPIOF_NO_OUTPUT) { gc->set = bgpio_set_none; gc->set_multiple = NULL; } else { gc->set = bgpio_set; gc->set_multiple = bgpio_set_multiple; } if (!(flags & BGPIOF_UNREADABLE_REG_SET) && (flags & BGPIOF_READ_OUTPUT_REG_SET)) gc->get = bgpio_get_set; else gc->get = bgpio_get; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles6839.08%444.44%
anton vorontsovanton vorontsov3017.24%111.11%
vladimir zapolskiyvladimir zapolskiy2514.37%111.11%
rabin vincentrabin vincent1910.92%111.11%
linus walleijlinus walleij179.77%111.11%
rojhalat ibrahimrojhalat ibrahim158.62%111.11%
Total174100.00%9100.00%


static int bgpio_setup_direction(struct gpio_chip *gc, void __iomem *dirout, void __iomem *dirin, unsigned long flags) { if (dirout && dirin) { return -EINVAL; } else if (dirout) { gc->reg_dir = dirout; gc->direction_output = bgpio_dir_out; gc->direction_input = bgpio_dir_in; gc->get_direction = bgpio_get_dir; } else if (dirin) { gc->reg_dir = dirin; gc->direction_output = bgpio_dir_out_inv; gc->direction_input = bgpio_dir_in_inv; gc->get_direction = bgpio_get_dir_inv; } else { if (flags & BGPIOF_NO_OUTPUT) gc->direction_output = bgpio_dir_out_err; else gc->direction_output = bgpio_simple_dir_out; gc->direction_input = bgpio_simple_dir_in; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles9170.00%240.00%
rabin vincentrabin vincent1612.31%120.00%
linus walleijlinus walleij1310.00%120.00%
philipp zabelphilipp zabel107.69%120.00%
Total130100.00%5100.00%


static int bgpio_request(struct gpio_chip *chip, unsigned gpio_pin) { if (gpio_pin < chip->ngpio) return 0; return -EINVAL; }

Contributors

PersonTokensPropCommitsCommitProp
anthony feeanthony fee29100.00%1100.00%
Total29100.00%1100.00%


int bgpio_init(struct gpio_chip *gc, struct device *dev, unsigned long sz, void __iomem *dat, void __iomem *set, void __iomem *clr, void __iomem *dirout, void __iomem *dirin, unsigned long flags) { int ret; if (!is_power_of_2(sz)) return -EINVAL; gc->bgpio_bits = sz * 8; if (gc->bgpio_bits > BITS_PER_LONG) return -EINVAL; spin_lock_init(&gc->bgpio_lock); gc->parent = dev; gc->label = dev_name(dev); gc->base = -1; gc->ngpio = gc->bgpio_bits; gc->request = bgpio_request; ret = bgpio_setup_io(gc, dat, set, clr, flags); if (ret) return ret; ret = bgpio_setup_accessors(dev, gc, flags & BGPIOF_BIG_ENDIAN, flags & BGPIOF_BIG_ENDIAN_BYTE_ORDER); if (ret) return ret; ret = bgpio_setup_direction(gc, dirout, dirin, flags); if (ret) return ret; gc->bgpio_data = gc->read_reg(gc->reg_dat); if (gc->set == bgpio_set_set && !(flags & BGPIOF_UNREADABLE_REG_SET)) gc->bgpio_data = gc->read_reg(gc->reg_set); if (gc->reg_dir && !(flags & BGPIOF_UNREADABLE_REG_DIR)) gc->bgpio_dir = gc->read_reg(gc->reg_dir); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles16763.50%112.50%
shawn guoshawn guo5019.01%112.50%
linus walleijlinus walleij3312.55%225.00%
anthony feeanthony fee51.90%112.50%
andreas larssonandreas larsson41.52%112.50%
vladimir zapolskiyvladimir zapolskiy20.76%112.50%
rabin vincentrabin vincent20.76%112.50%
Total263100.00%8100.00%

EXPORT_SYMBOL_GPL(bgpio_init); #if IS_ENABLED(CONFIG_GPIO_GENERIC_PLATFORM)
static void __iomem *bgpio_map(struct platform_device *pdev, const char *name, resource_size_t sane_sz) { struct resource *r; resource_size_t sz; r = platform_get_resource_byname(pdev, IORESOURCE_MEM, name); if (!r) return NULL; sz = resource_size(r); if (sz != sane_sz) return IOMEM_ERR_PTR(-EINVAL); return devm_ioremap_resource(&pdev->dev, r); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles6784.81%125.00%
heiner kallweitheiner kallweit1113.92%250.00%
guenter roeckguenter roeck11.27%125.00%
Total79100.00%4100.00%


static int bgpio_pdev_probe(struct platform_device *pdev) { struct device *dev = &pdev->dev; struct resource *r; void __iomem *dat; void __iomem *set; void __iomem *clr; void __iomem *dirout; void __iomem *dirin; unsigned long sz; unsigned long flags = pdev->id_entry->driver_data; int err; struct gpio_chip *gc; struct bgpio_pdata *pdata = dev_get_platdata(dev); r = platform_get_resource_byname(pdev, IORESOURCE_MEM, "dat"); if (!r) return -EINVAL; sz = resource_size(r); dat = bgpio_map(pdev, "dat", sz); if (IS_ERR(dat)) return PTR_ERR(dat); set = bgpio_map(pdev, "set", sz); if (IS_ERR(set)) return PTR_ERR(set); clr = bgpio_map(pdev, "clr", sz); if (IS_ERR(clr)) return PTR_ERR(clr); dirout = bgpio_map(pdev, "dirout", sz); if (IS_ERR(dirout)) return PTR_ERR(dirout); dirin = bgpio_map(pdev, "dirin", sz); if (IS_ERR(dirin)) return PTR_ERR(dirin); gc = devm_kzalloc(&pdev->dev, sizeof(*gc), GFP_KERNEL); if (!gc) return -ENOMEM; err = bgpio_init(gc, dev, sz, dat, set, clr, dirout, dirin, flags); if (err) return err; if (pdata) { if (pdata->label) gc->label = pdata->label; gc->base = pdata->base; if (pdata->ngpio > 0) gc->ngpio = pdata->ngpio; } platform_set_drvdata(pdev, gc); return devm_gpiochip_add_data(&pdev->dev, gc, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles24369.23%646.15%
heiner kallweitheiner kallweit4011.40%17.69%
anton vorontsovanton vorontsov277.69%17.69%
pawel mollpawel moll133.70%17.69%
linus walleijlinus walleij123.42%17.69%
laxman dewanganlaxman dewangan61.71%17.69%
alexander shiyanalexander shiyan51.42%17.69%
shawn guoshawn guo51.42%17.69%
Total351100.00%13100.00%

static const struct platform_device_id bgpio_id_table[] = { { .name = "basic-mmio-gpio", .driver_data = 0, }, { .name = "basic-mmio-gpio-be", .driver_data = BGPIOF_BIG_ENDIAN, }, { } }; MODULE_DEVICE_TABLE(platform, bgpio_id_table); static struct platform_driver bgpio_driver = { .driver = { .name = "basic-mmio-gpio", }, .id_table = bgpio_id_table, .probe = bgpio_pdev_probe, }; module_platform_driver(bgpio_driver); #endif /* CONFIG_GPIO_GENERIC_PLATFORM */ MODULE_DESCRIPTION("Driver for basic memory-mapped GPIO controllers"); MODULE_AUTHOR("Anton Vorontsov <cbouatmailru@gmail.com>"); MODULE_LICENSE("GPL");

Overall Contributors

PersonTokensPropCommitsCommitProp
jamie ilesjamie iles127845.21%929.03%
anton vorontsovanton vorontsov38513.62%13.23%
rojhalat ibrahimrojhalat ibrahim33311.78%13.23%
linus walleijlinus walleij2609.20%516.13%
andreas larssonandreas larsson1475.20%13.23%
vladimir zapolskiyvladimir zapolskiy802.83%13.23%
rabin vincentrabin vincent762.69%13.23%
philipp zabelphilipp zabel742.62%13.23%
shawn guoshawn guo551.95%13.23%
heiner kallweitheiner kallweit511.80%26.45%
anthony feeanthony fee341.20%13.23%
alexander shiyanalexander shiyan250.88%13.23%
pawel mollpawel moll130.46%13.23%
laxman dewanganlaxman dewangan60.21%13.23%
christian lamparterchristian lamparter50.18%13.23%
grant likelygrant likely30.11%13.23%
guenter roeckguenter roeck10.04%13.23%
mark brownmark brown10.04%13.23%
Total2827100.00%31100.00%
Directory: drivers/gpio
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}