2017-11-03 09:18:41 +01:00
// SPDX-License-Identifier: GPL-2.0
2005-04-16 15:20:36 -07:00
/*
2006-10-03 23:01:26 +02:00
* drivers / usb / core / usb . c
2005-04-16 15:20:36 -07:00
*
* ( C ) Copyright Linus Torvalds 1999
* ( C ) Copyright Johannes Erdfelt 1999 - 2001
* ( C ) Copyright Andreas Gal 1999
* ( C ) Copyright Gregory P . Smith 1999
* ( C ) Copyright Deti Fliegl 1999 ( new USB architecture )
* ( C ) Copyright Randy Dunlap 2000
* ( C ) Copyright David Brownell 2000 - 2004
* ( C ) Copyright Yggdrasil Computing , Inc . 2000
* ( usb_device_id matching changes by Adam J . Richter )
* ( C ) Copyright Greg Kroah - Hartman 2002 - 2003
*
2016-10-28 17:16:36 -04:00
* Released under the GPLv2 only .
*
2005-04-16 15:20:36 -07:00
* NOTE ! This is not actually a driver at all , rather this is
* just a collection of helper routines that implement the
* generic USB things that the real drivers can use . .
*
2020-06-30 19:41:23 +02:00
* Think of this as a " USB library " rather than anything else ,
* with no callbacks . Callbacks are evil .
2005-04-16 15:20:36 -07:00
*/
# include <linux/module.h>
2007-02-20 15:00:53 -05:00
# include <linux/moduleparam.h>
2005-04-16 15:20:36 -07:00
# include <linux/string.h>
# include <linux/bitops.h>
# include <linux/slab.h>
# include <linux/kmod.h>
# include <linux/init.h>
# include <linux/spinlock.h>
# include <linux/errno.h>
# include <linux/usb.h>
2010-04-24 23:21:52 +02:00
# include <linux/usb/hcd.h>
2006-01-11 15:55:29 +01:00
# include <linux/mutex.h>
2006-09-19 10:14:07 -04:00
# include <linux/workqueue.h>
2009-04-24 14:56:26 -07:00
# include <linux/debugfs.h>
2016-02-19 17:26:15 +08:00
# include <linux/usb/of.h>
2005-04-16 15:20:36 -07:00
# include <asm/io.h>
2007-10-30 10:35:04 +01:00
# include <linux/scatterlist.h>
2005-04-16 15:20:36 -07:00
# include <linux/mm.h>
# include <linux/dma-mapping.h>
2019-02-16 23:21:51 -08:00
# include "hub.h"
2005-04-16 15:20:36 -07:00
const char * usbcore_name = " usbcore " ;
2012-01-13 09:32:20 +10:30
static bool nousb ; /* Disable USB when built into kernel image */
2005-04-16 15:20:36 -07:00
2015-03-20 09:04:41 +05:30
module_param ( nousb , bool , 0444 ) ;
/*
* for external read access to < nousb >
*/
int usb_disabled ( void )
{
return nousb ;
}
EXPORT_SYMBOL_GPL ( usb_disabled ) ;
2014-11-29 23:47:05 +01:00
# ifdef CONFIG_PM
2019-03-01 16:43:20 +00:00
/* Default delay value, in seconds */
static int usb_autosuspend_delay = CONFIG_USB_AUTOSUSPEND_DELAY ;
2007-03-13 16:39:15 -04:00
module_param_named ( autosuspend , usb_autosuspend_delay , int , 0644 ) ;
2007-02-20 15:00:53 -05:00
MODULE_PARM_DESC ( autosuspend , " default autosuspend delay " ) ;
# else
# define usb_autosuspend_delay 0
# endif
2017-03-17 11:35:31 +01:00
static bool match_endpoint ( struct usb_endpoint_descriptor * epd ,
struct usb_endpoint_descriptor * * bulk_in ,
struct usb_endpoint_descriptor * * bulk_out ,
struct usb_endpoint_descriptor * * int_in ,
struct usb_endpoint_descriptor * * int_out )
{
switch ( usb_endpoint_type ( epd ) ) {
case USB_ENDPOINT_XFER_BULK :
if ( usb_endpoint_dir_in ( epd ) ) {
if ( bulk_in & & ! * bulk_in ) {
* bulk_in = epd ;
break ;
}
} else {
if ( bulk_out & & ! * bulk_out ) {
* bulk_out = epd ;
break ;
}
}
return false ;
case USB_ENDPOINT_XFER_INT :
if ( usb_endpoint_dir_in ( epd ) ) {
if ( int_in & & ! * int_in ) {
* int_in = epd ;
break ;
}
} else {
if ( int_out & & ! * int_out ) {
* int_out = epd ;
break ;
}
}
return false ;
default :
return false ;
}
return ( ! bulk_in | | * bulk_in ) & & ( ! bulk_out | | * bulk_out ) & &
( ! int_in | | * int_in ) & & ( ! int_out | | * int_out ) ;
}
2005-04-16 15:20:36 -07:00
2017-03-17 11:35:30 +01:00
/**
* usb_find_common_endpoints ( ) - - look up common endpoint descriptors
* @ alt : alternate setting to search
* @ bulk_in : pointer to descriptor pointer , or NULL
* @ bulk_out : pointer to descriptor pointer , or NULL
* @ int_in : pointer to descriptor pointer , or NULL
* @ int_out : pointer to descriptor pointer , or NULL
*
* Search the alternate setting ' s endpoint descriptors for the first bulk - in ,
* bulk - out , interrupt - in and interrupt - out endpoints and return them in the
* provided pointers ( unless they are NULL ) .
*
* If a requested endpoint is not found , the corresponding pointer is set to
* NULL .
*
* Return : Zero if all requested descriptors were found , or - ENXIO otherwise .
*/
int usb_find_common_endpoints ( struct usb_host_interface * alt ,
struct usb_endpoint_descriptor * * bulk_in ,
struct usb_endpoint_descriptor * * bulk_out ,
struct usb_endpoint_descriptor * * int_in ,
struct usb_endpoint_descriptor * * int_out )
{
struct usb_endpoint_descriptor * epd ;
int i ;
if ( bulk_in )
* bulk_in = NULL ;
if ( bulk_out )
* bulk_out = NULL ;
if ( int_in )
* int_in = NULL ;
if ( int_out )
* int_out = NULL ;
for ( i = 0 ; i < alt - > desc . bNumEndpoints ; + + i ) {
epd = & alt - > endpoint [ i ] . desc ;
2017-03-17 11:35:31 +01:00
if ( match_endpoint ( epd , bulk_in , bulk_out , int_in , int_out ) )
return 0 ;
}
2017-03-17 11:35:30 +01:00
2017-03-17 11:35:31 +01:00
return - ENXIO ;
}
EXPORT_SYMBOL_GPL ( usb_find_common_endpoints ) ;
2017-03-17 11:35:30 +01:00
2017-03-17 11:35:31 +01:00
/**
* usb_find_common_endpoints_reverse ( ) - - look up common endpoint descriptors
2017-03-24 16:25:34 +01:00
* @ alt : alternate setting to search
* @ bulk_in : pointer to descriptor pointer , or NULL
* @ bulk_out : pointer to descriptor pointer , or NULL
* @ int_in : pointer to descriptor pointer , or NULL
* @ int_out : pointer to descriptor pointer , or NULL
*
* Search the alternate setting ' s endpoint descriptors for the last bulk - in ,
* bulk - out , interrupt - in and interrupt - out endpoints and return them in the
* provided pointers ( unless they are NULL ) .
*
* If a requested endpoint is not found , the corresponding pointer is set to
* NULL .
2017-03-17 11:35:31 +01:00
*
2017-03-24 16:25:34 +01:00
* Return : Zero if all requested descriptors were found , or - ENXIO otherwise .
2017-03-17 11:35:31 +01:00
*/
int usb_find_common_endpoints_reverse ( struct usb_host_interface * alt ,
struct usb_endpoint_descriptor * * bulk_in ,
struct usb_endpoint_descriptor * * bulk_out ,
struct usb_endpoint_descriptor * * int_in ,
struct usb_endpoint_descriptor * * int_out )
{
struct usb_endpoint_descriptor * epd ;
int i ;
2017-03-17 11:35:30 +01:00
2017-03-17 11:35:31 +01:00
if ( bulk_in )
* bulk_in = NULL ;
if ( bulk_out )
* bulk_out = NULL ;
if ( int_in )
* int_in = NULL ;
if ( int_out )
* int_out = NULL ;
for ( i = alt - > desc . bNumEndpoints - 1 ; i > = 0 ; - - i ) {
epd = & alt - > endpoint [ i ] . desc ;
if ( match_endpoint ( epd , bulk_in , bulk_out , int_in , int_out ) )
2017-03-17 11:35:30 +01:00
return 0 ;
}
return - ENXIO ;
}
2017-03-17 11:35:31 +01:00
EXPORT_SYMBOL_GPL ( usb_find_common_endpoints_reverse ) ;
2017-03-17 11:35:30 +01:00
2009-12-03 09:44:34 -08:00
/**
* usb_find_alt_setting ( ) - Given a configuration , find the alternate setting
* for the given interface .
2009-12-13 10:17:16 -08:00
* @ config : the configuration to search ( not necessarily the current config ) .
* @ iface_num : interface number to search in
* @ alt_num : alternate interface setting number to search for .
2009-12-03 09:44:34 -08:00
*
* Search the configuration ' s interface cache for the given alt setting .
2013-08-02 20:10:04 +02:00
*
* Return : The alternate setting , if found . % NULL otherwise .
2009-12-03 09:44:34 -08:00
*/
struct usb_host_interface * usb_find_alt_setting (
struct usb_host_config * config ,
unsigned int iface_num ,
unsigned int alt_num )
{
struct usb_interface_cache * intf_cache = NULL ;
int i ;
2018-09-10 14:00:53 -04:00
if ( ! config )
return NULL ;
2009-12-03 09:44:34 -08:00
for ( i = 0 ; i < config - > desc . bNumInterfaces ; i + + ) {
if ( config - > intf_cache [ i ] - > altsetting [ 0 ] . desc . bInterfaceNumber
= = iface_num ) {
intf_cache = config - > intf_cache [ i ] ;
break ;
}
}
if ( ! intf_cache )
return NULL ;
for ( i = 0 ; i < intf_cache - > num_altsetting ; i + + )
if ( intf_cache - > altsetting [ i ] . desc . bAlternateSetting = = alt_num )
return & intf_cache - > altsetting [ i ] ;
printk ( KERN_DEBUG " Did not find alt setting %u for intf %u, "
" config %u \n " , alt_num , iface_num ,
config - > desc . bConfigurationValue ) ;
return NULL ;
}
EXPORT_SYMBOL_GPL ( usb_find_alt_setting ) ;
2005-04-16 15:20:36 -07:00
/**
* usb_ifnum_to_if - get the interface object with a given interface number
* @ dev : the device whose current configuration is considered
* @ ifnum : the desired interface
*
* This walks the device descriptor for the currently active configuration
2013-08-02 20:10:04 +02:00
* to find the interface object with the particular interface number .
2005-04-16 15:20:36 -07:00
*
* Note that configuration descriptors are not required to assign interface
* numbers sequentially , so that it would be incorrect to assume that
* the first interface in that descriptor corresponds to interface zero .
* This routine helps device drivers avoid such mistakes .
* However , you should make sure that you do the right thing with any
* alternate settings available for this interfaces .
*
* Don ' t call this function unless you are bound to one of the interfaces
* on this device or you have locked the device !
2013-08-02 20:10:04 +02:00
*
* Return : A pointer to the interface that has @ ifnum as interface number ,
* if found . % NULL otherwise .
2005-04-16 15:20:36 -07:00
*/
2006-08-26 23:48:11 -03:00
struct usb_interface * usb_ifnum_to_if ( const struct usb_device * dev ,
unsigned ifnum )
2005-04-16 15:20:36 -07:00
{
struct usb_host_config * config = dev - > actconfig ;
int i ;
if ( ! config )
return NULL ;
for ( i = 0 ; i < config - > desc . bNumInterfaces ; i + + )
if ( config - > interface [ i ] - > altsetting [ 0 ]
. desc . bInterfaceNumber = = ifnum )
return config - > interface [ i ] ;
return NULL ;
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_ifnum_to_if ) ;
2005-04-16 15:20:36 -07:00
/**
2008-02-29 22:03:07 -08:00
* usb_altnum_to_altsetting - get the altsetting structure with a given alternate setting number .
2005-04-16 15:20:36 -07:00
* @ intf : the interface containing the altsetting in question
* @ altnum : the desired alternate setting number
*
* This searches the altsetting array of the specified interface for
2013-08-02 20:10:04 +02:00
* an entry with the correct bAlternateSetting value .
2005-04-16 15:20:36 -07:00
*
* Note that altsettings need not be stored sequentially by number , so
* it would be incorrect to assume that the first altsetting entry in
* the array corresponds to altsetting zero . This routine helps device
* drivers avoid such mistakes .
*
* Don ' t call this function unless you are bound to the intf interface
* or you have locked the device !
2013-08-02 20:10:04 +02:00
*
* Return : A pointer to the entry of the altsetting array of @ intf that
* has @ altnum as the alternate setting number . % NULL if not found .
2005-04-16 15:20:36 -07:00
*/
2008-01-30 15:21:33 -08:00
struct usb_host_interface * usb_altnum_to_altsetting (
const struct usb_interface * intf ,
unsigned int altnum )
2005-04-16 15:20:36 -07:00
{
int i ;
for ( i = 0 ; i < intf - > num_altsetting ; i + + ) {
if ( intf - > altsetting [ i ] . desc . bAlternateSetting = = altnum )
return & intf - > altsetting [ i ] ;
}
return NULL ;
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_altnum_to_altsetting ) ;
2005-04-16 15:20:36 -07:00
2009-12-15 07:47:28 -08:00
struct find_interface_arg {
int minor ;
2009-12-14 21:45:35 -07:00
struct device_driver * drv ;
2009-12-15 07:47:28 -08:00
} ;
2019-06-14 18:53:59 +01:00
static int __find_interface ( struct device * dev , const void * data )
2005-03-21 11:09:40 -08:00
{
2019-06-14 18:53:59 +01:00
const struct find_interface_arg * arg = data ;
2005-12-21 17:24:54 -08:00
struct usb_interface * intf ;
2005-03-21 11:09:40 -08:00
2009-05-04 19:48:32 +02:00
if ( ! is_usb_interface ( dev ) )
2005-03-21 11:09:40 -08:00
return 0 ;
2009-12-14 21:45:35 -07:00
if ( dev - > driver ! = arg - > drv )
return 0 ;
2005-03-21 11:09:40 -08:00
intf = to_usb_interface ( dev ) ;
2009-12-14 21:45:35 -07:00
return intf - > minor = = arg - > minor ;
2005-03-21 11:09:40 -08:00
}
2005-04-16 15:20:36 -07:00
/**
* usb_find_interface - find usb_interface pointer for driver and device
* @ drv : the driver whose current configuration is considered
* @ minor : the minor number of the desired device
*
2009-11-18 11:02:13 -07:00
* This walks the bus device list and returns a pointer to the interface
2009-12-14 21:45:35 -07:00
* with the matching minor and driver . Note , this only works for devices
* that share the USB major number .
2013-08-02 20:10:04 +02:00
*
* Return : A pointer to the interface with the matching major and @ minor .
2005-04-16 15:20:36 -07:00
*/
struct usb_interface * usb_find_interface ( struct usb_driver * drv , int minor )
{
2009-12-15 07:47:28 -08:00
struct find_interface_arg argb ;
2009-11-18 11:02:13 -07:00
struct device * dev ;
2009-12-15 07:47:28 -08:00
argb . minor = minor ;
2009-12-14 21:45:35 -07:00
argb . drv = & drv - > drvwrap . driver ;
dev = bus_find_device ( & usb_bus_type , NULL , & argb , __find_interface ) ;
2009-11-18 11:02:13 -07:00
/* Drop reference count from bus_find_device */
put_device ( dev ) ;
return dev ? to_usb_interface ( dev ) : NULL ;
2005-04-16 15:20:36 -07:00
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_find_interface ) ;
2005-04-16 15:20:36 -07:00
2013-05-17 12:08:51 -07:00
struct each_dev_arg {
void * data ;
int ( * fn ) ( struct usb_device * , void * ) ;
} ;
static int __each_dev ( struct device * dev , void * data )
{
struct each_dev_arg * arg = ( struct each_dev_arg * ) data ;
/* There are struct usb_interface on the same bus, filter them out */
if ( ! is_usb_device ( dev ) )
return 0 ;
2015-12-23 21:26:50 +08:00
return arg - > fn ( to_usb_device ( dev ) , arg - > data ) ;
2013-05-17 12:08:51 -07:00
}
/**
* usb_for_each_dev - iterate over all USB devices in the system
* @ data : data pointer that will be handed to the callback function
* @ fn : callback function to be called for each USB device
*
* Iterate over all USB devices and call @ fn for each , passing it @ data . If it
* returns anything other than 0 , we break the iteration prematurely and return
* that value .
*/
int usb_for_each_dev ( void * data , int ( * fn ) ( struct usb_device * , void * ) )
{
struct each_dev_arg arg = { data , fn } ;
return bus_for_each_dev ( & usb_bus_type , NULL , & arg , __each_dev ) ;
}
EXPORT_SYMBOL_GPL ( usb_for_each_dev ) ;
2005-04-16 15:20:36 -07:00
/**
* usb_release_dev - free a usb device structure when all users of it are finished .
* @ dev : device that ' s been disconnected
*
* Will be called only by the device core when all users of this usb device are
* done .
*/
static void usb_release_dev ( struct device * dev )
{
struct usb_device * udev ;
2009-04-27 19:57:26 -07:00
struct usb_hcd * hcd ;
2005-04-16 15:20:36 -07:00
udev = to_usb_device ( dev ) ;
2009-04-27 19:57:26 -07:00
hcd = bus_to_hcd ( udev - > bus ) ;
2005-04-16 15:20:36 -07:00
usb_destroy_configuration ( udev ) ;
2011-09-23 14:19:47 -07:00
usb_release_bos_descriptor ( udev ) ;
2017-06-06 17:59:02 +02:00
of_node_put ( dev - > of_node ) ;
2009-04-27 19:57:26 -07:00
usb_put_hcd ( hcd ) ;
2005-04-16 15:20:36 -07:00
kfree ( udev - > product ) ;
kfree ( udev - > manufacturer ) ;
kfree ( udev - > serial ) ;
kfree ( udev ) ;
}
2007-11-06 15:01:52 -05:00
static int usb_dev_uevent ( struct device * dev , struct kobj_uevent_env * env )
{
struct usb_device * usb_dev ;
usb_dev = to_usb_device ( dev ) ;
if ( add_uevent_var ( env , " BUSNUM=%03d " , usb_dev - > bus - > busnum ) )
return - ENOMEM ;
if ( add_uevent_var ( env , " DEVNUM=%03d " , usb_dev - > devnum ) )
return - ENOMEM ;
return 0 ;
}
2006-08-30 15:47:02 -04:00
# ifdef CONFIG_PM
2008-08-12 14:34:10 -04:00
/* USB device Power-Management thunks.
* There ' s no need to distinguish here between quiescing a USB device
* and powering it down ; the generic_suspend ( ) routine takes care of
* it by skipping the usb_port_suspend ( ) call for a quiesce . And for
* USB interfaces there ' s no difference at all .
*/
static int usb_dev_prepare ( struct device * dev )
{
2016-05-02 15:35:57 +02:00
return 0 ; /* Implement eventually? */
2008-08-12 14:34:10 -04:00
}
static void usb_dev_complete ( struct device * dev )
{
/* Currently used only for rebinding interfaces */
2012-01-11 08:38:35 +01:00
usb_resume_complete ( dev ) ;
2008-08-12 14:34:10 -04:00
}
static int usb_dev_suspend ( struct device * dev )
{
return usb_suspend ( dev , PMSG_SUSPEND ) ;
}
static int usb_dev_resume ( struct device * dev )
{
2008-11-25 16:39:18 -05:00
return usb_resume ( dev , PMSG_RESUME ) ;
2008-08-12 14:34:10 -04:00
}
static int usb_dev_freeze ( struct device * dev )
{
return usb_suspend ( dev , PMSG_FREEZE ) ;
}
static int usb_dev_thaw ( struct device * dev )
{
2008-11-25 16:39:18 -05:00
return usb_resume ( dev , PMSG_THAW ) ;
2008-08-12 14:34:10 -04:00
}
static int usb_dev_poweroff ( struct device * dev )
{
return usb_suspend ( dev , PMSG_HIBERNATE ) ;
}
static int usb_dev_restore ( struct device * dev )
{
2008-11-25 16:39:18 -05:00
return usb_resume ( dev , PMSG_RESTORE ) ;
2008-08-12 14:34:10 -04:00
}
2009-12-14 18:00:08 -08:00
static const struct dev_pm_ops usb_device_pm_ops = {
2008-08-12 14:34:10 -04:00
. prepare = usb_dev_prepare ,
. complete = usb_dev_complete ,
. suspend = usb_dev_suspend ,
. resume = usb_dev_resume ,
. freeze = usb_dev_freeze ,
. thaw = usb_dev_thaw ,
. poweroff = usb_dev_poweroff ,
. restore = usb_dev_restore ,
2011-03-18 19:55:36 +01:00
. runtime_suspend = usb_runtime_suspend ,
. runtime_resume = usb_runtime_resume ,
. runtime_idle = usb_runtime_idle ,
2008-08-12 14:34:10 -04:00
} ;
2006-11-13 15:02:04 -05:00
# endif /* CONFIG_PM */
2006-08-30 15:47:02 -04:00
2009-04-30 15:23:42 +02:00
2013-04-06 09:56:00 -07:00
static char * usb_devnode ( struct device * dev ,
2013-04-11 11:43:29 -07:00
umode_t * mode , kuid_t * uid , kgid_t * gid )
2009-04-30 15:23:42 +02:00
{
struct usb_device * usb_dev ;
usb_dev = to_usb_device ( dev ) ;
return kasprintf ( GFP_KERNEL , " bus/usb/%03d/%03d " ,
usb_dev - > bus - > busnum , usb_dev - > devnum ) ;
}
2008-08-12 14:34:10 -04:00
struct device_type usb_device_type = {
. name = " usb_device " ,
. release = usb_release_dev ,
. uevent = usb_dev_uevent ,
2009-09-18 23:01:12 +02:00
. devnode = usb_devnode ,
2010-08-05 13:12:14 -04:00
# ifdef CONFIG_PM
2008-08-12 14:34:10 -04:00
. pm = & usb_device_pm_ops ,
2010-08-05 13:12:14 -04:00
# endif
2008-08-12 14:34:10 -04:00
} ;
2007-07-31 20:34:00 -07:00
/* Returns 1 if @usb_bus is WUSB, 0 otherwise */
static unsigned usb_bus_is_wusb ( struct usb_bus * bus )
{
2015-12-23 21:26:51 +08:00
struct usb_hcd * hcd = bus_to_hcd ( bus ) ;
2007-07-31 20:34:00 -07:00
return hcd - > wireless ;
}
2019-02-16 23:21:51 -08:00
static bool usb_dev_authorized ( struct usb_device * dev , struct usb_hcd * hcd )
{
struct usb_hub * hub ;
if ( ! dev - > parent )
return true ; /* Root hub always ok [and always wired] */
switch ( hcd - > dev_policy ) {
case USB_DEVICE_AUTHORIZE_NONE :
default :
return false ;
case USB_DEVICE_AUTHORIZE_ALL :
return true ;
case USB_DEVICE_AUTHORIZE_INTERNAL :
hub = usb_hub_to_struct_hub ( dev - > parent ) ;
return hub - > ports [ dev - > portnum - 1 ] - > connect_type = =
USB_PORT_CONNECT_TYPE_HARD_WIRED ;
}
}
2007-07-31 20:34:00 -07:00
2005-04-16 15:20:36 -07:00
/**
* usb_alloc_dev - usb device constructor ( usbcore - internal )
* @ parent : hub to which device is connected ; null to allocate a root hub
* @ bus : bus used to access the device
* @ port1 : one - based index of port ; ignored for root hubs
2020-10-19 12:06:41 +02:00
*
* Context : task context , might sleep .
2005-04-16 15:20:36 -07:00
*
* Only hub drivers ( including virtual root hub drivers for host
* controllers ) should ever call this .
*
* This call may not be used in a non - sleeping context .
2013-08-02 20:10:04 +02:00
*
* Return : On success , a pointer to the allocated usb device . % NULL on
* failure .
2005-04-16 15:20:36 -07:00
*/
2008-01-30 15:21:33 -08:00
struct usb_device * usb_alloc_dev ( struct usb_device * parent ,
struct usb_bus * bus , unsigned port1 )
2005-04-16 15:20:36 -07:00
{
struct usb_device * dev ;
2012-10-06 15:23:17 +08:00
struct usb_hcd * usb_hcd = bus_to_hcd ( bus ) ;
2007-07-31 20:34:00 -07:00
unsigned root_hub = 0 ;
usb/core: usb_alloc_dev(): fix setting of ->portnum
With commit 69bec7259853 ("USB: core: let USB device know device node"),
the port1 argument of usb_alloc_dev() gets overwritten as follows:
... usb_alloc_dev(..., unsigned port1)
{
...
if (!parent->parent) {
port1 = usb_hcd_find_raw_port_number(..., port1);
}
...
}
Later on, this now overwritten port1 gets assigned to ->portnum:
dev->portnum = port1;
However, since xhci_find_raw_port_number() isn't idempotent, the
aforementioned commit causes a number of KASAN splats like the following:
BUG: KASAN: slab-out-of-bounds in xhci_find_raw_port_number+0x98/0x170
at addr ffff8801d9311670
Read of size 8 by task kworker/2:1/87
[...]
Workqueue: usb_hub_wq hub_event
0000000000000188 000000005814b877 ffff8800cba17588 ffffffff8191447e
0000000041b58ab3 ffffffff82a03209 ffffffff819143a2 ffffffff82a252f4
ffff8801d93115e0 0000000000000188 ffff8801d9311628 ffff8800cba17588
Call Trace:
[<ffffffff8191447e>] dump_stack+0xdc/0x15e
[<ffffffff819143a2>] ? _atomic_dec_and_lock+0xa2/0xa2
[<ffffffff814e2cd1>] ? print_section+0x61/0xb0
[<ffffffff814e4939>] print_trailer+0x179/0x2c0
[<ffffffff814f0d84>] object_err+0x34/0x40
[<ffffffff814f4388>] kasan_report_error+0x2f8/0x8b0
[<ffffffff814eb91e>] ? __slab_alloc+0x5e/0x90
[<ffffffff812178c0>] ? __lock_is_held+0x90/0x130
[<ffffffff814f5091>] kasan_report+0x71/0xa0
[<ffffffff814ec082>] ? kmem_cache_alloc_trace+0x212/0x560
[<ffffffff81d99468>] ? xhci_find_raw_port_number+0x98/0x170
[<ffffffff814f33d4>] __asan_load8+0x64/0x70
[<ffffffff81d99468>] xhci_find_raw_port_number+0x98/0x170
[<ffffffff81db0105>] xhci_setup_addressable_virt_dev+0x235/0xa10
[<ffffffff81d9ea51>] xhci_setup_device+0x3c1/0x1430
[<ffffffff8121cddd>] ? trace_hardirqs_on+0xd/0x10
[<ffffffff81d9fac0>] ? xhci_setup_device+0x1430/0x1430
[<ffffffff81d9fad3>] xhci_address_device+0x13/0x20
[<ffffffff81d2081a>] hub_port_init+0x55a/0x1550
[<ffffffff81d28705>] hub_event+0xef5/0x24d0
[<ffffffff81d27810>] ? hub_port_debounce+0x2f0/0x2f0
[<ffffffff8195e1ee>] ? debug_object_deactivate+0x1be/0x270
[<ffffffff81210203>] ? print_rt_rq+0x53/0x2d0
[<ffffffff8121657d>] ? trace_hardirqs_off+0xd/0x10
[<ffffffff8226acfb>] ? _raw_spin_unlock_irqrestore+0x5b/0x60
[<ffffffff81250000>] ? irq_domain_set_hwirq_and_chip+0x30/0xb0
[<ffffffff81256339>] ? debug_lockdep_rcu_enabled+0x39/0x40
[<ffffffff812178c0>] ? __lock_is_held+0x90/0x130
[<ffffffff81196877>] process_one_work+0x567/0xec0
[...]
Afterwards, xhci reports some functional errors:
xhci_hcd 0000:00:14.0: ERROR: unexpected setup address command completion
code 0x11.
xhci_hcd 0000:00:14.0: ERROR: unexpected setup address command completion
code 0x11.
usb 4-3: device not accepting address 2, error -22
Fix this by not overwriting the port1 argument in usb_alloc_dev(), but
storing the raw port number as required by OF in an additional variable,
raw_port.
Fixes: 69bec7259853 ("USB: core: let USB device know device node")
Signed-off-by: Nicolai Stange <nicstange@gmail.com>
Acked-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2016-03-17 23:53:02 +01:00
unsigned raw_port = port1 ;
2005-04-16 15:20:36 -07:00
2005-10-24 15:38:24 -04:00
dev = kzalloc ( sizeof ( * dev ) , GFP_KERNEL ) ;
2005-04-16 15:20:36 -07:00
if ( ! dev )
return NULL ;
2012-10-06 15:23:17 +08:00
if ( ! usb_get_hcd ( usb_hcd ) ) {
2005-04-16 15:20:36 -07:00
kfree ( dev ) ;
return NULL ;
}
2009-04-27 19:57:26 -07:00
/* Root hubs aren't true devices, so don't allocate HCD resources */
if ( usb_hcd - > driver - > alloc_dev & & parent & &
! usb_hcd - > driver - > alloc_dev ( usb_hcd , dev ) ) {
usb_put_hcd ( bus_to_hcd ( bus ) ) ;
kfree ( dev ) ;
return NULL ;
}
2005-04-16 15:20:36 -07:00
device_initialize ( & dev - > dev ) ;
dev - > dev . bus = & usb_bus_type ;
2007-03-13 15:59:31 +01:00
dev - > dev . type = & usb_device_type ;
2008-04-30 15:37:19 -04:00
dev - > dev . groups = usb_device_groups ;
2017-03-13 10:18:41 +08:00
set_dev_node ( & dev - > dev , dev_to_node ( bus - > sysdev ) ) ;
2005-04-16 15:20:36 -07:00
dev - > state = USB_STATE_ATTACHED ;
2012-07-03 23:22:38 -07:00
dev - > lpm_disable_count = 1 ;
2007-10-03 14:56:03 -07:00
atomic_set ( & dev - > urbnum , 0 ) ;
2005-04-16 15:20:36 -07:00
INIT_LIST_HEAD ( & dev - > ep0 . urb_list ) ;
dev - > ep0 . desc . bLength = USB_DT_ENDPOINT_SIZE ;
dev - > ep0 . desc . bDescriptorType = USB_DT_ENDPOINT ;
/* ep0 maxpacket comes later, from device descriptor */
2009-04-08 17:36:28 +00:00
usb_enable_endpoint ( dev , & dev - > ep0 , false ) ;
2007-09-10 11:34:26 -04:00
dev - > can_submit = 1 ;
2005-04-16 15:20:36 -07:00
/* Save readable and stable topology id, distinguishing devices
* by location for diagnostics , tools , driver model , etc . The
* string is a path along hub ports , from the root . Each device ' s
* dev - > devpath will be stable until USB is re - cabled , and hubs
2008-05-02 06:02:41 +02:00
* are often labeled with these port numbers . The name isn ' t
2005-04-16 15:20:36 -07:00
* as stable : bus - > busnum changes easily from modprobe order ,
* cardbus or pci hotplugging , and so on .
*/
2007-01-23 15:55:28 -05:00
if ( unlikely ( ! parent ) ) {
dev - > devpath [ 0 ] = ' 0 ' ;
2009-04-27 19:54:49 -07:00
dev - > route = 0 ;
2005-04-16 15:20:36 -07:00
dev - > dev . parent = bus - > controller ;
2017-06-06 17:59:02 +02:00
device_set_of_node_from_dev ( & dev - > dev , bus - > sysdev ) ;
2008-05-02 06:02:41 +02:00
dev_set_name ( & dev - > dev , " usb%d " , bus - > busnum ) ;
2007-07-31 20:34:00 -07:00
root_hub = 1 ;
2005-04-16 15:20:36 -07:00
} else {
/* match any labeling on the hubs; it's one-based */
2009-04-27 19:54:49 -07:00
if ( parent - > devpath [ 0 ] = = ' 0 ' ) {
2007-01-23 15:55:28 -05:00
snprintf ( dev - > devpath , sizeof dev - > devpath ,
2005-04-16 15:20:36 -07:00
" %d " , port1 ) ;
2009-04-27 19:54:49 -07:00
/* Root ports are not counted in route string */
dev - > route = 0 ;
} else {
2007-01-23 15:55:28 -05:00
snprintf ( dev - > devpath , sizeof dev - > devpath ,
2005-04-16 15:20:36 -07:00
" %s.%d " , parent - > devpath , port1 ) ;
2009-09-04 10:53:17 -07:00
/* Route string assumes hubs have less than 16 ports */
if ( port1 < 15 )
dev - > route = parent - > route +
( port1 < < ( ( parent - > level - 1 ) * 4 ) ) ;
else
dev - > route = parent - > route +
( 15 < < ( ( parent - > level - 1 ) * 4 ) ) ;
2009-04-27 19:54:49 -07:00
}
2005-04-16 15:20:36 -07:00
dev - > dev . parent = & parent - > dev ;
2008-05-02 06:02:41 +02:00
dev_set_name ( & dev - > dev , " %d-%s " , bus - > busnum , dev - > devpath ) ;
2005-04-16 15:20:36 -07:00
2016-02-19 17:26:15 +08:00
if ( ! parent - > parent ) {
/* device under root hub's port */
usb/core: usb_alloc_dev(): fix setting of ->portnum
With commit 69bec7259853 ("USB: core: let USB device know device node"),
the port1 argument of usb_alloc_dev() gets overwritten as follows:
... usb_alloc_dev(..., unsigned port1)
{
...
if (!parent->parent) {
port1 = usb_hcd_find_raw_port_number(..., port1);
}
...
}
Later on, this now overwritten port1 gets assigned to ->portnum:
dev->portnum = port1;
However, since xhci_find_raw_port_number() isn't idempotent, the
aforementioned commit causes a number of KASAN splats like the following:
BUG: KASAN: slab-out-of-bounds in xhci_find_raw_port_number+0x98/0x170
at addr ffff8801d9311670
Read of size 8 by task kworker/2:1/87
[...]
Workqueue: usb_hub_wq hub_event
0000000000000188 000000005814b877 ffff8800cba17588 ffffffff8191447e
0000000041b58ab3 ffffffff82a03209 ffffffff819143a2 ffffffff82a252f4
ffff8801d93115e0 0000000000000188 ffff8801d9311628 ffff8800cba17588
Call Trace:
[<ffffffff8191447e>] dump_stack+0xdc/0x15e
[<ffffffff819143a2>] ? _atomic_dec_and_lock+0xa2/0xa2
[<ffffffff814e2cd1>] ? print_section+0x61/0xb0
[<ffffffff814e4939>] print_trailer+0x179/0x2c0
[<ffffffff814f0d84>] object_err+0x34/0x40
[<ffffffff814f4388>] kasan_report_error+0x2f8/0x8b0
[<ffffffff814eb91e>] ? __slab_alloc+0x5e/0x90
[<ffffffff812178c0>] ? __lock_is_held+0x90/0x130
[<ffffffff814f5091>] kasan_report+0x71/0xa0
[<ffffffff814ec082>] ? kmem_cache_alloc_trace+0x212/0x560
[<ffffffff81d99468>] ? xhci_find_raw_port_number+0x98/0x170
[<ffffffff814f33d4>] __asan_load8+0x64/0x70
[<ffffffff81d99468>] xhci_find_raw_port_number+0x98/0x170
[<ffffffff81db0105>] xhci_setup_addressable_virt_dev+0x235/0xa10
[<ffffffff81d9ea51>] xhci_setup_device+0x3c1/0x1430
[<ffffffff8121cddd>] ? trace_hardirqs_on+0xd/0x10
[<ffffffff81d9fac0>] ? xhci_setup_device+0x1430/0x1430
[<ffffffff81d9fad3>] xhci_address_device+0x13/0x20
[<ffffffff81d2081a>] hub_port_init+0x55a/0x1550
[<ffffffff81d28705>] hub_event+0xef5/0x24d0
[<ffffffff81d27810>] ? hub_port_debounce+0x2f0/0x2f0
[<ffffffff8195e1ee>] ? debug_object_deactivate+0x1be/0x270
[<ffffffff81210203>] ? print_rt_rq+0x53/0x2d0
[<ffffffff8121657d>] ? trace_hardirqs_off+0xd/0x10
[<ffffffff8226acfb>] ? _raw_spin_unlock_irqrestore+0x5b/0x60
[<ffffffff81250000>] ? irq_domain_set_hwirq_and_chip+0x30/0xb0
[<ffffffff81256339>] ? debug_lockdep_rcu_enabled+0x39/0x40
[<ffffffff812178c0>] ? __lock_is_held+0x90/0x130
[<ffffffff81196877>] process_one_work+0x567/0xec0
[...]
Afterwards, xhci reports some functional errors:
xhci_hcd 0000:00:14.0: ERROR: unexpected setup address command completion
code 0x11.
xhci_hcd 0000:00:14.0: ERROR: unexpected setup address command completion
code 0x11.
usb 4-3: device not accepting address 2, error -22
Fix this by not overwriting the port1 argument in usb_alloc_dev(), but
storing the raw port number as required by OF in an additional variable,
raw_port.
Fixes: 69bec7259853 ("USB: core: let USB device know device node")
Signed-off-by: Nicolai Stange <nicstange@gmail.com>
Acked-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2016-03-17 23:53:02 +01:00
raw_port = usb_hcd_find_raw_port_number ( usb_hcd ,
2016-02-19 17:26:15 +08:00
port1 ) ;
}
2017-11-09 18:07:23 +01:00
dev - > dev . of_node = usb_of_get_device_node ( parent , raw_port ) ;
2016-02-19 17:26:15 +08:00
2005-04-16 15:20:36 -07:00
/* hub driver sets up TT records */
}
2005-11-23 12:09:52 -05:00
dev - > portnum = port1 ;
2005-04-16 15:20:36 -07:00
dev - > bus = bus ;
dev - > parent = parent ;
INIT_LIST_HEAD ( & dev - > filelist ) ;
2006-08-30 15:47:02 -04:00
# ifdef CONFIG_PM
2010-11-15 15:57:51 -05:00
pm_runtime_set_autosuspend_delay ( & dev - > dev ,
usb_autosuspend_delay * 1000 ) ;
2007-12-21 16:54:15 -08:00
dev - > connect_time = jiffies ;
dev - > active_duration = - jiffies ;
2006-08-30 15:47:02 -04:00
# endif
2019-02-16 23:21:51 -08:00
dev - > authorized = usb_dev_authorized ( dev , usb_hcd ) ;
if ( ! root_hub )
2013-10-10 23:41:27 +02:00
dev - > wusb = usb_bus_is_wusb ( bus ) ? 1 : 0 ;
2019-02-16 23:21:51 -08:00
2005-04-16 15:20:36 -07:00
return dev ;
}
2014-07-14 19:27:48 +05:30
EXPORT_SYMBOL_GPL ( usb_alloc_dev ) ;
2005-04-16 15:20:36 -07:00
/**
* usb_get_dev - increments the reference count of the usb device structure
* @ dev : the device being referenced
*
* Each live reference to a device should be refcounted .
*
* Drivers for USB interfaces should normally record such references in
* their probe ( ) methods , when they bind to an interface , and release
* them by calling usb_put_dev ( ) , in their disconnect ( ) methods .
2022-02-25 09:38:25 -05:00
* However , if a driver does not access the usb_device structure after
* its disconnect ( ) method returns then refcounting is not necessary ,
* because the USB core guarantees that a usb_device will not be
* deallocated until after all of its interface drivers have been unbound .
2005-04-16 15:20:36 -07:00
*
2013-08-02 20:10:04 +02:00
* Return : A pointer to the device with the incremented reference counter .
2005-04-16 15:20:36 -07:00
*/
struct usb_device * usb_get_dev ( struct usb_device * dev )
{
if ( dev )
get_device ( & dev - > dev ) ;
return dev ;
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_get_dev ) ;
2005-04-16 15:20:36 -07:00
/**
* usb_put_dev - release a use of the usb device structure
* @ dev : device that ' s been disconnected
*
* Must be called when a user of a device is finished with it . When the last
* user of the device calls this function , the memory of the device is freed .
*/
void usb_put_dev ( struct usb_device * dev )
{
if ( dev )
put_device ( & dev - > dev ) ;
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_put_dev ) ;
2005-04-16 15:20:36 -07:00
/**
* usb_get_intf - increments the reference count of the usb interface structure
* @ intf : the interface being referenced
*
* Each live reference to a interface must be refcounted .
*
* Drivers for USB interfaces should normally record such references in
* their probe ( ) methods , when they bind to an interface , and release
* them by calling usb_put_intf ( ) , in their disconnect ( ) methods .
2022-02-25 09:38:25 -05:00
* However , if a driver does not access the usb_interface structure after
* its disconnect ( ) method returns then refcounting is not necessary ,
* because the USB core guarantees that a usb_interface will not be
* deallocated until after its driver has been unbound .
2005-04-16 15:20:36 -07:00
*
2013-08-02 20:10:04 +02:00
* Return : A pointer to the interface with the incremented reference counter .
2005-04-16 15:20:36 -07:00
*/
struct usb_interface * usb_get_intf ( struct usb_interface * intf )
{
if ( intf )
get_device ( & intf - > dev ) ;
return intf ;
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_get_intf ) ;
2005-04-16 15:20:36 -07:00
/**
* usb_put_intf - release a use of the usb interface structure
* @ intf : interface that ' s been decremented
*
* Must be called when a user of an interface is finished with it . When the
* last user of the interface calls this function , the memory of the interface
* is freed .
*/
void usb_put_intf ( struct usb_interface * intf )
{
if ( intf )
put_device ( & intf - > dev ) ;
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_put_intf ) ;
2005-04-16 15:20:36 -07:00
2021-03-03 14:32:29 +01:00
/**
* usb_intf_get_dma_device - acquire a reference on the usb interface ' s DMA endpoint
* @ intf : the usb interface
*
* While a USB device cannot perform DMA operations by itself , many USB
* controllers can . A call to usb_intf_get_dma_device ( ) returns the DMA endpoint
* for the given USB interface , if any . The returned device structure must be
* released with put_device ( ) .
*
* See also usb_get_dma_device ( ) .
*
* Returns : A reference to the usb interface ' s DMA endpoint ; or NULL if none
* exists .
*/
struct device * usb_intf_get_dma_device ( struct usb_interface * intf )
{
struct usb_device * udev = interface_to_usbdev ( intf ) ;
struct device * dmadev ;
if ( ! udev - > bus )
return NULL ;
dmadev = get_device ( udev - > bus - > sysdev ) ;
if ( ! dmadev | | ! dmadev - > dma_mask ) {
put_device ( dmadev ) ;
return NULL ;
}
return dmadev ;
}
EXPORT_SYMBOL_GPL ( usb_intf_get_dma_device ) ;
2005-04-16 15:20:36 -07:00
/* USB device locking
*
2005-11-17 17:10:32 -05:00
* USB devices and interfaces are locked using the semaphore in their
* embedded struct device . The hub driver guarantees that whenever a
* device is connected or disconnected , drivers are called with the
* USB device locked as well as their particular interface .
2005-04-16 15:20:36 -07:00
*
* Complications arise when several devices are to be locked at the same
* time . Only hub - aware drivers that are part of usbcore ever have to
2005-11-17 17:10:32 -05:00
* do this ; nobody else needs to worry about it . The rule for locking
* is simple :
2005-04-16 15:20:36 -07:00
*
* When locking both a device and its parent , always lock the
2022-07-16 21:24:03 +08:00
* parent first .
2005-04-16 15:20:36 -07:00
*/
/**
2008-02-29 22:03:07 -08:00
* usb_lock_device_for_reset - cautiously acquire the lock for a usb device structure
2005-04-16 15:20:36 -07:00
* @ udev : device that ' s being locked
* @ iface : interface bound to the driver making the request ( optional )
*
* Attempts to acquire the device lock , but fails if the device is
* NOTATTACHED or SUSPENDED , or if iface is specified and the interface
* is neither BINDING nor BOUND . Rather than sleeping to wait for the
* lock , the routine polls repeatedly . This is to prevent deadlock with
* disconnect ; in some drivers ( such as usb - storage ) the disconnect ( )
2005-08-11 10:15:39 -04:00
* or suspend ( ) method will block waiting for a device reset to complete .
2005-04-16 15:20:36 -07:00
*
2013-08-02 20:10:04 +02:00
* Return : A negative error code for failure , otherwise 0.
2005-04-16 15:20:36 -07:00
*/
int usb_lock_device_for_reset ( struct usb_device * udev ,
2006-08-26 23:48:11 -03:00
const struct usb_interface * iface )
2005-04-16 15:20:36 -07:00
{
2005-08-11 10:15:39 -04:00
unsigned long jiffies_expire = jiffies + HZ ;
2005-04-16 15:20:36 -07:00
if ( udev - > state = = USB_STATE_NOTATTACHED )
return - ENODEV ;
if ( udev - > state = = USB_STATE_SUSPENDED )
return - EHOSTUNREACH ;
2008-11-04 11:29:27 -05:00
if ( iface & & ( iface - > condition = = USB_INTERFACE_UNBINDING | |
iface - > condition = = USB_INTERFACE_UNBOUND ) )
return - EINTR ;
2005-04-16 15:20:36 -07:00
2010-01-29 20:39:02 +00:00
while ( ! usb_trylock_device ( udev ) ) {
2005-08-11 10:15:39 -04:00
/* If we can't acquire the lock after waiting one second,
* we ' re probably deadlocked */
if ( time_after ( jiffies , jiffies_expire ) )
return - EBUSY ;
2005-04-16 15:20:36 -07:00
msleep ( 15 ) ;
if ( udev - > state = = USB_STATE_NOTATTACHED )
return - ENODEV ;
if ( udev - > state = = USB_STATE_SUSPENDED )
return - EHOSTUNREACH ;
2008-11-04 11:29:27 -05:00
if ( iface & & ( iface - > condition = = USB_INTERFACE_UNBINDING | |
iface - > condition = = USB_INTERFACE_UNBOUND ) )
2005-04-16 15:20:36 -07:00
return - EINTR ;
}
2008-11-04 11:29:27 -05:00
return 0 ;
2005-04-16 15:20:36 -07:00
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_lock_device_for_reset ) ;
2005-04-16 15:20:36 -07:00
/**
* usb_get_current_frame_number - return current bus frame number
* @ dev : the device whose bus is being queried
*
2013-08-02 20:10:04 +02:00
* Return : The current frame number for the USB host controller used
* with the given USB device . This can be used when scheduling
2005-04-16 15:20:36 -07:00
* isochronous requests .
*
2013-08-02 20:10:04 +02:00
* Note : Different kinds of host controller have different " scheduling
* horizons " . While one type might support scheduling only 32 frames
* into the future , others could support scheduling up to 1024 frames
* into the future .
*
2005-04-16 15:20:36 -07:00
*/
int usb_get_current_frame_number ( struct usb_device * dev )
{
2007-01-23 15:55:28 -05:00
return usb_hcd_get_frame_number ( dev ) ;
2005-04-16 15:20:36 -07:00
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( usb_get_current_frame_number ) ;
2005-04-16 15:20:36 -07:00
/*-------------------------------------------------------------------*/
/*
* __usb_get_extra_descriptor ( ) finds a descriptor of specific type in the
* extra field of the interface and endpoint descriptor structs .
*/
int __usb_get_extra_descriptor ( char * buffer , unsigned size ,
2018-12-05 21:19:59 +01:00
unsigned char type , void * * ptr , size_t minsize )
2005-04-16 15:20:36 -07:00
{
struct usb_descriptor_header * header ;
while ( size > = sizeof ( struct usb_descriptor_header ) ) {
header = ( struct usb_descriptor_header * ) buffer ;
2018-12-05 21:19:59 +01:00
if ( header - > bLength < 2 | | header - > bLength > size ) {
2005-04-16 15:20:36 -07:00
printk ( KERN_ERR
" %s: bogus descriptor, type %d length %d \n " ,
usbcore_name ,
2008-01-30 15:21:33 -08:00
header - > bDescriptorType ,
2005-04-16 15:20:36 -07:00
header - > bLength ) ;
return - 1 ;
}
2018-12-05 21:19:59 +01:00
if ( header - > bDescriptorType = = type & & header - > bLength > = minsize ) {
2005-04-16 15:20:36 -07:00
* ptr = header ;
return 0 ;
}
buffer + = header - > bLength ;
size - = header - > bLength ;
}
return - 1 ;
}
2008-01-25 11:12:21 -06:00
EXPORT_SYMBOL_GPL ( __usb_get_extra_descriptor ) ;
2005-04-16 15:20:36 -07:00
/**
2010-04-12 13:17:25 +02:00
* usb_alloc_coherent - allocate dma - consistent buffer for URB_NO_xxx_DMA_MAP
2005-04-16 15:20:36 -07:00
* @ dev : device the buffer will be used with
* @ size : requested buffer size
* @ mem_flags : affect whether allocation may block
* @ dma : used to return DMA address of buffer
*
2013-08-02 20:10:04 +02:00
* Return : Either null ( indicating no buffer could be allocated ) , or the
* cpu - space pointer to a buffer that may be used to perform DMA to the
2005-04-16 15:20:36 -07:00
* specified device . Such cpu - space buffers are returned along with the DMA
* address ( through the pointer provided ) .
*
2013-08-02 20:10:04 +02:00
* Note :
2005-04-16 15:20:36 -07:00
* These buffers are used with URB_NO_xxx_DMA_MAP set in urb - > transfer_flags
2007-07-01 23:33:12 -07:00
* to avoid behaviors like using " DMA bounce buffers " , or thrashing IOMMU
* hardware during URB completion / resubmit . The implementation varies between
2005-04-16 15:20:36 -07:00
* platforms , depending on details of how DMA will work to this device .
2007-07-01 23:33:12 -07:00
* Using these buffers also eliminates cacheline sharing problems on
* architectures where CPU caches are not DMA - coherent . On systems without
* bus - snooping caches , these buffers are uncached .
2005-04-16 15:20:36 -07:00
*
2010-04-12 13:17:25 +02:00
* When the buffer is no longer used , free it with usb_free_coherent ( ) .
2005-04-16 15:20:36 -07:00
*/
2010-04-12 13:17:25 +02:00
void * usb_alloc_coherent ( struct usb_device * dev , size_t size , gfp_t mem_flags ,
dma_addr_t * dma )
2005-04-16 15:20:36 -07:00
{
2006-08-30 11:27:36 -04:00
if ( ! dev | | ! dev - > bus )
2005-04-16 15:20:36 -07:00
return NULL ;
2007-01-23 15:55:28 -05:00
return hcd_buffer_alloc ( dev - > bus , size , mem_flags , dma ) ;
2005-04-16 15:20:36 -07:00
}
2010-04-12 13:17:25 +02:00
EXPORT_SYMBOL_GPL ( usb_alloc_coherent ) ;
2005-04-16 15:20:36 -07:00
/**
2010-04-12 13:17:25 +02:00
* usb_free_coherent - free memory allocated with usb_alloc_coherent ( )
2005-04-16 15:20:36 -07:00
* @ dev : device the buffer was used with
* @ size : requested buffer size
* @ addr : CPU address of buffer
* @ dma : DMA address of buffer
*
* This reclaims an I / O buffer , letting it be reused . The memory must have
2010-04-12 13:17:25 +02:00
* been allocated using usb_alloc_coherent ( ) , and the parameters must match
2007-07-01 23:33:12 -07:00
* those provided in that allocation request .
2005-04-16 15:20:36 -07:00
*/
2010-04-12 13:17:25 +02:00
void usb_free_coherent ( struct usb_device * dev , size_t size , void * addr ,
dma_addr_t dma )
2005-04-16 15:20:36 -07:00
{
2006-08-30 11:27:36 -04:00
if ( ! dev | | ! dev - > bus )
2006-08-01 22:33:34 -04:00
return ;
if ( ! addr )
return ;
2007-01-23 15:55:28 -05:00
hcd_buffer_free ( dev - > bus , size , addr , dma ) ;
2005-04-16 15:20:36 -07:00
}
2010-04-12 13:17:25 +02:00
EXPORT_SYMBOL_GPL ( usb_free_coherent ) ;
2005-04-16 15:20:36 -07:00
2008-12-05 14:10:34 -05:00
/*
* Notifications of device and interface registration
*/
static int usb_bus_notify ( struct notifier_block * nb , unsigned long action ,
void * data )
{
struct device * dev = data ;
switch ( action ) {
case BUS_NOTIFY_ADD_DEVICE :
if ( dev - > type = = & usb_device_type )
( void ) usb_create_sysfs_dev_files ( to_usb_device ( dev ) ) ;
else if ( dev - > type = = & usb_if_device_type )
2011-04-14 17:47:09 +02:00
usb_create_sysfs_intf_files ( to_usb_interface ( dev ) ) ;
2008-12-05 14:10:34 -05:00
break ;
case BUS_NOTIFY_DEL_DEVICE :
if ( dev - > type = = & usb_device_type )
usb_remove_sysfs_dev_files ( to_usb_device ( dev ) ) ;
else if ( dev - > type = = & usb_if_device_type )
usb_remove_sysfs_intf_files ( to_usb_interface ( dev ) ) ;
break ;
}
return 0 ;
}
static struct notifier_block usb_bus_nb = {
. notifier_call = usb_bus_notify ,
} ;
2018-05-29 17:30:59 +02:00
static void usb_debugfs_init ( void )
2009-04-24 14:56:26 -07:00
{
2021-02-16 11:14:32 +01:00
debugfs_create_file ( " devices " , 0444 , usb_debug_root , NULL ,
& usbfs_devices_fops ) ;
2009-04-24 14:56:26 -07:00
}
static void usb_debugfs_cleanup ( void )
{
2021-02-16 11:14:32 +01:00
debugfs_remove ( debugfs_lookup ( " devices " , usb_debug_root ) ) ;
2009-04-24 14:56:26 -07:00
}
2005-04-16 15:20:36 -07:00
/*
* Init
*/
static int __init usb_init ( void )
{
int retval ;
2015-03-20 09:04:40 +05:30
if ( usb_disabled ( ) ) {
2007-01-23 15:55:28 -05:00
pr_info ( " %s: USB support disabled \n " , usbcore_name ) ;
2005-04-16 15:20:36 -07:00
return 0 ;
}
2014-12-05 15:13:54 +01:00
usb_init_pool_max ( ) ;
2005-04-16 15:20:36 -07:00
2018-05-29 17:30:59 +02:00
usb_debugfs_init ( ) ;
2009-04-24 14:56:26 -07:00
2012-05-16 14:11:15 +02:00
usb_acpi_register ( ) ;
2005-04-16 15:20:36 -07:00
retval = bus_register ( & usb_bus_type ) ;
2008-01-30 15:21:33 -08:00
if ( retval )
2006-09-19 10:14:07 -04:00
goto bus_register_failed ;
2008-12-05 14:10:34 -05:00
retval = bus_register_notifier ( & usb_bus_type , & usb_bus_nb ) ;
if ( retval )
goto bus_notifier_failed ;
2005-04-16 15:20:36 -07:00
retval = usb_major_init ( ) ;
if ( retval )
goto major_init_failed ;
2005-07-31 01:05:53 +02:00
retval = usb_register ( & usbfs_driver ) ;
if ( retval )
goto driver_register_failed ;
2007-03-13 15:59:31 +01:00
retval = usb_devio_init ( ) ;
2005-07-31 01:05:53 +02:00
if ( retval )
2007-03-13 15:59:31 +01:00
goto usb_devio_init_failed ;
2005-04-16 15:20:36 -07:00
retval = usb_hub_init ( ) ;
if ( retval )
goto hub_init_failed ;
2006-07-01 22:08:49 -04:00
retval = usb_register_device_driver ( & usb_generic_driver , THIS_MODULE ) ;
2005-04-16 15:20:36 -07:00
if ( ! retval )
goto out ;
usb_hub_cleanup ( ) ;
hub_init_failed :
2007-03-13 15:59:31 +01:00
usb_devio_cleanup ( ) ;
usb_devio_init_failed :
2005-07-31 01:05:53 +02:00
usb_deregister ( & usbfs_driver ) ;
driver_register_failed :
usb_major_cleanup ( ) ;
2005-04-16 15:20:36 -07:00
major_init_failed :
2008-12-05 14:10:34 -05:00
bus_unregister_notifier ( & usb_bus_type , & usb_bus_nb ) ;
bus_notifier_failed :
2005-04-16 15:20:36 -07:00
bus_unregister ( & usb_bus_type ) ;
2006-09-19 10:14:07 -04:00
bus_register_failed :
2012-05-11 16:08:27 +08:00
usb_acpi_unregister ( ) ;
2010-01-08 12:57:28 -05:00
usb_debugfs_cleanup ( ) ;
2005-04-16 15:20:36 -07:00
out :
return retval ;
}
/*
* Cleanup
*/
static void __exit usb_exit ( void )
{
/* This will matter if shutdown/reboot does exitcalls. */
2015-03-20 09:04:40 +05:30
if ( usb_disabled ( ) )
2005-04-16 15:20:36 -07:00
return ;
2018-03-20 00:26:06 +08:00
usb_release_quirk_list ( ) ;
2006-07-01 22:08:49 -04:00
usb_deregister_device_driver ( & usb_generic_driver ) ;
2005-04-16 15:20:36 -07:00
usb_major_cleanup ( ) ;
2005-07-31 01:05:53 +02:00
usb_deregister ( & usbfs_driver ) ;
2007-03-13 15:59:31 +01:00
usb_devio_cleanup ( ) ;
2005-04-16 15:20:36 -07:00
usb_hub_cleanup ( ) ;
2008-12-05 14:10:34 -05:00
bus_unregister_notifier ( & usb_bus_type , & usb_bus_nb ) ;
2005-04-16 15:20:36 -07:00
bus_unregister ( & usb_bus_type ) ;
2012-05-11 16:08:27 +08:00
usb_acpi_unregister ( ) ;
2009-04-24 14:56:26 -07:00
usb_debugfs_cleanup ( ) ;
2016-01-25 20:30:30 +01:00
idr_destroy ( & usb_bus_idr ) ;
2005-04-16 15:20:36 -07:00
}
subsys_initcall ( usb_init ) ;
module_exit ( usb_exit ) ;
MODULE_LICENSE ( " GPL " ) ;