Thanks for explaining! I've resorted to creating a dummy_hcd2.c and zero2.c from corresponding existing sources, tweaked source and Makefiles a bit, compiled and loaded four modules. As a result I get two dummy buses and two zero gadgets, one on each bus.. perfect! Now to see if is usable.. -hinko On Thu, Nov 9, 2017 at 12:15 PM, Felipe Balbi <felipe.balbi@xxxxxxxxxxxxxxx> wrote: > > Hi, > > Hinko Kocevar <hinkocevar@xxxxxxxxx> writes: >>> The way dummy was written, it can only instantiate one gadget. You >>> either need a real USB peripheral controller, or you need to patch dummy >>> to instantiate more than one gadget. >>> >>> -- >>> balbi >> >> By dummy - are you referring to g_zero of dummy_hcd? > > Okay, we need a little more explanation. In order to have a gadget > driver like g_zero loaded, you need a USB peripheral controller (in your > case, that's handled by dummy). > > Now, when you want that g_zero to be useful, you need to plug it to a > USB host controller (in your case, that's also handled by dummy). > > What I'm saying, though, is that this dummy (dummy_hcd.c) can only > handle ONE gadget (a fake USB peripheral controller) at a time. It does > NOT instantiate more than one of those. Because of that, there's no way > to get g_zero to probe for a second time. > > In fact, even if you were to patch dummy_hcd.c to instantiate N gadgets, > you wouldn't be able to use g_zero.ko, and would be required to rely on > our configfs interface for dynamically generating and binding different > gadget drivers to each of your gadget instances, but that's another > story altogether. > > -- > balbi -- .. the more I see the less I believe.., AE AoR -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html