xrootd
XrdPosixFile.hh
Go to the documentation of this file.
1#ifndef __XRDPOSIXFILE_HH__
2#define __XRDPOSIXFILE_HH__
3/******************************************************************************/
4/* */
5/* X r d P o s i x F i l e . h h */
6/* */
7/* (c) 2013 by the Board of Trustees of the Leland Stanford, Jr., University */
8/* All Rights Reserved */
9/* Produced by Andrew Hanushevsky for Stanford University under contract */
10/* DE-AC02-76-SFO0515 with the Department of Energy */
11/* */
12/* This file is part of the XRootD software suite. */
13/* */
14/* XRootD is free software: you can redistribute it and/or modify it under */
15/* the terms of the GNU Lesser General Public License as published by the */
16/* Free Software Foundation, either version 3 of the License, or (at your */
17/* option) any later version. */
18/* */
19/* XRootD is distributed in the hope that it will be useful, but WITHOUT */
20/* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
21/* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public */
22/* License for more details. */
23/* */
24/* You should have received a copy of the GNU Lesser General Public License */
25/* along with XRootD in a file called COPYING.LESSER (LGPL license) and file */
26/* COPYING (GPL license). If not, see <http://www.gnu.org/licenses/>. */
27/* */
28/* The copyright holder's institutional names and contributor's names may not */
29/* be used to endorse or promote products derived from this software without */
30/* specific prior written permission of the institution or contributor. */
31/******************************************************************************/
32
33#include <errno.h>
34#include <fcntl.h>
35#include <sys/time.h>
36#include <sys/param.h>
37#include <sys/resource.h>
38#include <sys/uio.h>
39
41#include "XrdCl/XrdClFile.hh"
42#include "XrdCl/XrdClURL.hh"
44
46
49
50/******************************************************************************/
51/* X r d P o s i x F i l e C l a s s */
52/******************************************************************************/
53
55class XrdPosixPrepIO;
56
58 public XrdOucCacheIO2,
60{
61public:
62
66
67 long long addOffset(long long offs, int updtSz=0)
68 {updMutex.Lock();
69 currOffset += offs;
70 if (updtSz && currOffset > (long long)mySize)
72 long long retOffset = currOffset;
74 return retOffset;
75 }
76
77//atic XrdPosixFile *Alloc(const char *path, XrdPosixCallBack *cbP, int Opts);
78
79static void* DelayedDestroy(void*);
80
82
84
86
87 long long FSize() {AtomicBeg(updMutex);
88 long long retSize = AtomicGet(mySize);
90 return retSize;
91 }
92
93 int Fstat(struct stat &buf);
94
95 const char *Location();
96
98 XrdCl::AnyObject *response);
99
100 void isOpen();
101
103
105
107
108 const char *Origin() {return fOpen;}
109
110 const char *Path() {return fPath;}
111
112 int Read (char *Buff, long long Offs, int Len);
113
114 void Read (XrdOucCacheIOCB &iocb, char *buff, long long offs,
115 int rlen);
116
117 int ReadV (const XrdOucIOVec *readV, int n);
118
119 void ReadV (XrdOucCacheIOCB &iocb, const XrdOucIOVec *readV,
120 int n);
121
122 long long setOffset(long long offs)
123 {updMutex.Lock();
124 currOffset = offs;
126 return offs;
127 }
128
129 bool Stat(XrdCl::XRootDStatus &Status, bool force=false);
130
131 int Sync();
132
134
135 int Trunc(long long Offset);
136
137 void UpdtSize(size_t newsz)
138 {updMutex.Lock();
139 if (newsz > mySize) mySize = newsz;
141 }
142
144
145 bool Who(XrdPosixFile **fileP)
146 {*fileP = this; return true;}
147
148 int Write(char *Buff, long long Offs, int Len);
149
150 void Write(XrdOucCacheIOCB &iocb, char *buff, long long offs,
151 int wlen);
152
153 size_t mySize;
154 time_t myMtime;
155 dev_t myRdev;
156 ino_t myInode;
157 mode_t myMode;
158
159static
164static char *sfSFX;
165static short sfSLN;
166static bool ddPosted;
167static int ddNum;
168
169static const int realFD = 1;
170static const int isStrm = 2;
171static const int isUpdt = 4;
172
173 XrdPosixFile(bool &aOK, const char *path, XrdPosixCallBack *cbP=0,
174 int Opts=0);
176
177private:
178
179union {long long currOffset;
182 };
183
184char *fPath;
185char *fOpen;
186char *fLoc;
187union {int cOpt; int numTries;};
189};
190#endif
#define stat(a, b)
Definition: XrdPosix.hh:96
#define AtomicBeg(Mtx)
Definition: XrdSysAtomics.hh:63
#define AtomicGet(x)
Definition: XrdSysAtomics.hh:71
#define AtomicEnd(Mtx)
Definition: XrdSysAtomics.hh:64
#define AtomicRet(mtx, x)
Definition: XrdSysAtomics.hh:76
Definition: XrdClAnyObject.hh:33
A file.
Definition: XrdClFile.hh:45
Handle an async response.
Definition: XrdClXRootDResponses.hh:855
Request status.
Definition: XrdClXRootDResponses.hh:213
Definition: XrdOucCache2.hh:63
Definition: XrdOucCache.hh:94
An abstract class to define a callback for Open() call.
Definition: XrdPosixCallBack.hh:52
Definition: XrdPosixFile.hh:60
XrdPosixFile(bool &aOK, const char *path, XrdPosixCallBack *cbP=0, int Opts=0)
static XrdSysSemaphore ddSem
Definition: XrdPosixFile.hh:160
long long FSize()
Definition: XrdPosixFile.hh:87
static XrdSysMutex ddMutex
Definition: XrdPosixFile.hh:161
XrdPosixFile * nextFile
Definition: XrdPosixFile.hh:181
time_t myMtime
Definition: XrdPosixFile.hh:154
static XrdPosixFile * ddLost
Definition: XrdPosixFile.hh:163
const char * Location()
XrdOucCacheIO2 * XCio
Definition: XrdPosixFile.hh:63
static char * sfSFX
Definition: XrdPosixFile.hh:164
const char * Origin()
Definition: XrdPosixFile.hh:108
bool Who(XrdPosixFile **fileP)
Definition: XrdPosixFile.hh:145
int ReadV(const XrdOucIOVec *readV, int n)
int Write(char *Buff, long long Offs, int Len)
char * fPath
Definition: XrdPosixFile.hh:184
XrdPosixCallBack * theCB
Definition: XrdPosixFile.hh:180
static const int isUpdt
Definition: XrdPosixFile.hh:171
static XrdPosixFile * ddList
Definition: XrdPosixFile.hh:162
static void DelayedDestroy(XrdPosixFile *fp)
static const int isStrm
Definition: XrdPosixFile.hh:170
int cOpt
Definition: XrdPosixFile.hh:187
void Write(XrdOucCacheIOCB &iocb, char *buff, long long offs, int wlen)
XrdPosixPrepIO * PrepIO
Definition: XrdPosixFile.hh:64
void ReadV(XrdOucCacheIOCB &iocb, const XrdOucIOVec *readV, int n)
static bool ddPosted
Definition: XrdPosixFile.hh:166
void UpdtSize(size_t newsz)
Definition: XrdPosixFile.hh:137
long long addOffset(long long offs, int updtSz=0)
Definition: XrdPosixFile.hh:67
void Sync(XrdOucCacheIOCB &iocb)
dev_t myRdev
Definition: XrdPosixFile.hh:155
static int ddNum
Definition: XrdPosixFile.hh:167
int Read(char *Buff, long long Offs, int Len)
int Fstat(struct stat &buf)
char isStream
Definition: XrdPosixFile.hh:188
char * fOpen
Definition: XrdPosixFile.hh:185
size_t mySize
Definition: XrdPosixFile.hh:153
void updLock()
Definition: XrdPosixFile.hh:102
int Trunc(long long Offset)
void HandleResponse(XrdCl::XRootDStatus *status, XrdCl::AnyObject *response)
mode_t myMode
Definition: XrdPosixFile.hh:157
bool Stat(XrdCl::XRootDStatus &Status, bool force=false)
long long currOffset
Definition: XrdPosixFile.hh:179
void updUnLock()
Definition: XrdPosixFile.hh:104
char * fLoc
Definition: XrdPosixFile.hh:186
bool Close(XrdCl::XRootDStatus &Status)
static void * DelayedDestroy(void *)
static short sfSLN
Definition: XrdPosixFile.hh:165
XrdCl::File clFile
Definition: XrdPosixFile.hh:65
void Read(XrdOucCacheIOCB &iocb, char *buff, long long offs, int rlen)
ino_t myInode
Definition: XrdPosixFile.hh:156
const char * Path()
Definition: XrdPosixFile.hh:110
long long Offset()
Definition: XrdPosixFile.hh:106
int numTries
Definition: XrdPosixFile.hh:187
static const int realFD
Definition: XrdPosixFile.hh:169
bool Finalize(XrdCl::XRootDStatus *Status)
long long setOffset(long long offs)
Definition: XrdPosixFile.hh:122
Definition: XrdPosixObject.hh:42
XrdSysRecMutex updMutex
Definition: XrdPosixObject.hh:94
virtual bool Who(XrdPosixDir **dirP)
Definition: XrdPosixObject.hh:86
Definition: XrdPosixPrepIO.hh:37
Definition: XrdSysPthread.hh:166
void Lock()
Definition: XrdSysPthread.hh:220
void UnLock()
Definition: XrdSysPthread.hh:222
Definition: XrdSysPthread.hh:404
Definition: XrdOucIOVec.hh:41