All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ruchika Kharwar <ruchika@ti.com>
To: Dan Murphy <dmurphy@ti.com>
Cc: linux-usb@vger.kernel.org, linux-doc@vger.kernel.org,
	linux-omap@vger.kernel.org, Felipe Balbi <balbi@ti.com>,
	Kishon Vijay Abraham I <kishon@ti.com>,
	Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	Rob Landley <rob@landley.net>
Subject: Re: [PATCH] usb: dwc3: Addition of "dr_mode" dt property.
Date: Thu, 30 May 2013 17:47:17 -0500	[thread overview]
Message-ID: <51A7D6F5.9070501@ti.com> (raw)
In-Reply-To: <51A7B7FC.7090807@ti.com>


On 05/30/2013 03:35 PM, Dan Murphy wrote:
> Fix spelling in my own comments
>
> On 05/30/2013 03:31 PM, Dan Murphy wrote:
>> On 05/30/2013 03:14 PM, Ruchika Kharwar wrote:
>>> This patch adds an optional parameter "dr_mode" to the dwc3 core device node.
>>> In the case the compile flag for the DWC3 controller is set to
>>> "USB_DWC3_DUAL_ROLE" a device tree could restrain to either functionality of
>>> host or gadget. In the case the device tree does not use this optional flag or
>>> specifies it superfluously to "drd" the functionality will be that
>>> of a dual role device.
>>>
>>> Signed-off-by: Ruchika Kharwar <ruchika@ti.com>
>>> ---
>> Can you add patch history if this is truly a new patch to a previous submission
         Will do in the next pach submitted.
>>>   Documentation/devicetree/bindings/usb/dwc3.txt |    3 ++-
>>>   drivers/usb/dwc3/core.c                        |   21 +++++++++++++++++----
>>>   2 files changed, 19 insertions(+), 5 deletions(-)
>>>
>>> diff --git a/Documentation/devicetree/bindings/usb/dwc3.txt b/Documentation/devicetree/bindings/usb/dwc3.txt
>>> index 7a95c65..2f5d584 100644
>>> --- a/Documentation/devicetree/bindings/usb/dwc3.txt
>>> +++ b/Documentation/devicetree/bindings/usb/dwc3.txt
>>> @@ -10,7 +10,8 @@ Required properties:
>>>   
>>>   Optional properties:
>>>    - tx-fifo-resize: determines if the FIFO *has* to be reallocated.
>>> -
>>> + - dr_mode: determines the mode of core. Supported modes are "gadget", "host"
>>> +   and "drd".
>> My previous comments still stand for this section.  Nothing was addressed or commented back
>>
>> https://patchwork.kernel.org/patch/2638511/
>>>   This is usually a subnode to DWC3 glue to which it is connected.
>>>   
>>>   dwc3@4a030000 {
>>> diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c
>>> index c35d49d..e11660a 100644
>>> --- a/drivers/usb/dwc3/core.c
>>> +++ b/drivers/usb/dwc3/core.c
>>> @@ -378,7 +378,7 @@ static int dwc3_probe(struct platform_device *pdev)
>>>   	void			*mem;
>>>   
>>>   	u8			mode;
>>> -
>>> +	char			*dr_mode;
>>>   	mem = devm_kzalloc(dev, sizeof(*dwc) + DWC3_ALIGN_MASK, GFP_KERNEL);
>>>   	if (!mem) {
>>>   		dev_err(dev, "not enough memory\n");
>>> @@ -520,9 +520,22 @@ static int dwc3_probe(struct platform_device *pdev)
>>>   		mode = DWC3_MODE_HOST;
>>>   	else if (IS_ENABLED(CONFIG_USB_DWC3_GADGET))
>>>   		mode = DWC3_MODE_DEVICE;
>>> -	else
>>> -		mode = DWC3_MODE_DRD;
>>> -
>>> +	else {
>>> +		if (of_property_read_string(node, "dr_mode", &dr_mode))
>>> +			mode = DWC3_MODE_DRD;
>>> +		else {
>>> +			if (strcmp(dr_mode, "host") == 0)
>>> +				mode = DWC3_MODE_HOST;
>>> +			else if (strcmp(dr_mode, "gadget") == 0)
>>> +				mode = DWC3_MODE_DEVICE;
>>> +			else if (strcmp(dr_mode, "drd") == 0)
>>> +				mode = DWC3_MODE_DRD;
>> My previous comments still stand for this section.  Nothing was addressed or commented back
>>
>> https://patchwork.kernel.org/patch/2638511/
         DRD mode is the super set mode for Host and Gadget. The compile 
time flag is primary. If DRD is set, the host and gadget code is 
compiled in.
         The dr_mode property can be used *if* specified in the device 
tree. A specific example may be a board could have constraints where the 
port could only be a host
         or gadget. In that case, the dr_mode property is specified 
overrides the compile flag.
>>> +			else {
>>> +				dev_err(dev, "invalid dr_mode property value\n");
>>> +				goto err2;
>> This is still wrong.  You have not initialized and of the device's
> s/and/any
        This is correct as per 3.10-rc3. If you're looking at an older 
tree you'd be right.
>>> +			}
>>> +		}
>>> +	}
>>>   	switch (mode) {
>>>   	case DWC3_MODE_DEVICE:
>>>   		dwc3_set_mode(dwc, DWC3_GCTL_PRTCAP_DEVICE);
>> Is this a new patch?
>> Subject should say v2.
Yes, my bad.. learning.. next patch will have it.
>>
>


  reply	other threads:[~2013-05-30 22:47 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-05-30 20:14 [PATCH] usb: dwc3: Addition of "dr_mode" dt property Ruchika Kharwar
2013-05-30 20:19 ` Sergei Shtylyov
     [not found] ` <51A7B725.1090103@ti.com>
2013-05-30 20:35   ` Dan Murphy
2013-05-30 22:47     ` Ruchika Kharwar [this message]
2013-05-31  8:10 ` Michael Grzeschik
  -- strict thread matches above, loose matches on Subject: below --
2013-05-30 20:31 Ruchika Kharwar
2013-06-03 12:09 ` Michael Grzeschik
2013-05-30 17:56 Ruchika Kharwar
2013-05-30 19:53 ` Dan Murphy
2013-05-31  4:33   ` Felipe Balbi

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=51A7D6F5.9070501@ti.com \
    --to=ruchika@ti.com \
    --cc=balbi@ti.com \
    --cc=dmurphy@ti.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=kishon@ti.com \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux-omap@vger.kernel.org \
    --cc=linux-usb@vger.kernel.org \
    --cc=rob@landley.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.