Rev 4327 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 4327 | Rev 4581 | ||
|---|---|---|---|
| Line 42... | Line 42... | ||
| 42 | #include <errno.h> |
42 | #include <errno.h> |
| 43 | #include <fcntl.h> |
43 | #include <fcntl.h> |
| 44 | #include <task.h> |
44 | #include <task.h> |
| 45 | #include <malloc.h> |
45 | #include <malloc.h> |
| 46 | #include <macros.h> |
46 | #include <macros.h> |
| 47 | #include <console.h> |
- | |
| 48 | #include <string.h> |
47 | #include <string.h> |
| - | 48 | #include <devmap.h> |
|
| 49 | #include "init.h" |
49 | #include "init.h" |
| 50 | #include "version.h" |
- | |
| 51 | 50 | ||
| - | 51 | static void info_print(void) |
|
| - | 52 | { |
|
| - | 53 | printf(NAME ": HelenOS init\n"); |
|
| - | 54 | } |
|
| - | 55 | ||
| 52 | static bool mount_fs(const char *fstype) |
56 | static bool mount_root(const char *fstype) |
| 53 | { |
57 | { |
| 54 | int rc = -1; |
58 | int rc = -1; |
| 55 | char *opts = ""; |
59 | char *opts = ""; |
| - | 60 | const char *root_dev = "initrd"; |
|
| 56 | 61 | ||
| 57 | if (str_cmp(fstype, "tmpfs") == 0) |
62 | if (str_cmp(fstype, "tmpfs") == 0) |
| 58 | opts = "restore"; |
63 | opts = "restore"; |
| 59 | 64 | ||
| 60 | while (rc < 0) { |
65 | while (rc < 0) { |
| 61 | rc = mount(fstype, "/", "initrd", opts, IPC_FLAG_BLOCKING); |
66 | rc = mount(fstype, "/", root_dev, opts, IPC_FLAG_BLOCKING); |
| 62 | 67 | ||
| 63 | switch (rc) { |
68 | switch (rc) { |
| 64 | case EOK: |
69 | case EOK: |
| 65 | printf(NAME ": Root filesystem mounted\n"); |
70 | printf(NAME ": Root filesystem mounted, %s at %s\n", |
| - | 71 | fstype, root_dev); |
|
| 66 | break; |
72 | break; |
| 67 | case EBUSY: |
73 | case EBUSY: |
| 68 | printf(NAME ": Root filesystem already mounted\n"); |
74 | printf(NAME ": Root filesystem already mounted\n"); |
| 69 | break; |
75 | break; |
| 70 | case ELIMIT: |
76 | case ELIMIT: |
| Line 77... | Line 83... | ||
| 77 | } |
83 | } |
| 78 | 84 | ||
| 79 | return true; |
85 | return true; |
| 80 | } |
86 | } |
| 81 | 87 | ||
| - | 88 | static bool mount_devfs(void) |
|
| - | 89 | { |
|
| - | 90 | int rc = -1; |
|
| - | 91 | ||
| - | 92 | while (rc < 0) { |
|
| - | 93 | rc = mount("devfs", "/dev", "null", "", IPC_FLAG_BLOCKING); |
|
| - | 94 | ||
| - | 95 | switch (rc) { |
|
| - | 96 | case EOK: |
|
| - | 97 | printf(NAME ": Device filesystem mounted\n"); |
|
| - | 98 | break; |
|
| - | 99 | case EBUSY: |
|
| - | 100 | printf(NAME ": Device filesystem already mounted\n"); |
|
| - | 101 | break; |
|
| - | 102 | case ELIMIT: |
|
| - | 103 | printf(NAME ": Unable to mount device filesystem\n"); |
|
| - | 104 | return false; |
|
| - | 105 | case ENOENT: |
|
| - | 106 | printf(NAME ": Unknown filesystem type (devfs)\n"); |
|
| - | 107 | return false; |
|
| - | 108 | } |
|
| - | 109 | } |
|
| - | 110 | ||
| - | 111 | return true; |
|
| - | 112 | } |
|
| - | 113 | ||
| 82 | static void spawn(char *fname) |
114 | static void spawn(char *fname) |
| 83 | { |
115 | { |
| 84 | char *argv[2]; |
116 | char *argv[2]; |
| 85 | 117 | ||
| 86 | printf(NAME ": Spawning %s\n", fname); |
118 | printf(NAME ": Spawning %s\n", fname); |
| Line 90... | Line 122... | ||
| 90 | 122 | ||
| 91 | if (!task_spawn(fname, argv)) |
123 | if (!task_spawn(fname, argv)) |
| 92 | printf(NAME ": Error spawning %s\n", fname); |
124 | printf(NAME ": Error spawning %s\n", fname); |
| 93 | } |
125 | } |
| 94 | 126 | ||
| - | 127 | static void getvc(char *dev, char *app) |
|
| - | 128 | { |
|
| - | 129 | char *argv[4]; |
|
| - | 130 | char vc[MAX_DEVICE_NAME]; |
|
| - | 131 | int rc; |
|
| - | 132 | ||
| - | 133 | snprintf(vc, MAX_DEVICE_NAME, "/dev/%s", dev); |
|
| - | 134 | ||
| - | 135 | printf(NAME ": Spawning getvc on %s\n", vc); |
|
| - | 136 | ||
| - | 137 | dev_handle_t handle; |
|
| - | 138 | rc = devmap_device_get_handle(dev, &handle, IPC_FLAG_BLOCKING); |
|
| - | 139 | ||
| - | 140 | if (rc == EOK) { |
|
| - | 141 | argv[0] = "/app/getvc"; |
|
| - | 142 | argv[1] = vc; |
|
| - | 143 | argv[2] = app; |
|
| - | 144 | argv[3] = NULL; |
|
| - | 145 | ||
| - | 146 | if (!task_spawn("/app/getvc", argv)) |
|
| - | 147 | printf(NAME ": Error spawning getvc on %s\n", vc); |
|
| - | 148 | } else { |
|
| - | 149 | printf(NAME ": Error waiting on %s\n", vc); |
|
| - | 150 | } |
|
| - | 151 | } |
|
| - | 152 | ||
| - | 153 | void mount_data(void) |
|
| - | 154 | { |
|
| - | 155 | int rc; |
|
| - | 156 | ||
| - | 157 | printf("Trying to mount disk0 on /data... "); |
|
| - | 158 | fflush(stdout); |
|
| - | 159 | ||
| - | 160 | rc = mount("fat", "/data", "disk0", "wtcache", 0); |
|
| - | 161 | if (rc == EOK) |
|
| - | 162 | printf("OK\n"); |
|
| - | 163 | else |
|
| - | 164 | printf("Failed\n"); |
|
| - | 165 | } |
|
| - | 166 | ||
| 95 | int main(int argc, char *argv[]) |
167 | int main(int argc, char *argv[]) |
| 96 | { |
168 | { |
| 97 | info_print(); |
169 | info_print(); |
| 98 | 170 | ||
| 99 | if (!mount_fs(STRING(RDFMT))) { |
171 | if (!mount_root(STRING(RDFMT))) { |
| 100 | printf(NAME ": Exiting\n"); |
172 | printf(NAME ": Exiting\n"); |
| 101 | return -1; |
173 | return -1; |
| 102 | } |
174 | } |
| 103 | 175 | ||
| 104 | // FIXME: spawn("/srv/pci"); |
176 | spawn("/srv/devfs"); |
| - | 177 | ||
| - | 178 | if (!mount_devfs()) { |
|
| - | 179 | printf(NAME ": Exiting\n"); |
|
| - | 180 | return -2; |
|
| - | 181 | } |
|
| - | 182 | ||
| 105 | spawn("/srv/fb"); |
183 | spawn("/srv/fb"); |
| 106 | spawn("/srv/kbd"); |
184 | spawn("/srv/kbd"); |
| 107 | // spawn("/srv/netstart"); |
185 | // spawn("/srv/netstart"); |
| 108 | spawn("/srv/console"); |
186 | spawn("/srv/console"); |
| 109 | spawn("/srv/fhc"); |
187 | spawn("/srv/fhc"); |
| 110 | spawn("/srv/obio"); |
188 | spawn("/srv/obio"); |
| - | 189 | spawn("/srv/ata_bd"); |
|
| - | 190 | spawn("/srv/gxe_bd"); |
|
| 111 | 191 | ||
| 112 | console_wait(); |
192 | usleep(250000); |
| 113 | version_print(); |
193 | mount_data(); |
| 114 | 194 | ||
| - | 195 | getvc("vc0", "/app/bdsh"); |
|
| - | 196 | getvc("vc1", "/app/bdsh"); |
|
| - | 197 | getvc("vc2", "/app/bdsh"); |
|
| - | 198 | getvc("vc3", "/app/bdsh"); |
|
| 115 | spawn("/app/klog"); |
199 | getvc("vc4", "/app/bdsh"); |
| 116 | spawn("/app/bdsh"); |
200 | getvc("vc5", "/app/bdsh"); |
| - | 201 | getvc("vc6", "/app/klog"); |
|
| 117 | 202 | ||
| 118 | return 0; |
203 | return 0; |
| 119 | } |
204 | } |
| 120 | 205 | ||
| 121 | /** @} |
206 | /** @} |