diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-24 14:01:46 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-24 14:01:46 -0700 | 
| commit | b1bf7d4d1b3911352cf1ec63c1de06214288ccd0 (patch) | |
| tree | 0fd27c638977cb5c7e6e3f95085ce842b57a4ae3 /drivers/gpio/gpio-generic.c | |
| parent | 0708500d49e8439d9fe5529795bdc1485f0f46c3 (diff) | |
| parent | 3e11f7b840b4671213c66817294ad7dd0b572756 (diff) | |
| download | olio-linux-3.10-b1bf7d4d1b3911352cf1ec63c1de06214288ccd0.tar.xz olio-linux-3.10-b1bf7d4d1b3911352cf1ec63c1de06214288ccd0.zip  | |
Merge tag 'gpio-for-linus' of git://git.secretlab.ca/git/linux-2.6
Pull GPIO driver changes from Grant Likely:
 "Lots of gpio changes, both to core code and drivers.
  Changes do touch architecture code to remove the need for separate
  arm/gpio.h includes in most architectures.
  Some new drivers are added, and a number of gpio drivers are converted
  to use irq_domains for gpio inputs used as interrupts.  Device tree
  support has been amended to allow multiple gpio_chips to use the same
  device tree node.
  Remaining changes are primarily bug fixes."
* tag 'gpio-for-linus' of git://git.secretlab.ca/git/linux-2.6: (33 commits)
  gpio/generic: initialize basic_mmio_gpio shadow variables properly
  gpiolib: Remove 'const' from data argument of gpiochip_find()
  gpio/rc5t583: add gpio driver for RICOH PMIC RC5T583
  gpiolib: quiet gpiochip_add boot message noise
  gpio: mpc8xxx: Prevent NULL pointer deref in demux handler
  gpio/lpc32xx: Add device tree support
  gpio: Adjust of_xlate API to support multiple GPIO chips
  gpiolib: Implement devm_gpio_request_one()
  gpio-mcp23s08: dbg_show: fix pullup configuration display
  Add support for TCA6424A
  gpio/omap: (re)fix wakeups on level-triggered GPIOs
  gpio/omap: fix broken context restore for non-OFF mode transitions
  gpio/omap: fix missing check in *_runtime_suspend()
  gpio/omap: remove cpu_is_omapxxxx() checks from *_runtime_resume()
  gpio/omap: remove suspend/resume callbacks
  gpio/omap: remove retrigger variable in gpio_irq_handler
  gpio/omap: remove saved_wakeup field from struct gpio_bank
  gpio/omap: remove suspend_wakeup field from struct gpio_bank
  gpio/omap: remove saved_fallingdetect, saved_risingdetect
  gpio/omap: remove virtual_irq_start variable
  ...
Conflicts:
	drivers/gpio/gpio-samsung.c
Diffstat (limited to 'drivers/gpio/gpio-generic.c')
| -rw-r--r-- | drivers/gpio/gpio-generic.c | 16 | 
1 files changed, 11 insertions, 5 deletions
diff --git a/drivers/gpio/gpio-generic.c b/drivers/gpio/gpio-generic.c index e38dd0c3197..82e2e4fe599 100644 --- a/drivers/gpio/gpio-generic.c +++ b/drivers/gpio/gpio-generic.c @@ -364,7 +364,7 @@ EXPORT_SYMBOL_GPL(bgpio_remove);  int bgpio_init(struct bgpio_chip *bgc, struct device *dev,  	       unsigned long sz, void __iomem *dat, void __iomem *set,  	       void __iomem *clr, void __iomem *dirout, void __iomem *dirin, -	       bool big_endian) +	       unsigned long flags)  {  	int ret; @@ -385,7 +385,7 @@ int bgpio_init(struct bgpio_chip *bgc, struct device *dev,  	if (ret)  		return ret; -	ret = bgpio_setup_accessors(dev, bgc, big_endian); +	ret = bgpio_setup_accessors(dev, bgc, flags & BGPIOF_BIG_ENDIAN);  	if (ret)  		return ret; @@ -394,6 +394,11 @@ int bgpio_init(struct bgpio_chip *bgc, struct device *dev,  		return ret;  	bgc->data = bgc->read_reg(bgc->reg_dat); +	if (bgc->gc.set == bgpio_set_set && +			!(flags & BGPIOF_UNREADABLE_REG_SET)) +		bgc->data = bgc->read_reg(bgc->reg_set); +	if (bgc->reg_dir && !(flags & BGPIOF_UNREADABLE_REG_DIR)) +		bgc->dir = bgc->read_reg(bgc->reg_dir);  	return ret;  } @@ -449,7 +454,7 @@ static int __devinit bgpio_pdev_probe(struct platform_device *pdev)  	void __iomem *dirout;  	void __iomem *dirin;  	unsigned long sz; -	bool be; +	unsigned long flags = 0;  	int err;  	struct bgpio_chip *bgc;  	struct bgpio_pdata *pdata = dev_get_platdata(dev); @@ -480,13 +485,14 @@ static int __devinit bgpio_pdev_probe(struct platform_device *pdev)  	if (err)  		return err; -	be = !strcmp(platform_get_device_id(pdev)->name, "basic-mmio-gpio-be"); +	if (!strcmp(platform_get_device_id(pdev)->name, "basic-mmio-gpio-be")) +		flags |= BGPIOF_BIG_ENDIAN;  	bgc = devm_kzalloc(&pdev->dev, sizeof(*bgc), GFP_KERNEL);  	if (!bgc)  		return -ENOMEM; -	err = bgpio_init(bgc, dev, sz, dat, set, clr, dirout, dirin, be); +	err = bgpio_init(bgc, dev, sz, dat, set, clr, dirout, dirin, flags);  	if (err)  		return err;  |