cregit-Linux how code gets into the kernel

Release 4.14 drivers/gpio/gpio-tps65910.c

Directory: drivers/gpio
/*
 * TI TPS6591x GPIO driver
 *
 * Copyright 2010 Texas Instruments Inc.
 *
 * Author: Graeme Gregory <gg@slimlogic.co.uk>
 * Author: Jorge Eduardo Candelaria <jedu@slimlogic.co.uk>
 *
 *  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.
 *
 */

#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/errno.h>
#include <linux/gpio.h>
#include <linux/i2c.h>
#include <linux/platform_device.h>
#include <linux/mfd/tps65910.h>
#include <linux/of_device.h>


struct tps65910_gpio {
	
struct gpio_chip gpio_chip;
	
struct tps65910 *tps65910;
};


static int tps65910_gpio_get(struct gpio_chip *gc, unsigned offset) { struct tps65910_gpio *tps65910_gpio = gpiochip_get_data(gc); struct tps65910 *tps65910 = tps65910_gpio->tps65910; unsigned int val; tps65910_reg_read(tps65910, TPS65910_GPIO0 + offset, &val); if (val & GPIO_STS_MASK) return 1; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Graeme Gregory4370.49%120.00%
Laxman Dewangan1118.03%120.00%
Rhyland Klein34.92%120.00%
Jorge Eduardo Candelaria34.92%120.00%
Linus Walleij11.64%120.00%
Total61100.00%5100.00%


static void tps65910_gpio_set(struct gpio_chip *gc, unsigned offset, int value) { struct tps65910_gpio *tps65910_gpio = gpiochip_get_data(gc); struct tps65910 *tps65910 = tps65910_gpio->tps65910; if (value) tps65910_reg_set_bits(tps65910, TPS65910_GPIO0 + offset, GPIO_SET_MASK); else tps65910_reg_clear_bits(tps65910, TPS65910_GPIO0 + offset, GPIO_SET_MASK); }

Contributors

PersonTokensPropCommitsCommitProp
Graeme Gregory4368.25%120.00%
Laxman Dewangan1117.46%120.00%
Jorge Eduardo Candelaria69.52%120.00%
Rhyland Klein23.17%120.00%
Linus Walleij11.59%120.00%
Total63100.00%5100.00%


static int tps65910_gpio_output(struct gpio_chip *gc, unsigned offset, int value) { struct tps65910_gpio *tps65910_gpio = gpiochip_get_data(gc); struct tps65910 *tps65910 = tps65910_gpio->tps65910; /* Set the initial value */ tps65910_gpio_set(gc, offset, value); return tps65910_reg_set_bits(tps65910, TPS65910_GPIO0 + offset, GPIO_CFG_MASK); }

Contributors

PersonTokensPropCommitsCommitProp
Graeme Gregory4170.69%116.67%
Laxman Dewangan1220.69%233.33%
Jorge Eduardo Candelaria35.17%116.67%
Rhyland Klein11.72%116.67%
Linus Walleij11.72%116.67%
Total58100.00%6100.00%


static int tps65910_gpio_input(struct gpio_chip *gc, unsigned offset) { struct tps65910_gpio *tps65910_gpio = gpiochip_get_data(gc); struct tps65910 *tps65910 = tps65910_gpio->tps65910; return tps65910_reg_clear_bits(tps65910, TPS65910_GPIO0 + offset, GPIO_CFG_MASK); }

Contributors

PersonTokensPropCommitsCommitProp
Graeme Gregory2964.44%120.00%
Laxman Dewangan1124.44%120.00%
Jorge Eduardo Candelaria36.67%120.00%
Rhyland Klein12.22%120.00%
Linus Walleij12.22%120.00%
Total45100.00%5100.00%

#ifdef CONFIG_OF
static struct tps65910_board *tps65910_parse_dt_for_gpio(struct device *dev, struct tps65910 *tps65910, int chip_ngpio) { struct tps65910_board *tps65910_board = tps65910->of_plat_data; unsigned int prop_array[TPS6591X_MAX_NUM_GPIO]; int ngpio = min(chip_ngpio, TPS6591X_MAX_NUM_GPIO); int ret; int idx; tps65910_board->gpio_base = -1; ret = of_property_read_u32_array(tps65910->dev->of_node, "ti,en-gpio-sleep", prop_array, ngpio); if (ret < 0) { dev_dbg(dev, "ti,en-gpio-sleep not specified\n"); return tps65910_board; } for (idx = 0; idx < ngpio; idx++) tps65910_board->en_gpio_sleep[idx] = (prop_array[idx] != 0); return tps65910_board; }

Contributors

PersonTokensPropCommitsCommitProp
Laxman Dewangan127100.00%1100.00%
Total127100.00%1100.00%

#else
static struct tps65910_board *tps65910_parse_dt_for_gpio(struct device *dev, struct tps65910 *tps65910, int chip_ngpio) { return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
Laxman Dewangan24100.00%1100.00%
Total24100.00%1100.00%

#endif
static int tps65910_gpio_probe(struct platform_device *pdev) { struct tps65910 *tps65910 = dev_get_drvdata(pdev->dev.parent); struct tps65910_board *pdata = dev_get_platdata(tps65910->dev); struct tps65910_gpio *tps65910_gpio; int ret; int i; tps65910_gpio = devm_kzalloc(&pdev->dev, sizeof(*tps65910_gpio), GFP_KERNEL); if (!tps65910_gpio) return -ENOMEM; tps65910_gpio->tps65910 = tps65910; tps65910_gpio->gpio_chip.owner = THIS_MODULE; tps65910_gpio->gpio_chip.label = tps65910->i2c_client->name; switch (tps65910_chip_id(tps65910)) { case TPS65910: tps65910_gpio->gpio_chip.ngpio = TPS65910_NUM_GPIO; break; case TPS65911: tps65910_gpio->gpio_chip.ngpio = TPS65911_NUM_GPIO; break; default: return -EINVAL; } tps65910_gpio->gpio_chip.can_sleep = true; tps65910_gpio->gpio_chip.direction_input = tps65910_gpio_input; tps65910_gpio->gpio_chip.direction_output = tps65910_gpio_output; tps65910_gpio->gpio_chip.set = tps65910_gpio_set; tps65910_gpio->gpio_chip.get = tps65910_gpio_get; tps65910_gpio->gpio_chip.parent = &pdev->dev; #ifdef CONFIG_OF_GPIO tps65910_gpio->gpio_chip.of_node = tps65910->dev->of_node; #endif if (pdata && pdata->gpio_base) tps65910_gpio->gpio_chip.base = pdata->gpio_base; else tps65910_gpio->gpio_chip.base = -1; if (!pdata && tps65910->dev->of_node) pdata = tps65910_parse_dt_for_gpio(&pdev->dev, tps65910, tps65910_gpio->gpio_chip.ngpio); if (!pdata) goto skip_init; /* Configure sleep control for gpios if provided */ for (i = 0; i < tps65910_gpio->gpio_chip.ngpio; ++i) { if (!pdata->en_gpio_sleep[i]) continue; ret = tps65910_reg_set_bits(tps65910, TPS65910_GPIO0 + i, GPIO_SLEEP_MASK); if (ret < 0) dev_warn(tps65910->dev, "GPIO Sleep setting failed with err %d\n", ret); } skip_init: ret = devm_gpiochip_add_data(&pdev->dev, &tps65910_gpio->gpio_chip, tps65910_gpio); if (ret < 0) { dev_err(&pdev->dev, "Could not register gpiochip, %d\n", ret); return ret; } platform_set_drvdata(pdev, tps65910_gpio); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Laxman Dewangan27170.39%538.46%
Graeme Gregory8121.04%17.69%
Jorge Eduardo Candelaria215.45%17.69%
Gerard Snitselaar51.30%17.69%
Linus Walleij41.04%323.08%
Axel Lin20.52%17.69%
Rhyland Klein10.26%17.69%
Total385100.00%13100.00%

static struct platform_driver tps65910_gpio_driver = { .driver.name = "tps65910-gpio", .probe = tps65910_gpio_probe, };
static int __init tps65910_gpio_init(void) { return platform_driver_register(&tps65910_gpio_driver); }

Contributors

PersonTokensPropCommitsCommitProp
Laxman Dewangan16100.00%1100.00%
Total16100.00%1100.00%

subsys_initcall(tps65910_gpio_init);

Overall Contributors

PersonTokensPropCommitsCommitProp
Laxman Dewangan53462.90%640.00%
Graeme Gregory25429.92%16.67%
Jorge Eduardo Candelaria364.24%16.67%
Linus Walleij80.94%320.00%
Rhyland Klein80.94%16.67%
Gerard Snitselaar50.59%16.67%
Paul Gortmaker20.24%16.67%
Axel Lin20.24%16.67%
Total849100.00%15100.00%
Directory: drivers/gpio
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.