1. 08 7月, 2012 7 次提交
    • S
      I2C: OMAP: Handle error check for pm runtime · 3b0fb97c
      Shubhrajyoti D 提交于
      If PM runtime get_sync fails return with the error
      so that no further reads/writes goes through the interface.
      This will avoid possible abort. Add a error message in case
      of failure with the cause of the failure.
      Reviewed-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NShubhrajyoti D <shubhrajyoti@ti.com>
      Signed-off-by: NWolfram Sang <w.sang@pengutronix.de>
      3b0fb97c
    • S
      I2C: OMAP: Fix the crash in i2c remove · 0861f430
      Shubhrajyoti D 提交于
          In omap_i2c_remove we are accessing the I2C_CON register without
          enabling the clocks. Fix the same by ensure device is accessible by calling
          pm_runtime_get_sync before accessing the registers and calling pm_runtime_put
          after accessing.
      
          This fixes the following crash.
          [  154.723022] ------------[ cut here ]------------
          [  154.725677] WARNING: at arch/arm/mach-omap2/omap_l3_noc.c:112 l3_interrupt_handler+0x1b4/0x1c4()
          [  154.725677] L3 custom error: MASTER:MPU TARGET:L4 PER2
          [  154.742614] Modules linked in: i2c_omap(-)
          [  154.746948] Backtrace:
          [  154.746948] [<c0013078>] (dump_backtrace+0x0/0x110) from [<c026c158>] (dump_stack+0x18/0x1c)
          [  154.752716]  r6:00000070 r5:c002c43c r4:df9b9e98 r3:df9b8000
          [  154.764465] [<c026c140>] (dump_stack+0x0/0x1c) from [<c0041a2c>] (warn_slowpath_common+0x5c/0x6c)
          [  154.768341] [<c00419d0>] (warn_slowpath_common+0x0/0x6c) from [<c0041ae0>] (warn_slowpath_fmt+0x38/0x40)
          [  154.776153]  r8:00000180 r7:c0361594 r6:c0379b48 r5:00080003 r4:e0838b00
          [  154.790771] r3:00000009
          [  154.791778] [<c0041aa8>] (warn_slowpath_fmt+0x0/0x40) from [<c002c43c>] (l3_interrupt_handler+0x1b4/0x1c4)
          [  154.803710]  r3:c0361598 r2:c02ef74c
          [  154.807403] [<c002c288>] (l3_interrupt_handler+0x0/0x1c4) from [<c0085f44>] (handle_irq_event_percpu+0x58/0
          [  154.818237]  r8:0000002a r7:00000000 r6:00000000 r5:df808054 r4:df8893c0
          [  154.825378] [<c0085eec>] (handle_irq_event_percpu+0x0/0x188) from [<c00860b8>] (handle_irq_event+0x44/0x64)
          [  154.835662] [<c0086074>] (handle_irq_event+0x0/0x64) from [<c0088ec0>] (handle_fasteoi_irq+0xa4/0x10c)
          [  154.845458]  r6:0000002a r5:df808054 r4:df808000 r3:c034a150
          [  154.846466] [<c0088e1c>] (handle_fasteoi_irq+0x0/0x10c) from [<c0085ed0>] (generic_handle_irq+0x30/0x38)
          [  154.854278]  r5:c034aa48 r4:0000002a
          [  154.862091] [<c0085ea0>] (generic_handle_irq+0x0/0x38) from [<c000fd38>] (handle_IRQ+0x60/0xc0)
          [  154.874450]  r4:c034ea70 r3:000001f8
          [  154.878234] [<c000fcd8>] (handle_IRQ+0x0/0xc0) from [<c0008478>] (gic_handle_irq+0x20/0x5c)
          [  154.887023]  r7:ffffff40 r6:df9b9fb0 r5:c034e2b4 r4:0000001a
          [  154.887054] [<c0008458>] (gic_handle_irq+0x0/0x5c) from [<c000ea80>] (__irq_usr+0x40/0x60)
          [  154.901153] Exception stack(0xdf9b9fb0 to 0xdf9b9ff8)
          [  154.907104] 9fa0:                                     beaf1f04 4006be00 0000000f 0000000c
          [  154.915710] 9fc0: 4006c000 00000000 00008034 ffffff40 00000007 00000000 00000000 0007b8d7
          [  154.916778] 9fe0: 00000000 beaf1b68 0000d23c 4005baf0 80000010 ffffffff
          [  154.931335]  r6:ffffffff r5:80000010 r4:4005baf0 r3:beaf1f04
          [  154.937316] ---[ end trace 1b75b31a2719ed21 ]--
      
      Cc: Rajendra Nayak <rnayak@ti.com>
      Cc: Linux PM list <linux-pm@vger.kernel.org>
      Reviewed-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NShubhrajyoti D <shubhrajyoti@ti.com>
      Signed-off-by: NWolfram Sang <w.sang@pengutronix.de>
      0861f430
    • S
      I2C: OMAP: Don't check if wait_for_completion_timeout() returns less than zero · 33d54985
      Shubhrajyoti D 提交于
      By definition, wait_for_completion_timeout() returns an unsigned value and
      therefore, it is not necessary to check if the return value is less than zero
      as this is not possible.
      
      This is based on a patch from Jon Hunter <jon-hunter@ti.com>
      Changes from his patch
      - Declare a long as the wait_for_completion_timeout returns long.
      
      Original patch is
      http://git.omapzoom.org/?p=kernel/omap.git;a=commitdiff;h=ea02cece7b0000bc736e60c4188a11aaa74bc6e6Reviewed-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NJon Hunter <jon-hunter@ti.com>
      Signed-off-by: NShubhrajyoti D <shubhrajyoti@ti.com>
      Signed-off-by: NWolfram Sang <w.sang@pengutronix.de>
      33d54985
    • S
      I2C: OMAP: Prevent the register access after pm_runtime_put in probe · 62ff2c2b
      Shubhrajyoti D 提交于
      Currently in probe
      pm_runtime_put(dev->dev);
      
      ...
              /* i2c device drivers may be active on return from add_adapter() */
              adap->nr = pdev->id;
              r = i2c_add_numbered_adapter(adap);
              if (r) {
                      dev_err(dev->dev, "failure adding adapter\n");
                      goto err_free_irq;
              }
      ...
      
      return 0;
      
      err_free_irq:
              free_irq(dev->irq, dev);
      err_unuse_clocks:
              omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, 0);
              pm_runtime_put(dev->dev);
      
      This may access the i2c registers without the clocks in the error cases.
      Fix the same by moving the pm_runtime_put after the error check.
      Reviewed-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NShubhrajyoti D <shubhrajyoti@ti.com>
      Signed-off-by: NWolfram Sang <w.sang@pengutronix.de>
      62ff2c2b
    • S
      I2C: OMAP: Fix the interrupt clearing in OMAP4 · bd16c82f
      Shubhrajyoti D 提交于
      On OMAP4 we were writing 1 to IRQENABLE_CLR which cleared only
      the arbitration lost interrupt. The patch intends to fix the same by writing 0
      to the IE register clearing all interrupts.
      
      This is based on the work done by Vikram Pandita <vikram.pandita@ti.com>.
      
      The  changes from the original patch ...
      -  Does not use the IRQENABLE_CLR register to clear as it is not mentioned
        to be legacy register IRQENABLE_CLR helps in  atomically
        setting/clearing specific interrupts, instead use the OMAP_I2C_IE_REG as we
        are clearing all interrupts.
      
      Cc: Vikram Pandita <vikram.pandita@ti.com>
      Reviewed-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NShubhrajyoti D <shubhrajyoti@ti.com>
      Signed-off-by: NWolfram Sang <w.sang@pengutronix.de>
      bd16c82f
    • S
      I2C: OMAP: Fix the mismatch of pm_runtime enable and disable · 24740516
      Shubhrajyoti D 提交于
      Currently the i2c driver calls the pm_runtime_enable and never
      the disable. This may cause a warning when pm_runtime_enable
      checks for the count match.Fix the same by calling
      pm_runtime_disable in the error and the remove path.
      
      Cc: Rajendra Nayak <rnayak@ti.com>
      Acked-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NShubhrajyoti D <shubhrajyoti@ti.com>
      Signed-off-by: NWolfram Sang <w.sang@pengutronix.de>
      24740516
    • S
      I2C: OMAP: make omap_i2c_unidle/idle functions depend on CONFIG_PM_RUNTIME · 3dae3efb
      Shubhrajyoti D 提交于
      The functions omap_i2c_unidle/idle are called from omap_i2c_runtime_resume
      and omap_i2c_runtime_suspend which is compiled for CONFIG_PM_RUNTIME.
      This patch removes the omap_i2c_unidle/idle functions and folds them
      into the runtime callbacks.
      
      This fixes the below warn when CONFIG_PM_RUNTIME is not defined
      
       CC      arch/arm/mach-omap2/board-ti8168evm.o
      drivers/i2c/busses/i2c-omap.c:272: warning: 'omap_i2c_unidle' defined but not used
      drivers/i2c/busses/i2c-omap.c:293: warning: 'omap_i2c_idle' defined but not used
        CC      net/ipv4/ip_forward.o
      Reviewed-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NShubhrajyoti D <shubhrajyoti@ti.com>
      Signed-off-by: NWolfram Sang <w.sang@pengutronix.de>
      3dae3efb
  2. 21 1月, 2012 1 次提交
    • C
      i2c: OMAP: Fix OMAP1 build error · 6c5aa407
      Cousson, Benoit 提交于
      CONFIG_OF is not defined for OMAP1 yet and thus the omap1_defconfig build
      generate an error for 3.3-rc1.
      
      drivers/i2c/busses/i2c-omap.c: In function 'omap_i2c_probe':
      drivers/i2c/busses/i2c-omap.c:1021:26: error: 'omap_i2c_of_match' undeclared (first use in this function)
      drivers/i2c/busses/i2c-omap.c:1021:26: note: each undeclared identifier is reported only once for each function it appears in
      
      Wrap omap_i2c_of_match with of_match_ptr() to prevent compilation error in case of OMAP1 build.
      Signed-off-by: NBenoit Cousson <b-cousson@ti.com>
      Cc: Ben Dooks <ben-linux@fluff.org>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      6c5aa407
  3. 18 1月, 2012 3 次提交
  4. 18 12月, 2011 1 次提交
  5. 29 10月, 2011 9 次提交
  6. 24 8月, 2011 1 次提交
  7. 11 7月, 2011 1 次提交
  8. 07 3月, 2011 1 次提交
  9. 23 2月, 2011 4 次提交
    • B
      i2c-omap: fixup commit cb527ede whitespace · a5a595cc
      Ben Dooks 提交于
      Fixup the whitespace error noticed in cb527edeSigned-off-by: NBen Dooks <ben-linux@fluff.org>
      a5a595cc
    • R
      i2c-omap: Double clear of ARDY status in IRQ handler · cb527ede
      Richard woodruff 提交于
      This errata occurs when the ARDY interrupt generation is enabled.
      At the begining of every new transaction the ARDY interrupt is cleared.
      
      On continuous i2c transactions where after clearing the ARDY bit from
      I2C_STAT register (clearing the interrupt), the IRQ line is reasserted and the
      I2C_STAT[ARDY] bit set again on 1. In fact, the ARDY status bit is not cleared
      at the write access to I2C_STAT[ARDY] and only the IRQ line is deasserted and
      then reasserted. This is not captured in the usual errata documents.
      
      The workaround is to have a double clear of ARDY status in irq handler.
      Signed-off-by: NRichard woodruff <r-woodruff2@ti.com>
      Signed-off-by: NKeerthy <j-keerthy@ti.com>
      Signed-off-by: NBen Dooks <ben-linux@fluff.org>
      cb527ede
    • B
      i2c-omap: fix build for !CONFIG_SUSPEND · f72487e7
      Balaji T K 提交于
      fix the build break when !CONFIG_SUSPEND
      
      drivers/i2c/busses/i2c-omap.c:1173: error: lvalue required as unary '&' operand
      make[3]: *** [drivers/i2c/busses/i2c-omap.o] Error 1
      make[2]: *** [drivers/i2c/busses] Error 2
      make[1]: *** [drivers/i2c] Error 2
      make: *** [drivers] Error 2
      Signed-off-by: NBalaji T K <balajitk@ti.com>
      Signed-off-by: NBen Dooks <ben-linux@fluff.org>
      f72487e7
    • K
      i2c-omap: fix static suspend vs. runtime suspend · adf6e079
      Kevin Hilman 提交于
      When runtime PM is enabled, each OMAP i2c device is suspended after
      each i2c xfer.  However, there are two cases when the static suspend
      methods must be used to ensure the devices are suspended:
      
      1) runtime PM is disabled, either at compile time or dynamically
          via /sys/devices/.../power/control.
      2) an i2c client driver uses i2c during it's suspend callback, thus
         leaving the i2c driver active (NOTE: runtime suspend transitions are
         disabled during system suspend, so i2c activity during system
         suspend will runtime resume the device, but not runtime (re)suspend it.)
      
      Since the actual work to suspend the device is handled by the
      subsytem, call the bus methods to take care of it.
      
      NOTE: This takes care of a known suspend problem on OMAP3 where the
      TWL RTC driver does i2c xfers during its suspend path leaving the i2c
      driver in an active state (since runtime suspend transistions are
      disabled.)
      Signed-off-by: NKevin Hilman <khilman@ti.com>
      Signed-off-by: NBen Dooks <ben-linux@fluff.org>
      adf6e079
  10. 04 1月, 2011 1 次提交
  11. 21 12月, 2010 1 次提交
  12. 10 11月, 2010 1 次提交
  13. 22 9月, 2010 1 次提交
  14. 20 5月, 2010 6 次提交
  15. 20 4月, 2010 1 次提交
    • M
      i2c-omap: fix OOPS in omap_i2c_unidle() during probe · 7c6bd201
      Mika Westerberg 提交于
      Commit d84d3ea3 added register shift to allow
      also 16-bit register access. However, omap_i2c_unidle() is called before these
      are set which causes the following OOPS:
      
          Unhandled fault: alignment exception (0x801) at 0xfa070009
          Internal error: : 801 [#1]
          last sysfs file:
          Modules linked in:
          CPU: 0    Not tainted  (2.6.34-rc2-00052-gae6be51e #3)
          PC is at omap_i2c_unidle+0x44/0x138
          LR is at trace_hardirqs_on_caller+0x158/0x18c
          pc : [<c01cd2c4>]    lr : [<c00743f8>]    psr: 20000013
          sp : cfc2bf10  ip : 00000009  fp : 00000000
          r10: 00000000  r9 : 00000000  r8 : c0378560
          r7 : c0378b88  r6 : c0378558  r5 : cfcadc00  r4 : cfcadc00
          r3 : 00000009  r2 : fa070000  r1 : 00000000  r0 : 00000000
          Flags: nzCv  IRQs on  FIQs on  Mode SVC_32  ISA ARM  Segment kernel
          Control: 10c5387f  Table: 80004019  DAC: 00000017
          Process swapper (pid: 1, stack limit = 0xcfc2a2e8)
          Stack: (0xcfc2bf10 to 0xcfc2c000)
          bf00:                                     c0372cf8 c027225c 00000000 c0a69678
          bf20: cfc3e508 c0500898 c0378560 c0378560 c0500898 cfcac8c0 c04fc280 c017d4f4
          bf40: c0378560 c017c63c c0378560 c0378594 c0500898 cfcac8c0 c04fc280 c017c754
          bf60: 00000000 c017c6f4 c0500898 c017beac cfc16a5c cfc3fd94 c0023448 c0500898
          bf80: c0500898 c017b7d4 c032dc7f 00000093 cfc28d40 c0023448 00000000 c0500898
          bfa0: 00000000 00000000 00000000 c017ca48 c0023448 00000000 c001d274 00000000
          bfc0: 00000000 c002b344 00000031 00000000 00000000 00000192 00000000 c0023448
          bfe0: 00000000 00000000 00000000 c0008578 00000000 c002c304 ffdfffff ffffffff
          [<c01cd2c4>] (omap_i2c_unidle+0x44/0x138) from [<c027225c>] (omap_i2c_probe+0x1a4/0x398)
          [<c027225c>] (omap_i2c_probe+0x1a4/0x398) from [<c017d4f4>] (platform_drv_probe+0x18/0x1c)
          [<c017d4f4>] (platform_drv_probe+0x18/0x1c) from [<c017c63c>] (driver_probe_device+0xc0/0x178)
          [<c017c63c>] (driver_probe_device+0xc0/0x178) from [<c017c754>] (__driver_attach+0x60/0x84)
          [<c017c754>] (__driver_attach+0x60/0x84) from [<c017beac>] (bus_for_each_dev+0x44/0x74)
          [<c017beac>] (bus_for_each_dev+0x44/0x74) from [<c017b7d4>] (bus_add_driver+0x9c/0x218)
          [<c017b7d4>] (bus_add_driver+0x9c/0x218) from [<c017ca48>] (driver_register+0xa8/0x130)
          [<c017ca48>] (driver_register+0xa8/0x130) from [<c002b344>] (do_one_initcall+0x5c/0x1b8)
          [<c002b344>] (do_one_initcall+0x5c/0x1b8) from [<c0008578>] (kernel_init+0x90/0x144)
          [<c0008578>] (kernel_init+0x90/0x144) from [<c002c304>] (kernel_thread_exit+0x0/0x8)
          Code: e5942004 e3a0c009 e1a0331c e3a01000 (e18210b3)
          ---[ end trace 1b75b31a2719ed1c ]---
      
      This patch moves register shift setting before any register accesses are done.
      Signed-off-by: NMika Westerberg <ext-mika.1.westerberg@nokia.com>
      Cc: Cory Maccarrone <darkstar6262@gmail.com>
      Signed-off-by: NBen Dooks <ben-linux@fluff.org>
      7c6bd201
  16. 30 3月, 2010 1 次提交
    • T
      include cleanup: Update gfp.h and slab.h includes to prepare for breaking... · 5a0e3ad6
      Tejun Heo 提交于
      include cleanup: Update gfp.h and slab.h includes to prepare for breaking implicit slab.h inclusion from percpu.h
      
      percpu.h is included by sched.h and module.h and thus ends up being
      included when building most .c files.  percpu.h includes slab.h which
      in turn includes gfp.h making everything defined by the two files
      universally available and complicating inclusion dependencies.
      
      percpu.h -> slab.h dependency is about to be removed.  Prepare for
      this change by updating users of gfp and slab facilities include those
      headers directly instead of assuming availability.  As this conversion
      needs to touch large number of source files, the following script is
      used as the basis of conversion.
      
        http://userweb.kernel.org/~tj/misc/slabh-sweep.py
      
      The script does the followings.
      
      * Scan files for gfp and slab usages and update includes such that
        only the necessary includes are there.  ie. if only gfp is used,
        gfp.h, if slab is used, slab.h.
      
      * When the script inserts a new include, it looks at the include
        blocks and try to put the new include such that its order conforms
        to its surrounding.  It's put in the include block which contains
        core kernel includes, in the same order that the rest are ordered -
        alphabetical, Christmas tree, rev-Xmas-tree or at the end if there
        doesn't seem to be any matching order.
      
      * If the script can't find a place to put a new include (mostly
        because the file doesn't have fitting include block), it prints out
        an error message indicating which .h file needs to be added to the
        file.
      
      The conversion was done in the following steps.
      
      1. The initial automatic conversion of all .c files updated slightly
         over 4000 files, deleting around 700 includes and adding ~480 gfp.h
         and ~3000 slab.h inclusions.  The script emitted errors for ~400
         files.
      
      2. Each error was manually checked.  Some didn't need the inclusion,
         some needed manual addition while adding it to implementation .h or
         embedding .c file was more appropriate for others.  This step added
         inclusions to around 150 files.
      
      3. The script was run again and the output was compared to the edits
         from #2 to make sure no file was left behind.
      
      4. Several build tests were done and a couple of problems were fixed.
         e.g. lib/decompress_*.c used malloc/free() wrappers around slab
         APIs requiring slab.h to be added manually.
      
      5. The script was run on all .h files but without automatically
         editing them as sprinkling gfp.h and slab.h inclusions around .h
         files could easily lead to inclusion dependency hell.  Most gfp.h
         inclusion directives were ignored as stuff from gfp.h was usually
         wildly available and often used in preprocessor macros.  Each
         slab.h inclusion directive was examined and added manually as
         necessary.
      
      6. percpu.h was updated not to include slab.h.
      
      7. Build test were done on the following configurations and failures
         were fixed.  CONFIG_GCOV_KERNEL was turned off for all tests (as my
         distributed build env didn't work with gcov compiles) and a few
         more options had to be turned off depending on archs to make things
         build (like ipr on powerpc/64 which failed due to missing writeq).
      
         * x86 and x86_64 UP and SMP allmodconfig and a custom test config.
         * powerpc and powerpc64 SMP allmodconfig
         * sparc and sparc64 SMP allmodconfig
         * ia64 SMP allmodconfig
         * s390 SMP allmodconfig
         * alpha SMP allmodconfig
         * um on x86_64 SMP allmodconfig
      
      8. percpu.h modifications were reverted so that it could be applied as
         a separate patch and serve as bisection point.
      
      Given the fact that I had only a couple of failures from tests on step
      6, I'm fairly confident about the coverage of this conversion patch.
      If there is a breakage, it's likely to be something in one of the arch
      headers which should be easily discoverable easily on most builds of
      the specific arch.
      Signed-off-by: NTejun Heo <tj@kernel.org>
      Guess-its-ok-by: NChristoph Lameter <cl@linux-foundation.org>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Lee Schermerhorn <Lee.Schermerhorn@hp.com>
      5a0e3ad6