Changeset 23 for trunk/kernel/syscalls/sys_chdir.c
- Timestamp:
- Jun 18, 2017, 10:06:41 PM (7 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/kernel/syscalls/sys_chdir.c
r11 r23 1 1 /* 2 * sys_chdir: change process current work directory2 * sys_chdir: change process current working directory 3 3 * 4 * Copyright (c) 2008,2009,2010,2011,2012 Ghassan Almaless 4 * Author Alain Greiner (2016,2017) 5 * 5 6 * Copyright (c) 2011,2012 UPMC Sorbonne Universites 6 7 * 7 * This file is part of ALMOS- kernel.8 * This file is part of ALMOS-MKH. 8 9 * 9 * ALMOS- kernelis free software; you can redistribute it and/or modify it10 * ALMOS-MKH is free software; you can redistribute it and/or modify it 10 11 * under the terms of the GNU General Public License as published by 11 12 * the Free Software Foundation; version 2.0 of the License. 12 13 * 13 * ALMOS- kernelis distributed in the hope that it will be useful, but14 * ALMOS-MKH is distributed in the hope that it will be useful, but 14 15 * WITHOUT ANY WARRANTY; without even the implied warranty of 15 16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU … … 17 18 * 18 19 * You should have received a copy of the GNU General Public License 19 * along with ALMOS- kernel; if not, write to the Free Software Foundation,20 * along with ALMOS-MKH; if not, write to the Free Software Foundation, 20 21 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 21 22 */ 22 23 23 #include <cpu.h> 24 #include <hal_types.h> 25 #include <hal_uspace.h> 24 26 #include <chdev.h> 25 #include <driver.h>26 27 #include <rwlock.h> 27 28 #include <vfs.h> 28 #include < sys-vfs.h>29 #include <errno.h> 29 30 #include <thread.h> 30 #include < ku_transfert.h>31 #include < task.h>31 #include <printk.h> 32 #include <process.h> 32 33 33 int sys_chdir (char *pathname) 34 ///////////////////////////////// 35 int sys_chdir ( char * pathname ) 34 36 { 35 register error_t err = 0;36 register struct thread_s *this;37 register struct task_s *task;38 struct ku_obj ku_path;37 error_t error; 38 paddr_t paddr; 39 uint32_t length; 40 char kbuf[CONFIG_VFS_MAX_PATH_LENGTH]; 39 41 40 th is = current_thread;41 task = current_task;42 thread_t * this = CURRENT_THREAD; 43 process_t * process = this->process; 42 44 43 if(!pathname) 45 // check pathname in user space 46 error = vmm_v2p_translate( false , pathname , &paddr ); 47 48 if( error ) 44 49 { 45 this->info.errno = EINVAL; 50 printk("\n[ERROR] in %s : user buffer unmapped for thread %x in process %x\n", 51 __FUNCTION__ , this->trdid , process->pid ); 52 this->errno = EINVAL; 46 53 return -1; 47 54 } 48 55 49 KU_BUFF(ku_path, pathname); 50 rwlock_wrlock(&task->cwd_lock); 56 // get pathname length 57 length = hal_strlen_from_uspace( pathname ); 58 59 if( length >= CONFIG_VFS_MAX_PATH_LENGTH ) 60 { 61 printk("\n[ERROR] in %s : pathname too long for thread %x in process %x\n", 62 __FUNCTION__ , this->trdid , process->pid ); 63 this->errno = ENFILE; 64 return -1; 65 } 66 67 // get pathname copy in kernel space 68 hal_copy_from_uspace( kbuf, pathname, length ); 69 70 // get cluster and local pointer on reference process 71 xptr_t ref_xp = process->ref_xp; 72 process_t * ref_ptr = (process_t *)GET_PTR( ref_xp ); 73 cxy_t ref_cxy = GET_CXY( ref_xp ); 74 75 // get extended pointer on cwd lock in reference process 76 xptr_t lock_xp = hal_remote_lwd( XPTR( ref_cxy , &ref_ptr->cwd_lock ) ); 51 77 52 if((err = vfs_chdir(&ku_path, &task->vfs_cwd))) 78 // get cwd lock in read mode 79 remote_rwlock_rd_lock( lock_xp ); 80 81 // call relevant VFS function 82 error = vfs_chdir( process->vfs_cwd_xp , kbuf ); 83 84 // release cwd lock 85 remote_rwlock_rd_unlock( lock_xp ); 86 87 if( error ) 53 88 { 54 rwlock_unlock(&task->cwd_lock);55 this-> info.errno = (err < 0) ? -err : err;89 printk("\n[ERROR] in %s : cannot change current directory\n", __FUNCTION__ ); 90 this->errno = error; 56 91 return -1; 57 92 } 58 93 59 rwlock_unlock(&task->cwd_lock);60 94 return 0; 61 95 }
Note: See TracChangeset
for help on using the changeset viewer.