drivers/input/mouse/psmouse-smbus.c
Source file repositories/reference/linux-study-clean/drivers/input/mouse/psmouse-smbus.c
File Facts
- System
- Linux kernel
- Corpus path
drivers/input/mouse/psmouse-smbus.c- Extension
.c- Size
- 7954 bytes
- Lines
- 321
- Domain
- Driver Families
- Bucket
- drivers/input
- 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.
- 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/module.hlinux/libps2.hlinux/i2c.hlinux/serio.hlinux/slab.hlinux/workqueue.hpsmouse.h
Detected Declarations
struct psmouse_smbus_devstruct psmouse_smbus_removal_workfunction psmouse_smbus_check_adapterfunction list_for_each_entryfunction psmouse_smbus_detach_i2c_clientfunction list_for_each_entry_safefunction psmouse_smbus_notifier_callfunction psmouse_smbus_process_bytefunction psmouse_smbus_reconnectfunction psmouse_smbus_remove_i2c_devicefunction trackstickfunction psmouse_smbus_disconnectfunction psmouse_smbus_create_companionfunction psmouse_smbus_cleanupfunction list_for_each_entry_safefunction psmouse_smbus_initfunction scoped_guardfunction psmouse_smbus_module_initfunction psmouse_smbus_module_exit
Annotated Snippet
struct psmouse_smbus_dev {
struct i2c_board_info board;
struct psmouse *psmouse;
struct i2c_client *client;
struct list_head node;
bool dead;
bool need_deactivate;
};
static LIST_HEAD(psmouse_smbus_list);
static DEFINE_MUTEX(psmouse_smbus_mutex);
static struct workqueue_struct *psmouse_smbus_wq;
static void psmouse_smbus_check_adapter(struct i2c_adapter *adapter)
{
struct psmouse_smbus_dev *smbdev;
if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_HOST_NOTIFY))
return;
guard(mutex)(&psmouse_smbus_mutex);
list_for_each_entry(smbdev, &psmouse_smbus_list, node) {
if (smbdev->dead)
continue;
if (smbdev->client)
continue;
/*
* Here would be a good place to check if device is actually
* present, but it seems that SMBus will not respond unless we
* fully reset PS/2 connection. So cross our fingers, and try
* to switch over, hopefully our system will not have too many
* "host notify" I2C adapters.
*/
psmouse_dbg(smbdev->psmouse,
"SMBus candidate adapter appeared, triggering rescan\n");
serio_rescan(smbdev->psmouse->ps2dev.serio);
}
}
static void psmouse_smbus_detach_i2c_client(struct i2c_client *client)
{
struct psmouse_smbus_dev *smbdev, *tmp;
guard(mutex)(&psmouse_smbus_mutex);
list_for_each_entry_safe(smbdev, tmp, &psmouse_smbus_list, node) {
if (smbdev->client != client)
continue;
kfree(client->dev.platform_data);
client->dev.platform_data = NULL;
if (!smbdev->dead) {
psmouse_dbg(smbdev->psmouse,
"Marking SMBus companion %s as gone\n",
dev_name(&smbdev->client->dev));
smbdev->dead = true;
device_link_remove(&smbdev->client->dev,
&smbdev->psmouse->ps2dev.serio->dev);
serio_rescan(smbdev->psmouse->ps2dev.serio);
} else {
list_del(&smbdev->node);
kfree(smbdev);
}
}
}
static int psmouse_smbus_notifier_call(struct notifier_block *nb,
unsigned long action, void *data)
{
struct device *dev = data;
switch (action) {
case BUS_NOTIFY_ADD_DEVICE:
if (dev->type == &i2c_adapter_type)
psmouse_smbus_check_adapter(to_i2c_adapter(dev));
break;
case BUS_NOTIFY_REMOVED_DEVICE:
if (dev->type == &i2c_client_type)
psmouse_smbus_detach_i2c_client(to_i2c_client(dev));
break;
}
return 0;
}
Annotation
- Immediate include surface: `linux/kernel.h`, `linux/module.h`, `linux/libps2.h`, `linux/i2c.h`, `linux/serio.h`, `linux/slab.h`, `linux/workqueue.h`, `psmouse.h`.
- Detected declarations: `struct psmouse_smbus_dev`, `struct psmouse_smbus_removal_work`, `function psmouse_smbus_check_adapter`, `function list_for_each_entry`, `function psmouse_smbus_detach_i2c_client`, `function list_for_each_entry_safe`, `function psmouse_smbus_notifier_call`, `function psmouse_smbus_process_byte`, `function psmouse_smbus_reconnect`, `function psmouse_smbus_remove_i2c_device`.
- Atlas domain: Driver Families / drivers/input.
- Implementation status: integration implementation candidate.
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.