summaryrefslogtreecommitdiffstats
path: root/config.c
diff options
context:
space:
mode:
authorNeil Brown <neilb@suse.de>2003-02-12 01:17:26 +0100
committerNeil Brown <neilb@suse.de>2003-02-12 01:17:26 +0100
commit5787fa490612387a43c1897eb807b0c5612b5cd2 (patch)
tree7e126aef2e93da5052aa8c47128abb663e446e06 /config.c
parentmdadm-1.0.1 (diff)
downloadmdadm-5787fa490612387a43c1897eb807b0c5612b5cd2.tar.xz
mdadm-5787fa490612387a43c1897eb807b0c5612b5cd2.zip
mdadm-1.0.9mdadm-1.0.9
Diffstat (limited to 'config.c')
-rw-r--r--config.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/config.c b/config.c
index eef32480..1f252449 100644
--- a/config.c
+++ b/config.c
@@ -201,6 +201,33 @@ struct conf_dev {
char *name;
} *cdevlist = NULL;
+void load_partitions(void)
+{
+ FILE *f = fopen("/proc/partitions", "r");
+ char buf[1024];
+ if (f == NULL) {
+ fprintf(stderr, Name ": cannot open /proc/partitions\n");
+ return;
+ }
+ while (fgets(buf, 1024, f)) {
+ int major, minor;
+ char *name;
+ buf[1023] = '\0';
+ if (buf[0] != ' ')
+ continue;
+ if (sscanf(buf, " %d %d ", &major, &minor) != 2)
+ continue;
+ name = map_dev(major, minor);
+ if (name) {
+ struct conf_dev *cd;
+
+ cd = malloc(sizeof(*cd));
+ cd->name = strdup(name);
+ cd->next = cdevlist;
+ cdevlist = cd;
+ }
+ }
+}
void devline(char *line)
@@ -214,6 +241,9 @@ void devline(char *line)
cd->name = strdup(w);
cd->next = cdevlist;
cdevlist = cd;
+ } else if (strcasecmp(w, "partitions") == 0) {
+ /* read /proc/partitions, and look major/minor up in /dev */
+ load_partitions();
} else {
fprintf(stderr, Name ": unreconised word on DEVICE line: %s\n",
w);
@@ -349,6 +379,10 @@ void load_conffile(char *conffile)
if (conffile == NULL)
conffile = DefaultConfFile;
+ if (strcmp(conffile, "partitions")==0) {
+ load_partitions();
+ return;
+ }
f = fopen(conffile, "r");
if (f ==NULL)
return;