aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2015-04-20 18:16:25 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2015-04-20 18:16:25 -0400
commitbf2ae5d337cd09dfee3041364a36c5214cc7faf9 (patch)
tree57dd6a1995c4fdaf66ee0fc0d6726b0fe61063ab /drivers
parent14aa02449064541217836b9f3d3295e241d5ae9c (diff)
parent6b75b54c841a18ef114704aa5cf2cdf43487b0ae (diff)
Merge tag 'fbdev-4.1' of git://git.kernel.org/pub/scm/linux/kernel/git/tomba/linux
Pull fbdev updates from Tomi Valkeinen: "Small fixes and improvements to various fbdev drivers" * tag 'fbdev-4.1' of git://git.kernel.org/pub/scm/linux/kernel/git/tomba/linux: (24 commits) omapdss: extend pm notifier to handle hibernation OMAPDSS: Correct video ports description file path in DT binding doc OMAPDSS: disable VT switch fbdev: sh_mobile_lcdc: Fix destruction of uninitialized mutex video: fbdev: sh_mobile_lcdcfb: Fix ROP3 sysfs attribute parsing fbdev: pm3fb: cleanup some confusing indenting hyperv: hyperv_fb: match wait_for_completion_timeout return type video: fbdev: use msecs_to_jiffies for time conversions fbdev: via/via_clock: fix sparse warning video: fbdev: make of_device_id array const fbdev: sm501fb: use memset_io OMAPDSS: workaround for MFLAG + NV12 issue OMAPDSS: Add support for MFLAG OMAPDSS: setup default fifo thresholds OMAPDSS: DISPC: lock access to DISPC_CONTROL & DISPC_CONFIG OMAPDSS: DISPC: fix div by zero issue in overlay scaling OMAPDSS: DISPC: change sync_pclk_edge default value OMAPDSS: change signal_level & signal_edge enum values OMAPDSS: DISPC: explicit handling for sync and de levels OMAPDSS: DISPC: remove OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES ...
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gpu/drm/omapdrm/omap_connector.c2
-rw-r--r--drivers/video/fbdev/hyperv_fb.c6
-rw-r--r--drivers/video/fbdev/imxfb.c2
-rw-r--r--drivers/video/fbdev/omap2/displays-new/connector-dvi.c2
-rw-r--r--drivers/video/fbdev/omap2/displays-new/encoder-tfp410.c11
-rw-r--r--drivers/video/fbdev/omap2/displays-new/panel-lgphilips-lb035q02.c2
-rw-r--r--drivers/video/fbdev/omap2/displays-new/panel-sharp-ls037v7dw01.c2
-rw-r--r--drivers/video/fbdev/omap2/displays-new/panel-sony-acx565akm.c2
-rw-r--r--drivers/video/fbdev/omap2/displays-new/panel-tpo-td028ttec1.c2
-rw-r--r--drivers/video/fbdev/omap2/displays-new/panel-tpo-td043mtea1.c2
-rw-r--r--drivers/video/fbdev/omap2/dss/core.c4
-rw-r--r--drivers/video/fbdev/omap2/dss/dispc.c147
-rw-r--r--drivers/video/fbdev/omap2/dss/display.c2
-rw-r--r--drivers/video/fbdev/omap2/dss/dsi.c2
-rw-r--r--drivers/video/fbdev/omap2/dss/dss.c3
-rw-r--r--drivers/video/fbdev/omap2/dss/dss_features.c2
-rw-r--r--drivers/video/fbdev/omap2/dss/hdmi5_core.c2
-rw-r--r--drivers/video/fbdev/omap2/dss/rfbi.c2
-rw-r--r--drivers/video/fbdev/omap2/omapfb/omapfb-main.c4
-rw-r--r--drivers/video/fbdev/pm3fb.c6
-rw-r--r--drivers/video/fbdev/pxafb.c6
-rw-r--r--drivers/video/fbdev/sh_mobile_lcdcfb.c15
-rw-r--r--drivers/video/fbdev/sm501fb.c2
-rw-r--r--drivers/video/fbdev/via/via_clock.c2
24 files changed, 188 insertions, 44 deletions
diff --git a/drivers/gpu/drm/omapdrm/omap_connector.c b/drivers/gpu/drm/omapdrm/omap_connector.c
index b41965c2888d..17739737dcf6 100644
--- a/drivers/gpu/drm/omapdrm/omap_connector.c
+++ b/drivers/gpu/drm/omapdrm/omap_connector.c
@@ -102,7 +102,7 @@ void copy_timings_drm_to_omap(struct omap_video_timings *timings,
102 102
103 timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE; 103 timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
104 timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH; 104 timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
105 timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES; 105 timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
106} 106}
107 107
108static enum drm_connector_status omap_connector_detect( 108static enum drm_connector_status omap_connector_detect(
diff --git a/drivers/video/fbdev/hyperv_fb.c b/drivers/video/fbdev/hyperv_fb.c
index 42543362f163..807ee22ef229 100644
--- a/drivers/video/fbdev/hyperv_fb.c
+++ b/drivers/video/fbdev/hyperv_fb.c
@@ -415,7 +415,8 @@ static int synthvid_negotiate_ver(struct hv_device *hdev, u32 ver)
415 struct fb_info *info = hv_get_drvdata(hdev); 415 struct fb_info *info = hv_get_drvdata(hdev);
416 struct hvfb_par *par = info->par; 416 struct hvfb_par *par = info->par;
417 struct synthvid_msg *msg = (struct synthvid_msg *)par->init_buf; 417 struct synthvid_msg *msg = (struct synthvid_msg *)par->init_buf;
418 int t, ret = 0; 418 int ret = 0;
419 unsigned long t;
419 420
420 memset(msg, 0, sizeof(struct synthvid_msg)); 421 memset(msg, 0, sizeof(struct synthvid_msg));
421 msg->vid_hdr.type = SYNTHVID_VERSION_REQUEST; 422 msg->vid_hdr.type = SYNTHVID_VERSION_REQUEST;
@@ -488,7 +489,8 @@ static int synthvid_send_config(struct hv_device *hdev)
488 struct fb_info *info = hv_get_drvdata(hdev); 489 struct fb_info *info = hv_get_drvdata(hdev);
489 struct hvfb_par *par = info->par; 490 struct hvfb_par *par = info->par;
490 struct synthvid_msg *msg = (struct synthvid_msg *)par->init_buf; 491 struct synthvid_msg *msg = (struct synthvid_msg *)par->init_buf;
491 int t, ret = 0; 492 int ret = 0;
493 unsigned long t;
492 494
493 /* Send VRAM location */ 495 /* Send VRAM location */
494 memset(msg, 0, sizeof(struct synthvid_msg)); 496 memset(msg, 0, sizeof(struct synthvid_msg));
diff --git a/drivers/video/fbdev/imxfb.c b/drivers/video/fbdev/imxfb.c
index 3b6a3c8c36e2..84d1d29e532c 100644
--- a/drivers/video/fbdev/imxfb.c
+++ b/drivers/video/fbdev/imxfb.c
@@ -183,7 +183,7 @@ static struct platform_device_id imxfb_devtype[] = {
183}; 183};
184MODULE_DEVICE_TABLE(platform, imxfb_devtype); 184MODULE_DEVICE_TABLE(platform, imxfb_devtype);
185 185
186static struct of_device_id imxfb_of_dev_id[] = { 186static const struct of_device_id imxfb_of_dev_id[] = {
187 { 187 {
188 .compatible = "fsl,imx1-fb", 188 .compatible = "fsl,imx1-fb",
189 .data = &imxfb_devtype[IMX1_FB], 189 .data = &imxfb_devtype[IMX1_FB],
diff --git a/drivers/video/fbdev/omap2/displays-new/connector-dvi.c b/drivers/video/fbdev/omap2/displays-new/connector-dvi.c
index 0cdc97413020..a8ce920fa797 100644
--- a/drivers/video/fbdev/omap2/displays-new/connector-dvi.c
+++ b/drivers/video/fbdev/omap2/displays-new/connector-dvi.c
@@ -37,7 +37,7 @@ static const struct omap_video_timings dvic_default_timings = {
37 .hsync_level = OMAPDSS_SIG_ACTIVE_HIGH, 37 .hsync_level = OMAPDSS_SIG_ACTIVE_HIGH,
38 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE, 38 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
39 .de_level = OMAPDSS_SIG_ACTIVE_HIGH, 39 .de_level = OMAPDSS_SIG_ACTIVE_HIGH,
40 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES, 40 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
41}; 41};
42 42
43struct panel_drv_data { 43struct panel_drv_data {
diff --git a/drivers/video/fbdev/omap2/displays-new/encoder-tfp410.c b/drivers/video/fbdev/omap2/displays-new/encoder-tfp410.c
index 92919a74e715..d9048b3df495 100644
--- a/drivers/video/fbdev/omap2/displays-new/encoder-tfp410.c
+++ b/drivers/video/fbdev/omap2/displays-new/encoder-tfp410.c
@@ -114,12 +114,21 @@ static void tfp410_disable(struct omap_dss_device *dssdev)
114 dssdev->state = OMAP_DSS_DISPLAY_DISABLED; 114 dssdev->state = OMAP_DSS_DISPLAY_DISABLED;
115} 115}
116 116
117static void tfp410_fix_timings(struct omap_video_timings *timings)
118{
119 timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
120 timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
121 timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
122}
123
117static void tfp410_set_timings(struct omap_dss_device *dssdev, 124static void tfp410_set_timings(struct omap_dss_device *dssdev,
118 struct omap_video_timings *timings) 125 struct omap_video_timings *timings)
119{ 126{
120 struct panel_drv_data *ddata = to_panel_data(dssdev); 127 struct panel_drv_data *ddata = to_panel_data(dssdev);
121 struct omap_dss_device *in = ddata->in; 128 struct omap_dss_device *in = ddata->in;
122 129
130 tfp410_fix_timings(timings);
131
123 ddata->timings = *timings; 132 ddata->timings = *timings;
124 dssdev->panel.timings = *timings; 133 dssdev->panel.timings = *timings;
125 134
@@ -140,6 +149,8 @@ static int tfp410_check_timings(struct omap_dss_device *dssdev,
140 struct panel_drv_data *ddata = to_panel_data(dssdev); 149 struct panel_drv_data *ddata = to_panel_data(dssdev);
141 struct omap_dss_device *in = ddata->in; 150 struct omap_dss_device *in = ddata->in;
142 151
152 tfp410_fix_timings(timings);
153
143 return in->ops.dpi->check_timings(in, timings); 154 return in->ops.dpi->check_timings(in, timings);
144} 155}
145 156
diff --git a/drivers/video/fbdev/omap2/displays-new/panel-lgphilips-lb035q02.c b/drivers/video/fbdev/omap2/displays-new/panel-lgphilips-lb035q02.c
index 27d4fcfa1824..9974a37a11af 100644
--- a/drivers/video/fbdev/omap2/displays-new/panel-lgphilips-lb035q02.c
+++ b/drivers/video/fbdev/omap2/displays-new/panel-lgphilips-lb035q02.c
@@ -37,7 +37,7 @@ static struct omap_video_timings lb035q02_timings = {
37 .hsync_level = OMAPDSS_SIG_ACTIVE_LOW, 37 .hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
38 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE, 38 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
39 .de_level = OMAPDSS_SIG_ACTIVE_HIGH, 39 .de_level = OMAPDSS_SIG_ACTIVE_HIGH,
40 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES, 40 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
41}; 41};
42 42
43struct panel_drv_data { 43struct panel_drv_data {
diff --git a/drivers/video/fbdev/omap2/displays-new/panel-sharp-ls037v7dw01.c b/drivers/video/fbdev/omap2/displays-new/panel-sharp-ls037v7dw01.c
index 18b19b6e1ac2..eae263702964 100644
--- a/drivers/video/fbdev/omap2/displays-new/panel-sharp-ls037v7dw01.c
+++ b/drivers/video/fbdev/omap2/displays-new/panel-sharp-ls037v7dw01.c
@@ -54,7 +54,7 @@ static const struct omap_video_timings sharp_ls_timings = {
54 .hsync_level = OMAPDSS_SIG_ACTIVE_LOW, 54 .hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
55 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE, 55 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
56 .de_level = OMAPDSS_SIG_ACTIVE_HIGH, 56 .de_level = OMAPDSS_SIG_ACTIVE_HIGH,
57 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES, 57 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
58}; 58};
59 59
60#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev) 60#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
diff --git a/drivers/video/fbdev/omap2/displays-new/panel-sony-acx565akm.c b/drivers/video/fbdev/omap2/displays-new/panel-sony-acx565akm.c
index 337ccc5c0f5e..90cbc4c3406c 100644
--- a/drivers/video/fbdev/omap2/displays-new/panel-sony-acx565akm.c
+++ b/drivers/video/fbdev/omap2/displays-new/panel-sony-acx565akm.c
@@ -108,7 +108,7 @@ static const struct omap_video_timings acx565akm_panel_timings = {
108 108
109 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE, 109 .data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
110 .de_level = OMAPDSS_SIG_ACTIVE_HIGH, 110 .de_level = OMAPDSS_SIG_ACTIVE_HIGH,
111 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES, 111 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
112}; 112};
113 113
114#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev) 114#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
diff --git a/drivers/video/fbdev/omap2/displays-new/panel-tpo-td028ttec1.c b/drivers/video/fbdev/omap2/displays-new/panel-tpo-td028ttec1.c
index fbba0b8ca871..9edc51133c59 100644
--- a/drivers/video/fbdev/omap2/displays-new/panel-tpo-td028ttec1.c
+++ b/drivers/video/fbdev/omap2/displays-new/panel-tpo-td028ttec1.c
@@ -58,7 +58,7 @@ static struct omap_video_timings td028ttec1_panel_timings = {
58 58
59 .data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE, 59 .data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
60 .de_level = OMAPDSS_SIG_ACTIVE_HIGH, 60 .de_level = OMAPDSS_SIG_ACTIVE_HIGH,
61 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES, 61 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
62}; 62};
63 63
64#define JBT_COMMAND 0x000 64#define JBT_COMMAND 0x000
diff --git a/drivers/video/fbdev/omap2/displays-new/panel-tpo-td043mtea1.c b/drivers/video/fbdev/omap2/displays-new/panel-tpo-td043mtea1.c
index 5aba76bca25a..79e4a029aab9 100644
--- a/drivers/video/fbdev/omap2/displays-new/panel-tpo-td043mtea1.c
+++ b/drivers/video/fbdev/omap2/displays-new/panel-tpo-td043mtea1.c
@@ -91,7 +91,7 @@ static const struct omap_video_timings tpo_td043_timings = {
91 .hsync_level = OMAPDSS_SIG_ACTIVE_LOW, 91 .hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
92 .data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE, 92 .data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
93 .de_level = OMAPDSS_SIG_ACTIVE_HIGH, 93 .de_level = OMAPDSS_SIG_ACTIVE_HIGH,
94 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES, 94 .sync_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
95}; 95};
96 96
97#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev) 97#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
diff --git a/drivers/video/fbdev/omap2/dss/core.c b/drivers/video/fbdev/omap2/dss/core.c
index d5d92124e019..16751755d433 100644
--- a/drivers/video/fbdev/omap2/dss/core.c
+++ b/drivers/video/fbdev/omap2/dss/core.c
@@ -179,10 +179,14 @@ static int omap_dss_pm_notif(struct notifier_block *b, unsigned long v, void *d)
179 179
180 switch (v) { 180 switch (v) {
181 case PM_SUSPEND_PREPARE: 181 case PM_SUSPEND_PREPARE:
182 case PM_HIBERNATION_PREPARE:
183 case PM_RESTORE_PREPARE:
182 DSSDBG("suspending displays\n"); 184 DSSDBG("suspending displays\n");
183 return dss_suspend_all_devices(); 185 return dss_suspend_all_devices();
184 186
185 case PM_POST_SUSPEND: 187 case PM_POST_SUSPEND:
188 case PM_POST_HIBERNATION:
189 case PM_POST_RESTORE:
186 DSSDBG("resuming displays\n"); 190 DSSDBG("resuming displays\n");
187 return dss_resume_all_devices(); 191 return dss_resume_all_devices();
188 192
diff --git a/drivers/video/fbdev/omap2/dss/dispc.c b/drivers/video/fbdev/omap2/dss/dispc.c
index 31b743c70272..f4fc77d9d3bf 100644
--- a/drivers/video/fbdev/omap2/dss/dispc.c
+++ b/drivers/video/fbdev/omap2/dss/dispc.c
@@ -123,6 +123,9 @@ static struct {
123 123
124 struct regmap *syscon_pol; 124 struct regmap *syscon_pol;
125 u32 syscon_pol_offset; 125 u32 syscon_pol_offset;
126
127 /* DISPC_CONTROL & DISPC_CONFIG lock*/
128 spinlock_t control_lock;
126} dispc; 129} dispc;
127 130
128enum omap_color_component { 131enum omap_color_component {
@@ -261,7 +264,16 @@ static u32 mgr_fld_read(enum omap_channel channel, enum mgr_reg_fields regfld)
261static void mgr_fld_write(enum omap_channel channel, 264static void mgr_fld_write(enum omap_channel channel,
262 enum mgr_reg_fields regfld, int val) { 265 enum mgr_reg_fields regfld, int val) {
263 const struct dispc_reg_field rfld = mgr_desc[channel].reg_desc[regfld]; 266 const struct dispc_reg_field rfld = mgr_desc[channel].reg_desc[regfld];
267 const bool need_lock = rfld.reg == DISPC_CONTROL || rfld.reg == DISPC_CONFIG;
268 unsigned long flags;
269
270 if (need_lock)
271 spin_lock_irqsave(&dispc.control_lock, flags);
272
264 REG_FLD_MOD(rfld.reg, val, rfld.high, rfld.low); 273 REG_FLD_MOD(rfld.reg, val, rfld.high, rfld.low);
274
275 if (need_lock)
276 spin_unlock_irqrestore(&dispc.control_lock, flags);
265} 277}
266 278
267#define SR(reg) \ 279#define SR(reg) \
@@ -1126,6 +1138,7 @@ static void dispc_init_fifos(void)
1126 int fifo; 1138 int fifo;
1127 u8 start, end; 1139 u8 start, end;
1128 u32 unit; 1140 u32 unit;
1141 int i;
1129 1142
1130 unit = dss_feat_get_buffer_size_unit(); 1143 unit = dss_feat_get_buffer_size_unit();
1131 1144
@@ -1165,6 +1178,20 @@ static void dispc_init_fifos(void)
1165 dispc.fifo_assignment[OMAP_DSS_GFX] = OMAP_DSS_WB; 1178 dispc.fifo_assignment[OMAP_DSS_GFX] = OMAP_DSS_WB;
1166 dispc.fifo_assignment[OMAP_DSS_WB] = OMAP_DSS_GFX; 1179 dispc.fifo_assignment[OMAP_DSS_WB] = OMAP_DSS_GFX;
1167 } 1180 }
1181
1182 /*
1183 * Setup default fifo thresholds.
1184 */
1185 for (i = 0; i < dss_feat_get_num_ovls(); ++i) {
1186 u32 low, high;
1187 const bool use_fifomerge = false;
1188 const bool manual_update = false;
1189
1190 dispc_ovl_compute_fifo_thresholds(i, &low, &high,
1191 use_fifomerge, manual_update);
1192
1193 dispc_ovl_set_fifo_threshold(i, low, high);
1194 }
1168} 1195}
1169 1196
1170static u32 dispc_ovl_get_fifo_size(enum omap_plane plane) 1197static u32 dispc_ovl_get_fifo_size(enum omap_plane plane)
@@ -1278,6 +1305,63 @@ void dispc_ovl_compute_fifo_thresholds(enum omap_plane plane,
1278} 1305}
1279EXPORT_SYMBOL(dispc_ovl_compute_fifo_thresholds); 1306EXPORT_SYMBOL(dispc_ovl_compute_fifo_thresholds);
1280 1307
1308static void dispc_ovl_set_mflag(enum omap_plane plane, bool enable)
1309{
1310 int bit;
1311
1312 if (plane == OMAP_DSS_GFX)
1313 bit = 14;
1314 else
1315 bit = 23;
1316
1317 REG_FLD_MOD(DISPC_OVL_ATTRIBUTES(plane), enable, bit, bit);
1318}
1319
1320static void dispc_ovl_set_mflag_threshold(enum omap_plane plane,
1321 int low, int high)
1322{
1323 dispc_write_reg(DISPC_OVL_MFLAG_THRESHOLD(plane),
1324 FLD_VAL(high, 31, 16) | FLD_VAL(low, 15, 0));
1325}
1326
1327static void dispc_init_mflag(void)
1328{
1329 int i;
1330
1331 /*
1332 * HACK: NV12 color format and MFLAG seem to have problems working
1333 * together: using two displays, and having an NV12 overlay on one of
1334 * the displays will cause underflows/synclosts when MFLAG_CTRL=2.
1335 * Changing MFLAG thresholds and PRELOAD to certain values seem to
1336 * remove the errors, but there doesn't seem to be a clear logic on
1337 * which values work and which not.
1338 *
1339 * As a work-around, set force MFLAG to always on.
1340 */
1341 dispc_write_reg(DISPC_GLOBAL_MFLAG_ATTRIBUTE,
1342 (1 << 0) | /* MFLAG_CTRL = force always on */
1343 (0 << 2)); /* MFLAG_START = disable */
1344
1345 for (i = 0; i < dss_feat_get_num_ovls(); ++i) {
1346 u32 size = dispc_ovl_get_fifo_size(i);
1347 u32 unit = dss_feat_get_buffer_size_unit();
1348 u32 low, high;
1349
1350 dispc_ovl_set_mflag(i, true);
1351
1352 /*
1353 * Simulation team suggests below thesholds:
1354 * HT = fifosize * 5 / 8;
1355 * LT = fifosize * 4 / 8;
1356 */
1357
1358 low = size * 4 / 8 / unit;
1359 high = size * 5 / 8 / unit;
1360
1361 dispc_ovl_set_mflag_threshold(i, low, high);
1362 }
1363}
1364
1281static void dispc_ovl_set_fir(enum omap_plane plane, 1365static void dispc_ovl_set_fir(enum omap_plane plane,
1282 int hinc, int vinc, 1366 int hinc, int vinc,
1283 enum omap_color_component color_comp) 1367 enum omap_color_component color_comp)
@@ -2322,6 +2406,11 @@ static int dispc_ovl_calc_scaling(unsigned long pclk, unsigned long lclk,
2322 if (width == out_width && height == out_height) 2406 if (width == out_width && height == out_height)
2323 return 0; 2407 return 0;
2324 2408
2409 if (pclk == 0 || mgr_timings->pixelclock == 0) {
2410 DSSERR("cannot calculate scaling settings: pclk is zero\n");
2411 return -EINVAL;
2412 }
2413
2325 if ((caps & OMAP_DSS_OVL_CAP_SCALE) == 0) 2414 if ((caps & OMAP_DSS_OVL_CAP_SCALE) == 0)
2326 return -EINVAL; 2415 return -EINVAL;
2327 2416
@@ -2441,7 +2530,7 @@ static int dispc_ovl_setup_common(enum omap_plane plane,
2441 unsigned long pclk = dispc_plane_pclk_rate(plane); 2530 unsigned long pclk = dispc_plane_pclk_rate(plane);
2442 unsigned long lclk = dispc_plane_lclk_rate(plane); 2531 unsigned long lclk = dispc_plane_lclk_rate(plane);
2443 2532
2444 if (paddr == 0) 2533 if (paddr == 0 && rotation_type != OMAP_DSS_ROT_TILER)
2445 return -EINVAL; 2534 return -EINVAL;
2446 2535
2447 out_width = out_width == 0 ? width : out_width; 2536 out_width = out_width == 0 ? width : out_width;
@@ -2915,7 +3004,7 @@ static void _dispc_mgr_set_lcd_timings(enum omap_channel channel, int hsw,
2915 3004
2916{ 3005{
2917 u32 timing_h, timing_v, l; 3006 u32 timing_h, timing_v, l;
2918 bool onoff, rf, ipc; 3007 bool onoff, rf, ipc, vs, hs, de;
2919 3008
2920 timing_h = FLD_VAL(hsw-1, dispc.feat->sw_start, 0) | 3009 timing_h = FLD_VAL(hsw-1, dispc.feat->sw_start, 0) |
2921 FLD_VAL(hfp-1, dispc.feat->fp_start, 8) | 3010 FLD_VAL(hfp-1, dispc.feat->fp_start, 8) |
@@ -2927,6 +3016,39 @@ static void _dispc_mgr_set_lcd_timings(enum omap_channel channel, int hsw,
2927 dispc_write_reg(DISPC_TIMING_H(channel), timing_h); 3016 dispc_write_reg(DISPC_TIMING_H(channel), timing_h);
2928 dispc_write_reg(DISPC_TIMING_V(channel), timing_v); 3017 dispc_write_reg(DISPC_TIMING_V(channel), timing_v);
2929 3018
3019 switch (vsync_level) {
3020 case OMAPDSS_SIG_ACTIVE_LOW:
3021 vs = true;
3022 break;
3023 case OMAPDSS_SIG_ACTIVE_HIGH:
3024 vs = false;
3025 break;
3026 default:
3027 BUG();
3028 }
3029
3030 switch (hsync_level) {
3031 case OMAPDSS_SIG_ACTIVE_LOW:
3032 hs = true;
3033 break;
3034 case OMAPDSS_SIG_ACTIVE_HIGH:
3035 hs = false;
3036 break;
3037 default:
3038 BUG();
3039 }
3040
3041 switch (de_level) {
3042 case OMAPDSS_SIG_ACTIVE_LOW:
3043 de = true;
3044 break;
3045 case OMAPDSS_SIG_ACTIVE_HIGH:
3046 de = false;
3047 break;
3048 default:
3049 BUG();
3050 }
3051
2930 switch (data_pclk_edge) { 3052 switch (data_pclk_edge) {
2931 case OMAPDSS_DRIVE_SIG_RISING_EDGE: 3053 case OMAPDSS_DRIVE_SIG_RISING_EDGE:
2932 ipc = false; 3054 ipc = false;
@@ -2934,22 +3056,18 @@ static void _dispc_mgr_set_lcd_timings(enum omap_channel channel, int hsw,
2934 case OMAPDSS_DRIVE_SIG_FALLING_EDGE: 3056 case OMAPDSS_DRIVE_SIG_FALLING_EDGE:
2935 ipc = true; 3057 ipc = true;
2936 break; 3058 break;
2937 case OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES:
2938 default: 3059 default:
2939 BUG(); 3060 BUG();
2940 } 3061 }
2941 3062
3063 /* always use the 'rf' setting */
3064 onoff = true;
3065
2942 switch (sync_pclk_edge) { 3066 switch (sync_pclk_edge) {
2943 case OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES:
2944 onoff = false;
2945 rf = false;
2946 break;
2947 case OMAPDSS_DRIVE_SIG_FALLING_EDGE: 3067 case OMAPDSS_DRIVE_SIG_FALLING_EDGE:
2948 onoff = true;
2949 rf = false; 3068 rf = false;
2950 break; 3069 break;
2951 case OMAPDSS_DRIVE_SIG_RISING_EDGE: 3070 case OMAPDSS_DRIVE_SIG_RISING_EDGE:
2952 onoff = true;
2953 rf = true; 3071 rf = true;
2954 break; 3072 break;
2955 default: 3073 default:
@@ -2958,10 +3076,10 @@ static void _dispc_mgr_set_lcd_timings(enum omap_channel channel, int hsw,
2958 3076
2959 l = FLD_VAL(onoff, 17, 17) | 3077 l = FLD_VAL(onoff, 17, 17) |
2960 FLD_VAL(rf, 16, 16) | 3078 FLD_VAL(rf, 16, 16) |
2961 FLD_VAL(de_level, 15, 15) | 3079 FLD_VAL(de, 15, 15) |
2962 FLD_VAL(ipc, 14, 14) | 3080 FLD_VAL(ipc, 14, 14) |
2963 FLD_VAL(hsync_level, 13, 13) | 3081 FLD_VAL(hs, 13, 13) |
2964 FLD_VAL(vsync_level, 12, 12); 3082 FLD_VAL(vs, 12, 12);
2965 3083
2966 dispc_write_reg(DISPC_POL_FREQ(channel), l); 3084 dispc_write_reg(DISPC_POL_FREQ(channel), l);
2967 3085
@@ -3569,6 +3687,9 @@ static void _omap_dispc_initial_config(void)
3569 3687
3570 if (dispc.feat->mstandby_workaround) 3688 if (dispc.feat->mstandby_workaround)
3571 REG_FLD_MOD(DISPC_MSTANDBY_CTRL, 1, 0, 0); 3689 REG_FLD_MOD(DISPC_MSTANDBY_CTRL, 1, 0, 0);
3690
3691 if (dss_has_feature(FEAT_MFLAG))
3692 dispc_init_mflag();
3572} 3693}
3573 3694
3574static const struct dispc_features omap24xx_dispc_feats __initconst = { 3695static const struct dispc_features omap24xx_dispc_feats __initconst = {
@@ -3770,6 +3891,8 @@ static int __init omap_dispchw_probe(struct platform_device *pdev)
3770 3891
3771 dispc.pdev = pdev; 3892 dispc.pdev = pdev;
3772 3893
3894 spin_lock_init(&dispc.control_lock);
3895
3773 r = dispc_init_features(dispc.pdev); 3896 r = dispc_init_features(dispc.pdev);
3774 if (r) 3897 if (r)
3775 return r; 3898 return r;
diff --git a/drivers/video/fbdev/omap2/dss/display.c b/drivers/video/fbdev/omap2/dss/display.c
index 2412a0dd0c13..ef5b9027985d 100644
--- a/drivers/video/fbdev/omap2/dss/display.c
+++ b/drivers/video/fbdev/omap2/dss/display.c
@@ -295,7 +295,7 @@ void videomode_to_omap_video_timings(const struct videomode *vm,
295 OMAPDSS_DRIVE_SIG_RISING_EDGE : 295 OMAPDSS_DRIVE_SIG_RISING_EDGE :
296 OMAPDSS_DRIVE_SIG_FALLING_EDGE; 296 OMAPDSS_DRIVE_SIG_FALLING_EDGE;
297 297
298 ovt->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES; 298 ovt->sync_pclk_edge = ovt->data_pclk_edge;
299} 299}
300EXPORT_SYMBOL(videomode_to_omap_video_timings); 300EXPORT_SYMBOL(videomode_to_omap_video_timings);
301 301
diff --git a/drivers/video/fbdev/omap2/dss/dsi.c b/drivers/video/fbdev/omap2/dss/dsi.c
index 5081f6fb1737..28b0bc11669d 100644
--- a/drivers/video/fbdev/omap2/dss/dsi.c
+++ b/drivers/video/fbdev/omap2/dss/dsi.c
@@ -4137,7 +4137,7 @@ static int dsi_display_init_dispc(struct platform_device *dsidev,
4137 dsi->timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH; 4137 dsi->timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH;
4138 dsi->timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE; 4138 dsi->timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
4139 dsi->timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH; 4139 dsi->timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH;
4140 dsi->timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES; 4140 dsi->timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
4141 4141
4142 dss_mgr_set_timings(mgr, &dsi->timings); 4142 dss_mgr_set_timings(mgr, &dsi->timings);
4143 4143
diff --git a/drivers/video/fbdev/omap2/dss/dss.c b/drivers/video/fbdev/omap2/dss/dss.c
index a6d10d4279f3..7f978b6a34e8 100644
--- a/drivers/video/fbdev/omap2/dss/dss.c
+++ b/drivers/video/fbdev/omap2/dss/dss.c
@@ -38,6 +38,7 @@
38#include <linux/regmap.h> 38#include <linux/regmap.h>
39#include <linux/of.h> 39#include <linux/of.h>
40#include <linux/regulator/consumer.h> 40#include <linux/regulator/consumer.h>
41#include <linux/suspend.h>
41 42
42#include <video/omapdss.h> 43#include <video/omapdss.h>
43 44
@@ -1138,6 +1139,8 @@ static int __init omap_dsshw_probe(struct platform_device *pdev)
1138 1139
1139 dss_debugfs_create_file("dss", dss_dump_regs); 1140 dss_debugfs_create_file("dss", dss_dump_regs);
1140 1141
1142 pm_set_vt_switch(0);
1143
1141 return 0; 1144 return 0;
1142 1145
1143err_pll_init: 1146err_pll_init:
diff --git a/drivers/video/fbdev/omap2/dss/dss_features.c b/drivers/video/fbdev/omap2/dss/dss_features.c
index 376270b777f8..b0b6dfd657bf 100644
--- a/drivers/video/fbdev/omap2/dss/dss_features.c
+++ b/drivers/video/fbdev/omap2/dss/dss_features.c
@@ -440,7 +440,7 @@ static const struct dss_param_range omap3_dss_param_range[] = {
440 440
441static const struct dss_param_range am43xx_dss_param_range[] = { 441static const struct dss_param_range am43xx_dss_param_range[] = {
442 [FEAT_PARAM_DSS_FCK] = { 0, 200000000 }, 442 [FEAT_PARAM_DSS_FCK] = { 0, 200000000 },
443 [FEAT_PARAM_DSS_PCD] = { 2, 255 }, 443 [FEAT_PARAM_DSS_PCD] = { 1, 255 },
444 [FEAT_PARAM_DOWNSCALE] = { 1, 4 }, 444 [FEAT_PARAM_DOWNSCALE] = { 1, 4 },
445 [FEAT_PARAM_LINEWIDTH] = { 1, 1024 }, 445 [FEAT_PARAM_LINEWIDTH] = { 1, 1024 },
446}; 446};
diff --git a/drivers/video/fbdev/omap2/dss/hdmi5_core.c b/drivers/video/fbdev/omap2/dss/hdmi5_core.c
index a3cfe3d708f7..bfc0c4c297d6 100644
--- a/drivers/video/fbdev/omap2/dss/hdmi5_core.c
+++ b/drivers/video/fbdev/omap2/dss/hdmi5_core.c
@@ -55,7 +55,7 @@ static void hdmi_core_ddc_init(struct hdmi_core_data *core)
55 const unsigned ss_scl_low = 4700; /* ns */ 55 const unsigned ss_scl_low = 4700; /* ns */
56 const unsigned fs_scl_high = 600; /* ns */ 56 const unsigned fs_scl_high = 600; /* ns */
57 const unsigned fs_scl_low = 1300; /* ns */ 57 const unsigned fs_scl_low = 1300; /* ns */
58 const unsigned sda_hold = 300; /* ns */ 58 const unsigned sda_hold = 1000; /* ns */
59 const unsigned sfr_div = 10; 59 const unsigned sfr_div = 10;
60 unsigned long long sfr; 60 unsigned long long sfr;
61 unsigned v; 61 unsigned v;
diff --git a/drivers/video/fbdev/omap2/dss/rfbi.c b/drivers/video/fbdev/omap2/dss/rfbi.c
index 28e694b11ff9..065effca9236 100644
--- a/drivers/video/fbdev/omap2/dss/rfbi.c
+++ b/drivers/video/fbdev/omap2/dss/rfbi.c
@@ -869,7 +869,7 @@ static void rfbi_config_lcd_manager(struct omap_dss_device *dssdev)
869 rfbi.timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH; 869 rfbi.timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH;
870 rfbi.timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE; 870 rfbi.timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
871 rfbi.timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH; 871 rfbi.timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH;
872 rfbi.timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES; 872 rfbi.timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
873 873
874 dss_mgr_set_timings(mgr, &rfbi.timings); 874 dss_mgr_set_timings(mgr, &rfbi.timings);
875} 875}
diff --git a/drivers/video/fbdev/omap2/omapfb/omapfb-main.c b/drivers/video/fbdev/omap2/omapfb/omapfb-main.c
index 22f07f88bc40..4f0cbb54d4db 100644
--- a/drivers/video/fbdev/omap2/omapfb/omapfb-main.c
+++ b/drivers/video/fbdev/omap2/omapfb/omapfb-main.c
@@ -2073,7 +2073,7 @@ static int omapfb_mode_to_timings(const char *mode_str,
2073 } else { 2073 } else {
2074 timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE; 2074 timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
2075 timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH; 2075 timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
2076 timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES; 2076 timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
2077 } 2077 }
2078 2078
2079 timings->pixelclock = PICOS2KHZ(var->pixclock) * 1000; 2079 timings->pixelclock = PICOS2KHZ(var->pixclock) * 1000;
@@ -2223,7 +2223,7 @@ static void fb_videomode_to_omap_timings(struct fb_videomode *m,
2223 } else { 2223 } else {
2224 t->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE; 2224 t->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
2225 t->de_level = OMAPDSS_SIG_ACTIVE_HIGH; 2225 t->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
2226 t->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES; 2226 t->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
2227 } 2227 }
2228 2228
2229 t->x_res = m->xres; 2229 t->x_res = m->xres;
diff --git a/drivers/video/fbdev/pm3fb.c b/drivers/video/fbdev/pm3fb.c
index 4bf3273d0433..77b99ed39ad0 100644
--- a/drivers/video/fbdev/pm3fb.c
+++ b/drivers/video/fbdev/pm3fb.c
@@ -1479,9 +1479,9 @@ static void pm3fb_remove(struct pci_dev *dev)
1479 fb_dealloc_cmap(&info->cmap); 1479 fb_dealloc_cmap(&info->cmap);
1480 1480
1481#ifdef CONFIG_MTRR 1481#ifdef CONFIG_MTRR
1482 if (par->mtrr_handle >= 0) 1482 if (par->mtrr_handle >= 0)
1483 mtrr_del(par->mtrr_handle, info->fix.smem_start, 1483 mtrr_del(par->mtrr_handle, info->fix.smem_start,
1484 info->fix.smem_len); 1484 info->fix.smem_len);
1485#endif /* CONFIG_MTRR */ 1485#endif /* CONFIG_MTRR */
1486 iounmap(info->screen_base); 1486 iounmap(info->screen_base);
1487 release_mem_region(fix->smem_start, fix->smem_len); 1487 release_mem_region(fix->smem_start, fix->smem_len);
diff --git a/drivers/video/fbdev/pxafb.c b/drivers/video/fbdev/pxafb.c
index da2431eda2fd..7245611ec963 100644
--- a/drivers/video/fbdev/pxafb.c
+++ b/drivers/video/fbdev/pxafb.c
@@ -1285,7 +1285,7 @@ static int pxafb_smart_thread(void *arg)
1285 mutex_unlock(&fbi->ctrlr_lock); 1285 mutex_unlock(&fbi->ctrlr_lock);
1286 1286
1287 set_current_state(TASK_INTERRUPTIBLE); 1287 set_current_state(TASK_INTERRUPTIBLE);
1288 schedule_timeout(30 * HZ / 1000); 1288 schedule_timeout(msecs_to_jiffies(30));
1289 } 1289 }
1290 1290
1291 pr_debug("%s(): task ending\n", __func__); 1291 pr_debug("%s(): task ending\n", __func__);
@@ -1460,7 +1460,7 @@ static void pxafb_disable_controller(struct pxafb_info *fbi)
1460#ifdef CONFIG_FB_PXA_SMARTPANEL 1460#ifdef CONFIG_FB_PXA_SMARTPANEL
1461 if (fbi->lccr0 & LCCR0_LCDT) { 1461 if (fbi->lccr0 & LCCR0_LCDT) {
1462 wait_for_completion_timeout(&fbi->refresh_done, 1462 wait_for_completion_timeout(&fbi->refresh_done,
1463 200 * HZ / 1000); 1463 msecs_to_jiffies(200));
1464 return; 1464 return;
1465 } 1465 }
1466#endif 1466#endif
@@ -1472,7 +1472,7 @@ static void pxafb_disable_controller(struct pxafb_info *fbi)
1472 lcd_writel(fbi, LCCR0, lccr0); 1472 lcd_writel(fbi, LCCR0, lccr0);
1473 lcd_writel(fbi, LCCR0, lccr0 | LCCR0_DIS); 1473 lcd_writel(fbi, LCCR0, lccr0 | LCCR0_DIS);
1474 1474
1475 wait_for_completion_timeout(&fbi->disable_done, 200 * HZ / 1000); 1475 wait_for_completion_timeout(&fbi->disable_done, msecs_to_jiffies(200));
1476 1476
1477 /* disable LCD controller clock */ 1477 /* disable LCD controller clock */
1478 clk_disable_unprepare(fbi->clk); 1478 clk_disable_unprepare(fbi->clk);
diff --git a/drivers/video/fbdev/sh_mobile_lcdcfb.c b/drivers/video/fbdev/sh_mobile_lcdcfb.c
index d3013cd9f976..82c0a8caa9b8 100644
--- a/drivers/video/fbdev/sh_mobile_lcdcfb.c
+++ b/drivers/video/fbdev/sh_mobile_lcdcfb.c
@@ -1461,7 +1461,7 @@ overlay_rop3_store(struct device *dev, struct device_attribute *attr,
1461 unsigned int rop3; 1461 unsigned int rop3;
1462 char *endp; 1462 char *endp;
1463 1463
1464 rop3 = !!simple_strtoul(buf, &endp, 10); 1464 rop3 = simple_strtoul(buf, &endp, 10);
1465 if (isspace(*endp)) 1465 if (isspace(*endp))
1466 endp++; 1466 endp++;
1467 1467
@@ -2605,7 +2605,6 @@ sh_mobile_lcdc_channel_init(struct sh_mobile_lcdc_chan *ch)
2605 unsigned int max_size; 2605 unsigned int max_size;
2606 unsigned int i; 2606 unsigned int i;
2607 2607
2608 mutex_init(&ch->open_lock);
2609 ch->notify = sh_mobile_lcdc_display_notify; 2608 ch->notify = sh_mobile_lcdc_display_notify;
2610 2609
2611 /* Validate the format. */ 2610 /* Validate the format. */
@@ -2704,7 +2703,7 @@ static int sh_mobile_lcdc_probe(struct platform_device *pdev)
2704 struct resource *res; 2703 struct resource *res;
2705 int num_channels; 2704 int num_channels;
2706 int error; 2705 int error;
2707 int i; 2706 int irq, i;
2708 2707
2709 if (!pdata) { 2708 if (!pdata) {
2710 dev_err(&pdev->dev, "no platform data defined\n"); 2709 dev_err(&pdev->dev, "no platform data defined\n");
@@ -2712,8 +2711,8 @@ static int sh_mobile_lcdc_probe(struct platform_device *pdev)
2712 } 2711 }
2713 2712
2714 res = platform_get_resource(pdev, IORESOURCE_MEM, 0); 2713 res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
2715 i = platform_get_irq(pdev, 0); 2714 irq = platform_get_irq(pdev, 0);
2716 if (!res || i < 0) { 2715 if (!res || irq < 0) {
2717 dev_err(&pdev->dev, "cannot get platform resources\n"); 2716 dev_err(&pdev->dev, "cannot get platform resources\n");
2718 return -ENOENT; 2717 return -ENOENT;
2719 } 2718 }
@@ -2726,16 +2725,18 @@ static int sh_mobile_lcdc_probe(struct platform_device *pdev)
2726 2725
2727 priv->dev = &pdev->dev; 2726 priv->dev = &pdev->dev;
2728 priv->meram_dev = pdata->meram_dev; 2727 priv->meram_dev = pdata->meram_dev;
2728 for (i = 0; i < ARRAY_SIZE(priv->ch); i++)
2729 mutex_init(&priv->ch[i].open_lock);
2729 platform_set_drvdata(pdev, priv); 2730 platform_set_drvdata(pdev, priv);
2730 2731
2731 error = request_irq(i, sh_mobile_lcdc_irq, 0, 2732 error = request_irq(irq, sh_mobile_lcdc_irq, 0,
2732 dev_name(&pdev->dev), priv); 2733 dev_name(&pdev->dev), priv);
2733 if (error) { 2734 if (error) {
2734 dev_err(&pdev->dev, "unable to request irq\n"); 2735 dev_err(&pdev->dev, "unable to request irq\n");
2735 goto err1; 2736 goto err1;
2736 } 2737 }
2737 2738
2738 priv->irq = i; 2739 priv->irq = irq;
2739 atomic_set(&priv->hw_usecnt, -1); 2740 atomic_set(&priv->hw_usecnt, -1);
2740 2741
2741 for (i = 0, num_channels = 0; i < ARRAY_SIZE(pdata->ch); i++) { 2742 for (i = 0, num_channels = 0; i < ARRAY_SIZE(pdata->ch); i++) {
diff --git a/drivers/video/fbdev/sm501fb.c b/drivers/video/fbdev/sm501fb.c
index e8d4121783fb..d0a4e2f79a57 100644
--- a/drivers/video/fbdev/sm501fb.c
+++ b/drivers/video/fbdev/sm501fb.c
@@ -1606,7 +1606,7 @@ static int sm501fb_start(struct sm501fb_info *info,
1606 info->fbmem_len = resource_size(res); 1606 info->fbmem_len = resource_size(res);
1607 1607
1608 /* clear framebuffer memory - avoids garbage data on unused fb */ 1608 /* clear framebuffer memory - avoids garbage data on unused fb */
1609 memset(info->fbmem, 0, info->fbmem_len); 1609 memset_io(info->fbmem, 0, info->fbmem_len);
1610 1610
1611 /* clear palette ram - undefined at power on */ 1611 /* clear palette ram - undefined at power on */
1612 for (k = 0; k < (256 * 3); k++) 1612 for (k = 0; k < (256 * 3); k++)
diff --git a/drivers/video/fbdev/via/via_clock.c b/drivers/video/fbdev/via/via_clock.c
index db1e39277e32..bf269fa43977 100644
--- a/drivers/video/fbdev/via/via_clock.c
+++ b/drivers/video/fbdev/via/via_clock.c
@@ -30,7 +30,7 @@
30#include "global.h" 30#include "global.h"
31#include "debug.h" 31#include "debug.h"
32 32
33const char *via_slap = "Please slap VIA Technologies to motivate them " 33static const char *via_slap = "Please slap VIA Technologies to motivate them "
34 "releasing full documentation for your platform!\n"; 34 "releasing full documentation for your platform!\n";
35 35
36static inline u32 cle266_encode_pll(struct via_pll_config pll) 36static inline u32 cle266_encode_pll(struct via_pll_config pll)