Hi Vladimir,Yes.
On Mon, Feb 24, 2014 at 4:34 PM, Vladimir Barinov
<vladimir.barinov@xxxxxxxxxxxxxxxxxx> wrote:
Hello Magnus,Yeah, I understand. But with the current patches I wonder, isn't there
Thank you for the quick response.
On 02/24/2014 07:52 AM, Magnus Damm wrote:
+static int usbhs_hardware_init(struct platform_device *pdev)Yes, I've seen your work for lager board.
+{
+ struct usbhs_private *priv = usbhs_get_priv(pdev);
+ struct usb_phy *phy;
+
+ phy = usb_get_phy_dev(&pdev->dev, 0);
+ if (IS_ERR(phy))
+ return PTR_ERR(phy);
+
+ priv->phy = phy;
+ return 0;
+}
+
+static int usbhs_hardware_exit(struct platform_device *pdev)
+{
+ struct usbhs_private *priv = usbhs_get_priv(pdev);
+
+ if (!priv->phy)
+ return 0;
+
+ usb_put_phy(priv->phy);
+ priv->phy = NULL;
+ return 0;
+}
+
+static int usbhs_get_id(struct platform_device *pdev)
+{
+ return USBHS_GADGET;
+}
Uhm, I sort of expected this place to be where you read out the ID pin
state from the MAX device.
I did differently then you beacause of problem in USBHS Host driver, hence
the need of setup PHY at initial stage to PCI USB and not to USBHS.
risk for short circuit ? Say that a USB host cable is connected during
boot and the PCI USB host controller is hooked up, what is stopping us
from switching the cable and driving VBUS from two sides using a USB
function cable? So the current patches seem a bit unsafe to me.
No need, there is a set_vbus callback in HSBHS platform code for this purpose.
To control USB0_VBUS as GPIO you may need to adjust the PFC tables forI see.+static u32 koelsch_usbhs_pipe_type[] = {I don't think we should perform this kind of check at boot-up. This
+
+/* Add all available USB devices */
+static void __init koelsch_add_usb_devices(void)
+{
+ /* MAX3355E ID pin */
+ gpio_request_one(RCAR_GP_PIN(5, 31), GPIOF_IN, NULL);
+ if (!gpio_get_value(RCAR_GP_PIN(5, 31))) {
+ usbhs_phy_pdata.chan0_pci = 1; /* Channel 0 is PCI USB
host */
+ koelsch_add_usb0_host();
+ } else {
+ usbhs_phy_pdata.chan0_pci = 0; /* Channel 0 is USBHS */
+ koelsch_add_usb0_gadget();
+ }
goes without saying, but normal USB supports hot-plug so we should
check the cable type when the cable insertion event happens. Please
see my comment above for USBHS-specific location.
I do however understand that according to your investigation you
cannot use USBHS in host mode. I believe further investigation is
needed in that area to determine what is the best way forward.
Regarding VBUS control, I believe it should be possible to drive the
USB0_VBUS as GPIO and manually control the power.
pinctrl. At some point, would it be possible for you to cook up some
prototype code to try to control the USB0_VBUS signal via GPIO? This
may be pointless if the USBHS hardware cannot operate in Host mode
though.
Sure, will do.
Thanks for your offer. Yes, that would be nice. May I suggest doing itWould it be possible for you to break out USB PCI support for USB1 andWouldn't you like me also add USBHS in gadget mode for USB0 with the similar
resend that so we can begin by merging that?
check like you did on lager (with ID pin),
since it does not need the gpio-rcar changes too.
on two levels:
1) Gadget-only support (is it possible to perform runtime check of ID
pin value at insert event and give error in case of Host?)
2) Incremental USBHS host patch
Using two incremental patches like above we can begin by merging 1)
and keep on working on 2).
Also if you'd like I can add the USBHS in Host mode with the ID pin checkPlease add it as a separate incremental patch if possible. I'd like to
like you suggested, but the usb0 host will not be stable.
Probably this could speed up the USBHS Host development/fixing.
have some kind of stable level of support without any funky
dependencies as a first goal, then keep on trying to get USBHS
working.
I think PCI USB for the micro USB port can simply be dropped now and
only use USBHS.