1. 08 Nov, 2012 9 commits
    • Paul Walmsley's avatar
      ARM: OMAP2xxx: APLL/CM: convert to use omap2_cm_wait_module_ready() · b6ffa050
      Paul Walmsley authored
      Convert the OMAP2xxx APLL code to use omap2_cm_wait_module_ready(),
      and move the low-level CM register manipulation functions to
      mach-omap2/cm2xxx.c.  The objectives here are to remove the dependency
      on the deprecated omap2_cm_wait_idlest() function in
      mach-omap2/prcm.c, so that code can be removed later; and move
      low-level register accesses to the CM IP block to the CM code, which
      will soon be moved into drivers/.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      
      b6ffa050
    • Paul Walmsley's avatar
      ARM: OMAP2+: board files: use SoC-specific system restart functions · 187e3e06
      Paul Walmsley authored
      Modify the board files to use the SoC-specific system restart
      functions.  At this point it's possible to remove omap_prcm_restart()
      from mach-omap2/prcm.c.
      
      While removing the prototypes for the now-unused restart functions, clean
      up a few more obsolete prototypes in mach-omap2/clock.h.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      187e3e06
    • Paul Walmsley's avatar
      ARM: OMAP2+: PRCM: create SoC-specific chip restart functions · 2f334a38
      Paul Walmsley authored
      Split omap_prcm_restart() from mach-omap2/prcm.c into SoC-specific
      variants.  These functions need to be able to save the reboot reason
      into the scratchpad RAM.  This implies a dependency on both the PRM
      and SCM IP blocks, so they've been moved into their own file.  This
      will eventually call functions in the PRM and SCM drivers, once those
      are created.
      
      Vaibhav Hiremath <hvaibhav@ti.com> identified an unused prototype in
      the first version of this patch - now removed.  Tony Lindgren
      <tony@atomide.com> noted a compile problem with some RMK Kconfigs;
      resolved in this patch.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Cc: Vaibhav Hiremath <hvaibhav@ti.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      Cc: Tony Lindgren <tony@atomide.com>
      2f334a38
    • Paul Walmsley's avatar
      ARM: OMAP2xxx: clock: move virt_prcm_set code into clkt2xxx_virt_prcm_set.c · baa689b8
      Paul Walmsley authored
      Collect all of the virt_prcm_set-specific clocktype code into
      mach-omap2/clkt2xxx_virt_prcm_set.c.  Remove its dependency on the
      'sclk' and 'vclk' global variables.  Those variables will be removed
      by subsequent patches.
      
      This is part of the process of cleaning up the OMAP2xxx clock code
      and preparing for the removal of the omap_prcm_restart() function.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      baa689b8
    • Paul Walmsley's avatar
      ARM: OMAP2xxx: clock: remove global 'dclk' variable · 5f039377
      Paul Walmsley authored
      Remove the global 'dclk' variable, instead replacing it with a
      variable local to the dpllcore clock type C file.  This removes some
      of the special-case code surrounding the OMAP2xxx clock init.
      
      This patch is a prerequisite for the removal of the
      omap_prcm_restart() code from arch/arm/mach-omap2/prcm.c.  It also
      cleans up some special-case OMAP2xxx clock code in the process.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      5f039377
    • Paul Walmsley's avatar
      ARM: OMAP2/3: PRM: add SoC reset functions (using the CORE DPLL method) · d08cce6a
      Paul Walmsley authored
      Add SoC reset functions into the PRM code.  These functions are based
      on code from mach-omap2/prcm.c.  They reset the SoC using the CORE DPLL
      reset method (as opposed to one of the other two or three chip reset
      methods).
      
      Adding them here will facilitate their removal from
      arch/arm/mach-omap2/prcm.c.  (prcm.c is deprecated.)
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      d08cce6a
    • Paul Walmsley's avatar
      ARM: OMAP2+: common: remove mach-omap2/common.c globals and map_common_io code · b6a4226c
      Paul Walmsley authored
      Get rid of the mach-omap2/common.c globals by moving the global
      initialization for IP block addresses that must occur early into
      mach-omap2/io.c.  In the process, remove the *_map_common_io*() and
      SoC-specific *set_globals* functions.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      b6a4226c
    • Paul Walmsley's avatar
      ARM: OMAP2+: PRCM: remove omap_prcm_get_reset_sources() · 76e0e16d
      Paul Walmsley authored
      omap_prcm_get_reset_sources() is now unused; so, remove it.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Tested-by: default avatarVaibhav Hiremath <hvaibhav@ti.com>
      76e0e16d
    • Paul Walmsley's avatar
      watchdog: OMAP: use standard GETBOOTSTATUS interface; use platform_data fn ptr · 129f5577
      Paul Walmsley authored
      Previously the OMAP watchdog driver used a non-standard way to report
      the chip reset source via the GETBOOTSTATUS ioctl.  This patch
      converts the driver to use the standard WDIOF_* flags for this
      purpose.
      
      This patch may break existing userspace code that uses the existing
      non-standard data format returned by the OMAP watchdog driver's
      GETBOOTSTATUS ioctl.  To fetch detailed reset source information,
      userspace code will need to retrieve it directly from the CGRM or PRM
      drivers when those are completed.
      
      Previously, to fetch the reset source, the driver either read a
      register outside the watchdog IP block (OMAP1), or called a function
      exported directly from arch/arm/mach-omap2.  Both approaches are
      broken.  This patch also converts the driver to use a platform_data
      function pointer.  This approach is temporary, and is due to the lack
      of drivers for the OMAP16xx+ Clock Generation and Reset Management IP
      block and the OMAP2+ Power and Reset Management IP block.  Once
      drivers are available for those IP blocks, the watchdog driver can be
      converted to call exported functions from those drivers directly.
      At that point, the platform_data function pointer can be removed.
      
      In the short term, this patch is needed to allow the PRM code to be
      removed from arch/arm/mach-omap2 (it is being moved to a driver).
      
      This version integrates a fix from Jon Hunter <jon-hunter@ti.com>
      that avoids a NULL pointer dereference in a DT-only boot, and integrates
      a patch commit message fix from Felipe Balbi <balbi@ti.com>.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      Cc: Wim Van Sebroeck <wim@iguana.be>
      Acked-by: default avatarWim Van Sebroeck <wim@iguana.be>
      [paul@pwsan.com: integrated pdata fix from Jon Hunter]
      Cc: Jon Hunter <jon-hunter@ti.com>
      [paul@pwsan.com: integrated changelog fix from Felipe Balbi]
      Cc: Felipe Balbi <balbi@ti.com>
      129f5577
  2. 30 Oct, 2012 2 commits
    • Paul Walmsley's avatar
      ARM: OMAP2+: WDT: move init; add read_reset_sources pdata function pointer · 37c67d03
      Paul Walmsley authored
      The OMAP watchdog timer driver directly calls a function exported by
      code in arch/arm/mach-omap2.  This is not good; it tightly couples
      this driver to the mach-omap2 integration code.  Instead, add a
      temporary platform_data function pointer to abstract this function
      call.  A subsequent patch will convert the watchdog driver to use this
      function pointer.
      
      This patch also moves the device creation code out of
      arch/arm/mach-omap2/devices.c and into arch/arm/mach-omap2/wd_timer.c.
      This is another step towards the removal of
      arch/arm/mach-omap2/devices.c.
      
      Cc: Wim Van Sebroeck <wim@iguana.be>
      Acked-by: default avatarWim Van Sebroeck <wim@iguana.be>
      [paul@pwsan.com: skip wd_timer device creation when DT blob is present]
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      37c67d03
    • Paul Walmsley's avatar
      ARM: OMAP1: CGRM: fix omap1_get_reset_sources() return type · 508c0d47
      Paul Walmsley authored
      An older version of the patch "ARM: OMAP1: create read_reset_sources()
      function (for initial use by watchdog)" was sent upstream, which used
      the wrong return type for the omap1_get_reset_sources() function.
      Fix it to return a u32, which is what the WDTIMER platform_data
      function pointer read_reset_sources() expects.
      Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
      508c0d47
  3. 26 Oct, 2012 5 commits
  4. 25 Oct, 2012 2 commits
  5. 24 Oct, 2012 11 commits
  6. 22 Oct, 2012 11 commits