Hello Sergei,
On 08.02.2016 12:20, Sergei Shtylyov wrote:
And the patch is against 3.17? You should only submit patches
against the recent kernel. In this case, against the -next branch of
Felipe's repo on kernel.org.
Could you give me the full branch name please.
I was wondering about a PHY driver too. However the AM1808 has no
standalone
PHY module like e.g. the AM335x does. The PHY together with the USB
core are
integrated into a single block and there is only a little control
through the
SYSCFG registers.
The CFGCHIP2 register controls the PHY in practice. The code
manipulating it should be moved to a PHY driver.
I'm not sure if I can do that at the moment. Would you accept the patch
using the current situation, i.e. the CFGCHIP2 being manipulated in the
da8xx.c?
No way. You'l probably need to select a lowest common denominator
model.
I don't remember offhand but I don't think DA850 (AM1808) is
different from
DA830 (AM170x)...
So I'd suggest "ti,da830-musb".
Thanks. I've just checked the da830 doc and I don't see any difference
in the USB register sets. So I will update the name as you suggest.
All the other MUSBs specify these parameters in the DT. Do you want
to make an
exception?
I'd prefer doing it that way, sure.
OK. So I will move the num_eps and ram_bits into the "compatible"
structure.
And leave the mode, power and multipoint still configurable via DT as
they depend on the hardware wiring.
I believe someone still might want to set multipoint to 0 if he has a
single device (not a hub) hard-connected directly to the controller.
Even if I don't see a benefit of doing so.
Why does this parameter exist at all?
[...]
[...]
@@ -527,6 +561,35 @@ static const struct platform_device_info
da8xx_dev_info = {
.dma_mask = DMA_BIT_MASK(32),
};
+static int get_musb_port_mode(struct device_node *np)
+{
+ enum usb_dr_mode mode;
+
+ mode = of_usb_get_dr_mode(np);
+ switch (mode) {
+ case USB_DR_MODE_HOST:
+ return MUSB_HOST;
+
+ case USB_DR_MODE_PERIPHERAL:
+ return MUSB_PERIPHERAL;
+
+ case USB_DR_MODE_OTG:
+ return MUSB_OTG;
+
+ default:
+ return MUSB_UNDEFINED;
+ }
+}
This is clearly MUSB generic code.
So what does it mean?
Define this function in musb_core.c.
I will do. Why doesn't the musb core use directly the USB_DR_MODE_xxx
literals instead?
I don't see any benefit of defining them again and translating.
[...]
+ /* optional parameter reference clock frequency */
+ if (!of_property_read_u32(np, "ti,phy20-clkmux-cfg",
+ &phy20_clkmux_cfg)) {
+ u32 cfgchip2;
+
+ /*
+ * Select internal reference clock for USB 2.0 PHY
+ * and use it as a clock source for USB 1.1 PHY
+ * (this is the default setting anyway).
+ */
+
+ cfgchip2 = __raw_readl(
+ DA8XX_SYSCFG0_VIRT(DA8XX_CFGCHIP2_REG));
That's why a PHY driver is needed. DA8XX_SYSCFG2_VIRT() shouldn't
be used
outside arch/arm/mach-davinci/.
See above.
Why are you not using CFGCHIP2 macro in this file as the rest of
the code does?
I've just noticed that too. I will use the CFGCHIP2 macro.
Regards
Petr
--
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