1. 29 10月, 2016 1 次提交
  2. 24 10月, 2016 4 次提交
  3. 04 10月, 2016 1 次提交
    • L
      gpio: acpi: separation of concerns · 031ba28a
      Linus Walleij 提交于
      The generic GPIO library directly implement code for acpi_find_gpio()
      which is only used with CONFIG_ACPI. This was probably done because
      OF did the same thing, but I removed that so remove this too.
      
      Rename the internal acpi_find_gpio() in gpiolib-acpi.c to
      acpi_populate_gpio_lookup() which seems to be more appropriate anyway
      so as to avoid a namespace clash with the same function.
      
      Make the stub return -ENOENT rather than -ENOSYS (as that is for
      syscalls!).
      
      For some reason the sunxi pin control driver was including the private
      gpiolib header, it works just fine without it so remove that oneliner.
      
      Cc: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
      Acked-by: NMika Westerberg <mika.westerberg@linux.intel.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      031ba28a
  4. 08 9月, 2016 2 次提交
  5. 23 8月, 2016 1 次提交
  6. 11 8月, 2016 1 次提交
  7. 05 7月, 2016 1 次提交
  8. 21 4月, 2016 1 次提交
  9. 30 3月, 2016 1 次提交
    • H
      pinctrl: sunxi: Fix A33 external interrupts not working · 5e7515ba
      Hans de Goede 提交于
      pinctrl-sun8i-a33.c (and the dts) declare only 2 interrupt banks,
      where as the closely related a23 has 3 banks. This matches with the
      datasheet for the A33 where only interrupt banks B and G are specified
      where as the A23 has banks A, B and G.
      
      However the A33 being the A23 derative it is means that the interrupt
      configure/status io-addresses for the 2 banks it has are not changed
      from the A23, iow they have the same address as if bank A was still
      present. Where as the sunxi pinctrl currently tries to use the A23 bank
      A addresses for bank B, since the pinctrl code does not know about the
      removed bank A.
      
      Add a irq_bank_base parameter and use this where appropriate to take
      the missing bank A into account.
      
      This fixes external interrupts not working on the A33 (tested with
      an i2c touchscreen controller which uses an external interrupt).
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NHans de Goede <hdegoede@redhat.com>
      Acked-by: NMaxime Ripard <maxime.ripard@free-electrons.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      5e7515ba
  10. 11 3月, 2016 1 次提交
  11. 09 3月, 2016 2 次提交
  12. 08 3月, 2016 2 次提交
    • H
      pinctrl: sunxi: Change mux setting on PI irq pins · 7866f5a0
      Henry Paulissen 提交于
      While I was testing irq's on the cubietruck I found a couple of
      not working irq pins. Further diving into the problem it opened
      up a mess called "manual".
      
      This so called manual (A20 user manual v1.3 dated 2014-10-10) says:
      
      Pin overview:
          Page 237:       EINT26 is on mux 5.
          Page 288:       EINT26 is on mux 6.
      
      The manual is so contradicting that further tests had to be made
      to see which of the 2 statements where correct.
      
      This patch is based on actual outcome of these tests and not what
      the manual says.
      
      Test procedure used:
      
      Connect a 1 pulse per second (GPS) line to the pin.
      
      echo pin### > /sys/class/gpio/export
      echo in > /sys/class/gpio/gpio###/direction
      echo rising > /sys/class/gpio/gpio###/edge
      
      Check /proc/interrupts if a irq was attached and if irq's where
      received.
      
      Hardware used:
      Henry Paulissen: Cubietruck
      Andere Przywara: BananaPi M1
      Tested-by: NAndre Przywara <andre.przywara@arm.com>
      Reviewed-by: NAndre Przywara <andre.przywara@arm.com>
      Signed-off-by: NHenry Paulissen <henry@nitronetworks.nl>
      Acked-by: NMaxime Ripard <maxime.ripard@free-electrons.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      7866f5a0
    • H
      pinctrl: sunxi: Remove non existing irq's · 9c24ef41
      Henry Paulissen 提交于
      While I was testing irq's on the cubietruck I found a couple of
      not working irq pins. Further diving into the problem it opened
      up a mess called "manual".
      
      This so called manual (A20 user manual v1.3 dated 2014-10-10) says:
      
      Pin overview:
          Page 233:       EINT12 is on pin PC19 mux6.
          Page 236:       EINT12 is on pin PH12 mux6.
      
      Now, it is a bit strange to have the same IRQ on 2 different pins,
      but I guess this could still be possible hardware wise. But then:
      
      Pin registers:
          Page 253:       EINT12 is *not* on pin PC19.
          Page 281:       EINT12 is on pin PH12.
      
      The manual is so contradicting that further tests had to be made
      to see which of the 2 statements where correct.
      
      This patch is based on actual outcome of these tests and not what
      the manual says.
      
      Test procedure used:
      
      Connect a 1 pulse per second (GPS) line to the pin.
      
      echo pin### > /sys/class/gpio/export
      echo in > /sys/class/gpio/gpio###/direction
      echo rising > /sys/class/gpio/gpio###/edge
      
      Check /proc/interrupts if a irq was attached and if irq's where
      received.
      Signed-off-by: NHenry Paulissen <henry@nitronetworks.nl>
      Acked-by: NMaxime Ripard <maxime.ripard@free-electrons.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      9c24ef41
  13. 12 2月, 2016 1 次提交
    • L
      gpio/pinctrl: sunxi: stop poking around in private vars · 6cee3821
      Linus Walleij 提交于
      This kind of hacks disturbs the refactoring of the gpiolib.
      
      The descriptor table belongs to the gpiolib, if we want to know
      something about something in it, use or define the proper accessor
      functions. Let's add this gpiochip_lins_is_irq() to do what the
      sunxi driver is trying at so we can privatize the descriptors
      properly.
      
      Cc: Maxime Ripard <maxime.ripard@free-electrons.com>
      Cc: Chen-Yu Tsai <wens@csie.org>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      6cee3821
  14. 11 2月, 2016 3 次提交
  15. 28 1月, 2016 1 次提交
  16. 05 1月, 2016 1 次提交
  17. 27 12月, 2015 1 次提交
  18. 22 12月, 2015 1 次提交
  19. 11 12月, 2015 1 次提交
  20. 19 11月, 2015 1 次提交
    • L
      gpio: change member .dev to .parent · 58383c78
      Linus Walleij 提交于
      The name .dev in a struct is normally reserved for a struct device
      that is let us say a superclass to the thing described by the struct.
      struct gpio_chip stands out by confusingly using a struct device *dev
      to point to the parent device (such as a platform_device) that
      represents the hardware. As we want to give gpio_chip:s real devices,
      this is not working. We need to rename this member to parent.
      
      This was done by two coccinelle scripts, I guess it is possible to
      combine them into one, but I don't know such stuff. They look like
      this:
      
      @@
      struct gpio_chip *var;
      @@
      -var->dev
      +var->parent
      
      and:
      
      @@
      struct gpio_chip var;
      @@
      -var.dev
      +var.parent
      
      and:
      
      @@
      struct bgpio_chip *var;
      @@
      -var->gc.dev
      +var->gc.parent
      
      Plus a few instances of bgpio that I couldn't figure out how
      to teach Coccinelle to rewrite.
      
      This patch hits all over the place, but I *strongly* prefer this
      solution to any piecemal approaches that just exercise patch
      mechanics all over the place. It mainly hits drivers/gpio and
      drivers/pinctrl which is my own backyard anyway.
      
      Cc: Haavard Skinnemoen <hskinnemoen@gmail.com>
      Cc: Rafał Miłecki <zajec5@gmail.com>
      Cc: Richard Purdie <rpurdie@rpsys.net>
      Cc: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
      Cc: Alek Du <alek.du@intel.com>
      Cc: Jaroslav Kysela <perex@perex.cz>
      Cc: Takashi Iwai <tiwai@suse.com>
      Acked-by: NDmitry Torokhov <dmitry.torokhov@gmail.com>
      Acked-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Acked-by: NLee Jones <lee.jones@linaro.org>
      Acked-by: NJiri Kosina <jkosina@suse.cz>
      Acked-by: NHans-Christian Egtvedt <egtvedt@samfundet.no>
      Acked-by: NJacek Anaszewski <j.anaszewski@samsung.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      58383c78
  21. 23 10月, 2015 2 次提交
  22. 17 10月, 2015 1 次提交
  23. 02 10月, 2015 3 次提交
  24. 16 9月, 2015 2 次提交
  25. 13 8月, 2015 1 次提交
  26. 27 7月, 2015 3 次提交