Changes in uspace/app/init/init.c [cc1f8d4:9f51afc] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/app/init/init.c
rcc1f8d4 r9f51afc 50 50 #include "init.h" 51 51 52 #define DEVFS_MOUNT_POINT "/dev" 53 54 #define SRV_CONSOLE "/srv/console" 55 #define APP_GETTERM "/app/getterm" 56 52 57 static void info_print(void) 53 58 { … … 58 63 { 59 64 char *opts = ""; 60 const char *root_dev = " initrd";65 const char *root_dev = "bd/initrd"; 61 66 62 67 if (str_cmp(fstype, "tmpfs") == 0) … … 97 102 } 98 103 99 snprintf(null, MAX_DEVICE_NAME, "null %d", null_id);100 int rc = mount("devfs", "/dev", null, "", IPC_FLAG_BLOCKING);104 snprintf(null, MAX_DEVICE_NAME, "null/%d", null_id); 105 int rc = mount("devfs", DEVFS_MOUNT_POINT, null, "", IPC_FLAG_BLOCKING); 101 106 102 107 switch (rc) { … … 170 175 } 171 176 172 if ( texit != TASK_EXIT_NORMAL || retval != 0) {177 if ((texit != TASK_EXIT_NORMAL) || (retval != 0)) { 173 178 printf(NAME ": Server %s failed to start (returned %d)\n", 174 179 fname, retval); … … 176 181 } 177 182 178 static void getvc(char *dev, char *app)179 { 180 char *argv[ 4];181 char vc[MAX_DEVICE_NAME];183 static void console(char *dev) 184 { 185 char *argv[3]; 186 char hid_in[MAX_DEVICE_NAME]; 182 187 int rc; 183 188 184 snprintf(vc, MAX_DEVICE_NAME, "/dev/%s", dev); 185 186 printf(NAME ": Spawning getvc on %s\n", vc); 187 189 snprintf(hid_in, MAX_DEVICE_NAME, "%s/%s", DEVFS_MOUNT_POINT, dev); 190 191 printf(NAME ": Spawning %s with %s\n", SRV_CONSOLE, hid_in); 192 193 /* Wait for the input device to be ready */ 188 194 dev_handle_t handle; 189 195 rc = devmap_device_get_handle(dev, &handle, IPC_FLAG_BLOCKING); 190 196 191 197 if (rc == EOK) { 192 argv[0] = "/app/getvc"; 193 argv[1] = vc; 198 argv[0] = SRV_CONSOLE; 199 argv[1] = hid_in; 200 argv[2] = NULL; 201 202 if (!task_spawn(SRV_CONSOLE, argv)) 203 printf(NAME ": Error spawning %s with %s\n", SRV_CONSOLE, hid_in); 204 } else 205 printf(NAME ": Error waiting on %s\n", hid_in); 206 } 207 208 static void getterm(char *dev, char *app) 209 { 210 char *argv[4]; 211 char term[MAX_DEVICE_NAME]; 212 int rc; 213 214 snprintf(term, MAX_DEVICE_NAME, "%s/%s", DEVFS_MOUNT_POINT, dev); 215 216 printf(NAME ": Spawning %s with %s %s\n", APP_GETTERM, term, app); 217 218 /* Wait for the terminal device to be ready */ 219 dev_handle_t handle; 220 rc = devmap_device_get_handle(dev, &handle, IPC_FLAG_BLOCKING); 221 222 if (rc == EOK) { 223 argv[0] = APP_GETTERM; 224 argv[1] = term; 194 225 argv[2] = app; 195 226 argv[3] = NULL; 196 227 197 if (!task_spawn( "/app/getvc", argv))198 printf(NAME ": Error spawning getvc on %s\n", vc);199 } else {200 printf(NAME ": Error waiting on %s\n", vc);201 }228 if (!task_spawn(APP_GETTERM, argv)) 229 printf(NAME ": Error spawning %s with %s %s\n", APP_GETTERM, 230 term, app); 231 } else 232 printf(NAME ": Error waiting on %s\n", term); 202 233 } 203 234 … … 206 237 int rc; 207 238 208 printf("Trying to mount disk0 on /data... ");239 printf("Trying to mount bd/disk0 on /data... "); 209 240 fflush(stdout); 210 241 211 rc = mount("fat", "/data", " disk0", "wtcache", 0);242 rc = mount("fat", "/data", "bd/disk0", "wtcache", 0); 212 243 if (rc == EOK) 213 244 printf("OK\n"); … … 232 263 } 233 264 265 spawn("/srv/fhc"); 266 spawn("/srv/obio"); 267 srv_start("/srv/i8042"); 268 srv_start("/srv/c_mouse"); 269 234 270 spawn("/srv/fb"); 235 271 spawn("/srv/kbd"); 236 spawn("/srv/console");237 spawn("/srv/fhc");238 spawn("/srv/ obio");272 console("hid_in/kbd"); 273 274 spawn("/srv/clip"); 239 275 240 276 /* … … 255 291 #endif 256 292 257 get vc("vc0", "/app/bdsh");258 get vc("vc1", "/app/bdsh");259 get vc("vc2", "/app/bdsh");260 get vc("vc3", "/app/bdsh");261 get vc("vc4", "/app/bdsh");262 get vc("vc5", "/app/bdsh");263 get vc("vc6", "/app/klog");293 getterm("term/vc0", "/app/bdsh"); 294 getterm("term/vc1", "/app/bdsh"); 295 getterm("term/vc2", "/app/bdsh"); 296 getterm("term/vc3", "/app/bdsh"); 297 getterm("term/vc4", "/app/bdsh"); 298 getterm("term/vc5", "/app/bdsh"); 299 getterm("term/vc6", "/app/klog"); 264 300 265 301 return 0;
Note:
See TracChangeset
for help on using the changeset viewer.