Changeset 15f3c3f in mainline for uspace/srv/vfs


Ignore:
Timestamp:
2011-06-22T22:00:52Z (14 years ago)
Author:
Jiri Svoboda <jiri@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
86ffa27f
Parents:
ef09a7a
Message:

Rename devmap to loc, devfs to locfs.

Location:
uspace/srv/vfs
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • uspace/srv/vfs/vfs.h

    ref09a7a r15f3c3f  
    3838#include <fibril_synch.h>
    3939#include <sys/types.h>
    40 #include <devmap.h>
     40#include <loc.h>
    4141#include <bool.h>
    4242#include <ipc/vfs.h>
     
    6161#define VFS_PAIR \
    6262        fs_handle_t fs_handle; \
    63         devmap_handle_t devmap_handle;
     63        service_id_t service_id;
    6464
    6565/**
     
    6767 * doesn't contain any state. For a stateful structure, see vfs_node_t.
    6868 *
    69  * @note        fs_handle, devmap_handle and index are meant to be returned in one
     69 * @note        fs_handle, service_id and index are meant to be returned in one
    7070 *              IPC reply.
    7171 */
     
    181181extern void vfs_node_put(vfs_node_t *);
    182182extern void vfs_node_forget(vfs_node_t *);
    183 extern unsigned vfs_nodes_refcount_sum_get(fs_handle_t, devmap_handle_t);
     183extern unsigned vfs_nodes_refcount_sum_get(fs_handle_t, service_id_t);
    184184
    185185
  • uspace/srv/vfs/vfs_file.c

    ref09a7a r15f3c3f  
    115115       
    116116        ipc_call_t answer;
    117         aid_t msg = async_send_2(exch, VFS_OUT_CLOSE, file->node->devmap_handle,
     117        aid_t msg = async_send_2(exch, VFS_OUT_CLOSE, file->node->service_id,
    118118            file->node->index, &answer);
    119119       
  • uspace/srv/vfs/vfs_lookup.c

    ref09a7a r15f3c3f  
    162162        aid_t req = async_send_5(exch, VFS_OUT_LOOKUP, (sysarg_t) first,
    163163            (sysarg_t) (first + len - 1) % PLB_SIZE,
    164             (sysarg_t) root->devmap_handle, (sysarg_t) lflag, (sysarg_t) index,
     164            (sysarg_t) root->service_id, (sysarg_t) lflag, (sysarg_t) index,
    165165            &answer);
    166166       
     
    185185       
    186186        result->triplet.fs_handle = (fs_handle_t) rc;
    187         result->triplet.devmap_handle = (devmap_handle_t) IPC_GET_ARG1(answer);
     187        result->triplet.service_id = (service_id_t) IPC_GET_ARG1(answer);
    188188        result->triplet.index = (fs_index_t) IPC_GET_ARG2(answer);
    189189        result->size =
     
    212212        ipc_call_t answer;
    213213        aid_t req = async_send_2(exch, VFS_OUT_OPEN_NODE,
    214             (sysarg_t) result->triplet.devmap_handle,
     214            (sysarg_t) result->triplet.service_id,
    215215            (sysarg_t) result->triplet.index, &answer);
    216216       
  • uspace/srv/vfs/vfs_node.c

    ref09a7a r15f3c3f  
    116116                unsigned long key[] = {
    117117                        [KEY_FS_HANDLE] = node->fs_handle,
    118                         [KEY_DEV_HANDLE] = node->devmap_handle,
     118                        [KEY_DEV_HANDLE] = node->service_id,
    119119                        [KEY_INDEX] = node->index
    120120                };
     
    138138                async_exch_t *exch = vfs_exchange_grab(node->fs_handle);
    139139                sysarg_t rc = async_req_2_0(exch, VFS_OUT_DESTROY,
    140                     (sysarg_t) node->devmap_handle, (sysarg_t)node->index);
     140                    (sysarg_t) node->service_id, (sysarg_t)node->index);
    141141               
    142142                assert(rc == EOK);
     
    160160        unsigned long key[] = {
    161161                [KEY_FS_HANDLE] = node->fs_handle,
    162                 [KEY_DEV_HANDLE] = node->devmap_handle,
     162                [KEY_DEV_HANDLE] = node->service_id,
    163163                [KEY_INDEX] = node->index
    164164        };
     
    184184        unsigned long key[] = {
    185185                [KEY_FS_HANDLE] = result->triplet.fs_handle,
    186                 [KEY_DEV_HANDLE] = result->triplet.devmap_handle,
     186                [KEY_DEV_HANDLE] = result->triplet.service_id,
    187187                [KEY_INDEX] = result->triplet.index
    188188        };
     
    200200                memset(node, 0, sizeof(vfs_node_t));
    201201                node->fs_handle = result->triplet.fs_handle;
    202                 node->devmap_handle = result->triplet.devmap_handle;
     202                node->service_id = result->triplet.service_id;
    203203                node->index = result->triplet.index;
    204204                node->size = result->size;
     
    252252        vfs_node_t *node = hash_table_get_instance(item, vfs_node_t, nh_link);
    253253        return (node->fs_handle == (fs_handle_t) key[KEY_FS_HANDLE]) &&
    254             (node->devmap_handle == key[KEY_DEV_HANDLE]) &&
     254            (node->service_id == key[KEY_DEV_HANDLE]) &&
    255255            (node->index == key[KEY_INDEX]);
    256256}
     
    264264        unsigned refcnt;
    265265        fs_handle_t fs_handle;
    266         devmap_handle_t devmap_handle;
     266        service_id_t service_id;
    267267};
    268268
     
    273273
    274274        if ((node->fs_handle == rd->fs_handle) &&
    275             (node->devmap_handle == rd->devmap_handle))
     275            (node->service_id == rd->service_id))
    276276                rd->refcnt += node->refcnt;
    277277}
    278278
    279279unsigned
    280 vfs_nodes_refcount_sum_get(fs_handle_t fs_handle, devmap_handle_t devmap_handle)
     280vfs_nodes_refcount_sum_get(fs_handle_t fs_handle, service_id_t service_id)
    281281{
    282282        struct refcnt_data rd = {
    283283                .refcnt = 0,
    284284                .fs_handle = fs_handle,
    285                 .devmap_handle = devmap_handle
     285                .service_id = service_id
    286286        };
    287287
  • uspace/srv/vfs/vfs_ops.c

    ref09a7a r15f3c3f  
    5454
    5555/* Forward declarations of static functions. */
    56 static int vfs_truncate_internal(fs_handle_t, devmap_handle_t, fs_index_t,
     56static int vfs_truncate_internal(fs_handle_t, service_id_t, fs_index_t,
    5757    aoff64_t);
    5858
     
    6565vfs_pair_t rootfs = {
    6666        .fs_handle = 0,
    67         .devmap_handle = 0
     67        .service_id = 0
    6868};
    6969
    70 static void vfs_mount_internal(ipc_callid_t rid, devmap_handle_t devmap_handle,
     70static void vfs_mount_internal(ipc_callid_t rid, service_id_t service_id,
    7171    fs_handle_t fs_handle, char *mp, char *opts)
    7272{
     
    125125                        exch = vfs_exchange_grab(fs_handle);
    126126                        msg = async_send_1(exch, VFS_OUT_MOUNTED,
    127                             (sysarg_t) devmap_handle, &answer);
     127                            (sysarg_t) service_id, &answer);
    128128                        /* Send the mount options */
    129129                        rc = async_data_write_start(exch, (void *)opts,
     
    150150                       
    151151                        mr_res.triplet.fs_handle = fs_handle;
    152                         mr_res.triplet.devmap_handle = devmap_handle;
     152                        mr_res.triplet.service_id = service_id;
    153153                        mr_res.triplet.index = rindex;
    154154                        mr_res.size = rsize;
     
    157157                       
    158158                        rootfs.fs_handle = fs_handle;
    159                         rootfs.devmap_handle = devmap_handle;
     159                        rootfs.service_id = service_id;
    160160                       
    161161                        /* Add reference to the mounted root. */
     
    178178       
    179179        /*
    180          * At this point, we have all necessary pieces: file system and device
    181          * 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.
    182182         */
    183183       
     
    187187        exch = vfs_exchange_grab(mp_res.triplet.fs_handle);
    188188        msg = async_send_4(exch, VFS_OUT_MOUNT,
    189             (sysarg_t) mp_res.triplet.devmap_handle,
     189            (sysarg_t) mp_res.triplet.service_id,
    190190            (sysarg_t) mp_res.triplet.index,
    191191            (sysarg_t) fs_handle,
    192             (sysarg_t) devmap_handle, &answer);
     192            (sysarg_t) service_id, &answer);
    193193       
    194194        /* Send connection */
     
    233233               
    234234                mr_res.triplet.fs_handle = fs_handle;
    235                 mr_res.triplet.devmap_handle = devmap_handle;
     235                mr_res.triplet.service_id = service_id;
    236236                mr_res.triplet.index = rindex;
    237237                mr_res.size = rsize;
     
    254254void vfs_mount(ipc_callid_t rid, ipc_call_t *request)
    255255{
    256         devmap_handle_t devmap_handle;
     256        service_id_t service_id;
    257257
    258258        /*
     
    261261         * in the request.
    262262         */
    263         devmap_handle = (devmap_handle_t) IPC_GET_ARG1(*request);
     263        service_id = (service_id_t) IPC_GET_ARG1(*request);
    264264       
    265265        /*
     
    349349       
    350350        /* Do the mount */
    351         vfs_mount_internal(rid, devmap_handle, fs_handle, mp, opts);
     351        vfs_mount_internal(rid, service_id, fs_handle, mp, opts);
    352352        free(mp);
    353353        free(fs_name);
     
    408408         */
    409409        if (vfs_nodes_refcount_sum_get(mr_node->fs_handle,
    410             mr_node->devmap_handle) != 2) {
     410            mr_node->service_id) != 2) {
    411411                fibril_rwlock_write_unlock(&namespace_rwlock);
    412412                vfs_node_put(mr_node);
     
    429429                exch = vfs_exchange_grab(mr_node->fs_handle);
    430430                rc = async_req_1_0(exch, VFS_OUT_UNMOUNTED,
    431                     mr_node->devmap_handle);
     431                    mr_node->service_id);
    432432                vfs_exchange_release(exch);
    433433               
     
    440440               
    441441                rootfs.fs_handle = 0;
    442                 rootfs.devmap_handle = 0;
     442                rootfs.service_id = 0;
    443443        } else {
    444444               
     
    469469                exch = vfs_exchange_grab(mp_node->fs_handle);
    470470                rc = async_req_2_0(exch, VFS_OUT_UNMOUNT,
    471                     mp_node->devmap_handle, mp_node->index);
     471                    mp_node->service_id, mp_node->index);
    472472                vfs_exchange_release(exch);
    473473               
     
    574574                if (node->size) {
    575575                        rc = vfs_truncate_internal(node->fs_handle,
    576                             node->devmap_handle, node->index, 0);
     576                            node->service_id, node->index, 0);
    577577                        if (rc) {
    578578                                fibril_rwlock_write_unlock(&node->contents_rwlock);
     
    627627       
    628628        lr.triplet.fs_handle = IPC_GET_ARG1(*request);
    629         lr.triplet.devmap_handle = IPC_GET_ARG2(*request);
     629        lr.triplet.service_id = IPC_GET_ARG2(*request);
    630630        lr.triplet.index = IPC_GET_ARG3(*request);
    631631        int oflag = IPC_GET_ARG4(*request);
     
    648648                if (node->size) {
    649649                        rc = vfs_truncate_internal(node->fs_handle,
    650                             node->devmap_handle, node->index, 0);
     650                            node->service_id, node->index, 0);
    651651                        if (rc) {
    652652                                fibril_rwlock_write_unlock(&node->contents_rwlock);
     
    711711        aid_t msg;
    712712        ipc_call_t answer;
    713         msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node->devmap_handle,
     713        msg = async_send_2(fs_exch, VFS_OUT_SYNC, file->node->service_id,
    714714            file->node->index, &answer);
    715715       
     
    796796        if (read) {
    797797                rc = async_data_read_forward_3_1(fs_exch, VFS_OUT_READ,
    798                     file->node->devmap_handle, file->node->index, file->pos,
     798                    file->node->service_id, file->node->index, file->pos,
    799799                    &answer);
    800800        } else {
     
    803803               
    804804                rc = async_data_write_forward_3_1(fs_exch, VFS_OUT_WRITE,
    805                     file->node->devmap_handle, file->node->index, file->pos,
     805                    file->node->service_id, file->node->index, file->pos,
    806806                    &answer);
    807807        }
     
    933933}
    934934
    935 int vfs_truncate_internal(fs_handle_t fs_handle, devmap_handle_t devmap_handle,
     935int vfs_truncate_internal(fs_handle_t fs_handle, service_id_t service_id,
    936936    fs_index_t index, aoff64_t size)
    937937{
    938938        async_exch_t *exch = vfs_exchange_grab(fs_handle);
    939939        sysarg_t rc = async_req_4_0(exch, VFS_OUT_TRUNCATE,
    940             (sysarg_t) devmap_handle, (sysarg_t) index, LOWER32(size),
     940            (sysarg_t) service_id, (sysarg_t) index, LOWER32(size),
    941941            UPPER32(size));
    942942        vfs_exchange_release(exch);
     
    961961        fibril_rwlock_write_lock(&file->node->contents_rwlock);
    962962        rc = vfs_truncate_internal(file->node->fs_handle,
    963             file->node->devmap_handle, file->node->index, size);
     963            file->node->service_id, file->node->index, size);
    964964        if (rc == EOK)
    965965                file->node->size = size;
     
    995995       
    996996        aid_t msg;
    997         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,
    998998            file->node->index, true, NULL);
    999999        async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME);
     
    10481048       
    10491049        aid_t msg;
    1050         msg = async_send_3(exch, VFS_OUT_STAT, node->devmap_handle,
     1050        msg = async_send_3(exch, VFS_OUT_STAT, node->service_id,
    10511051            node->index, false, NULL);
    10521052        async_forward_fast(callid, exch, 0, 0, 0, IPC_FF_ROUTE_FROM_ME);
     
    12251225        /* Check whether linking to the same file system instance. */
    12261226        if ((old_node->fs_handle != new_par_lr.triplet.fs_handle) ||
    1227             (old_node->devmap_handle != new_par_lr.triplet.devmap_handle)) {
     1227            (old_node->service_id != new_par_lr.triplet.service_id)) {
    12281228                fibril_rwlock_write_unlock(&namespace_rwlock);
    12291229                vfs_node_put(old_node);
  • uspace/srv/vfs/vfs_register.c

    ref09a7a r15f3c3f  
    306306        list_foreach(fs_list, cur) {
    307307                fs_info_t *fs = list_get_instance(cur, fs_info_t, fs_link);
    308                 if (str_cmp(fs->vfs_info.name, name) == 0) { 
     308                if (str_cmp(fs->vfs_info.name, name) == 0) {
    309309                        handle = fs->fs_handle;
    310310                        break;
Note: See TracChangeset for help on using the changeset viewer.