Hello.

On 20-03-2014 10:42, Arnd Bergmann wrote:

Both the OHCI and MUSB drivers use exactly one register (CFGCHIP2)

     The idea at the time was to just ioremap() this register but I was not
very eager.

... also it was suggested to pass the CFGCHIP2 address as a resource. I certainly wasn't eager to do that since if done for both MUSB and OHCI, it would cause sort of a resource conflict (platform device resources are automatically registered in the resource tree, although without marking them exclusive), even if we don't call request_mem_region() on them (we can't do that since in this case the resource would be registered as exclusive, and the second call would fail).

Yes, that would work, too. However, that would cause problems later
if we ever try to make the davinci platform "multiplatform", unless we also
pass the physical address in a platform resource and make this a larger
driver.

In my opinion, we don't have to pass CFGCHIP2 as a resource and could just ioremap() the raw physical address.

I think we can reasonably have an exported set of functions
declared in the platform data header file for these drivers, but passing
the physical address through a header file

   That's how it's passed today (however, thru <mach/da8xx.h>).

wouldn't be much of an improvement
over passing the virtual address.

   Not sure I understood about passing virtual address.

There was no USB PHY driver subsystem yet.

to control the clock, phy

     Note that it only controls PHY clock (PLL) which could be covered by an
USB PHY driver.

Good point.

and host/gadget mode switch.

     The main mode the USB 2.0 PHY should function now is OTG. The host/gadged
modes are forced overrides of the ID pin. Unfortunately, the board code has to
force host mode when host-only driver config is selected (these MUSB's
host/gadget only modes were removed at one point but got reintroduced again).

I think they are also required for 'randconfig' builds to some degree, because
you can build a kernel without host mode for instance.

   Yes.

In the modern world, we'd probably want to have a clock driver and

     Not sure about the clock driver...

a phy driver for these,

     Yes, that's what the MUSB maintainer wants too. The issue is the driver
should somehow differ which USB controller it's bound too and do different
things depending on that (at least that's how it looks now). I'm not sure it's
possible, so probably should be rethought.

Yes, a phy driver seems the right approach if we can find someone to do it.

Perhaps a person that tried to unbreak the DA8xx MUSB driver could be interested (and competent) enough to do it...

Ideally that should let us use generic versions of the ohci and musb drivers
even, if that's the only davinci specific part of these drivers.

No, not really. MUSB ceratinly has DaVinci specific register set mapped in its register space. OHCI has up to 2 clocks to enable since USB 1.1 PHY can be clocked from USB 2.0 PHY clock.

based on a syscon driver.

     I don't know what syscon is...

The syscon (system controller) framework helps share a set of registers
across multiple drivers. If all accesses to the CFGCHIP2 register are
in a single PHY driver, we wouldn't need it.

   Where can I find it in the kernel tree?

In all honesty I don't see that happening on davinci.

     I don't think people use USB 1.1 controllers these days, especially when
there is USB 2.0 in the same SoC. For MUSB, there were recent attempt to get
the DA8xx driver out of the broken state but it was turned down as well, IIRC,
since it didn't offer a PHY driver.

For USB 2.0 compliance you actually need to provide something to handle the
low speed modes. A lot of people use a hub to do that nowadays rather than
an OHCI or UHCI, but I don't know if that works with OTG.

MUSB handles all speeds. I think the reason TI also included USB 1.1 controller lies in the somewhat dubious reputation of both MUSB hardware and the Linux driver.

        Arnd

WBR, Sergei

_______________________________________________
Davinci-linux-open-source mailing list
Davinci-linux-open-source@linux.davincidsp.com
http://linux.davincidsp.com/mailman/listinfo/davinci-linux-open-source

Reply via email to