Changes in uspace/srv/vfs/vfs_ops.c [27b76ca:e6da6d5] in mainline
- File:
-
- 1 edited
-
uspace/srv/vfs/vfs_ops.c (modified) (37 diffs)
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/vfs/vfs_ops.c
r27b76ca re6da6d5 52 52 #include <assert.h> 53 53 #include <vfs/canonify.h> 54 #include <vfs/vfs_mtab.h> 55 56 FIBRIL_MUTEX_INITIALIZE(mtab_list_lock); 57 LIST_INITIALIZE(mtab_list); 58 static size_t mtab_size = 0; 54 59 55 60 /* Forward declarations of static functions. */ 56 static int vfs_truncate_internal(fs_handle_t, devmap_handle_t, fs_index_t,61 static int vfs_truncate_internal(fs_handle_t, service_id_t, fs_index_t, 57 62 aoff64_t); 58 63 … … 65 70 vfs_pair_t rootfs = { 66 71 .fs_handle = 0, 67 . devmap_handle= 072 .service_id = 0 68 73 }; 69 74 70 static void vfs_mount_internal(ipc_callid_t rid, devmap_handle_t devmap_handle,75 static int vfs_mount_internal(ipc_callid_t rid, service_id_t service_id, 71 76 fs_handle_t fs_handle, char *mp, char *opts) 72 77 { … … 91 96 fibril_rwlock_write_unlock(&namespace_rwlock); 92 97 async_answer_0(rid, EBUSY); 93 return ;98 return EBUSY; 94 99 } 95 100 … … 99 104 fibril_rwlock_write_unlock(&namespace_rwlock); 100 105 async_answer_0(rid, rc); 101 return ;106 return rc; 102 107 } 103 108 … … 106 111 fibril_rwlock_write_unlock(&namespace_rwlock); 107 112 async_answer_0(rid, ENOMEM); 108 return ;113 return ENOMEM; 109 114 } 110 115 … … 125 130 exch = vfs_exchange_grab(fs_handle); 126 131 msg = async_send_1(exch, VFS_OUT_MOUNTED, 127 (sysarg_t) devmap_handle, &answer);132 (sysarg_t) service_id, &answer); 128 133 /* Send the mount options */ 129 134 rc = async_data_write_start(exch, (void *)opts, … … 135 140 fibril_rwlock_write_unlock(&namespace_rwlock); 136 141 async_answer_0(rid, rc); 137 return ;142 return rc; 138 143 } 139 144 async_wait_for(msg, &rc); … … 142 147 fibril_rwlock_write_unlock(&namespace_rwlock); 143 148 async_answer_0(rid, rc); 144 return ;149 return rc; 145 150 } 146 151 147 152 rindex = (fs_index_t) IPC_GET_ARG1(answer); 148 rsize = (aoff64_t) MERGE_LOUP32(IPC_GET_ARG2(answer), IPC_GET_ARG3(answer)); 153 rsize = (aoff64_t) MERGE_LOUP32(IPC_GET_ARG2(answer), 154 IPC_GET_ARG3(answer)); 149 155 rlnkcnt = (unsigned) IPC_GET_ARG4(answer); 150 156 151 157 mr_res.triplet.fs_handle = fs_handle; 152 mr_res.triplet. devmap_handle = devmap_handle;158 mr_res.triplet.service_id = service_id; 153 159 mr_res.triplet.index = rindex; 154 160 mr_res.size = rsize; … … 157 163 158 164 rootfs.fs_handle = fs_handle; 159 rootfs. devmap_handle = devmap_handle;165 rootfs.service_id = service_id; 160 166 161 167 /* Add reference to the mounted root. */ … … 165 171 fibril_rwlock_write_unlock(&namespace_rwlock); 166 172 async_answer_0(rid, rc); 167 return ;173 return rc; 168 174 } else { 169 175 /* … … 173 179 fibril_rwlock_write_unlock(&namespace_rwlock); 174 180 async_answer_0(rid, ENOENT); 175 return ;176 } 177 } 178 179 /* 180 * At this point, we have all necessary pieces: file system and device181 * handles, and we know the mount point VFS node.181 return ENOENT; 182 } 183 } 184 185 /* 186 * At this point, we have all necessary pieces: file system handle 187 * and service ID, and we know the mount point VFS node. 182 188 */ 183 189 … … 187 193 exch = vfs_exchange_grab(mp_res.triplet.fs_handle); 188 194 msg = async_send_4(exch, VFS_OUT_MOUNT, 189 (sysarg_t) mp_res.triplet. devmap_handle,195 (sysarg_t) mp_res.triplet.service_id, 190 196 (sysarg_t) mp_res.triplet.index, 191 197 (sysarg_t) fs_handle, 192 (sysarg_t) devmap_handle, &answer);198 (sysarg_t) service_id, &answer); 193 199 194 200 /* Send connection */ … … 206 212 async_answer_0(rid, rc); 207 213 fibril_rwlock_write_unlock(&namespace_rwlock); 208 return ;214 return rc; 209 215 } 210 216 … … 221 227 fibril_rwlock_write_unlock(&namespace_rwlock); 222 228 async_answer_0(rid, rc); 223 return; 224 } 225 229 return rc; 230 } 231 232 /* 233 * Wait for the answer before releasing the exchange to avoid deadlock 234 * in case the answer depends on further calls to the same file system. 235 * Think of a case when mounting a FS on a file_bd backed by a file on 236 * the same FS. 237 */ 238 async_wait_for(msg, &rc); 226 239 vfs_exchange_release(exch); 227 async_wait_for(msg, &rc);228 240 229 241 if (rc == EOK) { … … 234 246 235 247 mr_res.triplet.fs_handle = fs_handle; 236 mr_res.triplet. devmap_handle = devmap_handle;248 mr_res.triplet.service_id = service_id; 237 249 mr_res.triplet.index = rindex; 238 250 mr_res.size = rsize; … … 251 263 async_answer_0(rid, rc); 252 264 fibril_rwlock_write_unlock(&namespace_rwlock); 265 return rc; 253 266 } 254 267 255 268 void vfs_mount(ipc_callid_t rid, ipc_call_t *request) 256 269 { 257 devmap_handle_t devmap_handle;270 service_id_t service_id; 258 271 259 272 /* … … 262 275 * in the request. 263 276 */ 264 devmap_handle = (devmap_handle_t) IPC_GET_ARG1(*request);277 service_id = (service_id_t) IPC_GET_ARG1(*request); 265 278 266 279 /* … … 270 283 271 284 /* 272 * For now, don't make use of ARG3, but it can be used to273 * carry mount options in the future.274 */275 285 * Instance number is passed as ARG3. 286 */ 287 unsigned int instance = IPC_GET_ARG3(*request); 288 276 289 /* We want the client to send us the mount point. */ 277 290 char *mp; … … 329 342 fs_handle_t fs_handle; 330 343 recheck: 331 fs_handle = fs_name_to_handle( fs_name, false);344 fs_handle = fs_name_to_handle(instance, fs_name, false); 332 345 if (!fs_handle) { 333 346 if (flags & IPC_FLAG_BLOCKING) { … … 345 358 } 346 359 fibril_mutex_unlock(&fs_list_lock); 347 348 /* Acknowledge that we know fs_name. */ 349 async_answer_0(callid, EOK); 350 360 361 /* Add the filesystem info to the list of mounted filesystems */ 362 mtab_ent_t *mtab_ent = malloc(sizeof(mtab_ent_t)); 363 if (!mtab_ent) { 364 async_answer_0(callid, ENOMEM); 365 async_answer_0(rid, ENOMEM); 366 free(mp); 367 free(fs_name); 368 free(opts); 369 return; 370 } 371 351 372 /* Do the mount */ 352 vfs_mount_internal(rid, devmap_handle, fs_handle, mp, opts); 373 rc = vfs_mount_internal(rid, service_id, fs_handle, mp, opts); 374 if (rc != EOK) { 375 async_answer_0(callid, ENOTSUP); 376 async_answer_0(rid, ENOTSUP); 377 free(mtab_ent); 378 free(mp); 379 free(opts); 380 free(fs_name); 381 return; 382 } 383 384 /* Add the filesystem info to the list of mounted filesystems */ 385 386 str_cpy(mtab_ent->mp, MAX_PATH_LEN, mp); 387 str_cpy(mtab_ent->fs_name, FS_NAME_MAXLEN, fs_name); 388 str_cpy(mtab_ent->opts, MAX_MNTOPTS_LEN, opts); 389 mtab_ent->instance = instance; 390 mtab_ent->service_id = service_id; 391 392 link_initialize(&mtab_ent->link); 393 394 fibril_mutex_lock(&mtab_list_lock); 395 list_append(&mtab_ent->link, &mtab_list); 396 mtab_size++; 397 fibril_mutex_unlock(&mtab_list_lock); 398 353 399 free(mp); 354 400 free(fs_name); 355 401 free(opts); 402 403 /* Acknowledge that we know fs_name. */ 404 async_answer_0(callid, EOK); 356 405 } 357 406 … … 409 458 */ 410 459 if (vfs_nodes_refcount_sum_get(mr_node->fs_handle, 411 mr_node-> devmap_handle) != 2) {460 mr_node->service_id) != 2) { 412 461 fibril_rwlock_write_unlock(&namespace_rwlock); 413 462 vfs_node_put(mr_node); … … 426 475 */ 427 476 428 free(mp);429 430 477 exch = vfs_exchange_grab(mr_node->fs_handle); 431 478 rc = async_req_1_0(exch, VFS_OUT_UNMOUNTED, 432 mr_node-> devmap_handle);479 mr_node->service_id); 433 480 vfs_exchange_release(exch); 434 481 435 482 if (rc != EOK) { 436 483 fibril_rwlock_write_unlock(&namespace_rwlock); 484 free(mp); 437 485 vfs_node_put(mr_node); 438 486 async_answer_0(rid, rc); … … 441 489 442 490 rootfs.fs_handle = 0; 443 rootfs. devmap_handle= 0;491 rootfs.service_id = 0; 444 492 } else { 445 493 … … 452 500 453 501 rc = vfs_lookup_internal(mp, L_MP, &mp_res, NULL); 454 free(mp);455 502 if (rc != EOK) { 456 503 fibril_rwlock_write_unlock(&namespace_rwlock); 504 free(mp); 457 505 vfs_node_put(mr_node); 458 506 async_answer_0(rid, rc); … … 463 511 if (!mp_node) { 464 512 fibril_rwlock_write_unlock(&namespace_rwlock); 513 free(mp); 465 514 vfs_node_put(mr_node); 466 515 async_answer_0(rid, ENOMEM); … … 470 519 exch = vfs_exchange_grab(mp_node->fs_handle); 471 520 rc = async_req_2_0(exch, VFS_OUT_UNMOUNT, 472 mp_node-> devmap_handle, mp_node->index);521 mp_node->service_id, mp_node->index); 473 522 vfs_exchange_release(exch); 474 523 475 524 if (rc != EOK) { 476 525 fibril_rwlock_write_unlock(&namespace_rwlock); 526 free(mp); 477 527 vfs_node_put(mp_node); 478 528 vfs_node_put(mr_node); … … 492 542 */ 493 543 vfs_node_forget(mr_node); 494 495 544 fibril_rwlock_write_unlock(&namespace_rwlock); 545 546 fibril_mutex_lock(&mtab_list_lock); 547 548 int found = 0; 549 550 list_foreach(mtab_list, cur) { 551 mtab_ent_t *mtab_ent = list_get_instance(cur, mtab_ent_t, 552 link); 553 554 if (str_cmp(mtab_ent->mp, mp) == 0) { 555 list_remove(&mtab_ent->link); 556 mtab_size--; 557 free(mtab_ent); 558 found = 1; 559 break; 560 } 561 } 562 assert(found); 563 fibril_mutex_unlock(&mtab_list_lock); 564 565 free(mp); 566 496 567 async_answer_0(rid, EOK); 497 568 } … … 575 646 if (node->size) { 576 647 rc = vfs_truncate_internal(node->fs_handle, 577 node-> devmap_handle, node->index, 0);648 node->service_id, node->index, 0); 578 649 if (rc) { 579 650 fibril_rwlock_write_unlock(&node->contents_rwlock); … … 639 710 aid_t msg; 640 711 ipc_call_t answer; 641 msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node-> devmap_handle,712 msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node->service_id, 642 713 file->node->index, &answer); 643 714 … … 724 795 if (read) { 725 796 rc = async_data_read_forward_4_1(fs_exch, VFS_OUT_READ, 726 file->node-> devmap_handle, file->node->index,797 file->node->service_id, file->node->index, 727 798 LOWER32(file->pos), UPPER32(file->pos), &answer); 728 799 } else { … … 731 802 732 803 rc = async_data_write_forward_4_1(fs_exch, VFS_OUT_WRITE, 733 file->node-> devmap_handle, file->node->index,804 file->node->service_id, file->node->index, 734 805 LOWER32(file->pos), UPPER32(file->pos), &answer); 735 806 } … … 862 933 } 863 934 864 int vfs_truncate_internal(fs_handle_t fs_handle, devmap_handle_t devmap_handle,935 int vfs_truncate_internal(fs_handle_t fs_handle, service_id_t service_id, 865 936 fs_index_t index, aoff64_t size) 866 937 { 867 938 async_exch_t *exch = vfs_exchange_grab(fs_handle); 868 939 sysarg_t rc = async_req_4_0(exch, VFS_OUT_TRUNCATE, 869 (sysarg_t) devmap_handle, (sysarg_t) index, LOWER32(size),940 (sysarg_t) service_id, (sysarg_t) index, LOWER32(size), 870 941 UPPER32(size)); 871 942 vfs_exchange_release(exch); … … 890 961 fibril_rwlock_write_lock(&file->node->contents_rwlock); 891 962 rc = vfs_truncate_internal(file->node->fs_handle, 892 file->node-> devmap_handle, file->node->index, size);963 file->node->service_id, file->node->index, size); 893 964 if (rc == EOK) 894 965 file->node->size = size; … … 924 995 925 996 aid_t msg; 926 msg = async_send_3(exch, VFS_OUT_STAT, file->node-> devmap_handle,997 msg = async_send_3(exch, VFS_OUT_STAT, file->node->service_id, 927 998 file->node->index, true, NULL); 928 999 async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME); … … 977 1048 978 1049 aid_t msg; 979 msg = async_send_3(exch, VFS_OUT_STAT, node-> devmap_handle,1050 msg = async_send_3(exch, VFS_OUT_STAT, node->service_id, 980 1051 node->index, false, NULL); 981 1052 async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME); … … 1154 1225 /* Check whether linking to the same file system instance. */ 1155 1226 if ((old_node->fs_handle != new_par_lr.triplet.fs_handle) || 1156 (old_node-> devmap_handle != new_par_lr.triplet.devmap_handle)) {1227 (old_node->service_id != new_par_lr.triplet.service_id)) { 1157 1228 fibril_rwlock_write_unlock(&namespace_rwlock); 1158 1229 vfs_node_put(old_node); … … 1282 1353 } 1283 1354 1355 void vfs_get_mtab(ipc_callid_t rid, ipc_call_t *request) 1356 { 1357 ipc_callid_t callid; 1358 ipc_call_t data; 1359 sysarg_t rc = EOK; 1360 size_t len; 1361 1362 fibril_mutex_lock(&mtab_list_lock); 1363 1364 /* Send to the caller the number of mounted filesystems */ 1365 callid = async_get_call(&data); 1366 if (IPC_GET_IMETHOD(data) != VFS_IN_PING) { 1367 rc = ENOTSUP; 1368 async_answer_0(callid, rc); 1369 goto exit; 1370 } 1371 async_answer_1(callid, EOK, mtab_size); 1372 1373 list_foreach(mtab_list, cur) { 1374 mtab_ent_t *mtab_ent = list_get_instance(cur, mtab_ent_t, 1375 link); 1376 1377 rc = ENOTSUP; 1378 1379 if (!async_data_read_receive(&callid, &len)) { 1380 async_answer_0(callid, rc); 1381 goto exit; 1382 } 1383 1384 (void) async_data_read_finalize(callid, mtab_ent->mp, 1385 str_size(mtab_ent->mp)); 1386 1387 if (!async_data_read_receive(&callid, &len)) { 1388 async_answer_0(callid, rc); 1389 goto exit; 1390 } 1391 1392 (void) async_data_read_finalize(callid, mtab_ent->opts, 1393 str_size(mtab_ent->opts)); 1394 1395 if (!async_data_read_receive(&callid, &len)) { 1396 async_answer_0(callid, rc); 1397 goto exit; 1398 } 1399 1400 (void) async_data_read_finalize(callid, mtab_ent->fs_name, 1401 str_size(mtab_ent->fs_name)); 1402 1403 callid = async_get_call(&data); 1404 1405 if (IPC_GET_IMETHOD(data) != VFS_IN_PING) { 1406 async_answer_0(callid, rc); 1407 goto exit; 1408 } 1409 1410 rc = EOK; 1411 async_answer_2(callid, rc, mtab_ent->instance, 1412 mtab_ent->service_id); 1413 } 1414 1415 exit: 1416 fibril_mutex_unlock(&mtab_list_lock); 1417 async_answer_0(rid, rc); 1418 } 1419 1284 1420 /** 1285 1421 * @}
Note:
See TracChangeset
for help on using the changeset viewer.
