Changes in uspace/srv/vfs/vfs_ops.c [15f3c3f:5bb9907] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/vfs/vfs_ops.c
r15f3c3f r5bb9907 54 54 55 55 /* Forward declarations of static functions. */ 56 static int vfs_truncate_internal(fs_handle_t, service_id_t, fs_index_t,56 static int vfs_truncate_internal(fs_handle_t, devmap_handle_t, fs_index_t, 57 57 aoff64_t); 58 58 … … 65 65 vfs_pair_t rootfs = { 66 66 .fs_handle = 0, 67 . service_id= 067 .devmap_handle = 0 68 68 }; 69 69 70 static void vfs_mount_internal(ipc_callid_t rid, service_id_t service_id,70 static void vfs_mount_internal(ipc_callid_t rid, devmap_handle_t devmap_handle, 71 71 fs_handle_t fs_handle, char *mp, char *opts) 72 72 { … … 76 76 vfs_node_t *mr_node; 77 77 fs_index_t rindex; 78 size_t rsize;78 aoff64_t rsize; 79 79 unsigned rlnkcnt; 80 80 async_exch_t *exch; … … 125 125 exch = vfs_exchange_grab(fs_handle); 126 126 msg = async_send_1(exch, VFS_OUT_MOUNTED, 127 (sysarg_t) service_id, &answer);127 (sysarg_t) devmap_handle, &answer); 128 128 /* Send the mount options */ 129 129 rc = async_data_write_start(exch, (void *)opts, … … 146 146 147 147 rindex = (fs_index_t) IPC_GET_ARG1(answer); 148 rsize = ( size_t) IPC_GET_ARG2(answer);149 rlnkcnt = (unsigned) IPC_GET_ARG 3(answer);148 rsize = (aoff64_t) MERGE_LOUP32(IPC_GET_ARG2(answer), IPC_GET_ARG3(answer)); 149 rlnkcnt = (unsigned) IPC_GET_ARG4(answer); 150 150 151 151 mr_res.triplet.fs_handle = fs_handle; 152 mr_res.triplet. service_id = service_id;152 mr_res.triplet.devmap_handle = devmap_handle; 153 153 mr_res.triplet.index = rindex; 154 154 mr_res.size = rsize; … … 157 157 158 158 rootfs.fs_handle = fs_handle; 159 rootfs. service_id = service_id;159 rootfs.devmap_handle = devmap_handle; 160 160 161 161 /* Add reference to the mounted root. */ … … 178 178 179 179 /* 180 * At this point, we have all necessary pieces: file system handle181 * and service ID, and we know the mount point VFS node.180 * At this point, we have all necessary pieces: file system and device 181 * handles, and we know the mount point VFS node. 182 182 */ 183 183 … … 187 187 exch = vfs_exchange_grab(mp_res.triplet.fs_handle); 188 188 msg = async_send_4(exch, VFS_OUT_MOUNT, 189 (sysarg_t) mp_res.triplet. service_id,189 (sysarg_t) mp_res.triplet.devmap_handle, 190 190 (sysarg_t) mp_res.triplet.index, 191 191 (sysarg_t) fs_handle, 192 (sysarg_t) service_id, &answer);192 (sysarg_t) devmap_handle, &answer); 193 193 194 194 /* Send connection */ … … 229 229 if (rc == EOK) { 230 230 rindex = (fs_index_t) IPC_GET_ARG1(answer); 231 rsize = (size_t) IPC_GET_ARG2(answer); 232 rlnkcnt = (unsigned) IPC_GET_ARG3(answer); 231 rsize = (aoff64_t) MERGE_LOUP32(IPC_GET_ARG2(answer), 232 IPC_GET_ARG3(answer)); 233 rlnkcnt = (unsigned) IPC_GET_ARG4(answer); 233 234 234 235 mr_res.triplet.fs_handle = fs_handle; 235 mr_res.triplet. service_id = service_id;236 mr_res.triplet.devmap_handle = devmap_handle; 236 237 mr_res.triplet.index = rindex; 237 238 mr_res.size = rsize; … … 254 255 void vfs_mount(ipc_callid_t rid, ipc_call_t *request) 255 256 { 256 service_id_t service_id;257 devmap_handle_t devmap_handle; 257 258 258 259 /* … … 261 262 * in the request. 262 263 */ 263 service_id = (service_id_t) IPC_GET_ARG1(*request);264 devmap_handle = (devmap_handle_t) IPC_GET_ARG1(*request); 264 265 265 266 /* … … 349 350 350 351 /* Do the mount */ 351 vfs_mount_internal(rid, service_id, fs_handle, mp, opts);352 vfs_mount_internal(rid, devmap_handle, fs_handle, mp, opts); 352 353 free(mp); 353 354 free(fs_name); … … 408 409 */ 409 410 if (vfs_nodes_refcount_sum_get(mr_node->fs_handle, 410 mr_node-> service_id) != 2) {411 mr_node->devmap_handle) != 2) { 411 412 fibril_rwlock_write_unlock(&namespace_rwlock); 412 413 vfs_node_put(mr_node); … … 429 430 exch = vfs_exchange_grab(mr_node->fs_handle); 430 431 rc = async_req_1_0(exch, VFS_OUT_UNMOUNTED, 431 mr_node-> service_id);432 mr_node->devmap_handle); 432 433 vfs_exchange_release(exch); 433 434 … … 440 441 441 442 rootfs.fs_handle = 0; 442 rootfs. service_id= 0;443 rootfs.devmap_handle = 0; 443 444 } else { 444 445 … … 469 470 exch = vfs_exchange_grab(mp_node->fs_handle); 470 471 rc = async_req_2_0(exch, VFS_OUT_UNMOUNT, 471 mp_node-> service_id, mp_node->index);472 mp_node->devmap_handle, mp_node->index); 472 473 vfs_exchange_release(exch); 473 474 … … 574 575 if (node->size) { 575 576 rc = vfs_truncate_internal(node->fs_handle, 576 node-> service_id, node->index, 0);577 node->devmap_handle, node->index, 0); 577 578 if (rc) { 578 579 fibril_rwlock_write_unlock(&node->contents_rwlock); … … 627 628 628 629 lr.triplet.fs_handle = IPC_GET_ARG1(*request); 629 lr.triplet. service_id= IPC_GET_ARG2(*request);630 lr.triplet.devmap_handle = IPC_GET_ARG2(*request); 630 631 lr.triplet.index = IPC_GET_ARG3(*request); 631 632 int oflag = IPC_GET_ARG4(*request); … … 648 649 if (node->size) { 649 650 rc = vfs_truncate_internal(node->fs_handle, 650 node-> service_id, node->index, 0);651 node->devmap_handle, node->index, 0); 651 652 if (rc) { 652 653 fibril_rwlock_write_unlock(&node->contents_rwlock); … … 711 712 aid_t msg; 712 713 ipc_call_t answer; 713 msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node-> service_id,714 msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node->devmap_handle, 714 715 file->node->index, &answer); 715 716 … … 795 796 ipc_call_t answer; 796 797 if (read) { 797 rc = async_data_read_forward_ 3_1(fs_exch, VFS_OUT_READ,798 file->node-> service_id, file->node->index, file->pos,799 &answer);798 rc = async_data_read_forward_4_1(fs_exch, VFS_OUT_READ, 799 file->node->devmap_handle, file->node->index, 800 LOWER32(file->pos), UPPER32(file->pos), &answer); 800 801 } else { 801 802 if (file->append) 802 803 file->pos = file->node->size; 803 804 804 rc = async_data_write_forward_ 3_1(fs_exch, VFS_OUT_WRITE,805 file->node-> service_id, file->node->index, file->pos,806 &answer);805 rc = async_data_write_forward_4_1(fs_exch, VFS_OUT_WRITE, 806 file->node->devmap_handle, file->node->index, 807 LOWER32(file->pos), UPPER32(file->pos), &answer); 807 808 } 808 809 … … 821 822 /* Update the cached version of node's size. */ 822 823 if (rc == EOK) 823 file->node->size = IPC_GET_ARG2(answer); 824 file->node->size = MERGE_LOUP32(IPC_GET_ARG2(answer), 825 IPC_GET_ARG3(answer)); 824 826 fibril_rwlock_write_unlock(&file->node->contents_rwlock); 825 827 } … … 933 935 } 934 936 935 int vfs_truncate_internal(fs_handle_t fs_handle, service_id_t service_id,937 int vfs_truncate_internal(fs_handle_t fs_handle, devmap_handle_t devmap_handle, 936 938 fs_index_t index, aoff64_t size) 937 939 { 938 940 async_exch_t *exch = vfs_exchange_grab(fs_handle); 939 941 sysarg_t rc = async_req_4_0(exch, VFS_OUT_TRUNCATE, 940 (sysarg_t) service_id, (sysarg_t) index, LOWER32(size),942 (sysarg_t) devmap_handle, (sysarg_t) index, LOWER32(size), 941 943 UPPER32(size)); 942 944 vfs_exchange_release(exch); … … 961 963 fibril_rwlock_write_lock(&file->node->contents_rwlock); 962 964 rc = vfs_truncate_internal(file->node->fs_handle, 963 file->node-> service_id, file->node->index, size);965 file->node->devmap_handle, file->node->index, size); 964 966 if (rc == EOK) 965 967 file->node->size = size; … … 995 997 996 998 aid_t msg; 997 msg = async_send_3(exch, VFS_OUT_STAT, file->node-> service_id,999 msg = async_send_3(exch, VFS_OUT_STAT, file->node->devmap_handle, 998 1000 file->node->index, true, NULL); 999 1001 async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME); … … 1048 1050 1049 1051 aid_t msg; 1050 msg = async_send_3(exch, VFS_OUT_STAT, node-> service_id,1052 msg = async_send_3(exch, VFS_OUT_STAT, node->devmap_handle, 1051 1053 node->index, false, NULL); 1052 1054 async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME); … … 1225 1227 /* Check whether linking to the same file system instance. */ 1226 1228 if ((old_node->fs_handle != new_par_lr.triplet.fs_handle) || 1227 (old_node-> service_id != new_par_lr.triplet.service_id)) {1229 (old_node->devmap_handle != new_par_lr.triplet.devmap_handle)) { 1228 1230 fibril_rwlock_write_unlock(&namespace_rwlock); 1229 1231 vfs_node_put(old_node);
Note:
See TracChangeset
for help on using the changeset viewer.