vold2: Add block device udev bootstrapping
Signed-off-by: San Mehat <san@android.com>
diff --git a/main.cpp b/main.cpp
index 1ccd147..ba8c33d 100644
--- a/main.cpp
+++ b/main.cpp
@@ -18,6 +18,11 @@
#include <stdlib.h>
#include <errno.h>
#include <string.h>
+#include <sys/stat.h>
+#include <sys/types.h>
+
+#include <fcntl.h>
+#include <dirent.h>
#define LOG_TAG "Vold"
@@ -29,6 +34,7 @@
#include "DeviceVolume.h"
static int process_config(VolumeManager *vm);
+static void coldboot(const char *path);
int main() {
@@ -68,6 +74,8 @@
exit(1);
}
+ coldboot("/sys/block");
+
/*
* Now that we're up, we can respond to commands
*/
@@ -85,6 +93,51 @@
exit(0);
}
+static void do_coldboot(DIR *d, int lvl)
+{
+ struct dirent *de;
+ int dfd, fd;
+
+ dfd = dirfd(d);
+
+ fd = openat(dfd, "uevent", O_WRONLY);
+ if(fd >= 0) {
+ write(fd, "add\n", 4);
+ close(fd);
+ }
+
+ while((de = readdir(d))) {
+ DIR *d2;
+
+ if (de->d_name[0] == '.')
+ continue;
+
+ if (de->d_type != DT_DIR && lvl > 0)
+ continue;
+
+ fd = openat(dfd, de->d_name, O_RDONLY | O_DIRECTORY);
+ if(fd < 0)
+ continue;
+
+ d2 = fdopendir(fd);
+ if(d2 == 0)
+ close(fd);
+ else {
+ do_coldboot(d2, lvl + 1);
+ closedir(d2);
+ }
+ }
+}
+
+static void coldboot(const char *path)
+{
+ DIR *d = opendir(path);
+ if(d) {
+ do_coldboot(d, 0);
+ closedir(d);
+ }
+}
+
static int process_config(VolumeManager *vm) {
FILE *fp;
int n = 0;