video: exynos_dp: move sw reset prioir to enabling sw defined function
authorJingoo Han <jg1.han@samsung.com>
Fri, 25 May 2012 07:21:08 +0000 (16:21 +0900)
committerFlorian Tobias Schandinat <FlorianSchandinat@gmx.de>
Tue, 29 May 2012 13:16:15 +0000 (13:16 +0000)
The sw reset should be called prioir to enabling sw defined function,
according to datasheet.

Signed-off-by: Jingoo Han <jg1.han@samsung.com>
Signed-off-by: Florian Tobias Schandinat <FlorianSchandinat@gmx.de>
drivers/video/exynos/exynos_dp_core.c
drivers/video/exynos/exynos_dp_core.h
drivers/video/exynos/exynos_dp_reg.c

index aabd214990d30ef5dc3dcd6a41ac96d0e81247c3..b446f7e42f2a7b3abcc3b29a30ef3e323c83eec8 100644 (file)
@@ -27,6 +27,8 @@ static int exynos_dp_init_dp(struct exynos_dp_device *dp)
 {
        exynos_dp_reset(dp);
 
+       exynos_dp_swreset(dp);
+
        /* SW defined function Normal operation */
        exynos_dp_enable_sw_function(dp);
 
index 8f596b9e7b2b139b57217b330bffbf29c41ceb03..1e0f998e0c9f4c872d132aafa640442a0b2d4189 100644 (file)
@@ -41,6 +41,7 @@ void exynos_dp_lane_swap(struct exynos_dp_device *dp, bool enable);
 void exynos_dp_init_analog_param(struct exynos_dp_device *dp);
 void exynos_dp_init_interrupt(struct exynos_dp_device *dp);
 void exynos_dp_reset(struct exynos_dp_device *dp);
+void exynos_dp_swreset(struct exynos_dp_device *dp);
 void exynos_dp_config_interrupt(struct exynos_dp_device *dp);
 u32 exynos_dp_get_pll_lock_status(struct exynos_dp_device *dp);
 void exynos_dp_set_pll_power_down(struct exynos_dp_device *dp, bool enable);
index 99bafb82537e8905710725bca26ecf37496e3026..6ce76d56c3a1a2a7d3920d7eebfca34001b64dc7 100644 (file)
@@ -109,8 +109,6 @@ void exynos_dp_reset(struct exynos_dp_device *dp)
 {
        u32 reg;
 
-       writel(RESET_DP_TX, dp->reg_base + EXYNOS_DP_TX_SW_RESET);
-
        exynos_dp_stop_video(dp);
        exynos_dp_enable_video_mute(dp, 0);
 
@@ -155,6 +153,11 @@ void exynos_dp_reset(struct exynos_dp_device *dp)
        exynos_dp_init_interrupt(dp);
 }
 
+void exynos_dp_swreset(struct exynos_dp_device *dp)
+{
+       writel(RESET_DP_TX, dp->reg_base + EXYNOS_DP_TX_SW_RESET);
+}
+
 void exynos_dp_config_interrupt(struct exynos_dp_device *dp)
 {
        u32 reg;