On 16.12.2012 14:16, Thierry Reding wrote: > Okay, so we're back on the topic of using globals. I need to assert > again that this is not an option. If we were to use globals, then we > could just as well leave out the dummy device and just do all of that in > the tegra-drm driver's initialization function. I found a way of dropping the global in a straightforward way, and introduce dummy device for drm_platform_init(). I added dummy device and driver, and moved the tegradrm global (previously called struct host1x *host1x) allocation to happen in the probe. In addition, probe calls device tree node traversal to do the tegra_drm_add_client() calls. The dummy device is owner for this global. I changed the device tree node traversal so that it goes actually through each host1x child, checks if it's supported by tegradrm, and if so, sets its drvdata to point to the tegradrm data. Each probe will add the client with tegra_drm_register_client(), and that will find the global via dev_get_drvdata(). In the end of probe, each driver will replace the drvdata with its own data. I am also setting the coherent_dma_mask for dummy device so that it can be used with CMA FB helper. Would this be ok for you? I could send a patchset with this implemented by tomorrow and let it simmer for 2-3 weeks due to my and everybody elses' holidays. I'm hoping we would have 2D acceleration in Linux kernel 3.9. Terje -- To unsubscribe from this list: send the line "unsubscribe linux-tegra" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html