1. 27 2月, 2020 1 次提交
    • T
      ARM: OMAP2+: Fix compile if CONFIG_HAVE_ARM_SMCCC is not set · 51c22d7b
      Tony Lindgren 提交于
      Recent omap changes added runtime checks to use omap_smccc_smc()
      when optee is configured in dts. As the omap-secure code can be
      built for ARMv6 only without ARMv7 and use custom smc calls, we
      now get a build error:
      
      omap-secure.c:(.text+0x94): undefined reference to `__arm_smccc_smc'
      
      As there secure calls are not used for ARMv6, we should not build
      secure-common, and not call omap_secure_init() for omap2.
      
      Fixes: c37baa06 ("ARM: OMAP2+: Fix undefined reference to omap_secure_init")
      Reported-by: Nkbuild test robot <lkp@intel.com>
      Cc: Aaro Koskinen <aaro.koskinen@iki.fi>
      Cc: Andrew F. Davis <afd@ti.com>
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Catalin Marinas <catalin.marinas@arm.com>
      Cc: Marc Zyngier <maz@kernel.org>
      Cc: Rob Herring <robh@kernel.org>
      Cc: Russell King <rmk+kernel@arm.linux.org.uk>
      Cc: Steven Price <steven.price@arm.com>
      Cc: Will Deacon <will@kernel.org>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      51c22d7b
  2. 14 1月, 2020 1 次提交
  3. 19 6月, 2019 1 次提交
  4. 27 3月, 2019 1 次提交
    • T
      ARM: OMAP2+: Define _HWMOD_STATE_DEFAULT and use it · 6d63b12d
      Tony Lindgren 提交于
      For dynamically allocated struct hwmod entries probing with ti-sysc
      interconnect target module driver, we need to specify the initial default
      state the same way as we do for the platform data cases.
      
      Let's prepare for that by adding _HWMOD_STATE_DEFAULT that we can then
      use to set the initial default state without a need to add similar
      CONFIG_PM handling in multiple places.
      
      Cc: Paul Walmsley <paul@pwsan.com>
      Cc: Tero Kristo <t-kristo@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      6d63b12d
  5. 01 5月, 2018 1 次提交
    • T
      ARM: OMAP2+: Initialize SoC PM later · 02b83dcb
      Tony Lindgren 提交于
      There's no need to probe devices until at module_init time and we
      currently have at least PM trying to use I2C for PMICs early on.
      
      As only a part of the SoC init_early is SoC specific, we only need to call
      the SoC specific PM init function. And we can modify omap2_common_pm_late_init()
      so it becomes a late_initcall().
      
      Note that this changes am335x to call omap2_clk_enable_autoidle_all() that
      seems to be missing currently.
      
      Cc: Keerthy <j-keerthy@ti.com>
      Cc: Tero Kristo <t-kristo@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      02b83dcb
  6. 17 4月, 2018 1 次提交
    • T
      ARM: OMAP2+: Drop unused pm-noop · 44773ba1
      Tony Lindgren 提交于
      Looks like these functions don't do anything in the mainline kernel so
      we can just drop it.
      
      Note that we must now also remove ir-rx51 pdata as it relies on the dummy
      platform data that does not do anything. And ir-rx51 is calling a pdata
      callback that doesn't do anything without checking if it exists first.
      
      For configuring device specific minimal latencies, the interface to use
      is pm_qos_add_request(). For an example, see what was done in commit
      9834ffd1 ("ASoC: omap-mcbsp: Add PM QoS support for McBSP to prevent
      glitches"). I've added some comments to ir-rx51 so people using it can
      add pm_qos support and test it.
      
      Cc: Ivaylo Dimitrov <ivo.g.dimitrov.75@gmail.com>
      Cc: Kevin Hilman <khilman@kernel.org>
      Cc: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
      Cc: Tomi Valkeinen <tomi.valkeinen@ti.com>
      Acked-by: NMauro Carvalho Chehab <mchehab+samsung@kernel.org>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      44773ba1
  7. 28 2月, 2018 1 次提交
    • D
      ARM: OMAP2+: pm33xx-core: Add platform code needed for PM · 41d9d44d
      Dave Gerlach 提交于
      Most of the PM code needed for am335x and am437x can be moved into a
      module under drivers but some core code must remain in mach-omap2 at the
      moment. This includes some internal clockdomain APIs and low-level ARM
      APIs which are also not exported for use by modules.
      
      Implement a few functions that handle these low-level platform
      operations can be passed to the pm33xx module through the use of
      platform data.
      
      In addition to this, to be able to share data structures between C and
      the sleep33xx and sleep43xx assembly code, we can automatically generate
      all of the C struct member offsets and sizes as macros by processing
      pm-asm-offsets.c into assembly code and then extracting the relevant
      data as is done for the generated platform asm-offsets.h files.
      
      Finally, add amx3_common_pm_init to create a dummy platform_device for
      pm33xx so that our soon to be introduced pm33xx module can probe on
      am335x and am437x platforms to enable basic suspend to mem and standby
      support.
      Signed-off-by: NDave Gerlach <d-gerlach@ti.com>
      Acked-by: NSantosh Shilimkar <ssantosh@kernel.org>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      41d9d44d
  8. 15 8月, 2017 1 次提交
  9. 28 7月, 2017 1 次提交
  10. 08 6月, 2017 1 次提交
  11. 11 11月, 2016 1 次提交
  12. 08 11月, 2016 1 次提交
  13. 23 6月, 2016 2 次提交
    • T
      ARM: OMAP4+: Prevent CPU1 related hang with kexec · 0573b957
      Tony Lindgren 提交于
      Kexec booted kernels on omap4 will hang early during the boot if the
      booted kernel is different version from the previous kernel.
      
      This is because the previous kernel may have configured low-power mode
      using CPU1_WAKEUP_NS_PA_ADDR. In that case it points to the previous
      kernel's omap4_secondary_startup(), and CPU1 can be in low power mode
      from the previous kernel. When the new kernel configures the CPU1
      clockdomain, CPU1 can wake from low power state prematurely during
      omap44xx_clockdomains_init() running random code.
      
      Let's fix the issue by configuring CPU1_WAKEUP_NS_PA_ADDR before we
      call omap44xx_clockdomains_init(). Note that this is very early during
      the init, and we will do proper CPU1 reset during SMP init a bit later
      on in omap4_smp_prepare_cpus(). And we need to do this when SMP is
      not enabled as the previous kernel may have had it enabled.
      Acked-by: NSantosh Shilimkar <ssantosh@kernel.org>
      Tested-by: NKeerthy <j-keerthy@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      0573b957
    • T
      ARM: OMAP4+: Initialize SAR RAM base early for proper CPU1 reset for kexec · f4b9f40a
      Tony Lindgren 提交于
      Prepare things for making kexec work on SMP omap variants by initializing
      SARM RAM base early. This allows us to configure CPU1 for kexec in case
      the previous kernel has put CPU1 in low power mode.
      
      Note that this should not prevent moving other SAR RAM code to live
      under drivers. However for kexec, we will need this very early.
      Acked-by: NSantosh Shilimkar <ssantosh@kernel.org>
      Tested-by: NKeerthy <j-keerthy@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      f4b9f40a
  14. 08 4月, 2016 1 次提交
  15. 31 3月, 2016 1 次提交
  16. 10 12月, 2015 1 次提交
  17. 17 9月, 2015 1 次提交
  18. 25 7月, 2015 1 次提交
  19. 24 7月, 2015 1 次提交
  20. 16 7月, 2015 3 次提交
  21. 02 6月, 2015 2 次提交
  22. 01 4月, 2015 4 次提交
  23. 27 3月, 2015 4 次提交
  24. 25 3月, 2015 4 次提交
  25. 17 3月, 2015 1 次提交
  26. 31 1月, 2015 1 次提交
  27. 27 1月, 2015 1 次提交