[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <Z3IDh0TOAKqaovz2@per.namespace.at>
Date: Mon, 30 Dec 2024 03:20:55 +0100
From: Chris Hofstaedtler <zeha@...ian.org>
To: Heiko Stuebner <heiko@...ech.de>
Cc: andy.yan@...k-chips.com, maarten.lankhorst@...ux.intel.com,
mripard@...nel.org, tzimmermann@...e.de, robh@...nel.org,
krzk+dt@...nel.org, conor+dt@...nel.org, andrzej.hajda@...el.com,
neil.armstrong@...aro.org, rfoss@...nel.org,
Laurent.pinchart@...asonboard.com, jonas@...boo.se,
jernej.skrabec@...il.com, dri-devel@...ts.freedesktop.org,
devicetree@...r.kernel.org, linux-arm-kernel@...ts.infradead.org,
linux-rockchip@...ts.infradead.org, linux-kernel@...r.kernel.org,
quentin.schulz@...rry.de, Heiko Stuebner <heiko.stuebner@...rry.de>,
Daniel Semkowicz <dse@...umatec.com>,
Dmitry Yashin <dmt.yashin@...il.com>
Subject: Re: [PATCH v4 1/3] drm/bridge/synopsys: Add MIPI DSI2 host
controller bridge
Hi,
On Tue, Dec 10, 2024 at 12:10:19AM +0100, Heiko Stuebner wrote:
> From: Heiko Stuebner <heiko.stuebner@...rry.de>
>
> Add a Synopsys Designware MIPI DSI host DRM bridge driver for their
> DSI2 host controller, based on the Rockchip version from the driver
> rockchip/dw-mipi-dsi2.c in their vendor-kernel with phy & bridge APIs.
>
> While the driver is heavily modelled after the previous IP, the register
> set of this DSI2 controller is completely different and there are also
> additional properties like the variable-width phy interface.
>
> Tested-by: Daniel Semkowicz <dse@...umatec.com>
> Tested-by: Dmitry Yashin <dmt.yashin@...il.com>
> Reviewed-by: Neil Armstrong <neil.armstrong@...aro.org>
> Signed-off-by: Heiko Stuebner <heiko.stuebner@...rry.de>
[..]
> +static void dw_mipi_dsi2_set_vid_mode(struct dw_mipi_dsi2 *dsi2)
> +{
> + u32 val = 0, mode;
> + int ret;
> +
> + if (dsi2->mode_flags & MIPI_DSI_MODE_VIDEO_NO_HFP)
> + val |= BLK_HFP_HS_EN;
> +
> + if (dsi2->mode_flags & MIPI_DSI_MODE_VIDEO_NO_HBP)
> + val |= BLK_HBP_HS_EN;
> +
> + if (dsi2->mode_flags & MIPI_DSI_MODE_VIDEO_NO_HSA)
> + val |= BLK_HSA_HS_EN;
For all three of these: is setting an ENable bit the right thing to
turn features *off*?
> + if (dsi2->mode_flags & MIPI_DSI_MODE_VIDEO_BURST)
> + val |= VID_MODE_TYPE_BURST;
> + else if (dsi2->mode_flags & MIPI_DSI_MODE_VIDEO_SYNC_PULSE)
> + val |= VID_MODE_TYPE_NON_BURST_SYNC_PULSES;
> + else
> + val |= VID_MODE_TYPE_NON_BURST_SYNC_EVENTS;
> +
> + regmap_write(dsi2->regmap, DSI2_DSI_VID_TX_CFG, val);
> +
> + regmap_write(dsi2->regmap, DSI2_MODE_CTRL, VIDEO_MODE);
> + ret = regmap_read_poll_timeout(dsi2->regmap, DSI2_MODE_STATUS,
> + mode, mode & VIDEO_MODE,
> + 1000, MODE_STATUS_TIMEOUT_US);
> + if (ret < 0)
> + dev_err(dsi2->dev, "failed to enter video mode\n");
> +}
...
Chris
Powered by blists - more mailing lists