Hi, On 04/07/2015 08:14 AM, Tobias Jakobi wrote: > While the VP (video processor) supports arbitrary scaling > of its input, the mixer just supports a simple 2x (line > doubling) scaling. Expose this functionality and exit > early when an unsupported scaling configuration is > encountered. > > This was tested with modetest's DRM plane test (from > the libdrm test suite) on an Odroid-X2 (Exynos4412). > > v2: Put if- and return-statement on different lines. > > Reviewed-by: Gustavo Padovan <gustavo.padovan@xxxxxxxxxxxxxxx> > Signed-off-by: Tobias Jakobi <tjakobi@xxxxxxxxxxxxxxxxxxxxx> > --- > drivers/gpu/drm/exynos/exynos_mixer.c | 36 +++++++++++++++++++++++++++++------ > 1 file changed, 30 insertions(+), 6 deletions(-) > > diff --git a/drivers/gpu/drm/exynos/exynos_mixer.c b/drivers/gpu/drm/exynos/exynos_mixer.c > index 5ab0e32..f51011e 100644 > --- a/drivers/gpu/drm/exynos/exynos_mixer.c > +++ b/drivers/gpu/drm/exynos/exynos_mixer.c > @@ -499,12 +499,36 @@ static void mixer_layer_update(struct mixer_context *ctx) > mixer_reg_writemask(res, MXR_CFG, ~0, MXR_CFG_LAYER_UPDATE); > } > > +static int mixer_setup_scale(const struct exynos_drm_plane *plane, > + unsigned int *x_ratio, unsigned int *y_ratio) > +{ > + if (plane->crtc_width != plane->src_width) { > + if (plane->crtc_width == 2 * plane->src_width) > + *x_ratio = 1; > + else > + goto fail; > + } > + > + if (plane->crtc_height != plane->src_height) { > + if (plane->crtc_height == 2 * plane->src_height) > + *y_ratio = 1; > + else > + goto fail; > + } > + > + return 0; > + > +fail: > + DRM_DEBUG_KMS("only 2x width/height scaling of plane supported\n"); > + return -ENOTSUPP; > +} > + > static void mixer_graph_buffer(struct mixer_context *ctx, int win) > { > struct mixer_resources *res = &ctx->mixer_res; > unsigned long flags; > struct exynos_drm_plane *plane; > - unsigned int x_ratio, y_ratio; > + unsigned int x_ratio = 0, y_ratio = 0; > unsigned int src_x_offset, src_y_offset, dst_x_offset, dst_y_offset; > dma_addr_t dma_addr; > unsigned int fmt; > @@ -528,9 +552,9 @@ static void mixer_graph_buffer(struct mixer_context *ctx, int win) > fmt = ARGB8888; > } > > - /* 2x scaling feature */ > - x_ratio = 0; > - y_ratio = 0; > + /* check if mixer supports requested scaling setup */ > + if (mixer_setup_scale(plane, &x_ratio, &y_ratio)) > + return; > > dst_x_offset = plane->crtc_x; > dst_y_offset = plane->crtc_y; > @@ -566,8 +590,8 @@ static void mixer_graph_buffer(struct mixer_context *ctx, int win) > mixer_reg_write(res, MXR_RESOLUTION, val); > } > > - val = MXR_GRP_WH_WIDTH(plane->crtc_width); > - val |= MXR_GRP_WH_HEIGHT(plane->crtc_height); > + val = MXR_GRP_WH_WIDTH(plane->src_width); > + val |= MXR_GRP_WH_HEIGHT(plane->src_height); With this changes, i got errors when crtc gets out bound of actual screen area. I sent patch to fix it and to calculate ratio from exynos_drm plane codes. Acked-by: Joonyoung Shim <jy0922.shim@xxxxxxxxxxx> Thanks. _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/dri-devel