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 char __thread databuffer[_9p_READ_BUFFER_SIZE] ; 00054 00055 int _9p_read( _9p_request_data_t * preq9p, 00056 void * pworker_data, 00057 u32 * plenout, 00058 char * preply) 00059 { 00060 char * cursor = preq9p->_9pmsg + _9P_HDR_SIZE + _9P_TYPE_SIZE ; 00061 00062 u16 * msgtag = NULL ; 00063 u32 * fid = NULL ; 00064 u64 * offset = NULL ; 00065 u32 * count = NULL ; 00066 u32 outcount = 0 ; 00067 00068 _9p_fid_t * pfid = NULL ; 00069 00070 size_t read_size = 0; 00071 bool_t eof_met; 00072 cache_inode_status_t cache_status = CACHE_INODE_SUCCESS; 00073 // uint64_t stable_flag = CACHE_INODE_SAFE_WRITE_TO_FS; 00074 uint64_t stable_flag = CACHE_INODE_UNSAFE_WRITE_TO_FS_BUFFER; 00075 00076 /* Get data */ 00077 _9p_getptr( cursor, msgtag, u16 ) ; 00078 _9p_getptr( cursor, fid, u32 ) ; 00079 _9p_getptr( cursor, offset, u64 ) ; 00080 _9p_getptr( cursor, count, u32 ) ; 00081 00082 LogDebug( COMPONENT_9P, "TREAD: tag=%u fid=%u offset=%llu count=%u", 00083 (u32)*msgtag, *fid, (unsigned long long)*offset, *count ) ; 00084 00085 if( *fid >= _9P_FID_PER_CONN ) 00086 return _9p_rerror( preq9p, msgtag, ERANGE, plenout, preply ) ; 00087 00088 pfid = &preq9p->pconn->fids[*fid] ; 00089 00090 /* Do the job */ 00091 if( pfid->specdata.xattr.xattr_content != NULL ) 00092 { 00093 /* Copy the value cached during xattrwalk */ 00094 memcpy( databuffer, pfid->specdata.xattr.xattr_content, *count ) ; 00095 00096 outcount = (u32)*count ; 00097 } 00098 else 00099 { 00100 if(cache_inode_rdwr( pfid->pentry, 00101 CACHE_INODE_READ, 00102 *offset, 00103 *count, 00104 &read_size, 00105 databuffer, 00106 &eof_met, 00107 &pfid->fsal_op_context, 00108 stable_flag, 00109 &cache_status ) != CACHE_INODE_SUCCESS ) 00110 return _9p_rerror( preq9p, msgtag, _9p_tools_errno( cache_status ), plenout, preply ) ; 00111 00112 outcount = (u32)read_size ; 00113 } 00114 /* Build the reply */ 00115 _9p_setinitptr( cursor, preply, _9P_RREAD ) ; 00116 _9p_setptr( cursor, msgtag, u16 ) ; 00117 00118 _9p_setbuffer( cursor, outcount, databuffer ) ; 00119 00120 _9p_setendptr( cursor, preply ) ; 00121 _9p_checkbound( cursor, preply, plenout ) ; 00122 00123 LogDebug( COMPONENT_9P, "RREAD: tag=%u fid=%u offset=%llu count=%u", 00124 (u32)*msgtag, *fid , (unsigned long long)*offset, *count ) ; 00125 00126 return 1 ; 00127 } 00128