On Wed, Dec 05, 2012 at 01:31:54PM +0100, Daniel Vetter wrote: > On Wed, Dec 5, 2012 at 1:22 PM, Thierry Reding > <thierry.reding@xxxxxxxxxxxxxxxxx> 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. > > 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
Attachment:
pgplSK94_NvL6.pgp
Description: PGP signature