drivers/usb/serial/usb-serial.c
Source file repositories/reference/linux-study-clean/drivers/usb/serial/usb-serial.c
File Facts
- System
- Linux kernel
- Corpus path
drivers/usb/serial/usb-serial.c- Extension
.c- Size
- 41604 bytes
- Lines
- 1554
- Domain
- Driver Families
- Bucket
- drivers/usb
- Inferred role
- Driver Families: exported/initcall integration point
- Status
- integration implementation candidate
Why This File Exists
Repeatable hardware-adapter layer. Deep compatibility for every driver is out of scope; this atlas records patterns, probe lifecycles, bus glue, IRQ/DMA usage, and links back to core abstractions.
- Repeatable hardware-adapter layer. Deep compatibility for every driver is out of scope; this atlas records patterns, probe lifecycles, bus glue, IRQ/DMA usage, and links back to core abstractions.
- Exports symbols or registers init work; inspect boot/module ordering and who consumes the exported contract.
- Uses kernel synchronization; read lock ordering, sleepability, and interrupt context assumptions before translating.
- Allocates kernel memory; connect allocation flags and lifetime to context constraints.
- Defines or uses C structs; map object ownership, embedded links, reference counts, and lock ownership.
Dependency Surface
linux/kernel.hlinux/errno.hlinux/init.hlinux/slab.hlinux/tty.hlinux/tty_driver.hlinux/tty_flip.hlinux/module.hlinux/moduleparam.hlinux/seq_file.hlinux/spinlock.hlinux/mutex.hlinux/list.hlinux/uaccess.hlinux/serial.hlinux/usb.hlinux/usb/serial.hlinux/kfifo.hlinux/idr.h
Detected Declarations
function allocate_minorsfunction release_minorsfunction usb_serial_claim_interfacefunction release_siblingfunction destroy_serialfunction usb_serial_putfunction serial_cleanupfunction serial_port_activatefunction serial_openfunction serial_port_shutdownfunction serial_hangupfunction serial_closefunction serial_cleanupfunction serial_writefunction serial_write_roomfunction serial_chars_in_bufferfunction serial_wait_until_sentfunction serial_throttlefunction serial_unthrottlefunction serial_get_serialfunction serial_set_serialfunction serial_ioctlfunction serial_set_termiosfunction serial_breakfunction serial_proc_showfunction serial_tiocmgetfunction serial_tiocmsetfunction serial_get_icountfunction callbackfunction usb_serial_port_workfunction usb_serial_port_poison_urbsfunction usb_serial_port_unpoison_urbsfunction usb_serial_port_releasefunction serial_port_carrier_raisedfunction serial_port_dtr_rtsfunction port_number_showfunction store_endpointfunction find_endpointsfunction setup_port_bulk_infunction setup_port_bulk_outfunction setup_port_interrupt_infunction setup_port_interrupt_outfunction usb_serial_probefunction usb_serial_disconnectfunction usb_serial_suspendfunction usb_serial_unpoison_port_urbsfunction usb_serial_resumefunction usb_serial_reset_resume
Annotated Snippet
retval = device_add(&port->dev);
if (retval)
dev_err(ddev, "Error registering port device, continuing\n");
}
if (num_ports > 0)
usb_serial_console_init(serial->port[0]->minor);
exit:
kfree(epds);
module_put(type->driver.owner);
return 0;
err_free_epds:
kfree(epds);
err_release_sibling:
release_sibling(serial, interface);
usb_serial_put(serial);
err_put_module:
module_put(type->driver.owner);
return retval;
}
static void usb_serial_disconnect(struct usb_interface *interface)
{
int i;
struct usb_serial *serial = usb_get_intfdata(interface);
struct device *dev = &interface->dev;
struct usb_serial_port *port;
/* sibling interface is cleaning up */
if (!serial)
return;
usb_serial_console_disconnect(serial);
mutex_lock(&serial->disc_mutex);
/* must set a flag, to signal subdrivers */
serial->disconnected = 1;
mutex_unlock(&serial->disc_mutex);
for (i = 0; i < serial->num_ports; ++i) {
port = serial->port[i];
tty_port_tty_vhangup(&port->port);
usb_serial_port_poison_urbs(port);
wake_up_interruptible(&port->port.delta_msr_wait);
cancel_work_sync(&port->work);
if (device_is_registered(&port->dev))
device_del(&port->dev);
}
if (serial->type->disconnect)
serial->type->disconnect(serial);
release_sibling(serial, interface);
/* let the last holder of this object cause it to be cleaned up */
usb_serial_put(serial);
dev_info(dev, "device disconnected\n");
}
int usb_serial_suspend(struct usb_interface *intf, pm_message_t message)
{
struct usb_serial *serial = usb_get_intfdata(intf);
int i, r;
/* suspend when called for first sibling interface */
if (serial->suspend_count++)
return 0;
/*
* serial->type->suspend() MUST return 0 in system sleep context,
* otherwise, the resume callback has to recover device from
* previous suspend failure.
*/
if (serial->type->suspend) {
r = serial->type->suspend(serial, message);
if (r < 0) {
serial->suspend_count--;
return r;
}
}
for (i = 0; i < serial->num_ports; ++i)
usb_serial_port_poison_urbs(serial->port[i]);
return 0;
}
EXPORT_SYMBOL(usb_serial_suspend);
static void usb_serial_unpoison_port_urbs(struct usb_serial *serial)
Annotation
- Immediate include surface: `linux/kernel.h`, `linux/errno.h`, `linux/init.h`, `linux/slab.h`, `linux/tty.h`, `linux/tty_driver.h`, `linux/tty_flip.h`, `linux/module.h`.
- Detected declarations: `function allocate_minors`, `function release_minors`, `function usb_serial_claim_interface`, `function release_sibling`, `function destroy_serial`, `function usb_serial_put`, `function serial_cleanup`, `function serial_port_activate`, `function serial_open`, `function serial_port_shutdown`.
- Atlas domain: Driver Families / drivers/usb.
- Implementation status: integration implementation candidate.
- Synchronization appears in or near this file; preserve lock ordering, sleepability, and interrupt-context constraints.
Implementation Notes
- This generated page is the file-by-file coverage layer; curated subsystem chapters should link here when they synthesize a multi-file control flow.
- Core OS pages should be promoted from atlas-only to deep-reviewed when they explain data structures, invariants, locking, lifecycle, and C implementation snippets.
- Driver-family pages are intentionally pattern-oriented unless they are part of the selected PCIe/NVMe representative device path.