Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754021AbbKXMiW (ORCPT ); Tue, 24 Nov 2015 07:38:22 -0500 Received: from mailout3.w1.samsung.com ([210.118.77.13]:63143 "EHLO mailout3.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753866AbbKXMiT (ORCPT ); Tue, 24 Nov 2015 07:38:19 -0500 X-AuditID: cbfec7f5-f79b16d000005389-1d-56545a38a78d Subject: Re: [PATCH v7 4/4] usb: gadget: udc-core: independent registration of gadgets and gadget drivers To: Alan Stern References: Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Ruslan Bilovol , Bartlomiej Zolnierkiewicz From: Marek Szyprowski Message-id: <56545A37.1040203@samsung.com> Date: Tue, 24 Nov 2015 13:38:15 +0100 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:38.0) Gecko/20100101 Thunderbird/38.3.0 MIME-version: 1.0 In-reply-to: Content-type: text/plain; charset=utf-8; format=flowed Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrDLMWRmVeSWpSXmKPExsVy+t/xK7oWUSFhBnNPaVtsnLGe1eLyrjls FouWtTJb9Ow8wWgx4fcFNgdWj52z7rJ7zL77g9Gjb8sqRo/Pm+QCWKK4bFJSczLLUov07RK4 Mr63yxSsE63Y8qCJsYFxjWAXIyeHhICJxIFpa1khbDGJC/fWs3UxcnEICSxllPj96wIzhPOc UaL91A7GLkYODmGBbInuRwYgDSICWhKbm14yg9hCAj4Sz599YgWpZxZYwCgx+9hLFpAEm4Ch RNfbLjYQmxeoYduEvWANLAKqEi9mfwWLiwrESLzftIoRokZQ4sfke2C9nAK+EkdfdDGB2MwC ZhJfXh5mhbDlJTavecs8gVFgFpKWWUjKZiEpW8DIvIpRNLU0uaA4KT3XSK84Mbe4NC9dLzk/ dxMjJIy/7mBceszqEKMAB6MSD++HkuAwIdbEsuLK3EOMEhzMSiK81vohYUK8KYmVValF+fFF pTmpxYcYpTlYlMR5Z+56HyIkkJ5YkpqdmlqQWgSTZeLglGpgVPVjmm9luGR5amzyrKzl3rdl XQQfr2R7sdP4aEHjnnJhVqmCmXf/dfTeTylNt+gX/vzpfNbGTaI/uKcanT1ts8nw+Wq3z/9m Xtqb4ufmFz7Pb+eGKTpqh6bXv2dwizA5JXdTba4lS0TYi/ns+58tOWG6SHeFPHf9o9+tezPf /5hwzd/cNm2mpxJLcUaioRZzUXEiAGPJ/yFfAgAA Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2906 Lines: 78 Hello, On 2015-11-23 16:32, Alan Stern wrote: > On Mon, 23 Nov 2015, Marek Szyprowski wrote: > >> From: Ruslan Bilovol >> >> Change behavior during registration of gadgets and >> gadget drivers in udc-core. Instead of previous >> approach when for successful probe of usb gadget driver >> at least one usb gadget should be already registered >> use another one where gadget drivers and gadgets >> can be registered in udc-core independently. >> >> Independent registration of gadgets and gadget drivers >> is useful for built-in into kernel gadget and gadget >> driver case - because it's possible that gadget is >> really probed only on late_init stage (due to deferred >> probe) whereas gadget driver's probe is silently failed >> on module_init stage due to no any UDC added. >> >> Also it is useful for modules case - now there is no >> difference what module to insert first: gadget module >> or gadget driver one. >> >> Tested-by: Maxime Ripard >> Signed-off-by: Ruslan Bilovol >> [simplified code as requested by Alan Stern and Felipe Balbi, >> fixed checkpatch issues] >> Signed-off-by: Marek Szyprowski >> Tested-by: Peter Chen > I missed this the last time through... > >> @@ -403,6 +408,18 @@ int usb_add_gadget_udc_release(struct device *parent, struct usb_gadget *gadget, >> usb_gadget_set_state(gadget, USB_STATE_NOTATTACHED); >> udc->vbus = true; >> >> + /* pick up one of pending gadget drivers */ >> + list_for_each_entry(driver, &gadget_driver_pending_list, pending) { >> + if (!driver->udc_name || strcmp(driver->udc_name, >> + dev_name(&udc->dev)) == 0) { >> + ret = udc_bind_to_driver(udc, driver); >> + if (ret) >> + goto err4; >> + list_del(&driver->pending); > This has to be list_del_init(). And somewhere in > usb_gadget_probe_driver() you need to do > INIT_LIST_HEAD(&driver->pending). > >> @@ -577,6 +596,10 @@ int usb_gadget_unregister_driver(struct usb_gadget_driver *driver) >> break; >> } >> >> + if (ret) { >> + list_del(&driver->pending); > Otherwise this will cause a crash or corrupt some random area of > memory. 'pending' handle is added to gadget_driver_pending_list in usb_gadget_probe_driver(), then when udc is available it is removed from this list and bound to the given driver. In usb_gadget_unregister_driver() the gadget is either unbound from the udc or if is was not bound to any udc, removed from pending list. I see no need for adding INIT_LIST_HEAD. Best regards -- Marek Szyprowski, PhD Samsung R&D Institute Poland -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/