diff options
author | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2010-10-07 06:59:22 -0400 |
---|---|---|
committer | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2011-05-11 07:20:16 -0400 |
commit | 03329ace1dc7dc9319f6f405381d898fc66fb2cb (patch) | |
tree | ca282fb0107a545f66601921c85618732faffdb2 | |
parent | 65c62bb953d216aaf0e22692e8e12e5c568a3b02 (diff) |
OMAP: DSS2: DSI: wait for TXCLKESC domain to come out of reset
Add dsi_cio_wait_tx_clk_esc_reset() function which waits for the
TXCLKESC domains to come out of reset.
Things have worked fine without this, but better be safe than sorry.
Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
-rw-r--r-- | drivers/video/omap2/dss/dsi.c | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/drivers/video/omap2/dss/dsi.c b/drivers/video/omap2/dss/dsi.c index f4219628444..8bc443bae6b 100644 --- a/drivers/video/omap2/dss/dsi.c +++ b/drivers/video/omap2/dss/dsi.c | |||
@@ -1969,6 +1969,65 @@ static void dsi_cio_disable_lane_override(void) | |||
1969 | REG_FLD_MOD(DSI_DSIPHY_CFG10, 0, 22, 17); /* REGLPTXSCPDAT4TO0DXDY */ | 1969 | REG_FLD_MOD(DSI_DSIPHY_CFG10, 0, 22, 17); /* REGLPTXSCPDAT4TO0DXDY */ |
1970 | } | 1970 | } |
1971 | 1971 | ||
1972 | static int dsi_cio_wait_tx_clk_esc_reset(struct omap_dss_device *dssdev) | ||
1973 | { | ||
1974 | int t; | ||
1975 | int bits[3]; | ||
1976 | bool in_use[3]; | ||
1977 | |||
1978 | if (dss_has_feature(FEAT_DSI_REVERSE_TXCLKESC)) { | ||
1979 | bits[0] = 28; | ||
1980 | bits[1] = 27; | ||
1981 | bits[2] = 26; | ||
1982 | } else { | ||
1983 | bits[0] = 24; | ||
1984 | bits[1] = 25; | ||
1985 | bits[2] = 26; | ||
1986 | } | ||
1987 | |||
1988 | in_use[0] = false; | ||
1989 | in_use[1] = false; | ||
1990 | in_use[2] = false; | ||
1991 | |||
1992 | if (dssdev->phy.dsi.clk_lane != 0) | ||
1993 | in_use[dssdev->phy.dsi.clk_lane - 1] = true; | ||
1994 | if (dssdev->phy.dsi.data1_lane != 0) | ||
1995 | in_use[dssdev->phy.dsi.data1_lane - 1] = true; | ||
1996 | if (dssdev->phy.dsi.data2_lane != 0) | ||
1997 | in_use[dssdev->phy.dsi.data2_lane - 1] = true; | ||
1998 | |||
1999 | t = 100000; | ||
2000 | while (true) { | ||
2001 | u32 l; | ||
2002 | int i; | ||
2003 | int ok; | ||
2004 | |||
2005 | l = dsi_read_reg(DSI_DSIPHY_CFG5); | ||
2006 | |||
2007 | ok = 0; | ||
2008 | for (i = 0; i < 3; ++i) { | ||
2009 | if (!in_use[i] || (l & (1 << bits[i]))) | ||
2010 | ok++; | ||
2011 | } | ||
2012 | |||
2013 | if (ok == 3) | ||
2014 | break; | ||
2015 | |||
2016 | if (--t == 0) { | ||
2017 | for (i = 0; i < 3; ++i) { | ||
2018 | if (!in_use[i] || (l & (1 << bits[i]))) | ||
2019 | continue; | ||
2020 | |||
2021 | DSSERR("CIO TXCLKESC%d domain not coming " \ | ||
2022 | "out of reset\n", i); | ||
2023 | } | ||
2024 | return -EIO; | ||
2025 | } | ||
2026 | } | ||
2027 | |||
2028 | return 0; | ||
2029 | } | ||
2030 | |||
1972 | static int dsi_cio_init(struct omap_dss_device *dssdev) | 2031 | static int dsi_cio_init(struct omap_dss_device *dssdev) |
1973 | { | 2032 | { |
1974 | int r; | 2033 | int r; |
@@ -2028,6 +2087,10 @@ static int dsi_cio_init(struct omap_dss_device *dssdev) | |||
2028 | dsi_if_enable(false); | 2087 | dsi_if_enable(false); |
2029 | REG_FLD_MOD(DSI_CLK_CTRL, 1, 20, 20); /* LP_CLK_ENABLE */ | 2088 | REG_FLD_MOD(DSI_CLK_CTRL, 1, 20, 20); /* LP_CLK_ENABLE */ |
2030 | 2089 | ||
2090 | r = dsi_cio_wait_tx_clk_esc_reset(dssdev); | ||
2091 | if (r) | ||
2092 | goto err_tx_clk_esc_rst; | ||
2093 | |||
2031 | if (dsi.ulps_enabled) { | 2094 | if (dsi.ulps_enabled) { |
2032 | /* Keep Mark-1 state for 1ms (as per DSI spec) */ | 2095 | /* Keep Mark-1 state for 1ms (as per DSI spec) */ |
2033 | ktime_t wait = ns_to_ktime(1000 * 1000); | 2096 | ktime_t wait = ns_to_ktime(1000 * 1000); |
@@ -2050,6 +2113,8 @@ static int dsi_cio_init(struct omap_dss_device *dssdev) | |||
2050 | 2113 | ||
2051 | return 0; | 2114 | return 0; |
2052 | 2115 | ||
2116 | err_tx_clk_esc_rst: | ||
2117 | REG_FLD_MOD(DSI_CLK_CTRL, 0, 20, 20); /* LP_CLK_ENABLE */ | ||
2053 | err_cio_pwr_dom: | 2118 | err_cio_pwr_dom: |
2054 | dsi_cio_power(DSI_COMPLEXIO_POWER_OFF); | 2119 | dsi_cio_power(DSI_COMPLEXIO_POWER_OFF); |
2055 | err_cio_pwr: | 2120 | err_cio_pwr: |