Hi,

Alan Stern <st...@rowland.harvard.edu> writes:
> On Thu, 8 Jun 2017, Felipe Balbi wrote:
>
>> Hi Alan,
>> 
>> Alan Stern <st...@rowland.harvard.edu> writes:
>> > On Wed, 7 Jun 2017, Felipe Balbi wrote:
>> >
>> >> Move the code which was part of pullup() to the newly introduced
>> >> method.
>> >
>> > Comments inline...
>> 
>> thanks for your comments. I think I've fixed them all.
>> 
>> 8<------------------------------------------------------------------------
>> 
>> From 20e574323d3b6d4e5444815e19fb2096b9656727 Mon Sep 17 00:00:00 2001
>> From: Felipe Balbi <felipe.ba...@linux.intel.com>
>> Date: Wed, 7 Jun 2017 13:52:54 +0300
>> Subject: [PATCH v2] usb: gadget: dummy: implement ->udc_set_speed()
>> 
>> Move the code which was part of pullup() to the newly introduced
>> method.
>> 
>> Signed-off-by: Felipe Balbi <felipe.ba...@linux.intel.com>
>> ---
>> 
>> Changes since v1:
>>      - Move set_udc_speed() after pullup()
>>         - remove switch statement in favor a more compact construct
>>         - Fix dev_dbg() call to rely on 'speed' parameter instead.
>> 
>>  drivers/usb/gadget/udc/dummy_hcd.c | 39 
>> ++++++++++++++++++++++----------------
>>  1 file changed, 23 insertions(+), 16 deletions(-)
>> 
>> diff --git a/drivers/usb/gadget/udc/dummy_hcd.c 
>> b/drivers/usb/gadget/udc/dummy_hcd.c
>> index c79081952ea0..156380e4e0af 100644
>> --- a/drivers/usb/gadget/udc/dummy_hcd.c
>> +++ b/drivers/usb/gadget/udc/dummy_hcd.c
>> @@ -888,22 +888,6 @@ static int dummy_pullup(struct usb_gadget *_gadget, int 
>> value)
>>      unsigned long   flags;
>>  
>>      dum = gadget_dev_to_dummy(&_gadget->dev);
>> -
>> -    if (value && dum->driver) {
>> -            if (mod_data.is_super_speed)
>> -                    dum->gadget.speed = dum->driver->max_speed;
>> -            else if (mod_data.is_high_speed)
>> -                    dum->gadget.speed = min_t(u8, USB_SPEED_HIGH,
>> -                                    dum->driver->max_speed);
>> -            else
>> -                    dum->gadget.speed = USB_SPEED_FULL;
>> -            dummy_udc_update_ep0(dum);
>> -
>> -            if (dum->gadget.speed < dum->driver->max_speed)
>> -                    dev_dbg(udc_dev(dum), "This device can perform faster"
>> -                            " if you connect it to a %s port...\n",
>> -                            usb_speed_string(dum->driver->max_speed));
>> -    }
>>      dum_hcd = gadget_to_dummy_hcd(_gadget);
>>  
>>      spin_lock_irqsave(&dum->lock, flags);
>> @@ -915,6 +899,28 @@ static int dummy_pullup(struct usb_gadget *_gadget, int 
>> value)
>>      return 0;
>>  }
>>  
>> +static void dummy_udc_set_speed(struct usb_gadget *_gadget,
>> +            enum usb_device_speed speed)
>> +{
>> +    struct dummy    *dum;
>> +
>> +    dum = gadget_dev_to_dummy(&_gadget->dev);
>> +
>> +     if (mod_data.is_super_speed)
>> +             dum->gadget.speed = min_t(u8, USB_SPEED_SUPER, speed);
>> +     else if (mod_data.is_high_speed)
>> +             dum->gadget.speed = min_t(u8, USB_SPEED_HIGH, speed);
>> +     else
>> +             dum->gadget.speed = USB_SPEED_FULL;
>> +
>
> What's with the funky extra space characters after the tabs?

Odd, I didn't add them. I'll take them away.

>> +    dummy_udc_update_ep0(dum);
>> +
>> +    if (dum->gadget.speed < speed)
>> +            dev_dbg(udc_dev(dum), "This device can perform faster"
>> +                    " if you connect it to a %s port...\n",
>> +                    usb_speed_string(speed));
>> +}
>> +
>>  static int dummy_udc_start(struct usb_gadget *g,
>>              struct usb_gadget_driver *driver);
>>  static int dummy_udc_stop(struct usb_gadget *g);
>> @@ -926,6 +932,7 @@ static const struct usb_gadget_ops dummy_ops = {
>>      .pullup         = dummy_pullup,
>>      .udc_start      = dummy_udc_start,
>>      .udc_stop       = dummy_udc_stop,
>> +    .udc_set_speed  = dummy_udc_set_speed,
>>  };
>>  
>>  
>> /*-------------------------------------------------------------------------*/
>
> That looks fine.  You can add:
>
> Acked-by: Alan Stern <st...@rowland.harvard.edu>

Thanks :-)

> Any results on testing the new memory barrier and exception handling 
> patches for f_mass_storage?

Oh, I couldn't reproduce anymore. I thought I had told ya. Hopefully,
this will be the last we hear from this problem :-s 

-- 
balbi
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to