mirror of
https://github.com/ipxe/ipxe
synced 2025-12-13 23:41:45 +03:00
[usb] Maintain a list of all USB buses
Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
@@ -40,6 +40,9 @@ FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/** List of USB buses */
|
||||||
|
struct list_head usb_buses = LIST_HEAD_INIT ( usb_buses );
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
*
|
*
|
||||||
* Utility functions
|
* Utility functions
|
||||||
@@ -1894,6 +1897,9 @@ int register_usb_bus ( struct usb_bus *bus ) {
|
|||||||
if ( ( rc = bus->host->open ( bus ) ) != 0 )
|
if ( ( rc = bus->host->open ( bus ) ) != 0 )
|
||||||
goto err_open;
|
goto err_open;
|
||||||
|
|
||||||
|
/* Add to list of USB buses */
|
||||||
|
list_add_tail ( &bus->list, &usb_buses );
|
||||||
|
|
||||||
/* Register root hub */
|
/* Register root hub */
|
||||||
if ( ( rc = register_usb_hub ( bus->hub ) ) != 0 )
|
if ( ( rc = register_usb_hub ( bus->hub ) ) != 0 )
|
||||||
goto err_register_hub;
|
goto err_register_hub;
|
||||||
@@ -1905,6 +1911,7 @@ int register_usb_bus ( struct usb_bus *bus ) {
|
|||||||
|
|
||||||
unregister_usb_hub ( bus->hub );
|
unregister_usb_hub ( bus->hub );
|
||||||
err_register_hub:
|
err_register_hub:
|
||||||
|
list_del ( &bus->list );
|
||||||
bus->host->close ( bus );
|
bus->host->close ( bus );
|
||||||
err_open:
|
err_open:
|
||||||
return rc;
|
return rc;
|
||||||
@@ -1927,6 +1934,9 @@ void unregister_usb_bus ( struct usb_bus *bus ) {
|
|||||||
/* Unregister root hub */
|
/* Unregister root hub */
|
||||||
unregister_usb_hub ( bus->hub );
|
unregister_usb_hub ( bus->hub );
|
||||||
|
|
||||||
|
/* Remove from list of USB buses */
|
||||||
|
list_del ( &bus->list );
|
||||||
|
|
||||||
/* Close bus */
|
/* Close bus */
|
||||||
bus->host->close ( bus );
|
bus->host->close ( bus );
|
||||||
|
|
||||||
|
|||||||
@@ -916,6 +916,8 @@ struct usb_bus {
|
|||||||
/** Root hub */
|
/** Root hub */
|
||||||
struct usb_hub *hub;
|
struct usb_hub *hub;
|
||||||
|
|
||||||
|
/** List of USB buses */
|
||||||
|
struct list_head list;
|
||||||
/** List of devices */
|
/** List of devices */
|
||||||
struct list_head devices;
|
struct list_head devices;
|
||||||
/** List of hubs */
|
/** List of hubs */
|
||||||
@@ -999,6 +1001,10 @@ usb_poll ( struct usb_bus *bus ) {
|
|||||||
bus->host->poll ( bus );
|
bus->host->poll ( bus );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Iterate over all USB buses */
|
||||||
|
#define for_each_usb_bus( bus ) \
|
||||||
|
list_for_each_entry ( (bus), &usb_buses, list )
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Complete transfer (without error)
|
* Complete transfer (without error)
|
||||||
*
|
*
|
||||||
@@ -1182,6 +1188,8 @@ usb_set_interface ( struct usb_device *usb, unsigned int interface,
|
|||||||
NULL, 0 );
|
NULL, 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern struct list_head usb_buses;
|
||||||
|
|
||||||
extern struct usb_interface_descriptor *
|
extern struct usb_interface_descriptor *
|
||||||
usb_interface_descriptor ( struct usb_configuration_descriptor *config,
|
usb_interface_descriptor ( struct usb_configuration_descriptor *config,
|
||||||
unsigned int interface, unsigned int alternate );
|
unsigned int interface, unsigned int alternate );
|
||||||
|
|||||||
Reference in New Issue
Block a user