nfs-ganesha 1.4
|
00001 /* 00002 * vim:expandtab:shiftwidth=8:tabstop=8: 00003 * 00004 * Copyright CEA/DAM/DIF (2011) 00005 * contributeur : Philippe DENIEL philippe.deniel@cea.fr 00006 * Thomas LEIBOVICI thomas.leibovici@cea.fr 00007 * 00008 * 00009 * This program is free software; you can redistribute it and/or 00010 * modify it under the terms of the GNU Lesser General Public 00011 * License as published by the Free Software Foundation; either 00012 * version 3 of the License, or (at your option) any later version. 00013 * 00014 * This program is distributed in the hope that it will be useful, 00015 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00016 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00017 * Lesser General Public License for more details. 00018 * 00019 * You should have received a copy of the GNU Lesser General Public 00020 * License along with this library; if not, write to the Free Software 00021 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 00022 * 00023 * --------------------------------------- 00024 */ 00025 00035 #ifdef HAVE_CONFIG_H 00036 #include "config.h" 00037 #endif 00038 00039 #ifdef _SOLARIS 00040 #include "solaris_port.h" 00041 #endif 00042 00043 #include <stdio.h> 00044 #include <string.h> 00045 #include <pthread.h> 00046 #include <sys/stat.h> 00047 #include "nfs_core.h" 00048 #include "log.h" 00049 #include "cache_inode.h" 00050 #include "fsal.h" 00051 #include "9p.h" 00052 00053 00054 int _9p_lopen( _9p_request_data_t * preq9p, 00055 void * pworker_data, 00056 u32 * plenout, 00057 char * preply) 00058 { 00059 char * cursor = preq9p->_9pmsg + _9P_HDR_SIZE + _9P_TYPE_SIZE ; 00060 00061 u16 * msgtag = NULL ; 00062 u32 * fid = NULL ; 00063 u32 * flags = NULL ; 00064 00065 cache_inode_status_t cache_status ; 00066 fsal_openflags_t openflags = 0 ; 00067 00068 if( !preq9p || !pworker_data || !plenout || !preply ) 00069 return -1 ; 00070 00071 _9p_fid_t * pfid = NULL ; 00072 00073 /* Get data */ 00074 _9p_getptr( cursor, msgtag, u16 ) ; 00075 _9p_getptr( cursor, fid, u32 ) ; 00076 _9p_getptr( cursor, flags, u32 ) ; 00077 00078 LogDebug( COMPONENT_9P, "TLOPEN: tag=%u fid=%u flags=0x%x", 00079 (u32)*msgtag, *fid, *flags ) ; 00080 00081 if( *fid >= _9P_FID_PER_CONN ) 00082 return _9p_rerror( preq9p, msgtag, ERANGE, plenout, preply ) ; 00083 00084 pfid = &preq9p->pconn->fids[*fid] ; 00085 00086 _9p_openflags2FSAL( flags, &openflags ) ; 00087 00088 if( pfid->pentry->type == REGULAR_FILE ) 00089 { 00090 if(cache_inode_open( pfid->pentry, 00091 openflags, 00092 &pfid->fsal_op_context, 00093 0, 00094 &cache_status) != CACHE_INODE_SUCCESS) 00095 return _9p_rerror( preq9p, msgtag, _9p_tools_errno( cache_status ), plenout, preply ) ; 00096 } 00097 00098 /* iounit = 0 by default */ 00099 pfid->specdata.iounit = 0 ; 00100 00101 /* Build the reply */ 00102 _9p_setinitptr( cursor, preply, _9P_RLOPEN ) ; 00103 _9p_setptr( cursor, msgtag, u16 ) ; 00104 00105 _9p_setqid( cursor, pfid->qid ) ; 00106 _9p_setptr( cursor, &pfid->specdata.iounit, u32 ) ; 00107 00108 _9p_setendptr( cursor, preply ) ; 00109 _9p_checkbound( cursor, preply, plenout ) ; 00110 00111 LogDebug( COMPONENT_9P, "RLOPEN: tag=%u fid=%u qid=(type=%u,version=%u,path=%llu) iounit=%u", 00112 *msgtag, *fid, (u32)pfid->qid.type, pfid->qid.version, (unsigned long long)pfid->qid.path, pfid->specdata.iounit ) ; 00113 00114 return 1 ; 00115 } 00116