1. 29 4月, 2013 1 次提交
  2. 12 3月, 2013 1 次提交
    • S
      ARM: tegra: remove save/restore of CPU diag register · 02e75d64
      Stephen Warren 提交于
      Prior to this change, {save,restore}_cpu_arch_register() collaborated to
      maintain the value of the CPU diagnostic register across power cycles.
      This was required to maintain any CPU errata workaround enable bits in
      that register. However, now that the Tegra reset vector code always
      enables all required workarounds, there is no need to save and restore
      the diagnostic register; it is always explicitly programmed in the
      required manner.
      
      Hence, remove the save/restore logic.
      
      This has the advantage that the kernel always directly controls the value
      of this register every boot, rather than relying on a bootloader or other
      kernel code having previously written the correct value into it. This
      makes CPU0 (which was previously saved/restored) and CPUn (which should
      have been set up by the reset vector) be controlled in exactly the same
      way, which is easier to debug/find/...
      
      In particular, when converting Tegra to a multi-platform kernel, the CPU0
      diagnostic register value initially comes from the bootloader. Most Tegra
      bootloaders don't yet enable all required CPU bug workarounds. The
      previous commit updates the kernel to do so on any CPU power cycle.
      However, the save/restore code ends up over-writing the value with the
      old bootloader-driven value instead of the now more-likely-to-be-correct
      kernel value!
      
      Even irrespective of multi-platform conversion, this change limits the
      kernel's exposure to any WARs the bootloader didn't enable for CPU0: on
      the very first LP2 transition (CPU power-saving which power-cycles the
      CPU), the correct value will be enabled.
      Signed-off-by: NStephen Warren <swarren@nvidia.com>
      02e75d64
  3. 29 1月, 2013 3 次提交
    • J
      ARM: tegra20: cpuidle: add powered-down state for secondary CPU · 5c1350bd
      Joseph Lo 提交于
      The powered-down state of Tegra20 requires power gating both CPU cores.
      When the secondary CPU requests to enter powered-down state, it saves
      its own contexts and then enters WFI. The Tegra20 had a limition to
      power down both CPU cores. The secondary CPU must waits for CPU0 in
      powered-down state too. If the secondary CPU be woken up before CPU0
      entering powered-down state, then it needs to restore its CPU states
      and waits for next chance.
      
      Be aware of that, you may see the legacy power state "LP2" in the code
      which is exactly the same meaning of "CPU power down".
      
      Based on the work by:
      Colin Cross <ccross@android.com>
      Gary King <gking@nvidia.com>
      Signed-off-by: NJoseph Lo <josephl@nvidia.com>
      Signed-off-by: NStephen Warren <swarren@nvidia.com>
      5c1350bd
    • P
      ARM: tegra: move tegra_cpu_car.h to linux/clk/tegra.h · 89572c77
      Prashant Gaikwad 提交于
      tegra_cpu_car_ops struct is going to be accessed from drivers/clk/tegra.
      Move the tegra_cpu_car_ops to include/linux/clk/tegra.h.
      Signed-off-by: NPrashant Gaikwad <pgaikwad@nvidia.com>
      Signed-off-by: NStephen Warren <swarren@nvidia.com>
      89572c77
    • J
      ARM: tegra: clean up the CPUINIT section · 8c627fa6
      Joseph Lo 提交于
      There are some redundant codes in the CPUINIT section that was caused by
      some codes not be organized well in "headsmp.S". Currently all the codes
      in "headsmp.S" were put into CPUINIT section. But actually it doesn't
      need to be loacted in CPUINIT section. There is no fuction access them
      in CPUINIT section and we will relocate them to IRAM.
      
      These codes also caused some unnecessary functions that access these
      codes been put into CPUINIT section too. This patch clean it up and put
      them into normal text section.
      Signed-off-by: NJoseph Lo <josephl@nvidia.com>
      Signed-off-by: NStephen Warren <swarren@nvidia.com>
      8c627fa6
  4. 16 11月, 2012 3 次提交