1. 31 5月, 2013 1 次提交
  2. 27 5月, 2013 2 次提交
    • L
      mmc: sdhci-esdhc-imx: fix multiblock reads on i.MX53 · 361b8482
      Lucas Stach 提交于
      The eSDHC controller on the i.MX53 needs an additional, non spec
      compliant CMD12 after a multiblock read with a predefined number of
      blocks. Otherwise the internal state machine won't go back to the
      idle state.
      
      This commit effectively reverts 5b6b0ad6 (mmc: sdhci-esdhc-imx:
      fix for mmc cards on i.MX5), which fixed part of the problem by
      making multiblock reads work, however this fix was not sufficient
      when multi- and singleblock reads got intermixed.
      
      This implements the recommended workaround (Freescale i.MX Reference
      Manual, section 29.6.8 "Multi-block Read") by manually sending a
      CMD12 with the RSPTYP bits cleared.
      Signed-off-by: NLucas Stach <l.stach@pengutronix.de>
      Signed-off-by: NChris Ball <cjb@laptop.org>
      361b8482
    • M
      mmc: sdhci-esdhc-imx: Fix SDIO interrupts · f6825748
      Martin Fuzzey 提交于
      Currently SDIO interrupts do not work on i.MX53 and maybe others.
      
      This was observed with a Marvell 8787 based SDIO wifi adapter
      using the mwifiex driver and firmware from the Marvell git
      repository.
      The symptom was a timeout after firmware download.
      
      Observing the SDIO_DAT1 line showed that an interrupt was requested
      (level 0) but no interrupt was generated in software, the line
      stayed low until a timeout ocurred and the card was reset.
      
      There is a Freescale errata
      	ENGcm11186 "eSDHC misses SDIO interrupt when CINT is disabled"
      
      The workaround suggested by this errata is already implemented and
      involves clearing and then setting the D3CD bit in the host control
      register [see esdhc_writel_le()]
      
      However, when esdhc_writeb_le() is later used to write to
      SDHCI_HOST_CONTROL it always resets the D3CD bit.
      
      To fix this simply add the D3CD bit to the set of bits
      not modified by esdhc_writeb_le().
      Signed-off-by: NMartin Fuzzey <mfuzzey@parkeon.com>
      Signed-off-by: NChris Ball <cjb@laptop.org>
      f6825748
  3. 23 3月, 2013 2 次提交
  4. 25 2月, 2013 9 次提交
  5. 12 2月, 2013 2 次提交
  6. 28 1月, 2013 2 次提交
  7. 07 12月, 2012 1 次提交
  8. 29 11月, 2012 3 次提交
  9. 14 9月, 2012 1 次提交
  10. 02 9月, 2012 1 次提交
  11. 23 7月, 2012 1 次提交
  12. 15 5月, 2012 1 次提交
  13. 11 5月, 2012 1 次提交
  14. 25 4月, 2012 1 次提交
    • S
      mmc sdhc i.MX: do not depend on grouped clocks · 52dac615
      Sascha Hauer 提交于
      the current i.MX clock support groups together unrelated clocks
      to a single clock which is then used by the driver. This can't
      be accomplished with the generic clock framework so we instead
      request the individual clocks in the driver. For i.MX there are
      generally three different clocks:
      
      ipg: bus clock (needed to access registers)
      ahb: dma relevant clock, sometimes referred to as hclk in the datasheet
      per: bit clock, pixel clock
      
      This patch changes the driver to request the individual clocks.
      Currently all clk_get will get the same clock until the SoCs
      are converted to the generic clock framework
      Signed-off-by: NSascha Hauer <s.hauer@pengutronix.de>
      52dac615
  15. 21 4月, 2012 1 次提交
  16. 05 3月, 2012 1 次提交
    • S
      mmc: sdhci-esdhc-imx: fix for mmc cards on i.MX5 · 5b6b0ad6
      Sascha Hauer 提交于
      On i.MX53 we have to write a special SDHCI_CMD_ABORTCMD to the
      SDHCI_TRANSFER_MODE register during a MMC_STOP_TRANSMISSION
      command. This works for SD cards. However, with MMC cards
      the MMC_SET_BLOCK_COUNT command is used instead, but this
      needs the same handling. Fix MMC cards by testing for the
      MMC_SET_BLOCK_COUNT command aswell. Tested on a custom i.MX53
      board with a Transcend MMC+ card and eMMC.
      
      The kernel started used MMC_SET_BLOCK_COUNT in 3.0, so this
      is a regression for these boards introduced in 3.0; it should
      go to 3.0/3.1/3.2-stable.
      Signed-off-by: NSascha Hauer <s.hauer@pengutronix.de>
      Acked-by: NShawn Guo <shawn.guo@linaro.org>
      Cc: <stable@vger.kernel.org>
      Signed-off-by: NChris Ball <cjb@laptop.org>
      5b6b0ad6
  17. 01 2月, 2012 1 次提交
  18. 12 1月, 2012 1 次提交
  19. 20 12月, 2011 1 次提交
  20. 11 11月, 2011 1 次提交
    • S
      arm/imx: fix imx6q mmc error when mounting rootfs · f750ba9b
      Shawn Guo 提交于
      The following error is seen in some case when mounting rootfs from
      SD/MMC cards.
      
        Waiting for root device /dev/mmcblk0p1...
        mmc1: host does not support reading read-only switch. assuming write-enable.
        mmc1: new high speed SDHC card at address b368
        mmcblk0: mmc1:b368 SDC   3.74 GiB
         mmcblk0: p1
        mmc1: Timeout waiting for hardware interrupt.
        mmcblk0: error -110 transferring data, sector 3678224, nr 40, cmd response 0x900, card status 0xc00
        end_request: I/O error, dev mmcblk0, sector 3678225
        Buffer I/O error on device mmcblk0p1, logical block 458754
        lost page write due to I/O error on mmcblk0p1
      
      This patch fixes the problem by lowering the usdhc clock and correcting
      watermark configuration.
      Signed-off-by: NShawn Guo <shawn.guo@linaro.org>
      Cc: Chris Ball <cjb@laptop.org>
      Cc: Sascha Hauer <s.hauer@pengutronix.de>
      Signed-off-by: NSascha Hauer <s.hauer@pengutronix.de>
      f750ba9b
  21. 27 10月, 2011 2 次提交
  22. 29 8月, 2011 1 次提交
  23. 14 8月, 2011 1 次提交
  24. 27 7月, 2011 2 次提交