Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/lib/libc/generic/vfs/vfs.c

    r2b88074b r0da4e41  
    5757static futex_t cwd_futex = FUTEX_INITIALIZER;
    5858
    59 static int cwd_fd = -1;
    60 static char *cwd_path = NULL;
    61 static size_t cwd_size = 0;
     59DIR *cwd_dir = NULL;
     60char *cwd_path = NULL;
     61size_t cwd_size = 0;
    6262
    6363char *absolutize(const char *path, size_t *retlen)
     
    197197}
    198198
    199 static int open_internal(const char *abs, size_t abs_size, int lflag, int oflag)
    200 {
    201         futex_down(&vfs_phone_futex);
    202         async_serialize_start();
    203         vfs_connect();
    204        
     199static int _open(const char *path, int lflag, int oflag, ...)
     200{
     201        ipcarg_t rc;
    205202        ipc_call_t answer;
    206         aid_t req = async_send_3(vfs_phone, VFS_IN_OPEN, lflag, oflag, 0, &answer);
    207         ipcarg_t rc = async_data_write_start(vfs_phone, abs, abs_size);
    208        
     203        aid_t req;
     204       
     205        size_t pa_size;
     206        char *pa = absolutize(path, &pa_size);
     207        if (!pa)
     208                return ENOMEM;
     209       
     210        futex_down(&vfs_phone_futex);
     211        async_serialize_start();
     212        vfs_connect();
     213       
     214        req = async_send_3(vfs_phone, VFS_IN_OPEN, lflag, oflag, 0, &answer);
     215        rc = async_data_write_start(vfs_phone, pa, pa_size);
    209216        if (rc != EOK) {
    210217                ipcarg_t rc_orig;
    211                 async_wait_for(req, &rc_orig);
    212                
    213                 async_serialize_end();
    214                 futex_up(&vfs_phone_futex);
    215                
    216                 if (rc_orig == EOK)
    217                         return (int) rc;
    218                 else
    219                         return (int) rc_orig;
    220         }
    221        
    222         async_wait_for(req, &rc);
    223         async_serialize_end();
    224         futex_up(&vfs_phone_futex);
     218       
     219                async_wait_for(req, &rc_orig);
     220                async_serialize_end();
     221                futex_up(&vfs_phone_futex);
     222                free(pa);
     223                if (rc_orig == EOK)
     224                        return (int) rc;
     225                else
     226                        return (int) rc_orig;
     227        }
     228        async_wait_for(req, &rc);
     229        async_serialize_end();
     230        futex_up(&vfs_phone_futex);
     231        free(pa);
    225232       
    226233        if (rc != EOK)
     
    232239int open(const char *path, int oflag, ...)
    233240{
    234         size_t abs_size;
    235         char *abs = absolutize(path, &abs_size);
    236         if (!abs)
    237                 return ENOMEM;
    238        
    239         int ret = open_internal(abs, abs_size, L_FILE, oflag);
    240         free(abs);
    241        
    242         return ret;
     241        return _open(path, L_FILE, oflag);
    243242}
    244243
     
    472471        if (!dirp)
    473472                return NULL;
    474        
    475         size_t abs_size;
    476         char *abs = absolutize(dirname, &abs_size);
    477         if (!abs) {
    478                 free(dirp);
    479                 return ENOMEM;
    480         }
    481        
    482         int ret = open_internal(abs, abs_size, L_DIRECTORY, 0);
    483         free(abs);
    484        
    485         if (ret < 0) {
     473        dirp->fd = _open(dirname, L_DIRECTORY, 0);
     474        if (dirp->fd < 0) {
    486475                free(dirp);
    487476                return NULL;
    488477        }
    489        
    490         dirp->fd = ret;
    491478        return dirp;
    492479}
     
    649636int chdir(const char *path)
    650637{
    651         size_t abs_size;
    652         char *abs = absolutize(path, &abs_size);
    653         if (!abs)
     638        size_t pa_size;
     639        char *pa = absolutize(path, &pa_size);
     640        if (!pa)
    654641                return ENOMEM;
    655        
    656         int fd = open_internal(abs, abs_size, L_DIRECTORY, O_DESC);
    657        
    658         if (fd < 0) {
    659                 free(abs);
     642
     643        DIR *d = opendir(pa);
     644        if (!d) {
     645                free(pa);
    660646                return ENOENT;
    661647        }
    662        
     648
    663649        futex_down(&cwd_futex);
    664        
    665         if (cwd_fd >= 0)
    666                 close(cwd_fd);
    667        
    668        
    669         if (cwd_path)
    670                 free(cwd_path);
    671        
    672         cwd_fd = fd;
    673         cwd_path = abs;
    674         cwd_size = abs_size;
    675        
     650        if (cwd_dir) {
     651                closedir(cwd_dir);
     652                cwd_dir = NULL;
     653                free(cwd_path);
     654                cwd_path = NULL;
     655                cwd_size = 0;
     656        }
     657        cwd_dir = d;
     658        cwd_path = pa;
     659        cwd_size = pa_size;
    676660        futex_up(&cwd_futex);
    677661        return EOK;
     
    680664char *getcwd(char *buf, size_t size)
    681665{
    682         if (size == 0)
     666        if (!size)
    683667                return NULL;
    684        
    685668        futex_down(&cwd_futex);
    686        
    687         if ((cwd_size == 0) || (size < cwd_size + 1)) {
     669        if (size < cwd_size + 1) {
    688670                futex_up(&cwd_futex);
    689671                return NULL;
    690672        }
    691        
    692673        str_cpy(buf, size, cwd_path);
    693674        futex_up(&cwd_futex);
    694        
    695675        return buf;
    696676}
     
    725705}
    726706
    727 int dup2(int oldfd, int newfd)
    728 {
    729         futex_down(&vfs_phone_futex);
    730         async_serialize_start();
    731         vfs_connect();
    732        
    733         ipcarg_t ret;
    734         ipcarg_t rc = async_req_2_1(vfs_phone, VFS_IN_DUP, oldfd, newfd, &ret);
    735        
    736         async_serialize_end();
    737         futex_up(&vfs_phone_futex);
    738        
    739         if (rc == EOK)
    740                 return (int) ret;
    741        
    742         return (int) rc;
    743 }
    744 
    745707/** @}
    746708 */
Note: See TracChangeset for help on using the changeset viewer.