1. 08 10月, 2019 3 次提交
  2. 07 9月, 2019 1 次提交
    • T
      bus: ti-sysc: Remove unpaired sysc_clkdm_deny_idle() · a4c8723a
      Tony Lindgren 提交于
      Commit d098913a ("bus: ti-sysc: Fix clock handling for no-idle
      quirks") fixed handling for no-idle quirk modules that are not enabled
      by the bootloader.
      
      But it also caused unpaired clockdomain calls that won't allow idling
      the system. That's because clkdm_allow_idle_nolock() and
      clkdm_deny_idle_nolock() have usage count with clkdm->forcewake_count.
      
      Let's drop the unpaired sysc_clkdm_deny_idle() to fix idling of devices.
      
      Fixes: d098913a ("bus: ti-sysc: Fix clock handling for no-idle quirks")
      Cc: Keerthy <j-keerthy@ti.com>
      Cc: Vignesh Raghavendra <vigneshr@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      a4c8723a
  3. 06 9月, 2019 1 次提交
    • T
      bus: ti-sysc: Fix handling of invalid clocks · 2783d063
      Tony Lindgren 提交于
      We can currently get "Unable to handle kernel paging request at
      virtual address" for invalid clocks with dts node but no driver:
      
      (__clk_get_hw) from [<c0138ebc>] (ti_sysc_find_one_clockdomain+0x18/0x34)
      (ti_sysc_find_one_clockdomain) from [<c0138f0c>] (ti_sysc_clkdm_init+0x34/0xdc)
      (ti_sysc_clkdm_init) from [<c0584660>] (sysc_probe+0xa50/0x10e8)
      (sysc_probe) from [<c065c6ac>] (platform_drv_probe+0x58/0xa8)
      
      Let's add IS_ERR checks to ti_sysc_clkdm_init() as And let's start treating
      clk_get() with -ENOENT as a proper error. If the clock name is specified
      in device tree we must succeed with clk_get() to continue. For modules with
      no clock names specified in device tree we will just ignore the clocks.
      
      Fixes: 2b2f7def ("bus: ti-sysc: Add support for missing clockdomain handling")
      Acked-by: NRoger Quadros <rogerq@ti.com>
      Tested-by: NKeerthy <j-keerthy@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      2783d063
  4. 05 9月, 2019 1 次提交
    • T
      bus: ti-sysc: Fix clock handling for no-idle quirks · d098913a
      Tony Lindgren 提交于
      NFSroot can fail on dra7 when cpsw is probed using ti-sysc interconnect
      target module driver as reported by Keerthy.
      
      Device clocks and the interconnect target module may or may not be
      enabled by the bootloader on init, but we currently assume the clocks
      and module are on from the bootloader for "ti,no-idle" and
      "ti,no-idle-on-init" quirks as reported by Grygorii Strashko.
      
      Let's fix the issue by always enabling clocks init, and
      never disable them for "ti,no-idle" quirk. For "ti,no-idle-on-init"
      quirk, we must decrement the usage count later on to allow PM
      runtime to idle the module if requested.
      
      Fixes: 1a5cd7c2 ("bus: ti-sysc: Enable all clocks directly during init to read revision")
      Cc: Keerthy <j-keerthy@ti.com>
      Cc: Vignesh Raghavendra <vigneshr@ti.com>
      Reported-by: NKeerthy <j-keerthy@ti.com>
      Reported-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Reviewed-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      d098913a
  5. 26 8月, 2019 3 次提交
  6. 13 8月, 2019 7 次提交
  7. 24 7月, 2019 3 次提交
  8. 10 6月, 2019 1 次提交
    • T
      bus: ti-sysc: Add support for module specific reset quirks · 4e23be47
      Tony Lindgren 提交于
      Some older interconnect target modules need module internal clock
      toggling quirks to reset properly. We've been doing this in the
      platform code earlier, but need to be able to it directly in the
      ti-sysc driver when we no longer rely on on the platform code.
      
      Let's add reset handling for 1-wire, i2c and watchdog. Later on
      we can add more modules like msdi and dss as they get tested.
      For dra7 pcie, we should be able to just use the rstctrl reset
      driver when available.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      4e23be47
  9. 28 5月, 2019 11 次提交
  10. 02 5月, 2019 1 次提交
    • T
      bus: ti-sysc: Handle devices with no control registers · e4f50c8d
      Tony Lindgren 提交于
      Some interconnect target modules have no module control registers at
      all, such as d_can on am335x and am437x.
      
      The d_can register offset at 0 is CTL register with 0x401 as the default
      value. I guess I mistook the 0x401 value for a revision register as the
      value happens to look similar to what the revision registers typically
      have for other modules.
      
      To handle modules with no control registers, we need to improve the
      ti-sysc driver a bit to bail out with errors on no control registers,
      and then we can remove the bogus revision registers for d_can.
      
      Cc: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
      Tested-by: NKeerthy <j-keerthy@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      e4f50c8d
  11. 09 4月, 2019 1 次提交
  12. 06 4月, 2019 2 次提交
  13. 04 4月, 2019 5 次提交
    • T
      bus: ti-sysc: Add quirk handling for external optional functional clock · a54275f4
      Tony Lindgren 提交于
      We cannot access mcpdm registers at all unless there is an optional pdmclk
      configured. As this is currently only needed for mcpdm, let's check for
      mcpdm in sysc_get_clocks(). If it turns out to be needed for other modules
      too, we can add more flags to the quirks table for this.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      a54275f4
    • T
      bus: ti-sysc: Add support for early quirks based on register address · 42b9c5c9
      Tony Lindgren 提交于
      At least mcpdm needs an optional external clock enabled to function and
      this clock typically comes from the PMIC. We can detect mcpdm based on
      the interconnect target module address and set a quirk flag early.
      
      To do this, let's initialize the clocks a bit later and add a new
      function for sysc_init_early_quirks(). Note that we cannot yet enable
      the early quirks for mcpdm until the optional external clocks are
      handled in the in the following patch.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      42b9c5c9
    • T
      bus: ti-sysc: Move rstctrl reset to happen later · b11c1ea1
      Tony Lindgren 提交于
      We can do the rsstctrl a bit later, but need to deassert rstctrl reset
      before the clocks are enabled if asserted. Let's only init restctrl
      in sysc_init_resets() and do the reset later on just before we enable
      the device clocks.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      b11c1ea1
    • T
      bus: ti-sysc: Manage clocks for the interconnect target module in all cases · 93de83a2
      Tony Lindgren 提交于
      We are currently not managing interconnect target module clocks in the
      for legacy platform data based case. This causes a problem for using the
      platform data based functions when dropping the platform data for the
      interconnect target module configuration.
      
      To avoid a situation where we need to populate the main and optional
      clocks also for the platform data based functions, let's just manage the
      clocks directly in ti-sysc driver. This means that until the interconnect
      target module confugration platform data is dropped our use count for
      clk_enable() will be 2 instead of 1.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      93de83a2
    • T
      bus: ti-sysc: Allocate mdata as needed and do platform data based init later · a3e92e7b
      Tony Lindgren 提交于
      The platform data based init functions typically reset the interconnect
      target module configure the registers. As we may need the interconnect
      target module specific quirks configured based on the revision register,
      we want to move the platform data based init to happen later.
      
      Let's allocate mdata as needed so it's available for sysc_legacy_init()
      that we call with module clocks enabled from sysc_init_module().
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      a3e92e7b