From: Thomas Zimmermann <tzimmermann@suse.de>
To: Tomohito Esaki <etom@igel.co.jp>,
Maarten Lankhorst <maarten.lankhorst@linux.intel.com>,
Maxime Ripard <mripard@kernel.org>,
David Airlie <airlied@linux.ie>, Daniel Vetter <daniel@ffwll.ch>,
Laurent Pinchart <laurent.pinchart@ideasonboard.com>,
Kieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Cc: dri-devlel@lists.freedesktop.org,
linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org,
devicetree@vger.kernel.org, linux-doc@vger.kernel.org
Subject: Re: [PATH 0/4] [RFC] Support virtual DRM
Date: Mon, 21 Jun 2021 09:10:19 +0200 [thread overview]
Message-ID: <9853d0a9-6053-db64-9c79-40b7e0689eec@suse.de> (raw)
In-Reply-To: <20210621062742.26073-1-etom@igel.co.jp>
[-- Attachment #1.1: Type: text/plain, Size: 4332 bytes --]
Hi
Am 21.06.21 um 08:27 schrieb Tomohito Esaki:
> Virtual DRM splits the overlay planes of a display controller into multiple
> virtual devices to allow each plane to be accessed by each process.
>
> This makes it possible to overlay images output from multiple processes on a
> display. For example, one process displays the camera image without compositor
> while another process overlays the UI.
I briefly looked over your patches. I didn't understand how this is
different to the functionality of a compositor? Shouldn't this be solved
in userspace?
Best regards
Thomas
>
> Virtual DRM driver doesn’t directly control the display hardware and has no
> access to the physical bus. Instead, the virtual DRM driver issues requests to
> the standard DRM device driver (parent) when the hardware needs to be
> controlled. The parent is modified to notify the virtual DRM driver of
> interruptevents from the display hardware. Therefore, in order to use virtual
> DRM, each DRM device driver needs to add code to support virutal DRM.
>
> The only driver supported in this patch series is rcar-du. This patch series
> is divided into multiple. The first patch adds vDRM feature to DRM, and the
> second patch support vDRM for the rcar-du driver. The other patches add
> documentation.
>
> In particular, I would appreciate your advice on the following points:
> * virtual DRM generalization
> I've only tested with rcar-du, is there anything I should consider to make
> virtual DRM work with other drivers?
>
> * Integration to upstream
> I think it is a good idea to add virtual DRM to the DRM core functionality,
> but I would appreciate any suggestions on what needs to be improved for
> integration to upstream.
>
> * dumb_create and fb_create callback
> I think that the dumb_create and fb_create callbacks need to be done by the
> parent, and it is preferable to use the parent's callbacks as they are.
> However, since the dumb buffer needs to be registered in the parent and
> the fb handle needs to be registered in the drm_file of the vDRM, the
> dumb_create callbacks from the parent driver cannot be used as is.
> Therefore, the current implementation of the dumb_create callback is
> workarround.
> What do you think is the best way to deal with this issue?
>
>
> Tomohito Esaki (4):
> Add Virtual DRM device driver
> rcar-du: Add support virtual DRM device
> dt-bindings: display: Add virtual DRM
> doc-rst: Add virtual DRM documentation
>
> .../devicetree/bindings/display/vdrm.yaml | 67 ++
> Documentation/gpu/drivers.rst | 1 +
> Documentation/gpu/vdrm.rst | 51 ++
> drivers/gpu/drm/Kconfig | 7 +
> drivers/gpu/drm/Makefile | 1 +
> drivers/gpu/drm/rcar-du/Kconfig | 4 +
> drivers/gpu/drm/rcar-du/Makefile | 1 +
> drivers/gpu/drm/rcar-du/rcar_du_crtc.c | 42 +
> drivers/gpu/drm/rcar-du/rcar_du_crtc.h | 13 +
> drivers/gpu/drm/rcar-du/rcar_du_drv.c | 13 +
> drivers/gpu/drm/rcar-du/rcar_du_drv.h | 3 +
> drivers/gpu/drm/rcar-du/rcar_du_vdrm.c | 191 ++++
> drivers/gpu/drm/rcar-du/rcar_du_vdrm.h | 67 ++
> drivers/gpu/drm/rcar-du/rcar_du_vsp.c | 22 +
> drivers/gpu/drm/rcar-du/rcar_du_vsp.h | 1 +
> drivers/gpu/drm/vdrm/vdrm_api.h | 68 ++
> drivers/gpu/drm/vdrm/vdrm_drv.c | 859 ++++++++++++++++++
> drivers/gpu/drm/vdrm/vdrm_drv.h | 80 ++
> 18 files changed, 1491 insertions(+)
> create mode 100644 Documentation/devicetree/bindings/display/vdrm.yaml
> create mode 100644 Documentation/gpu/vdrm.rst
> create mode 100644 drivers/gpu/drm/rcar-du/rcar_du_vdrm.c
> create mode 100644 drivers/gpu/drm/rcar-du/rcar_du_vdrm.h
> create mode 100644 drivers/gpu/drm/vdrm/vdrm_api.h
> create mode 100644 drivers/gpu/drm/vdrm/vdrm_drv.c
> create mode 100644 drivers/gpu/drm/vdrm/vdrm_drv.h
>
--
Thomas Zimmermann
Graphics Driver Developer
SUSE Software Solutions Germany GmbH
Maxfeldstr. 5, 90409 Nürnberg, Germany
(HRB 36809, AG Nürnberg)
Geschäftsführer: Felix Imendörffer
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 840 bytes --]
next prev parent reply other threads:[~2021-06-21 7:10 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-06-21 6:27 [PATH 0/4] [RFC] Support virtual DRM Tomohito Esaki
2021-06-21 6:27 ` [PATH 1/4] drm: Add Virtual DRM device driver Tomohito Esaki
2021-06-21 6:27 ` [PATH 2/4] rcar-du: Add support virtual DRM device Tomohito Esaki
2021-06-21 6:27 ` [PATH 3/4] dt-bindings: display: Add virtual DRM Tomohito Esaki
2021-06-21 6:27 ` [PATH 4/4] doc-rst: Add virtual DRM documentation Tomohito Esaki
2021-06-21 7:10 ` Thomas Zimmermann [this message]
2021-06-21 9:24 ` [PATH 0/4] [RFC] Support virtual DRM Maxime Ripard
2021-06-22 4:36 ` Esaki Tomohito
2021-06-23 14:39 ` Maxime Ripard
2021-06-22 4:02 ` Esaki Tomohito
2021-06-22 7:57 ` Pekka Paalanen
2021-06-23 8:04 ` Michel Dänzer
2021-06-23 8:21 ` Esaki Tomohito
2021-06-22 9:12 ` Thomas Zimmermann
2021-06-21 16:05 ` Enrico Weigelt, metux IT consult
2021-06-22 4:03 ` Esaki Tomohito
2021-06-22 8:12 ` Pekka Paalanen
2021-06-22 19:12 ` Daniel Vetter
2021-06-23 6:56 ` Esaki Tomohito
2021-06-23 8:39 ` Pekka Paalanen
2021-06-23 9:22 ` Esaki Tomohito
2021-06-23 11:41 ` Pekka Paalanen
2021-06-25 1:55 ` Esaki Tomohito
-- strict thread matches above, loose matches on Subject: below --
2021-06-21 6:43 Tomohito Esaki
2021-06-22 8:04 ` Simon Ser
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=9853d0a9-6053-db64-9c79-40b7e0689eec@suse.de \
--to=tzimmermann@suse.de \
--cc=airlied@linux.ie \
--cc=daniel@ffwll.ch \
--cc=devicetree@vger.kernel.org \
--cc=dri-devlel@lists.freedesktop.org \
--cc=etom@igel.co.jp \
--cc=kieran.bingham+renesas@ideasonboard.com \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linux-doc@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-renesas-soc@vger.kernel.org \
--cc=maarten.lankhorst@linux.intel.com \
--cc=mripard@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).