1. 09 2月, 2009 15 次提交
    • R
      [ARM] omap: fix clockdomain enable/disable ordering · 8263e5b3
      Russell King 提交于
      Based on a patch from Paul Walmsley <paul@pwsan.com>:
      
       omap2_clk_enable() should enable a clock's clockdomain before
       attempting to enable its parent clock's clockdomain.  Similarly, in
       the unlikely event that the parent clock enable fails, the clockdomain
       should be disabled.
      
       linux-omap source commit is 6d6e285e5a7912b1ea68fadac387304c914aaba8.
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      8263e5b3
    • R
      [ARM] omap: fix usecount decrement bug · a7f8c599
      Russell King 提交于
      Based upon a patch from Paul Walmsley <paul@pwsan.com>:
      
       If _omap2_clk_enable() fails, the clock's usecount must be decremented
       by one no matter whether the clock has a parent or not.
      
      but reorganised a bit.
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      a7f8c599
    • P
      [ARM] OMAP2/3 clock: convert remaining MPU barriers into OCP barriers · f11fda6a
      Paul Walmsley 提交于
      Several parts of the OMAP2/3 clock code use wmb() to try to ensure
      that the hardware write completes before continuing.  This approach is
      problematic: wmb() only ensures that the write leaves the ARM.  It
      does not ensure that the write actually reaches the endpoint device.
      The endpoint device in this case - either the PRM, CM, or SCM - is
      three interconnects away from the ARM - and the final interconnect is
      low-speed.  And the OCP interconnects will post the write, and who
      knows how long that will take to complete.  So the wmb() is not what
      we want.  Worse, the wmb() is indiscriminate; it causes the ARM to
      flush any other unrelated buffered writes and wait for the local
      interconnect to acknowledge them - potentially very expensive.
      
      Fix this by converting the wmb()s into readbacks of the same PRM/CM/SCM
      register.  Since the PRM/CM/SCM devices use a single OCP thread, this
      will cause the MPU to block while waiting for posted writes to that device
      to complete.
      
      linux-omap source commit is 260f5487848681b4d8ea7430a709a601bbcb21d1.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      f11fda6a
    • P
      [ARM] OMAP2xxx clock: consolidate DELAYED_APP clock commits; fix barrier · 439764cc
      Paul Walmsley 提交于
      Consolidate the commit code for DELAYED_APP clocks into a subroutine,
      _omap2xxx_clk_commit().  Also convert the MPU barrier wmb() into an
      OCP barrier, since with an MPU barrier, we have no guarantee that the
      write actually reached the endpoint device.
      
      linux-omap source commit is 0f5bdb736515801b296125d16937a21ff7b3cfdc.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      439764cc
    • P
      [ARM] OMAP2/3 clock: don't use a barrier after clk_disable() · de07fedd
      Paul Walmsley 提交于
      clk_disable() previously used an ARM barrier, wmb(), to try to ensure
      that the hardware write completed before continuing.  There are some
      problems with this approach.
      
      The first problem is that wmb() only ensures that the write leaves the
      ARM -- not that it actually reaches the endpoint device.  In this
      case, the endpoint device - either the PRM, CM, or SCM - is three
      interconnects away from the ARM, and the final interconnect is
      low-speed.  And the OCP interconnects will post the write, who knows
      how long that will take to complete.  So the wmb() is not really what
      we want.
      
      Worse, the wmb() is indiscriminate; it will cause the ARM to flush any
      other unrelated buffered writes and wait for the local interconnect to
      acknowledge them - potentially very expensive.
      
      This first problem could be fixed by doing a readback of the same PRM/CM/SCM
      register.  Since these devices use a single OCP thread, this will cause the
      MPU to wait for the write to complete.
      
      But the primary problem is a conceptual one: clk_disable() should not
      need any kind of barrier.  clk_enable() needs one since device driver
      code must not access a device until its clocks are known to be
      enabled.  But clk_disable() has no such restriction.
      
      Since blocking the MPU on a PRM/CM/SCM write can be a very
      high-latency operation - several hundred MPU cycles - it's worth
      avoiding this barrier if possible.
      
      linux-omap source commit is f4aacad2c0ed1055622d5c1e910befece24ef0e2.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      de07fedd
    • R
      [ARM] omap: create a proper tree of clocks · 3f0a820c
      Russell King 提交于
      Traditionally, we've tracked the parent/child relationships between
      clk structures by setting the child's parent member to point at the
      upstream clock.  As a result, when decending the tree, we have had
      to scan all clocks to find the children.
      
      Avoid this wasteful scanning by keeping a list of the clock's children.
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      3f0a820c
    • T
      [ARM] OMAP3: PM: Make sure clk_disable_unused() order is correct · 8463e20a
      Tero Kristo 提交于
      Current implementation will disable clocks in the order defined in clock34xx.h,
      at least DPLL4_M2X2 will hang in certain cases (and prevent retention / off)
      if clocks are not disabled in correct order. This patch makes sure the parent
      clocks will be active when disabling a clock.
      
      linux-omap source commit is 672680063420ef8c8c4e7271984bb9cc08171d29.
      Signed-off-by: NTero Kristo <tero.kristo@nokia.com>
      Signed-off-by: NKevin Hilman <khilman@deeprootsystems.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      8463e20a
    • P
      [ARM] OMAP2 SDRC: move mach-omap2/memory.h into mach/sdrc.h · f8de9b2c
      Paul Walmsley 提交于
      Move the contents of the arch/arm/mach-omap2/memory.h file to the
      existing mach/sdrc.h file, and remove memory.h.  Modify files which
      include memory.h to include asm/arch/sdrc.h instead.
      
      linux-omap source commit is e7ae2d89921372fc4b9712a32cc401d645597807.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      f8de9b2c
    • P
      [ARM] OMAP2/3 clock: clean up mach-omap2/clock.c · ee1eec36
      Paul Walmsley 提交于
      This patch rolls up several cleanup patches.
      
      1. Some unnecessarily verbose variable names are used in several clock.c
      functions; clean these up per CodingStyle.
      
      2. Remove omap2_get_clksel() and just use clk->clksel_reg and
      clk->clksel_mask directly.
      
      3. Get rid of void __iomem * usage in omap2_clksel_get_src_field.
      Prepend the function name with an underscore to highlight that it is a
      static function.
      
      linux-omap source commits are 7fa95e007ea2f3c4d0ecd2779d809756e7775894,
      af0ea23f1ee4a5bea3b026e38761b47089f9048a, and
      91c0c979b47c44b08f80e4f8d4c990fb158d82c4.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      ee1eec36
    • P
      [ARM] OMAP3 clock: avoid invalid FREQSEL values during DPLL rate rounding · 95f538ac
      Paul Walmsley 提交于
      The DPLL FREQSEL jitter correction bits are set based on a table in
      the 34xx TRM, Table 4-38, according to the DPLL's internal clock
      frequency "Fint."  Several Fint frequency ranges are missing from this
      table.  Previously, we allowed these Fint frequency ranges to be
      selected in the rate rounding code, but did not change the FREQSEL bits.
      Correspondence with the OMAP hardware team indicates that Fint values
      not in the table should not be used.  So, prevent them from being
      selected during DPLL rate rounding.  This removes warnings and also
      can prevent the chip from locking up.
      
      The first pass through the rate rounding code will update the DPLL max
      and min dividers appropriately, so later rate rounding passes will run
      faster than the first.
      
      Peter de Schrijver <peter.de-schrijver@nokia.com> put up with several
      test cycles of this patch - thanks Peter.
      
      linux-omap source commit is f9c1b82f55b60fc39eaa6e7aa1fbe380c0ffe2e9.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Cc: Peter de Schrijver <peter.de-schrijver@nokia.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      95f538ac
    • P
      [ARM] OMAP3 clock: optimize DPLL rate rounding algorithm · 85a5f78d
      Paul Walmsley 提交于
      The previous DPLL rate rounding algorithm counted the divider (N) down
      from the maximum to 1.  Since we currently use a broad DPLL rate
      tolerance, and lower N values are more power-efficient, we can often
      bypass several iterations through the loop by counting N upwards from
      1.
      
      Peter de Schrijver <peter.de-schrijver@nokia.com> put up with several
      test cycles of this patch - thanks Peter.
      
      linux-omap source commit is 6f6d82bb2f80fa20a841ac3e95a6f44a5a156188.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Cc: Peter de Schrijver <peter.de-schrijver@nokia.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      85a5f78d
    • P
      [ARM] OMAP3 clock: remove unnecessary dpll_data dereferences · b3245040
      Paul Walmsley 提交于
      Remove some clutter from omap2_dpll_round_rate().
      
      linux-omap source commit is 4625dceb8583c02a6d67ededc9f6a8347b6b8cb7.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      b3245040
    • P
      [ARM] OMAP: Fix sparse, checkpatch warnings in OMAP2/3 PRCM/PM code · fecb494b
      Paul Walmsley 提交于
      Fix sparse & checkpatch warnings in OMAP2/3 PRCM & PM code.  This mostly
      consists of:
      
      - converting pointer comparisons to integers in form similar to
        (ptr == 0) to the standard idiom (!ptr)
      
      - labeling a few non-static private functions as static
      
      - adding prototypes for *_init() functions in the appropriate header
        files, and getting rid of the corresponding open-coded extern
        prototypes in other C files
      
      - renaming the variable 'sclk' in mach-omap2/clock.c:omap2_get_apll_clkin
        to avoid shadowing an earlier declaration
      
      Clean up checkpatch issues.  This mostly involves:
      
      - converting some asm/ includes to linux/ includes
      
      - cleaning up some whitespace
      
      - getting rid of braces for conditionals with single following statements
      
      Also take care of a few odds and ends, including:
      
      - getting rid of unlikely() and likely() - none of this code is particularly
        fast-path code, so the performance impact seems slim; and some of those
        likely() and unlikely() indicators are probably not as accurate as the
        ARM's branch predictor
      
      - removing some superfluous casts
      
      linux-omap source commit is 347df59f5d20fdf905afbc26b1328b0e28a8a01b.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      fecb494b
    • R
      [ARM] omap: move propagate_rate() calls into generic omap clock code · 9a5fedac
      Russell King 提交于
      propagate_rate() is recursive, so it makes sense to minimise the
      amount of stack which is used for each recursion.  So, rather than
      recursing back into it from the ->recalc functions if RATE_PROPAGATES
      is set, do that test at the higher level.
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      9a5fedac
    • R
      [ARM] omap: move clock propagation into core omap clock code · c6af4508
      Russell King 提交于
      Move the clock propagation calls for set_parent and set_rate into
      the core omap clock code, rather than having these calls scattered
      throughout the OMAP1 and OMAP2 implementations.
      Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
      c6af4508
  2. 08 2月, 2009 5 次提交
  3. 02 2月, 2009 1 次提交
  4. 06 9月, 2008 3 次提交
  5. 19 8月, 2008 1 次提交
  6. 07 8月, 2008 1 次提交
  7. 03 7月, 2008 2 次提交
    • P
      ARM: OMAP2: Clock: New OMAP2/3 DPLL rate rounding algorithm · 88b8ba90
      Paul Walmsley 提交于
      This patch adds a new rate rounding algorithm for DPLL clocks on the
      OMAP2/3 architecture.
      
      For a desired DPLL target rate, there may be several
      multiplier/divider (M, N) values which will generate a sufficiently
      close rate.  Lower N values result in greater power economy.  However,
      lower N values can cause the difference between the rounded rate and
      the target rate ("rate error") to be larger than it would be with a
      higher N.  This can cause downstream devices to run more slowly than
      they otherwise would.
      
      This DPLL rate rounding algorithm:
      
      - attempts to find the lowest possible N (DPLL divider) to reach the
        target_rate (since, according to Richard Woodruff <r-woodruff@ti.com>,
        lower N values save more power than higher N values).
      
      - allows developers to set an upper bound on the error between the
        rounded rate and the desired target rate ("rate tolerance"), so an
        appropriate balance between rate fidelity and power savings can be
        set.  This maximum rate error tolerance is set via
        omap2_set_dpll_rate_tolerance().
      
      - never returns a rounded rate higher than the target rate.
      
      The rate rounding algorithm caches the last rounded M, N, and rate
      computation to avoid rounding the rate twice for each clk_set_rate()
      call.  (This patch does not yet implement set_rate for DPLLs; that
      follows in a future patch.)
      
      The algorithm trades execution speed for rate accuracy.  It will find
      the (M, N) set that results in the least rate error, within a
      specified rate tolerance.  It does this by evaluating each divider
      setting - on OMAP3, this involves 128 steps.  Another approach to DPLL
      rate rounding would be to bail out as soon as a valid rate is found
      within the rate tolerance, which would trade rate accuracy for
      execution speed.  Alternate implementations welcome.
      
      This code is not yet used by the OMAP24XX DPLL clock, since it
      is currently defined as a composite clock, fusing the DPLL M,N and the
      M2 output divider.  This patch also renames the existing OMAP24xx DPLL
      programming functions to highlight that they program both the DPLL and
      the DPLL's output multiplier.
      Signed-off-by: NPaul Walmsley <paul@pwsan.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      88b8ba90
    • T
      ARM: OMAP: SRAM: Split sram24xx.S into sram242x.S and sram243x.S · c2d43e39
      Tony Lindgren 提交于
      Split sram24xx.S into sram242x.S and sram243x.S
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      c2d43e39
  8. 10 5月, 2008 1 次提交
  9. 15 4月, 2008 6 次提交
  10. 31 10月, 2007 1 次提交
  11. 22 8月, 2007 1 次提交
  12. 21 5月, 2007 1 次提交
  13. 07 3月, 2007 1 次提交
  14. 25 9月, 2006 1 次提交