Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 70739
b: refs/heads/master
c: 4d936ec
h: refs/heads/master
i:
  70737: 03801be
  70735: c33e559
v: v3
  • Loading branch information
Michael J. Evans authored and Linus Torvalds committed Oct 17, 2007
1 parent b43fe41 commit f28fa6f
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 10 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a686cd898bd999fd026a51e90fb0a3410d258ddb
refs/heads/master: 4d936ec1fdc1541cd6d59d21ddb8b9386e2fcc4c
42 changes: 33 additions & 9 deletions trunk/drivers/md/md.c
Original file line number Diff line number Diff line change
Expand Up @@ -5770,26 +5770,47 @@ static int __init md_init(void)
* Searches all registered partitions for autorun RAID arrays
* at boot time.
*/
static dev_t detected_devices[128];
static int dev_cnt;

static LIST_HEAD(all_detected_devices);
struct detected_devices_node {
struct list_head list;
dev_t dev;
};

void md_autodetect_dev(dev_t dev)
{
if (dev_cnt >= 0 && dev_cnt < 127)
detected_devices[dev_cnt++] = dev;
struct detected_devices_node *node_detected_dev;

node_detected_dev = kzalloc(sizeof(*node_detected_dev), GFP_KERNEL);
if (node_detected_dev) {
node_detected_dev->dev = dev;
list_add_tail(&node_detected_dev->list, &all_detected_devices);
} else {
printk(KERN_CRIT "md: md_autodetect_dev: kzalloc failed"
", skipping dev(%d,%d)\n", MAJOR(dev), MINOR(dev));
}
}


static void autostart_arrays(int part)
{
mdk_rdev_t *rdev;
int i;
struct detected_devices_node *node_detected_dev;
dev_t dev;
int i_scanned, i_passed;

printk(KERN_INFO "md: Autodetecting RAID arrays.\n");
i_scanned = 0;
i_passed = 0;

for (i = 0; i < dev_cnt; i++) {
dev_t dev = detected_devices[i];
printk(KERN_INFO "md: Autodetecting RAID arrays.\n");

while (!list_empty(&all_detected_devices) && i_scanned < INT_MAX) {
i_scanned++;
node_detected_dev = list_entry(all_detected_devices.next,
struct detected_devices_node, list);
list_del(&node_detected_dev->list);
dev = node_detected_dev->dev;
kfree(node_detected_dev);
rdev = md_import_device(dev,0, 90);
if (IS_ERR(rdev))
continue;
Expand All @@ -5799,8 +5820,11 @@ static void autostart_arrays(int part)
continue;
}
list_add(&rdev->same_set, &pending_raid_disks);
i_passed++;
}
dev_cnt = 0;

printk(KERN_INFO "md: Scanned %d and added %d devices.\n",
i_scanned, i_passed);

autorun_devices(part);
}
Expand Down

0 comments on commit f28fa6f

Please sign in to comment.