1. 24 2月, 2014 1 次提交
  2. 26 12月, 2013 6 次提交
  3. 21 11月, 2013 1 次提交
  4. 24 9月, 2013 2 次提交
  5. 01 9月, 2012 1 次提交
  6. 13 3月, 2012 2 次提交
    • S
      gpio/davinci: fix enabling unbanked GPIO IRQs · 81b279d8
      Sekhar Nori 提交于
      Unbanked GPIO IRQ handling code made a copy of just
      the irq_chip structure for GPIO IRQ lines which caused
      problems after the generic IRQ chip conversion because
      there was no valid irq_chip_type structure with the
      right "regs" populated. irq_gc_mask_set_bit() was
      therefore accessing random addresses.
      
      Fix it by making a copy of irq_chip_type structure
      instead. This will ensure sane register offsets.
      
      Cc: <stable@vger.kernel.org> # v3.0.x+
      Reported-by: NJon Povey <Jon.Povey@racelogic.co.uk>
      Tested-by: NJon Povey <Jon.Povey@racelogic.co.uk>
      Signed-off-by: NSekhar Nori <nsekhar@ti.com>
      Signed-off-by: NGrant Likely <grant.likely@secretlab.ca>
      81b279d8
    • S
      gpio/davinci: fix oops on unbanked gpio irq request · ab2dde99
      Sekhar Nori 提交于
      Unbanked GPIO irq setup code was overwriting chip_data leading
      to the following oops on request_irq()
      
      Unable to handle kernel paging request at virtual address febfffff
      pgd = c22dc000
      [febfffff] *pgd=00000000
      Internal error: Oops: 801 [#1] PREEMPT
      Modules linked in: mcu(+) edmak irqk cmemk
      CPU: 0    Not tainted  (3.0.0-rc7+ #93)
      PC is at irq_gc_mask_set_bit+0x68/0x7c
      LR is at vprintk+0x22c/0x484
      pc : [<c0080c0c>]    lr : [<c00457e0>]    psr: 60000093
      sp : c33e3ba0  ip : c33e3af0  fp : c33e3bc4
      r10: c04555bc  r9 : c33d4340  r8 : 60000013
      r7 : 0000002d  r6 : c04555bc  r5 : fec67010  r4 : 00000000
      r3 : c04734c8  r2 : fec00000  r1 : ffffffff  r0 : 00000026
      Flags: nZCv  IRQs off  FIQs on  Mode SVC_32  ISA ARM  Segment user
      Control: 0005317f  Table: 822dc000  DAC: 00000015
      Process modprobe (pid: 526, stack limit = 0xc33e2270)
      Stack: (0xc33e3ba0 to 0xc33e4000)
      3ba0: 00000000 c007d3d4 c33e3bcc c04555bc c04555bc c33d4340 c33e3bdc c33e3bc8
      3bc0: c007f5f8 c0080bb4 00000000 c04555bc c33e3bf4 c33e3be0 c007f654 c007f5c0
      3be0: 00000000 c04555bc c33e3c24 c33e3bf8 c007e6e8 c007f618 c01f2284 c0350af8
      3c00: c0405214 bf016c98 00000001 00000000 c33dc008 0000002d c33e3c54 c33e3c28
      3c20: c007e888 c007e408 00000001 c23ef880 c33dc000 00000000 c33dc080 c25caa00
      3c40: c0487498 bf017078 c33e3c94 c33e3c58 bf016b44 c007e7d4 bf017078 c33dc008
      3c60: c25caa08 c33dc008 c33e3c84 bf017484 c25caa00 c25caa00 c01f5f48 c25caa08
      3c80: c0496d60 bf017484 c33e3ca4 c33e3c98 c022a698 bf01692c c33e3cd4 c33e3ca8
      3ca0: c01f5d88 c022a688 00000000 bf017484 c25caa00 c25caa00 c01f5f48 c25caa08
      3cc0: c0496d60 00000000 c33e3cec c33e3cd8 c01f5f8c c01f5d10 00000000 c33e3cf0
      3ce0: c33e3d14 c33e3cf0 c01f5210 c01f5f58 c303cb48 c25ecf94 c25caa00 c25caa00
      3d00: c25caa34 c33e3dd8 c33e3d34 c33e3d18 c01f6044 c01f51b8 c0496d3c c25caa00
      3d20: c044e918 c33e3dd8 c33e3d44 c33e3d38 c01f4ff4 c01f5fcc c33e3d94 c33e3d48
      3d40: c01f3d10 c01f4fd8 00000000 c044e918 00000000 00000000 c01f52c0 c034d570
      3d60: c33e3d84 c33e3d70 c022bf84 c25caa00 00000000 c044e918 c33e3dd8 c25c2e00
      3d80: c0496d60 bf01763c c33e3db4 c33e3d98 c022b1a0 c01f384c c25caa00 c33e3dd8
      3da0: 00000000 c33e3dd8 c33e3dd4 c33e3db8 c022b27c c022b0e8 00000000 bf01763c
      3dc0: c0451c80 c33e3dd8 c33e3e34 c33e3dd8 bf016f60 c022b210 5f75636d 746e6f63
      3de0: 006c6f72 00000000 00000000 00000000 00000000 00000000 00000000 bf0174bc
      3e00: 00000000 00989680 00000000 00000020 c0451c80 c0451c80 bf0174dc c01f5eb0
      3e20: c33f0f00 bf0174dc c33e3e44 c33e3e38 c01f72f4 bf016e2c c33e3e74 c33e3e48
      3e40: c01f5d88 c01f72e4 00000000 c0451c80 c0451cb4 bf0174dc c01f5eb0 c33f0f00
      3e60: c0473100 00000000 c33e3e94 c33e3e78 c01f5f44 c01f5d10 00000000 c33e3e98
      3e80: bf0174dc c01f5eb0 c33e3ebc c33e3e98 c01f5534 c01f5ec0 c303c038 c3061c30
      3ea0: 00003cd8 00098258 bf0174dc c0462ac8 c33e3ecc c33e3ec0 c01f5bec c01f54dc
      3ec0: c33e3efc c33e3ed0 c01f4d30 c01f5bdc bf0173a0 c33e2000 00003cd8 00098258
      3ee0: bf0174dc c33e2000 c00301a4 bf019000 c33e3f1c c33e3f00 c01f6588 c01f4c8c
      3f00: 00003cd8 00098258 00000000 c33e2000 c33e3f2c c33e3f20 c01f777c c01f6524
      3f20: c33e3f3c c33e3f30 bf019014 c01f7740 c33e3f7c c33e3f40 c002f3ec bf019010
      3f40: 00000000 00003cd8 00098258 bf017518 00000000 00003cd8 00098258 bf017518
      3f60: 00000000 c00301a4 c33e2000 00000000 c33e3fa4 c33e3f80 c007b934 c002f3c4
      3f80: c00b307c c00b2f48 00003cd8 00000000 00000003 00000080 00000000 c33e3fa8
      3fa0: c0030020 c007b8b8 00003cd8 00000000 00098288 00003cd8 00098258 00098240
      3fc0: 00003cd8 00000000 00000003 00000080 00098008 00098028 00098288 00000001
      3fe0: be892998 be892988 00013d7c 40178740 60000010 00098288 09089041 00200845
      Backtrace:
      [<c0080ba4>] (irq_gc_mask_set_bit+0x0/0x7c) from [<c007f5f8>] (irq_enable+0x48/0x58)
       r6:c33d4340 r5:c04555bc r4:c04555bc
      [<c007f5b0>] (irq_enable+0x0/0x58) from [<c007f654>] (irq_startup+0x4c/0x54)
       r5:c04555bc r4:00000000
      [<c007f608>] (irq_startup+0x0/0x54) from [<c007e6e8>] (__setup_irq+0x2f0/0x3cc)
       r5:c04555bc r4:00000000
      [<c007e3f8>] (__setup_irq+0x0/0x3cc) from [<c007e888>] (request_threaded_irq+0xc4/0x110)
       r8:0000002d r7:c33dc008 r6:00000000 r5:00000001 r4:bf016c98
      [<c007e7c4>] (request_threaded_irq+0x0/0x110) from [<bf016b44>] (mcu_spi_probe+0x228/0x37c [mcu])
      [<bf01691c>] (mcu_spi_probe+0x0/0x37c [mcu]) from [<c022a698>] (spi_drv_probe+0x20/0x24)
      [<c022a678>] (spi_drv_probe+0x0/0x24) from [<c01f5d88>] (driver_probe_device+0x88/0x1b0)
      [<c01f5d00>] (driver_probe_device+0x0/0x1b0) from [<c01f5f8c>] (__device_attach+0x44/0x48)
      [<c01f5f48>] (__device_attach+0x0/0x48) from [<c01f5210>] (bus_for_each_drv+0x68/0x94)
       r5:c33e3cf0 r4:00000000
      [<c01f51a8>] (bus_for_each_drv+0x0/0x94) from [<c01f6044>] (device_attach+0x88/0xa0)
       r7:c33e3dd8 r6:c25caa34 r5:c25caa00 r4:c25caa00
      [<c01f5fbc>] (device_attach+0x0/0xa0) from [<c01f4ff4>] (bus_probe_device+0x2c/0x4c)
       r7:c33e3dd8 r6:c044e918 r5:c25caa00 r4:c0496d3c
      [<c01f4fc8>] (bus_probe_device+0x0/0x4c) from [<c01f3d10>] (device_add+0x4d4/0x648)
      [<c01f383c>] (device_add+0x0/0x648) from [<c022b1a0>] (spi_add_device+0xc8/0x128)
      [<c022b0d8>] (spi_add_device+0x0/0x128) from [<c022b27c>] (spi_new_device+0x7c/0xb4)
       r7:c33e3dd8 r6:00000000 r5:c33e3dd8 r4:c25caa00
      [<c022b200>] (spi_new_device+0x0/0xb4) from [<bf016f60>] (mcu_probe+0x144/0x224 [mcu])
       r7:c33e3dd8 r6:c0451c80 r5:bf01763c r4:00000000
      [<bf016e1c>] (mcu_probe+0x0/0x224 [mcu]) from [<c01f72f4>] (platform_drv_probe+0x20/0x24)
      [<c01f72d4>] (platform_drv_probe+0x0/0x24) from [<c01f5d88>] (driver_probe_device+0x88/0x1b0)
      [<c01f5d00>] (driver_probe_device+0x0/0x1b0) from [<c01f5f44>] (__driver_attach+0x94/0x98)
      [<c01f5eb0>] (__driver_attach+0x0/0x98) from [<c01f5534>] (bus_for_each_dev+0x68/0x94)
       r7:c01f5eb0 r6:bf0174dc r5:c33e3e98 r4:00000000
      [<c01f54cc>] (bus_for_each_dev+0x0/0x94) from [<c01f5bec>] (driver_attach+0x20/0x28)
       r7:c0462ac8 r6:bf0174dc r5:00098258 r4:00003cd8
      [<c01f5bcc>] (driver_attach+0x0/0x28) from [<c01f4d30>] (bus_add_driver+0xb4/0x258)
      [<c01f4c7c>] (bus_add_driver+0x0/0x258) from [<c01f6588>] (driver_register+0x74/0x158)
      [<c01f6514>] (driver_register+0x0/0x158) from [<c01f777c>] (platform_driver_register+0x4c/0x60)
       r7:c33e2000 r6:00000000 r5:00098258 r4:00003cd8
      [<c01f7730>] (platform_driver_register+0x0/0x60) from [<bf019014>] (mcu_init+0x14/0x20 [mcu])
      [<bf019000>] (mcu_init+0x0/0x20 [mcu]) from [<c002f3ec>] (do_one_initcall+0x38/0x170)
      [<c002f3b4>] (do_one_initcall+0x0/0x170) from [<c007b934>] (sys_init_module+0x8c/0x1a4)
      [<c007b8a8>] (sys_init_module+0x0/0x1a4) from [<c0030020>] (ret_fast_syscall+0x0/0x2c)
       r7:00000080 r6:00000003 r5:00000000 r4:00003cd8
      Code: e1844003 e585400c e596300c e5932064 (e7814002)
      
      Fix the issue.
      
      Cc: <stable@vger.kernel.org> # v3.0.x+
      Reported-by: NJon Povey <Jon.Povey@racelogic.co.uk>
      Signed-off-by: NSekhar Nori <nsekhar@ti.com>
      Signed-off-by: NGrant Likely <grant.likely@secretlab.ca>
      ab2dde99
  7. 05 9月, 2011 1 次提交
  8. 22 8月, 2011 1 次提交
  9. 08 8月, 2011 1 次提交
  10. 12 7月, 2011 1 次提交
    • I
      arm: davinci: Fix low level gpio irq handlers' argument · f299bb95
      Ido Yariv 提交于
      Commit 74164016 ("arm: davinci: Fix fallout from generic irq chip
      conversion") introduced a bug, causing low level interrupt handlers to
      get a bogus irq number as an argument. The gpio irq handler falsely
      assumes that the handler data is the irq base number and that is no
      longer true.
      
      Set the irq handler data to be a pointer to the corresponding gpio
      controller. The chained irq handler can then use it to extract both the
      irq base number and the gpio registers structure.
      Signed-off-by: NIdo Yariv <ido@wizery.com>
      CC: Thomas Gleixner <tglx@linutronix.de>
      [nsekhar@ti.com: renamed "ctl" to "d", simplified indexing logic for chips and
      took care of odd bank handling in irq handler]
      Signed-off-by: NSekhar Nori <nsekhar@ti.com>
      f299bb95
  11. 08 6月, 2011 1 次提交
  12. 29 3月, 2011 2 次提交
  13. 14 1月, 2011 1 次提交
  14. 14 5月, 2010 1 次提交
  15. 07 5月, 2010 8 次提交
  16. 26 11月, 2009 1 次提交
  17. 26 8月, 2009 1 次提交
    • D
      davinci: dm365 gpio irq support · 7a36071e
      David Brownell 提交于
      Support DM365 GPIOs ... primarily by handling non-banked GPIO IRQs:
      
       - Flag DM365 chips as using non-banked GPIO interrupts, using a
         new soc_info field.
      
       - Replace the gpio_to_irq() mapping logic.  This now uses some
         runtime infrastructure, keyed off that new soc_info field,
         which doesn't handle irq_to_gpio().
      
       - Provide a new irq_chip ... GPIO IRQs handled directly by AINTC
         still need edge triggering managed by the GPIO controller.
      
      DM365 chips no longer falsely report 104 GPIO IRQs as they boot.
      
      Intelligence about IRQ muxing is missing, so for the moment this
      only exposes the first eight DM365 GPIOs, which are never muxed.
      The next eight are muxed, half with Ethernet (which uses most of
      those pins anyway).
      
      Tested on DM355 (10 unbanked IRQs _or_ 104 banked ones) and also
      on DM365 (16 unbanked ones, only 8 made available).
      Signed-off-by: NDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: NKevin Hilman <khilman@deeprootsystems.com>
      7a36071e
  18. 29 5月, 2009 1 次提交
    • M
      davinci: Make GPIO code more generic · a994955c
      Mark A. Greer 提交于
      The current gpio code needs to know the number of
      gpio irqs there are and what the bank irq number is.
      To determine those values, it checks the SoC type.
      
      It also assumes that the base address and the number
      of irqs the interrupt controller uses is fixed.
      
      To clean up the SoC checks and make it support
      different base addresses and interrupt controllers,
      have the SoC-specific code set those values in
      the soc_info structure and have the gpio code
      reference them there.
      Signed-off-by: NMark A. Greer <mgreer@mvista.com>
      Signed-off-by: NKevin Hilman <khilman@deeprootsystems.com>
      a994955c
  19. 26 5月, 2009 2 次提交
  20. 28 4月, 2009 1 次提交
    • D
      davinci: gpio bugfixes · 474dad54
      David Brownell 提交于
      Update the DaVinci GPIO code to work better on non-dm6446 parts,
      notably the dm355:
      
       - Only handle the number of GPIOs the chip actually has.  So
         for example on dm6467, GPIO-42 is the last GPIO, and trying
         to use GPIO-43 now fails cleanly; or GPIO-72 on dm6446.
      
       - Enable GPIO interrupts on each 16-bit GPIO-irq bank ...
         previously, only the first five were enabled, so GPIO-80
         and above (on dm355) wouldn't trigger IRQs.
      
       - Use the right IRQ for each GPIO bank.  The wrong values were
         used for dm355 chips, so GPIO IRQs got routed incorrectly.
      
       - Handle up to four pairs of 16-bit GPIO banks ... previously
         only three were handled, so accessing GPIO-96 and up (e.g. on
         dm355) would oops.
      
       - Update several comments that were dm6446-specific.
      
      Verified by receiving GPIO-1 (dm9000) and GPIO-5 (msp430) IRQs
      on the DM355 EVM.
      
      One thing this doesn't do is handle the way some of the GPIO
      numbers on dm6467 are reserved but aren't valid as GPIOs.  Some
      bitmap logic could fix that if needed.
      Signed-off-by: NDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: NKevin Hilman <khilman@deeprootsystems.com>
      474dad54
  21. 09 10月, 2008 1 次提交
  22. 17 9月, 2008 1 次提交
  23. 07 8月, 2008 1 次提交
  24. 12 7月, 2007 1 次提交