Changeset 903bac0a in mainline for uspace/srv/vfs/vfs_ops.c
- Timestamp:
- 2011-08-19T09:00:38Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- e2ab36f1
- Parents:
- d894fbd (diff), 42a619b (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/vfs/vfs_ops.c
rd894fbd r903bac0a 54 54 55 55 /* Forward declarations of static functions. */ 56 static int vfs_truncate_internal(fs_handle_t, devmap_handle_t, fs_index_t,56 static int vfs_truncate_internal(fs_handle_t, service_id_t, fs_index_t, 57 57 aoff64_t); 58 58 … … 65 65 vfs_pair_t rootfs = { 66 66 .fs_handle = 0, 67 . devmap_handle= 067 .service_id = 0 68 68 }; 69 69 70 static void vfs_mount_internal(ipc_callid_t rid, devmap_handle_t devmap_handle,70 static void vfs_mount_internal(ipc_callid_t rid, service_id_t service_id, 71 71 fs_handle_t fs_handle, char *mp, char *opts) 72 72 { … … 125 125 exch = vfs_exchange_grab(fs_handle); 126 126 msg = async_send_1(exch, VFS_OUT_MOUNTED, 127 (sysarg_t) devmap_handle, &answer);127 (sysarg_t) service_id, &answer); 128 128 /* Send the mount options */ 129 129 rc = async_data_write_start(exch, (void *)opts, … … 150 150 151 151 mr_res.triplet.fs_handle = fs_handle; 152 mr_res.triplet. devmap_handle = devmap_handle;152 mr_res.triplet.service_id = service_id; 153 153 mr_res.triplet.index = rindex; 154 154 mr_res.size = rsize; … … 157 157 158 158 rootfs.fs_handle = fs_handle; 159 rootfs. devmap_handle = devmap_handle;159 rootfs.service_id = service_id; 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 and device181 * handles, and we know the mount point VFS node.180 * At this point, we have all necessary pieces: file system handle 181 * and service ID, 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. devmap_handle,189 (sysarg_t) mp_res.triplet.service_id, 190 190 (sysarg_t) mp_res.triplet.index, 191 191 (sysarg_t) fs_handle, 192 (sysarg_t) devmap_handle, &answer);192 (sysarg_t) service_id, &answer); 193 193 194 194 /* Send connection */ … … 234 234 235 235 mr_res.triplet.fs_handle = fs_handle; 236 mr_res.triplet. devmap_handle = devmap_handle;236 mr_res.triplet.service_id = service_id; 237 237 mr_res.triplet.index = rindex; 238 238 mr_res.size = rsize; … … 255 255 void vfs_mount(ipc_callid_t rid, ipc_call_t *request) 256 256 { 257 devmap_handle_t devmap_handle;257 service_id_t service_id; 258 258 259 259 /* … … 262 262 * in the request. 263 263 */ 264 devmap_handle = (devmap_handle_t) IPC_GET_ARG1(*request);264 service_id = (service_id_t) IPC_GET_ARG1(*request); 265 265 266 266 /* … … 350 350 351 351 /* Do the mount */ 352 vfs_mount_internal(rid, devmap_handle, fs_handle, mp, opts);352 vfs_mount_internal(rid, service_id, fs_handle, mp, opts); 353 353 free(mp); 354 354 free(fs_name); … … 409 409 */ 410 410 if (vfs_nodes_refcount_sum_get(mr_node->fs_handle, 411 mr_node-> devmap_handle) != 2) {411 mr_node->service_id) != 2) { 412 412 fibril_rwlock_write_unlock(&namespace_rwlock); 413 413 vfs_node_put(mr_node); … … 430 430 exch = vfs_exchange_grab(mr_node->fs_handle); 431 431 rc = async_req_1_0(exch, VFS_OUT_UNMOUNTED, 432 mr_node-> devmap_handle);432 mr_node->service_id); 433 433 vfs_exchange_release(exch); 434 434 … … 441 441 442 442 rootfs.fs_handle = 0; 443 rootfs. devmap_handle= 0;443 rootfs.service_id = 0; 444 444 } else { 445 445 … … 470 470 exch = vfs_exchange_grab(mp_node->fs_handle); 471 471 rc = async_req_2_0(exch, VFS_OUT_UNMOUNT, 472 mp_node-> devmap_handle, mp_node->index);472 mp_node->service_id, mp_node->index); 473 473 vfs_exchange_release(exch); 474 474 … … 575 575 if (node->size) { 576 576 rc = vfs_truncate_internal(node->fs_handle, 577 node-> devmap_handle, node->index, 0);577 node->service_id, node->index, 0); 578 578 if (rc) { 579 579 fibril_rwlock_write_unlock(&node->contents_rwlock); … … 639 639 aid_t msg; 640 640 ipc_call_t answer; 641 msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node-> devmap_handle,641 msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node->service_id, 642 642 file->node->index, &answer); 643 643 … … 724 724 if (read) { 725 725 rc = async_data_read_forward_4_1(fs_exch, VFS_OUT_READ, 726 file->node-> devmap_handle, file->node->index,726 file->node->service_id, file->node->index, 727 727 LOWER32(file->pos), UPPER32(file->pos), &answer); 728 728 } else { … … 731 731 732 732 rc = async_data_write_forward_4_1(fs_exch, VFS_OUT_WRITE, 733 file->node-> devmap_handle, file->node->index,733 file->node->service_id, file->node->index, 734 734 LOWER32(file->pos), UPPER32(file->pos), &answer); 735 735 } … … 862 862 } 863 863 864 int vfs_truncate_internal(fs_handle_t fs_handle, devmap_handle_t devmap_handle,864 int vfs_truncate_internal(fs_handle_t fs_handle, service_id_t service_id, 865 865 fs_index_t index, aoff64_t size) 866 866 { 867 867 async_exch_t *exch = vfs_exchange_grab(fs_handle); 868 868 sysarg_t rc = async_req_4_0(exch, VFS_OUT_TRUNCATE, 869 (sysarg_t) devmap_handle, (sysarg_t) index, LOWER32(size),869 (sysarg_t) service_id, (sysarg_t) index, LOWER32(size), 870 870 UPPER32(size)); 871 871 vfs_exchange_release(exch); … … 890 890 fibril_rwlock_write_lock(&file->node->contents_rwlock); 891 891 rc = vfs_truncate_internal(file->node->fs_handle, 892 file->node-> devmap_handle, file->node->index, size);892 file->node->service_id, file->node->index, size); 893 893 if (rc == EOK) 894 894 file->node->size = size; … … 924 924 925 925 aid_t msg; 926 msg = async_send_3(exch, VFS_OUT_STAT, file->node-> devmap_handle,926 msg = async_send_3(exch, VFS_OUT_STAT, file->node->service_id, 927 927 file->node->index, true, NULL); 928 928 async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME); … … 977 977 978 978 aid_t msg; 979 msg = async_send_3(exch, VFS_OUT_STAT, node-> devmap_handle,979 msg = async_send_3(exch, VFS_OUT_STAT, node->service_id, 980 980 node->index, false, NULL); 981 981 async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME); … … 1154 1154 /* Check whether linking to the same file system instance. */ 1155 1155 if ((old_node->fs_handle != new_par_lr.triplet.fs_handle) || 1156 (old_node-> devmap_handle != new_par_lr.triplet.devmap_handle)) {1156 (old_node->service_id != new_par_lr.triplet.service_id)) { 1157 1157 fibril_rwlock_write_unlock(&namespace_rwlock); 1158 1158 vfs_node_put(old_node);
Note:
See TracChangeset
for help on using the changeset viewer.