u16 post_dsp_vact_st_f1, post_dsp_vact_end_f1;
u16 post_h_fac, post_v_fac;
+ screen->post_dsp_stx = x_res * (100 - dev_drv->overscan.left) / 200;
+ screen->post_dsp_sty = y_res * (100 - dev_drv->overscan.top) / 200;
+ screen->post_xsize = x_res *
+ (dev_drv->overscan.left + dev_drv->overscan.right) / 200;
+ screen->post_ysize = y_res *
+ (dev_drv->overscan.top + dev_drv->overscan.bottom) / 200;
+
h_total = screen->mode.hsync_len + screen->mode.left_margin +
x_res + screen->mode.right_margin;
v_total = screen->mode.vsync_len + screen->mode.upper_margin +
h_total = hsync_len + left_margin + x_res + right_margin;
v_total = vsync_len + upper_margin + y_res + lower_margin;
- screen->post_dsp_stx = x_res * (100 - screen->overscan.left) / 200;
- screen->post_dsp_sty = y_res * (100 - screen->overscan.top) / 200;
- screen->post_xsize = x_res *
- (screen->overscan.left + screen->overscan.right) / 200;
- screen->post_ysize = y_res *
- (screen->overscan.top + screen->overscan.bottom) / 200;
-
mask = m_DSP_HS_PW | m_DSP_HTOTAL;
val = v_DSP_HS_PW(hsync_len) | v_DSP_HTOTAL(h_total);
lcdc_msk_reg(lcdc_dev, DSP_HTOTAL_HS_END, mask, val);
return 0;
}
+static int rk3368_lcdc_set_overscan(struct rk_lcdc_driver *dev_drv,
+ struct overscan *overscan)
+{
+ rk3368_lcdc_post_cfg(dev_drv);
+
+ return 0;
+}
+
static struct rk_lcdc_drv_ops lcdc_drv_ops = {
.open = rk3368_lcdc_open,
.win_direct_en = rk3368_lcdc_win_direct_en,
.dsp_black = rk3368_lcdc_dsp_black,
.backlight_close = rk3368_lcdc_backlight_close,
.mmu_en = rk3368_lcdc_mmu_en,
+ .set_overscan = rk3368_lcdc_set_overscan,
};
#ifdef LCDC_IRQ_EMPTY_DEBUG
struct fb_info *fbi = dev_get_drvdata(dev);
struct rk_fb_par *fb_par = (struct rk_fb_par *)fbi->par;
struct rk_lcdc_driver *dev_drv = fb_par->lcdc_drv;
- struct rk_screen *screen = dev_drv->cur_screen;
return snprintf(buf, PAGE_SIZE,
"xscale=%d yscale=%d\nleft=%d top=%d right=%d bottom=%d\n",
- (screen->overscan.left + screen->overscan.right)/2,
- (screen->overscan.top + screen->overscan.bottom)/2,
- screen->overscan.left, screen->overscan.top,
- screen->overscan.right, screen->overscan.bottom);
+ (dev_drv->overscan.left + dev_drv->overscan.right) / 2,
+ (dev_drv->overscan.top + dev_drv->overscan.bottom) / 2,
+ dev_drv->overscan.left, dev_drv->overscan.top,
+ dev_drv->overscan.right, dev_drv->overscan.bottom);
}
static ssize_t set_scale(struct device *dev, struct device_attribute *attr,
struct fb_info *fbi = dev_get_drvdata(dev);
struct rk_fb_par *fb_par = (struct rk_fb_par *)fbi->par;
struct rk_lcdc_driver *dev_drv = fb_par->lcdc_drv;
- struct rk_screen *screen = dev_drv->cur_screen;
u32 left, top, right, bottom;
if (!strncmp(buf, "overscan", 8)) {
sscanf(buf,
"overscan %d,%d,%d,%d", &left, &top, &right, &bottom);
if (left > 0 && left <= 100)
- screen->overscan.left = left;
+ dev_drv->overscan.left = left;
if (top > 0 && top <= 100)
- screen->overscan.top = top;
+ dev_drv->overscan.top = top;
if (right > 0 && right <= 100)
- screen->overscan.right = right;
+ dev_drv->overscan.right = right;
if (bottom > 0 && bottom <= 100)
- screen->overscan.bottom = bottom;
+ dev_drv->overscan.bottom = bottom;
} else if (!strncmp(buf, "left", 4)) {
sscanf(buf, "left=%d", &left);
if (left > 0 && left <= 100)
- screen->overscan.left = left;
+ dev_drv->overscan.left = left;
} else if (!strncmp(buf, "top", 3)) {
sscanf(buf, "top=%d", &top);
if (top > 0 && top <= 100)
- screen->overscan.top = top;
+ dev_drv->overscan.top = top;
} else if (!strncmp(buf, "right", 5)) {
sscanf(buf, "right=%d", &right);
if (right > 0 && right <= 100)
- screen->overscan.right = right;
+ dev_drv->overscan.right = right;
} else if (!strncmp(buf, "bottom", 6)) {
sscanf(buf, "bottom=%d", &bottom);
if (bottom > 0 && bottom <= 100)
- screen->overscan.bottom = bottom;
+ dev_drv->overscan.bottom = bottom;
} else if (!strncmp(buf, "xscale", 6)) {
sscanf(buf, "xscale=%d", &left);
if (left > 0 && left <= 100) {
- screen->overscan.left = left;
- screen->overscan.right = left;
+ dev_drv->overscan.left = left;
+ dev_drv->overscan.right = left;
}
} else if (!strncmp(buf, "yscale", 6)) {
sscanf(buf, "yscale=%d", &left);
if (left > 0 && left <= 100) {
- screen->overscan.top = left;
- screen->overscan.bottom = left;
+ dev_drv->overscan.top = left;
+ dev_drv->overscan.bottom = left;
}
} else {
sscanf(buf, "%d", &left);
if (left > 0 && left <= 100) {
- screen->overscan.left = left;
- screen->overscan.right = left;
- screen->overscan.top = left;
- screen->overscan.bottom = left;
+ dev_drv->overscan.left = left;
+ dev_drv->overscan.right = left;
+ dev_drv->overscan.top = left;
+ dev_drv->overscan.bottom = left;
}
}
if (dev_drv->ops->set_overscan)
- dev_drv->ops->set_overscan(dev_drv, &screen->overscan);
+ dev_drv->ops->set_overscan(dev_drv, &dev_drv->overscan);
return count;
}