Rev 3386 | Rev 4327 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 3386 | Rev 4153 | ||
|---|---|---|---|
| Line 62... | Line 62... | ||
| 62 | * For now, we don't distinguish between different dev_handles/instances. All |
62 | * For now, we don't distinguish between different dev_handles/instances. All |
| 63 | * requests resolve to the only instance, rooted in the following variable. |
63 | * requests resolve to the only instance, rooted in the following variable. |
| 64 | */ |
64 | */ |
| 65 | static tmpfs_dentry_t *root; |
65 | static tmpfs_dentry_t *root; |
| 66 | 66 | ||
| - | 67 | #define TMPFS_DEV 0 /**< Dummy device handle for TMPFS */ |
|
| - | 68 | ||
| 67 | /* |
69 | /* |
| 68 | * Implementation of the libfs interface. |
70 | * Implementation of the libfs interface. |
| 69 | */ |
71 | */ |
| 70 | 72 | ||
| 71 | /* Forward declarations of static functions. */ |
73 | /* Forward declarations of static functions. */ |
| 72 | static void *tmpfs_match(void *, const char *); |
74 | static void *tmpfs_match(void *, const char *); |
| 73 | static void *tmpfs_node_get(dev_handle_t, fs_index_t); |
75 | static void *tmpfs_node_get(dev_handle_t, fs_index_t); |
| 74 | static void tmpfs_node_put(void *); |
76 | static void tmpfs_node_put(void *); |
| 75 | static void *tmpfs_create_node(int); |
77 | static void *tmpfs_create_node(dev_handle_t, int); |
| 76 | static bool tmpfs_link_node(void *, void *, const char *); |
78 | static int tmpfs_link_node(void *, void *, const char *); |
| 77 | static int tmpfs_unlink_node(void *, void *); |
79 | static int tmpfs_unlink_node(void *, void *); |
| 78 | static int tmpfs_destroy_node(void *); |
80 | static int tmpfs_destroy_node(void *); |
| 79 | 81 | ||
| 80 | /* Implementation of helper functions. */ |
82 | /* Implementation of helper functions. */ |
| 81 | static fs_index_t tmpfs_index_get(void *nodep) |
83 | static fs_index_t tmpfs_index_get(void *nodep) |
| Line 226... | Line 228... | ||
| 226 | 228 | ||
| 227 | static bool tmpfs_init(void) |
229 | static bool tmpfs_init(void) |
| 228 | { |
230 | { |
| 229 | if (!hash_table_create(&dentries, DENTRIES_BUCKETS, 1, &dentries_ops)) |
231 | if (!hash_table_create(&dentries, DENTRIES_BUCKETS, 1, &dentries_ops)) |
| 230 | return false; |
232 | return false; |
| 231 | root = (tmpfs_dentry_t *) tmpfs_create_node(L_DIRECTORY); |
233 | root = (tmpfs_dentry_t *) tmpfs_create_node(TMPFS_DEV, L_DIRECTORY); |
| 232 | if (!root) { |
234 | if (!root) { |
| 233 | hash_table_destroy(&dentries); |
235 | hash_table_destroy(&dentries); |
| 234 | return false; |
236 | return false; |
| 235 | } |
237 | } |
| 236 | root->lnkcnt = 0; /* FS root is not linked */ |
238 | root->lnkcnt = 0; /* FS root is not linked */ |
| Line 280... | Line 282... | ||
| 280 | void tmpfs_node_put(void *node) |
282 | void tmpfs_node_put(void *node) |
| 281 | { |
283 | { |
| 282 | /* nothing to do */ |
284 | /* nothing to do */ |
| 283 | } |
285 | } |
| 284 | 286 | ||
| 285 | void *tmpfs_create_node(int lflag) |
287 | void *tmpfs_create_node(dev_handle_t dev_handle, int lflag) |
| 286 | { |
288 | { |
| 287 | assert((lflag & L_FILE) ^ (lflag & L_DIRECTORY)); |
289 | assert((lflag & L_FILE) ^ (lflag & L_DIRECTORY)); |
| 288 | 290 | ||
| 289 | tmpfs_dentry_t *node = malloc(sizeof(tmpfs_dentry_t)); |
291 | tmpfs_dentry_t *node = malloc(sizeof(tmpfs_dentry_t)); |
| 290 | if (!node) |
292 | if (!node) |
| Line 304... | Line 306... | ||
| 304 | unsigned long key = node->index; |
306 | unsigned long key = node->index; |
| 305 | hash_table_insert(&dentries, &key, &node->dh_link); |
307 | hash_table_insert(&dentries, &key, &node->dh_link); |
| 306 | return (void *) node; |
308 | return (void *) node; |
| 307 | } |
309 | } |
| 308 | 310 | ||
| 309 | bool tmpfs_link_node(void *prnt, void *chld, const char *nm) |
311 | int tmpfs_link_node(void *prnt, void *chld, const char *nm) |
| 310 | { |
312 | { |
| 311 | tmpfs_dentry_t *parentp = (tmpfs_dentry_t *) prnt; |
313 | tmpfs_dentry_t *parentp = (tmpfs_dentry_t *) prnt; |
| 312 | tmpfs_dentry_t *childp = (tmpfs_dentry_t *) chld; |
314 | tmpfs_dentry_t *childp = (tmpfs_dentry_t *) chld; |
| 313 | 315 | ||
| 314 | assert(parentp->type == TMPFS_DIRECTORY); |
316 | assert(parentp->type == TMPFS_DIRECTORY); |
| 315 | 317 | ||
| 316 | tmpfs_name_t *namep = malloc(sizeof(tmpfs_name_t)); |
318 | tmpfs_name_t *namep = malloc(sizeof(tmpfs_name_t)); |
| 317 | if (!namep) |
319 | if (!namep) |
| 318 | return false; |
320 | return ENOMEM; |
| 319 | tmpfs_name_initialize(namep); |
321 | tmpfs_name_initialize(namep); |
| 320 | size_t len = strlen(nm); |
322 | size_t len = strlen(nm); |
| 321 | namep->name = malloc(len + 1); |
323 | namep->name = malloc(len + 1); |
| 322 | if (!namep->name) { |
324 | if (!namep->name) { |
| 323 | free(namep); |
325 | free(namep); |
| 324 | return false; |
326 | return ENOMEM; |
| 325 | } |
327 | } |
| 326 | strcpy(namep->name, nm); |
328 | strcpy(namep->name, nm); |
| 327 | namep->parent = parentp; |
329 | namep->parent = parentp; |
| 328 | 330 | ||
| 329 | childp->lnkcnt++; |
331 | childp->lnkcnt++; |
| Line 339... | Line 341... | ||
| 339 | tmp->sibling = childp; |
341 | tmp->sibling = childp; |
| 340 | } else { |
342 | } else { |
| 341 | parentp->child = childp; |
343 | parentp->child = childp; |
| 342 | } |
344 | } |
| 343 | 345 | ||
| 344 | return true; |
346 | return EOK; |
| 345 | } |
347 | } |
| 346 | 348 | ||
| 347 | int tmpfs_unlink_node(void *prnt, void *chld) |
349 | int tmpfs_unlink_node(void *prnt, void *chld) |
| 348 | { |
350 | { |
| 349 | tmpfs_dentry_t *parentp = (tmpfs_dentry_t *)prnt; |
351 | tmpfs_dentry_t *parentp = (tmpfs_dentry_t *)prnt; |