From: =?utf-8?q?Kristian_H=C3=B8gsberg?= Subject: [PATCH 9/11] firewire: Use atomic_t's for serial numbers. Date: Tue, 6 Feb 2007 14:49:38 -0500 Signed-off-by: Kristian Høgsberg Use atomic_inc_return. Signed-off-by: Stefan Richter Index: linux-2.6.20/drivers/firewire/fw-card.c =================================================================== --- linux-2.6.20.orig/drivers/firewire/fw-card.c +++ linux-2.6.20/drivers/firewire/fw-card.c @@ -367,9 +367,9 @@ void fw_card_initialize(struct fw_card *card, const struct fw_card_driver *driver, struct device *device) { - static int index; + static atomic_t index = ATOMIC_INIT(-1); - card->index = index++; + card->index = atomic_inc_return(&index); card->driver = driver; card->device = device; card->current_tlabel = 0; Index: linux-2.6.20/drivers/firewire/fw-device.c =================================================================== --- linux-2.6.20.orig/drivers/firewire/fw-device.c +++ linux-2.6.20/drivers/firewire/fw-device.c @@ -434,7 +434,7 @@ static void fw_device_shutdown(struct wo static void fw_device_init(struct work_struct *work) { - static int serial; + static atomic_t serial = ATOMIC_INIT(-1); struct fw_device *device = container_of(work, struct fw_device, work.work); @@ -460,7 +460,7 @@ static void fw_device_init(struct work_s device->device.release = fw_device_release; device->device.parent = device->card->device; snprintf(device->device.bus_id, sizeof device->device.bus_id, - "fw%d", serial++); + "fw%d", atomic_inc_return(&serial)); if (alloc_chrdev_region(&device->device.devt, 0, 1, "fw")) { fw_error("Failed to register char device region.\n");