From mboxrd@z Thu Jan 1 00:00:00 1970 From: Thierry Reding Subject: Re: [RFC v2 6/8] gpu: drm: tegra: Remove redundant host1x Date: Wed, 5 Dec 2012 14:28:43 +0100 Message-ID: <20121205132843.GA2834@avionic-0098.adnet.avionic-design.de> References: <1353935954-13763-1-git-send-email-tbergstrom@nvidia.com> <1353935954-13763-7-git-send-email-tbergstrom@nvidia.com> <20121205083335.GA20984@avionic-0098.adnet.avionic-design.de> <50BF1DAA.8030805@nvidia.com> <20121205111332.GA25676@avionic-0098.adnet.avionic-design.de> <50BF345A.8050201@nvidia.com> <20121205122209.GB29943@avionic-0098.adnet.avionic-design.de> Mime-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="fdj2RfSjLxBAspz7" Return-path: Content-Disposition: inline In-Reply-To: Sender: linux-tegra-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Daniel Vetter Cc: Terje =?utf-8?Q?Bergstr=C3=B6m?= , "linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org" , "linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org" , "dri-devel-PD4FTy7X32lNgt0PjOBp9y5qC8QIuHrW@public.gmane.org" , Arto Merilainen List-Id: linux-tegra@vger.kernel.org --fdj2RfSjLxBAspz7 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Wed, Dec 05, 2012 at 01:31:54PM +0100, Daniel Vetter wrote: > On Wed, Dec 5, 2012 at 1:22 PM, Thierry Reding > wrote: > > Maybe something more elaborate could help, though. Suppose we add > > functionality to DRM to instantiate a DRM device. We could call such a > > function from the host1x driver to add a device which the tegra-drm > > driver could bind to. This would entail something like a small bus > > implementation for DRM that would allow matching DRM devices to DRM > > drivers much like the platform or PCI busses. This could automatically > > take care of registering the DRM device with the proper parent so that > > host1x clients can lookup the host1x via dev->parent. > > > > Perhaps something as simple as > > > > int drm_device_register(struct device *parent, const char *name= , int id); > > > > could work. Or something more elaborate such as allocating a device with > > > > struct drm_device *drm_device_alloc(const char *name, int id); > > > > paired with > > > > int drm_device_register(struct drm_device *dev); > > > > would be more flexible in that drivers could modify the DRM device in > > between the two calls. >=20 > Imo that's worse, since now drm manages even more of the driver->hw > binding process. In my dream world the drm driver just registers a > normal driver at module load time directly with whatever bus it's > interested in, and then, from it the bus' ->probe callback setups up > the entire driver, calling down into drm to setup up interfaces to > userspace (dev node, sysfs, and whatever is required to implement the > ioctls) and uses the various helper libraries provided. So host1x > providing a virtual device that tegradrm can match sounds much better > (if that helps in decoupling from host1x). Okay, now I see where you're going. You want to replace the various drm_*_init() functions with something more fine-grained that does the initialization manually in each driver. Is that it? The obvious disadvantage is that a lot of code would have to be duplicated, though that can presumably be factored out into further helpers if necessary. On that note, I just noticed that drm_platform_init() actually binds a single platform_device to the drm_driver, which isn't going to work very well in case there are two devices that want to use the same driver. It would be nice to get rid of that limitation as well while at it. > Or simply call the tegradrm setup from host1x directly, creating a > depency on the tegradrm module. When trying to unload host1x it can > then also call down into tegradrm to tear down the drm device. > Afterwards you should be able to unload tegradrm without fuzz. And if > the hard dependcy is an issue for other host1x clients this > setup/teardown could be wrapped into an #ifdef CONFIG_TEGRADRM. This is what I originally proposed. However, since tegra-drm will need to call functions provided by host1x we have a cyclic dependency. Wouldn't that prevent either module from being unloaded? Thierry --fdj2RfSjLxBAspz7 Content-Type: application/pgp-signature -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.19 (GNU/Linux) iQIcBAEBAgAGBQJQv0wLAAoJEN0jrNd/PrOh1oUQAJ7KdT6Ztn9YiRnHO1p+yu/l XHpw+wAfR6ssxgo3nOzPM323AwGjt5T7vPDXruZSmQeRnBqCh3en0wgnH+ynVLax OpUAqwL2JLeU0NguA12CDAs9mlc+6ARKiTc+swTvNtmLRie4yD+0rUVaOBXnTzw2 UFzFeuMFo4hSrDTMEnBZNW7aQI9tKzp6aj0QzH6ebpH6T68t6CrIxtYwp6Is9kva XZgw0AoUWWeryUlUeVjQ/L3SJRQRvPlP+cqOnMsq0Lx8FXTkn0AuFcZ8JaHlilcq 08OjTF03M48NWfZG3zNHSdfn3faQ/qwkYecJQDkm6mmvdngfPoeswsowACqnaFTq SozQ8e3nXgBu50BtuhM7nI+Qmf9p9lIQHlf0753bDSvjuVq3i8n7keDPOHVlC1jk SuxGaAdEdKp2MFiP/X+tJUM7FUiLNo5O0sKK5V007TWHEvtHqVuzljKVQrvzDdZ3 tbR3cgcljMlCBFiJSeJz86Ug2x4sf0mOMpmdxGZi2o3ImJBmeBFTCXrLq9P0j5WT QBmA29pbwyecizKULhtSbL/M74iQco8/xcipolJicenXMaS2PDTU867drcctUPM3 gJ/mFYp87HVxsrmZQjRPPyewkGXilSzecIyhrIsfisKa/ZcN/589BYDWKerCSV/t wNh+g5hMABqJCX4wnYkQ =zby3 -----END PGP SIGNATURE----- --fdj2RfSjLxBAspz7--