1. 10 6月, 2015 1 次提交
  2. 02 6月, 2015 1 次提交
    • G
      gpio: Add GPIO support for Broadcom STB SoCs · 3b0213d5
      Gregory Fong 提交于
      This adds support for the GPIO IP "UPG GIO" used on
      Broadcom STB SoCs (BCM7XXX and some others). Uses
      basic_mmio_gpio to instantiate a gpio_chip for each bank.
      The driver assumes that it handles the base set of GPIOs
      on the system and that it can start its numbering sequence
      from 0, so any GPIO expanders used with it must dynamically
      assign GPIO numbers after this driver has finished
      registering its GPIOs.
      
      Does not implement the interrupt-controller portion yet,
      will be done in a future commit.
      
      v2:
      - change include to use <linux/gpio/driver.h> instead of
        <linux/gpio.h>
      - get rid of unnecessary imask member in struct bank
      - rename GPIO_PER_BANK -> MAX_GPIO_PER_BANK
      - always have 32 GPIOs per bank and add 'width' member in
        struct bank to hold actual number of GPIOs in use
      - mark of_match table as const
      List-usage-fixed-by: NBrian Norris <computersforpeace@gmail.com>
      Signed-off-by: NGregory Fong <gregory.0xf0@gmail.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      3b0213d5
  3. 06 5月, 2015 2 次提交
  4. 05 5月, 2015 1 次提交
  5. 09 4月, 2015 1 次提交
    • L
      gpio: dwapb: remove dependencies · 549c5dc1
      Linus Walleij 提交于
      The Synopsys DesignWare DWAPB GPIO block is popular to
      synthesize amongst many architectures: X86, ARM, ARC.
      The driver was restricted to only these archs due to
      using [read|write]l_relaxed() accessors that were not
      universally available in the past,
      but as of commit 9439eb3a
      "asm-generic: io: implement relaxed accessor macros as
      conditional wrappers" these accessors are available on all
      archs so this should not be a problem any more. Enable the
      driver for all archs.
      
      Cc: Alexey Brodkin <Alexey.Brodkin@synopsys.com>
      Cc: Will Deacon <will.deacon@arm.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      549c5dc1
  6. 08 4月, 2015 9 次提交
  7. 07 4月, 2015 1 次提交
  8. 04 4月, 2015 1 次提交
  9. 28 3月, 2015 1 次提交
  10. 26 3月, 2015 1 次提交
  11. 19 3月, 2015 1 次提交
  12. 18 3月, 2015 2 次提交
  13. 09 3月, 2015 1 次提交
  14. 08 3月, 2015 1 次提交
    • T
      drivers/gpio: Altera soft IP GPIO driver · c5abbba9
      Tien Hock Loh 提交于
      Adds a new driver for Altera soft GPIO IP. The driver is able to do
      read/write and allows GPIO to be a interrupt controller.
      
      Tested on Altera GHRD on interrupt handling and IO.
      
      v10:
      - Updated conflicting device tree parameters
      - Removed unused headers
      - Used macro instead of magic numbers for ngpio
      - Code readability cleanup using ?: and temporal variables
      - Removed leftover garbage and unnecessary function calls
      - Checked bgpio_init but unusable because Altera GPIO may not
        be a multiple of 8 bits
      
      v9:
      - Removed duplicated initialization on set_type using temporals
        to improve code readability in calling generic_handle_irq
      - Using ?: ternary to reduce code size
      
      v8:
      - Using for_each_set_bit
      - Added const for struct definition
      - Removed naggy pr_err
      - Sort alpha header
      - Remove unused macros
      - Use fixed width data types instead of unsigned long
      - Whitespace issue fixes
      - Removed _relaxed function for better compatibility across different
        CPU
      - Changed irq_create_mapping to platform_get_irq updated implementation
        to use gpiochip_irqchip_add
      - Reserve interrupt-cells number 2 in device tree binding for future
        use
      - Remove confusing sections on devicetree bindings
      - Added tristate Kconfig help text
      
      v7:
      - Used dev_warn instead of pr_warn
      - Clean up unnecesarry if else indentation
      
      v6:
      - Added irq_startup and irq_shutdown
      - Changed bitwise clamping style
      - Cleanup bitwise operation to improve readability change naming of
        mapped irqs from virq to mapped_irq
      
      v5:
      - Dispose irq_domain mapping correctly
      - Update optional binding description in binding docs
      
      v4:
      - Added vendor prefix to devicetree binding for IP specific properties
        using MMIO GPIO helper library instead of manually map PIO to memory
      - altera_gpio_chip inline struct documentation to kerneldoc
      - Using dev_ print to print a better failure message
      
      v2, v3:
      - Do not reference NO_IRQ
      - Updated irq_set_type to only allow the hardware configured irq type
      Signed-off-by: NTien Hock Loh <thloh@altera.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      c5abbba9
  15. 04 3月, 2015 1 次提交
  16. 02 3月, 2015 1 次提交
    • L
      gpio: max732x: convert to GPIOLIB_IRQCHIP · 984f6643
      Linus Walleij 提交于
      Take a sweep to bring the irq support for the MAX732x expanders
      into the gpiolib core to cut down on duplicated code.
      
      Only compile tested! I need some feedback from people using this
      expander with interrupts to tell me if things go right or
      wrong when I do this.
      
      Cc: Semen Protsenko <semen.protsenko@globallogic.com>
      Cc: Mans Rullgard <mans@mansr.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      984f6643
  17. 04 2月, 2015 1 次提交
  18. 20 1月, 2015 3 次提交
  19. 16 1月, 2015 7 次提交
  20. 09 1月, 2015 1 次提交
  21. 11 11月, 2014 1 次提交
  22. 28 10月, 2014 1 次提交
    • L
      gpio: dwapb: fix compile errors · 1972c97d
      Linus Walleij 提交于
      Whereas the DWAPB driver does not really depend on the ARM
      architecture, it uses [readl|writel]_relaxed() not found on
      arch such as Blackfin, so restrict this to ARM until there is
      another architecture that can make use of it.
      
      It is also using the of_node of the gpiochip, so fix this
      too by requiring OF_GPIO.
      
      All error/warnings:
      
      make.cross ARCH=blackfin
      drivers/gpio/gpio-dwapb.c: In function 'dwapb_irq_handler':
      drivers/gpio/gpio-dwapb.c:91:2: error: implicit declaration of function 'readl_relaxed' [-Werror=implicit-function-declaration]
      drivers/gpio/gpio-dwapb.c: In function 'dwapb_configure_irqs':
      drivers/gpio/gpio-dwapb.c:212:32: error: 'struct gpio_chip' has no member named 'of_node'
      drivers/gpio/gpio-dwapb.c:221:16: error: 'struct gpio_chip' has no member named 'of_node'
      drivers/gpio/gpio-dwapb.c: In function 'dwapb_gpio_add_port':
      drivers/gpio/gpio-dwapb.c:331:14: error: 'struct gpio_chip' has no member named 'of_node'
      cc1: some warnings being treated as errors
      
      Cc: Jamie Iles <jamie@jamieiles.com>
      Cc: Alan Tull <atull@altera.com>
      Reported-by: Nkbuild test robot <fengguang.wu@intel.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      1972c97d