1. 02 7月, 2014 2 次提交
  2. 20 5月, 2014 1 次提交
  3. 15 5月, 2014 1 次提交
  4. 05 5月, 2014 2 次提交
    • S
      ahci: imx: software workaround for phy reset issue in resume · e783c51c
      Shawn Guo 提交于
      When suspending imx6q systems which have rootfs on SATA, the following
      error will likely be seen in resume.  The SATA link will fail to come
      up, and it results in an unusable system across the suspend/resume
      cycle.
      
      $ echo mem > /sys/power/state
      PM: Syncing filesystems ... done.
      PM: Preparing system for mem sleep
      Freezing user space processes ... (elapsed 0.002 seconds) done.
      Freezing remaining freezable tasks ... (elapsed 0.002 seconds) done.
      PM: Entering mem sleep
      sd 0:0:0:0: [sda] Synchronizing SCSI cache
      sd 0:0:0:0: [sda] Stopping disk
      PM: suspend of devices complete after 61.914 msecs
      PM: suspend devices took 0.070 seconds
      PM: late suspend of devices complete after 4.906 msecs
      PM: noirq suspend of devices complete after 4.521 msecs
      Disabling non-boot CPUs ...
      CPU1: shutdown
      CPU2: shutdown
      CPU3: shutdown
      Enabling non-boot CPUs ...
      CPU1: Booted secondary processor
      CPU1 is up
      CPU2: Booted secondary processor
      CPU2 is up
      CPU3: Booted secondary processor
      CPU3 is up
      PM: noirq resume of devices complete after 10.486 msecs
      PM: early resume of devices complete after 4.679 msecs
      sd 0:0:0:0: [sda] Starting disk
      PM: resume of devices complete after 22.674 msecs
      PM: resume devices took 0.030 seconds
      PM: Finishing wakeup.
      Restarting tasks ... done.
      $ ata1: SATA link down (SStatus 1 SControl 300)
      ata1: SATA link down (SStatus 1 SControl 300)
      ata1: limiting SATA link speed to 1.5 Gbps
      ata1: SATA link down (SStatus 1 SControl 310)
      ata1.00: disabled
      ata1: exception Emask 0x10 SAct 0x0 SErr 0x4040000 action 0xe frozen t4
      ata1: irq_stat 0x00000040, connection status changed
      ata1: SError: { CommWake DevExch }
      ata1: hard resetting link
      sd 0:0:0:0: rejecting I/O to offline device
      sd 0:0:0:0: killing request
      sd 0:0:0:0: rejecting I/O to offline device
      Aborting journal on device sda2-8.
      sd 0:0:0:0: rejecting I/O to offline device
      EXT4-fs warning (device sda2): ext4_end_bio:317: I/O error writing to inode 132577 (offset 0 size 0 starting block 26235)
      Buffer I/O error on device sda2, logical block 10169
      ...
      
      It's caused by a silicon issue that SATA phy does not get reset by
      controller when coming back from LPM.  The patch adds a software
      workaround for this issue.  It enforces a software reset on SATA phy
      in imx_sata_enable() function, so that we can ensure SATA link will
      come up properly in both power-on and resume.
      
      The software reset is implemented by writing phy reset register through
      the phy control register bus interface.  Functions
      imx_phy_reg_[addressing|write|read]() implement this bus interface, while
      imx_sata_phy_reset() performs the actually reset operation.
      Signed-off-by: NRichard Zhu <r65037@freescale.com>
      Signed-off-by: NShawn Guo <shawn.guo@freescale.com>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      e783c51c
    • S
      ahci: imx: add namespace for register enums · 24a9ad5b
      Shawn Guo 提交于
      Update register enums a little bit to add proper namespace prefix, and
      have the names match i.MX reference manual.
      Signed-off-by: NShawn Guo <shawn.guo@freescale.com>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      24a9ad5b
  5. 07 3月, 2014 1 次提交
  6. 23 2月, 2014 1 次提交
  7. 12 12月, 2013 1 次提交
  8. 03 12月, 2013 4 次提交
  9. 15 10月, 2013 1 次提交
    • R
      ahci: imx: setup power saving methods · 8b789d89
      Richard Zhu 提交于
      In order to save power consumption as much as possible.
      
      * Disable sata phy internal pll reference clock when sysetem enter
        into suspend mode, enable it after resume.
      
      * Setup module parameter used to enable imx ahci test power down
        mode(PDDQ) or not, when there is no device detected on the port
      
      * minor modifications:
        - The format of the copyright is changed, because that the original
          one can't pass fsl internal patch reivew without the character
          '(c)'.
        - Exports ahci_platform_ops and ahci_error_handler().
      
      NOTE:
      * The hot-plug can't be supported when PDDQ mode is ever enabled.
      
      * module parameter usage how-to:
        - default: enable PDDQ mode when no device detected.
        - add "ahci-imx.hotplug=1" into kernel command line if your don't
          want to enable PDDQ mode when no device detected on the port.
      
      tj: Slightly updated description and comments.
      Signed-off-by: NRichard Zhu <r65037@freescale.com>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      8b789d89
  10. 25 7月, 2013 1 次提交
    • R
      ahci_imx: add ahci sata support on imx platforms · 9e54eae2
      Richard Zhu 提交于
      imx6q contains one Synopsys AHCI SATA controller, But it can't share
      ahci_platform driver with other controllers because there are some
      misalignments of the generic AHCI controller - the bits definitions of
      the HBA registers, the Vendor Specific registers, the AHCI PHY clock
      and the AHCI signals adjustment window(GPR13 register).
      
       - CAP_SSS(bit20) of the HOST_CAP is writable, default value is '0',
         should be configured to be '1'
      
       - bit0 (only one AHCI SATA port on imx6q) of the HOST_PORTS_IMPL
         should be set to be '1'.(default 0)
      
       - One Vendor Specific register HOST_TIMER1MS(offset:0xe0) should be
         configured regarding to the frequency of AHB bus clock.
      
       - Configurations of the AHCI PHY clock, and the signal parameters of
         the GPR13
      
      Setup its own ahci sata driver, contained the imx6q specific
      initialized codes, re-use the generic ahci_platform driver, and keep
      the generic ahci_platform driver clean as much as possible.
      
      tj: patch description reformatted
      Signed-off-by: NRichard Zhu <r65037@freescale.com>
      Reviewed-by: NShawn Guo <shawn.guo@linaro.org>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      9e54eae2