Hi Russell, On Wednesday 26 February 2014 13:28:56 Russell King - ARM Linux wrote: > On Wed, Feb 26, 2014 at 02:44:02PM +0200, Tomi Valkeinen wrote: > > > Also - DRM is not going to ever support hotplugging components - this > > > was discussed at kernel summit last year and David Airlie was quite > > > > Ok. Very odd stance. Maybe there's a reason for it that I just don't see. > > DRM is like ALSA - it's a card level subsystem. All components have > to be present before the card level is brought up for the subsystem to > function correctly. I agree with Tomi here, I believe hot-plug (without hot-unplug) would be useful in case part of a video pipeline fails to probe. In a multi-output system (let's say HDMI and DSI panel for instance) I'd like the HDMI output to work if the DSI panel driver isn't loaded. DRM doesn't support this, and will not in the near future, but let's just keep in mind that real use cases exist. I'm not asking anyone to implement DRM hot- plug support now, but the idea itself shouldn't be nacked if someone can come up with a proper implementation. > > > adamant about that. So, any "framework" which forces hotplugging of > > > components on subsystems isn't going to fly. > > > > CDF doesn't force hotplugging. > > > > Although without hotplugging (hot-unplug not needed), or at least some > > minimal form of it, the system is a bit crippled. Leave one kernel > > module out, or have one driver probe fail, the whole display subsystem > > fails, even if some display pipelines would work fine. > > That is, unfortunately, one of the side effects of the policy - but that's > not a policy that's going to change any time soon. As I said, that was > made very clear at the last kernel summit - we had a /specific/ session > on the issues around multi-device DRM chaired by David. > > There are some DRM drivers which have tried to do this, but they're all > buggy in some regard, whether that be to the point of oopsing the kernel > if things don't quite go to plan, or whether it's races between different > parts. > > > > This is why we now have the component helpers in the driver model - > > > to allow devices to be collected together into one logical subsystem > > > group, and bound/unbound as a group. > > > > Yep, it's a good start. The component helpers could well be used with CDF. > > > > But if I'm not mistaken, it suffers from the problems above, when there > > are multiple independent pipelines (simultaneous or non-simultaneous) > > handled by the same IPs. > > It may "suffer from the problems above" that you've raised, but that's > by explicit design of it - because that's what subsystems like DRM and > ALSA require, and this is _precisely_ the problem it's solving. > > It's solving the "subsystem requires a stable view of hardware components, > but we have multiple devices and drivers which need probing" problem. > > > And, while I may be mistaken, it sounds that the component helpers leave > > mostly everything up to the display drivers. Everyone devising their own > > way to describe the hardware in DT, and the connections between the > > components. Of course, the core component system shouldn't define > > anything DT related, as it doesn't. But that part is still needed, which > > is where CDF comes in. > > Sigh. It's very easy for people to get the wrong end of the stick. > > What the component helpers do is provide a _subsystem_ _independent_ > method of collecting a set of devices together and binding them to the > drivers at an appropriate time, in a way that is _completely_ independent > of whether you're using platform data, DT, ACPI, or whatever other > hardware description language comes along. I think we all agree here, the component framework is required to implement clean support for component-based, DT-based systems, but doesn't depend on DT and doesn't imply any specific DT binding. What I believe bother people is that the example you have goes in a direction that might not be future-proof, and should thus not be used as an example to create display-related DT bindings. My understanding is that it's just an example to illustrate the kind of use case that the component framework can help with, not a proper DT bindings example that should be followed to design now DT bindings. > It's up to the users of this to define how components are grouped > together, whether that be at the subsystem level or at the driver > level - whatever is appropriate. > > If a subsystem (eg, a display subsystem) wants to define "this is how > you define in DT the bindings between all components" and provide its > own hook for the "add_components" callback which does this, then it's > at liberty to do that. > > If we can come up with a generic way to describe how all the components > in a display subsystem should be connected together, then great - but > that needs to happen very quickly. Philipp Zabel is working on replacing > the imx-drm binding method right now for 3.15, and is probably completely > unaware of anything that's been talked about here. I need to sort out > Armada DRM at some point to use the component stuff, which includes > sorting out TDA998x for DT - which again needs to be done in such a way > that it follows a common theme. > > > I need to ask Dave why he is so strongly opposed to hotplugging > > components. > > I suspect one reason for it is because it means rewriting the XF86 > backend to Xorg to cope with it... <troll>The world is moving to Wayland anyway</troll> ;-) > > > Remember that "hotplugging" in this context does not mean that the > > > user can physically do something with the hardware. It means that > > > they're separate devices which can be probed/removed at will. Every > > > device in Linux can be bound and unbound from its driver at any time > > > by userspace, and that is something which is expected to be handled > > > gracefully. > > > > Hmm, sorry, can you rephrase? > > I'll do better than that. Try running this script with the > /sys/bus/.../drivers/whatever for the drivers you wish to test: > > #!/bin/sh > for driver in "$@"; do > if [ -f "${driver}/unbind" ]; then > for device in "${driver}"/*; do > if [ -d "${device}" ]; then > devname="$(basename "${device}")" > echo "$devname" > "${driver}/unbind" > echo "$devname" > "${driver}/bind" > fi > done > fi > done > > The system should survive that. I've kept this problem in the back of my head for some time now and I'm curious to know whether you have thought about how to solve it for component- based systems. Given that DRM doesn't support hot-unplug, is the solution based on preventing driver unbind by returning an error from the remove handler ? > > So with hotplug, a new fbdev or a combination of drm crtcs, encoders, > > etc, could appear even after the initial probe of the display controller. > > This is the exact situation that David is opposed to. DRM, like ALSA, > whats to have a stable view of hardware - once the drm_device has been > created and probed, no further changes to it are allowed. > > Certainly no changes to the CRTCs will _ever_ be permitted, because it > completely destroys the user API for referecing which encoders can be > associated with which CRTCs - not only at the kernel level, but also the > Xorg and Xrandr level too. That's done via a bitmask of allowable CRTCs, > where bit 0 refers to the first CRTC, bit 1 to the second and so on. > That's propagated all the way through to userspace, right through the Xorg > interfaces to applications. > > Connectors and encoders are fixed at the moment after initial probe time > in DRM due to the way the fbdev emulation layer works. There's also issues > there concerning bitmasks for which connectors can be cloned onto other > connectors which follows the same pattern as above - and again, that > propagates all the way through userspace. > > So, if this is going to get fixed, there has to be a desire to break > userspace quite badly, and there is no such desire to do that. > > For instance, let's say that Xorg is up and running, and you have the > gnome applet for configuring your display open, and you have two CRTCs. > Then the first CRTC is removed from the system, resulting in CRTC 1 > becoming CRTC 0 in the kernel. What happens... > > Think the same thing through for a system with three connectors, A, B, C > numbered 0, 1, and 2 respectively. A and be cloned onto B. Now connector > A is removed, meaning B and C appear to become numbers 0 and 1 in the > kernel... -- Regards, Laurent Pinchart -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html