Message ID | 1461244604.4695.38.camel@pengutronix.de (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Hi, Phillip! Thank you for the fast responce. Ifollowed your adviceandrealized thatIincorrectlyformulatedthought. I need a 180 degree rotation, not the flip. I got the vertical flip (screen reflected by Y axis), butmy attempt to reflect it by X axis (xrandr --output DISP3\ BG --reflect x) failed (nothing happened). Is there a way to do 180deg rotation somehow? On 21.04.2016 16:16, Philipp Zabel wrote: > to do a 180 degree vertical flip of the framebuffer using imx-drm > >upon kernel initialization. But I can see th Best regards, Ivan Nikolaenko. i.nikolaenko@geoscan.aero
Am Freitag, den 22.04.2016, 15:21 +0300 schrieb Ivan Nikolaenko: > Hi, Phillip! > > Thank you for the fast responce. > Ifollowed your adviceandrealized thatIincorrectlyformulatedthought. I > need a 180 degree rotation, not the flip. > I got the vertical flip (screen reflected by Y axis), butmy attempt to > reflect it by X axis (xrandr --output DISP3\ BG --reflect x) failed > (nothing happened). That is because the IDMAC controller considers the VF bit when calculating the line start addresses (so reflect Y works) but completely ignores the HF bit. The IC has a line buffer that is sampled backwards if the HF bit is set. > Is there a way to do 180deg rotation somehow? If your display is < 1024 pixels in both width and height, it should be possible to get reflect x functionality by hooking up the IC -> DMFC direct flow. regards Philipp
diff --git a/drivers/gpu/drm/imx/ipuv3-plane.c b/drivers/gpu/drm/imx/ipuv3-plane.c index 681ec6e..37d9ebd 100644 --- a/drivers/gpu/drm/imx/ipuv3-plane.c +++ b/drivers/gpu/drm/imx/ipuv3-plane.c @@ -291,6 +291,7 @@ int ipu_plane_mode_set(struct ipu_plane *ipu_plane, struct drm_crtc *crtc, ipu_dmfc_config_wait4eot(ipu_plane->dmfc, crtc_w); ipu_cpmem_zero(ipu_plane->ipu_ch); + ipu_cpmem_set_rotation(ipu_plane->ipu_ch, IPU_ROTATE_VERT_FLIP); ipu_cpmem_set_resolution(ipu_plane->ipu_ch, src_w, src_h); ret = ipu_cpmem_set_fmt(ipu_plane->ipu_ch, fb->pixel_format); if (ret < 0) {