Re: [PATCH 1/1] Drivers: USB: DA8xx MUSB: added DT support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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



[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux