nfs-ganesha 1.4

9p_read.c

Go to the documentation of this file.
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