cregit-Linux how code gets into the kernel

Release 4.11 arch/mips/alchemy/common/gpiolib.c

/*
 *  Copyright (C) 2007-2009, OpenWrt.org, Florian Fainelli <florian@openwrt.org>
 *      GPIOLIB support for Alchemy chips.
 *
 *  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.
 *
 *  THIS  SOFTWARE  IS PROVIDED   ``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 AUTHOR  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.
 *
 *  You should have received a copy of the  GNU General Public License along
 *  with this program; if not, write  to the Free Software Foundation, Inc.,
 *  675 Mass Ave, Cambridge, MA 02139, USA.
 *
 *  Notes :
 *      This file must ONLY be built when CONFIG_GPIOLIB=y and
 *       CONFIG_ALCHEMY_GPIO_INDIRECT=n, otherwise compilation will fail!
 *      au1000 SoC have only one GPIO block : GPIO1
 *      Au1100, Au15x0, Au12x0 have a second one : GPIO2
 *      Au1300 is totally different: 1 block with up to 128 GPIOs
 */

#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/types.h>
#include <linux/gpio.h>
#include <asm/mach-au1x00/gpio-au1000.h>
#include <asm/mach-au1x00/gpio-au1300.h>


static int gpio2_get(struct gpio_chip *chip, unsigned offset) { return !!alchemy_gpio2_get_value(offset + ALCHEMY_GPIO2_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss2291.67%150.00%
Linus Walleij28.33%150.00%
Total24100.00%2100.00%


static void gpio2_set(struct gpio_chip *chip, unsigned offset, int value) { alchemy_gpio2_set_value(offset + ALCHEMY_GPIO2_BASE, value); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss26100.00%1100.00%
Total26100.00%1100.00%


static int gpio2_direction_input(struct gpio_chip *chip, unsigned offset) { return alchemy_gpio2_direction_input(offset + ALCHEMY_GPIO2_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss22100.00%1100.00%
Total22100.00%1100.00%


static int gpio2_direction_output(struct gpio_chip *chip, unsigned offset, int value) { return alchemy_gpio2_direction_output(offset + ALCHEMY_GPIO2_BASE, value); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss27100.00%1100.00%
Total27100.00%1100.00%


static int gpio2_to_irq(struct gpio_chip *chip, unsigned offset) { return alchemy_gpio2_to_irq(offset + ALCHEMY_GPIO2_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss22100.00%1100.00%
Total22100.00%1100.00%


static int gpio1_get(struct gpio_chip *chip, unsigned offset) { return !!alchemy_gpio1_get_value(offset + ALCHEMY_GPIO1_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss2291.67%150.00%
Linus Walleij28.33%150.00%
Total24100.00%2100.00%


static void gpio1_set(struct gpio_chip *chip, unsigned offset, int value) { alchemy_gpio1_set_value(offset + ALCHEMY_GPIO1_BASE, value); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss26100.00%1100.00%
Total26100.00%1100.00%


static int gpio1_direction_input(struct gpio_chip *chip, unsigned offset) { return alchemy_gpio1_direction_input(offset + ALCHEMY_GPIO1_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss22100.00%1100.00%
Total22100.00%1100.00%


static int gpio1_direction_output(struct gpio_chip *chip, unsigned offset, int value) { return alchemy_gpio1_direction_output(offset + ALCHEMY_GPIO1_BASE, value); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss27100.00%1100.00%
Total27100.00%1100.00%


static int gpio1_to_irq(struct gpio_chip *chip, unsigned offset) { return alchemy_gpio1_to_irq(offset + ALCHEMY_GPIO1_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss22100.00%1100.00%
Total22100.00%1100.00%

struct gpio_chip alchemy_gpio_chip[] = { [0] = { .label = "alchemy-gpio1", .direction_input = gpio1_direction_input, .direction_output = gpio1_direction_output, .get = gpio1_get, .set = gpio1_set, .to_irq = gpio1_to_irq, .base = ALCHEMY_GPIO1_BASE, .ngpio = ALCHEMY_GPIO1_NUM, }, [1] = { .label = "alchemy-gpio2", .direction_input = gpio2_direction_input, .direction_output = gpio2_direction_output, .get = gpio2_get, .set = gpio2_set, .to_irq = gpio2_to_irq, .base = ALCHEMY_GPIO2_BASE, .ngpio = ALCHEMY_GPIO2_NUM, }, };
static int alchemy_gpic_get(struct gpio_chip *chip, unsigned int off) { return !!au1300_gpio_get_value(off + AU1300_GPIO_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss2392.00%150.00%
Linus Walleij28.00%150.00%
Total25100.00%2100.00%


static void alchemy_gpic_set(struct gpio_chip *chip, unsigned int off, int v) { au1300_gpio_set_value(off + AU1300_GPIO_BASE, v); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss27100.00%1100.00%
Total27100.00%1100.00%


static int alchemy_gpic_dir_input(struct gpio_chip *chip, unsigned int off) { return au1300_gpio_direction_input(off + AU1300_GPIO_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss23100.00%1100.00%
Total23100.00%1100.00%


static int alchemy_gpic_dir_output(struct gpio_chip *chip, unsigned int off, int v) { return au1300_gpio_direction_output(off + AU1300_GPIO_BASE, v); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss28100.00%1100.00%
Total28100.00%1100.00%


static int alchemy_gpic_gpio_to_irq(struct gpio_chip *chip, unsigned int off) { return au1300_gpio_to_irq(off + AU1300_GPIO_BASE); }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss23100.00%1100.00%
Total23100.00%1100.00%

static struct gpio_chip au1300_gpiochip = { .label = "alchemy-gpic", .direction_input = alchemy_gpic_dir_input, .direction_output = alchemy_gpic_dir_output, .get = alchemy_gpic_get, .set = alchemy_gpic_set, .to_irq = alchemy_gpic_gpio_to_irq, .base = AU1300_GPIO_BASE, .ngpio = AU1300_GPIO_NUM, };
static int __init alchemy_gpiochip_init(void) { int ret = 0; switch (alchemy_get_cputype()) { case ALCHEMY_CPU_AU1000: ret = gpiochip_add_data(&alchemy_gpio_chip[0], NULL); break; case ALCHEMY_CPU_AU1500...ALCHEMY_CPU_AU1200: ret = gpiochip_add_data(&alchemy_gpio_chip[0], NULL); ret |= gpiochip_add_data(&alchemy_gpio_chip[1], NULL); break; case ALCHEMY_CPU_AU1300: ret = gpiochip_add_data(&au1300_gpiochip, NULL); break; } return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss7586.21%375.00%
Linus Walleij1213.79%125.00%
Total87100.00%4100.00%

arch_initcall(alchemy_gpiochip_init);

Overall Contributors

PersonTokensPropCommitsCommitProp
Manuel Lauss60797.12%466.67%
Linus Walleij182.88%233.33%
Total625100.00%6100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.