virfile.h 14.3 KB
Newer Older
1
/*
E
Eric Blake 已提交
2
 * virfile.h: safer file handling
3
 *
4
 * Copyright (C) 2010-2014 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
 * Copyright (C) 2010 IBM Corporation
 * Copyright (C) 2010 Stefan Berger
 * Copyright (C) 2010 Eric Blake
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
20
 * License along with this library.  If not, see
O
Osier Yang 已提交
21
 * <http://www.gnu.org/licenses/>.
22 23 24
 *
 */

25
#pragma once
26

27
#include <dirent.h>
28

29 30 31 32
#include "internal.h"
#include "virbitmap.h"
#include "virstoragefile.h"
#include "virautoclean.h"
33

34
typedef enum {
35 36 37 38
    VIR_FILE_CLOSE_PRESERVE_ERRNO = 1 << 0,
    VIR_FILE_CLOSE_IGNORE_EBADF = 1 << 1,
    VIR_FILE_CLOSE_DONT_LOG = 1 << 2,
} virFileCloseFlags;
39

40 41 42
ssize_t saferead(int fd, void *buf, size_t count) ATTRIBUTE_RETURN_CHECK;
ssize_t safewrite(int fd, const void *buf, size_t count)
    ATTRIBUTE_RETURN_CHECK;
43
int safezero(int fd, off_t offset, off_t len)
44
    ATTRIBUTE_RETURN_CHECK;
45 46
int virFileAllocate(int fd, off_t offset, off_t len)
    ATTRIBUTE_RETURN_CHECK;
47

48
/* Don't call these directly - use the macros below */
49
int virFileClose(int *fdptr, virFileCloseFlags flags)
50
        ATTRIBUTE_RETURN_CHECK;
E
Eric Blake 已提交
51 52
int virFileFclose(FILE **file, bool preserve_errno) ATTRIBUTE_RETURN_CHECK;
FILE *virFileFdopen(int *fdptr, const char *mode) ATTRIBUTE_RETURN_CHECK;
53

54 55 56 57 58
static inline void virForceCloseHelper(int *fd)
{
    ignore_value(virFileClose(fd, VIR_FILE_CLOSE_PRESERVE_ERRNO));
}

59
/* For use on normal paths; caller must check return value,
60
   and failure sets errno per close. */
61 62
#define VIR_CLOSE(FD) virFileClose(&(FD), 0)
#define VIR_FCLOSE(FILE) virFileFclose(&(FILE), false)
63 64

/* Wrapper around fdopen that consumes fd on success. */
65
#define VIR_FDOPEN(FD, MODE) virFileFdopen(&(FD), MODE)
66 67 68

/* For use on cleanup paths; errno is unaffected by close,
   and no return value to worry about. */
69 70
#define VIR_FORCE_CLOSE(FD) virForceCloseHelper(&(FD))
#define VIR_FORCE_FCLOSE(FILE) ignore_value(virFileFclose(&(FILE), true))
71

72 73
/* Similar VIR_FORCE_CLOSE() but ignores EBADF errors since they are expected
 * during mass close after fork(). */
74
#define VIR_MASS_CLOSE(FD) \
75 76
    ignore_value(virFileClose(&(FD), \
                 VIR_FILE_CLOSE_PRESERVE_ERRNO | \
77 78
                 VIR_FILE_CLOSE_IGNORE_EBADF))

79
#define VIR_LOG_CLOSE(FD) \
80 81
    ignore_value(virFileClose(&(FD), \
                 VIR_FILE_CLOSE_PRESERVE_ERRNO | \
82
                 VIR_FILE_CLOSE_DONT_LOG))
83

84 85 86 87 88 89 90
/**
 * VIR_AUTOCLOSE:
 *
 * Macro to automatically force close the fd by calling virForceCloseHelper
 * when the fd goes out of scope. It's used to eliminate VIR_FORCE_CLOSE
 * in cleanup sections.
 */
91
#define VIR_AUTOCLOSE __attribute__((cleanup(virForceCloseHelper))) int
92 93


J
Jiri Denemark 已提交
94 95
/* Opaque type for managing a wrapper around a fd.  */
struct _virFileWrapperFd;
96

J
Jiri Denemark 已提交
97 98
typedef struct _virFileWrapperFd virFileWrapperFd;
typedef virFileWrapperFd *virFileWrapperFdPtr;
99 100 101

int virFileDirectFdFlag(void);

102
typedef enum {
J
Jiri Denemark 已提交
103 104
    VIR_FILE_WRAPPER_BYPASS_CACHE   = (1 << 0),
    VIR_FILE_WRAPPER_NON_BLOCKING   = (1 << 1),
105
} virFileWrapperFdFlags;
J
Jiri Denemark 已提交
106 107 108 109

virFileWrapperFdPtr virFileWrapperFdNew(int *fd,
                                        const char *name,
                                        unsigned int flags)
110 111
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;

J
Jiri Denemark 已提交
112
int virFileWrapperFdClose(virFileWrapperFdPtr dfd);
113

J
Jiri Denemark 已提交
114
void virFileWrapperFdFree(virFileWrapperFdPtr dfd);
115

116 117 118 119
int virFileLock(int fd, bool shared, off_t start, off_t len, bool waitForLock)
    ATTRIBUTE_NOINLINE;
int virFileUnlock(int fd, off_t start, off_t len)
    ATTRIBUTE_NOINLINE;
120

M
Martin Kletzander 已提交
121 122
int virFileFlock(int fd, bool lock, bool shared);

123
typedef int (*virFileRewriteFunc)(int fd, const void *opaque);
124 125 126
int virFileRewrite(const char *path,
                   mode_t mode,
                   virFileRewriteFunc rewrite,
127 128 129 130
                   const void *opaque);
int virFileRewriteStr(const char *path,
                      mode_t mode,
                      const char *str);
131

132 133
int virFileTouch(const char *path, mode_t mode);

134 135 136 137
int virFileUpdatePerm(const char *path,
                      mode_t mode_remove,
                      mode_t mode_add);

138 139 140
int virFileLoopDeviceAssociate(const char *file,
                               char **dev);

141
int virFileNBDDeviceAssociate(const char *file,
142
                              virStorageFileFormat fmt,
143 144 145
                              bool readonly,
                              char **dev);

146 147
int virFileDeleteTree(const char *dir);

148 149
int virFileReadHeaderFD(int fd, int maxlen, char **buf)
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(3);
150 151
int virFileReadHeaderQuiet(const char *path, int maxlen, char **buf)
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(3);
152 153 154 155
int virFileReadLimFD(int fd, int maxlen, char **buf)
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(3);
int virFileReadAll(const char *path, int maxlen, char **buf)
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(3);
J
Ján Tomko 已提交
156 157
int virFileReadAllQuiet(const char *path, int maxlen, char **buf)
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(3);
158 159
int virFileReadBufQuiet(const char *file, char *buf, int len)
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
160 161 162 163 164

int virFileWriteStr(const char *path, const char *str, mode_t mode)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;

int virFileLinkPointsTo(const char *checkLink,
165 166 167 168 169 170
                        const char *checkDest)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
int virFileRelLinkPointsTo(const char *directory,
                           const char *checkLink,
                           const char *checkDest)
    ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);
171 172 173 174 175 176 177 178 179

int virFileResolveLink(const char *linkpath,
                       char **resultpath) ATTRIBUTE_RETURN_CHECK;
int virFileResolveAllLinks(const char *linkpath,
                           char **resultpath) ATTRIBUTE_RETURN_CHECK;

int virFileIsLink(const char *linkpath)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

180 181 182
int virFileReadLink(const char *linkpath, char **resultpath)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;

183 184
char *virFindFileInPath(const char *file);

185 186 187 188 189 190 191 192 193 194 195 196 197 198
char *virFileFindResource(const char *filename,
                          const char *builddir,
                          const char *installdir)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);
char *virFileFindResourceFull(const char *filename,
                              const char *prefix,
                              const char *suffix,
                              const char *builddir,
                              const char *installdir,
                              const char *envname)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(4) ATTRIBUTE_NONNULL(5);
void virFileActivateDirOverride(const char *argv0)
    ATTRIBUTE_NONNULL(1);

L
Laine Stump 已提交
199
off_t virFileLength(const char *path, int fd) ATTRIBUTE_NONNULL(1);
200
bool virFileIsDir (const char *file) ATTRIBUTE_NONNULL(1);
201
bool virFileExists(const char *file) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NOINLINE;
202
bool virFileIsExecutable(const char *file) ATTRIBUTE_NONNULL(1);
203
bool virFileIsRegular(const char *file) ATTRIBUTE_NONNULL(1);
204

205 206 207 208 209 210 211
enum {
    VIR_FILE_SHFS_NFS = (1 << 0),
    VIR_FILE_SHFS_GFS2 = (1 << 1),
    VIR_FILE_SHFS_OCFS = (1 << 2),
    VIR_FILE_SHFS_AFS = (1 << 3),
    VIR_FILE_SHFS_SMB = (1 << 4),
    VIR_FILE_SHFS_CIFS = (1 << 5),
212
    VIR_FILE_SHFS_CEPH = (1 << 6),
213
    VIR_FILE_SHFS_GPFS = (1 << 7),
214 215 216 217
};

int virFileIsSharedFSType(const char *path, int fstypes) ATTRIBUTE_NONNULL(1);
int virFileIsSharedFS(const char *path) ATTRIBUTE_NONNULL(1);
218
int virFileIsMountPoint(const char *file) ATTRIBUTE_NONNULL(1);
219 220
int virFileIsCDROM(const char *path)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
221

222 223 224 225 226 227 228 229 230
int virFileGetMountSubtree(const char *mtabpath,
                           const char *prefix,
                           char ***mountsret,
                           size_t *nmountsret) ATTRIBUTE_RETURN_CHECK;
int virFileGetMountReverseSubtree(const char *mtabpath,
                                  const char *prefix,
                                  char ***mountsret,
                                  size_t *nmountsret) ATTRIBUTE_RETURN_CHECK;

231
char *virFileSanitizePath(const char *path);
232
char *virFileCanonicalizePath(const char *path) ATTRIBUTE_NOINLINE;
233 234 235 236 237 238 239 240 241 242 243 244 245 246 247

enum {
    VIR_FILE_OPEN_NONE        = 0,
    VIR_FILE_OPEN_NOFORK      = (1 << 0),
    VIR_FILE_OPEN_FORK        = (1 << 1),
    VIR_FILE_OPEN_FORCE_MODE  = (1 << 2),
    VIR_FILE_OPEN_FORCE_OWNER = (1 << 3),
};
int virFileAccessibleAs(const char *path, int mode,
                        uid_t uid, gid_t gid)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
int virFileOpenAs(const char *path, int openflags, mode_t mode,
                  uid_t uid, gid_t gid,
                  unsigned int flags)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
248
int virFileRemove(const char *path, uid_t uid, gid_t gid);
249

250 251 252
int virFileChownFiles(const char *name, uid_t uid, gid_t gid)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

253 254 255
enum {
    VIR_DIR_CREATE_NONE        = 0,
    VIR_DIR_CREATE_AS_UID      = (1 << 0),
256
    VIR_DIR_CREATE_ALLOW_EXIST = (1 << 1),
257 258 259
};
int virDirCreate(const char *path, mode_t mode, uid_t uid, gid_t gid,
                 unsigned int flags) ATTRIBUTE_RETURN_CHECK;
J
Ján Tomko 已提交
260 261
int virDirOpen(DIR **dirp, const char *dirname)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
J
Ján Tomko 已提交
262 263
int virDirOpenIfExists(DIR **dirp, const char *dirname)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
J
Ján Tomko 已提交
264 265
int virDirOpenQuiet(DIR **dirp, const char *dirname)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
266 267
int virDirRead(DIR *dirp, struct dirent **ent, const char *dirname)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
J
Ján Tomko 已提交
268 269
void virDirClose(DIR **dirp)
    ATTRIBUTE_NONNULL(1);
270
#define VIR_DIR_CLOSE(dir)  virDirClose(&(dir))
271

272 273 274
int virFileMakePath(const char *path) ATTRIBUTE_RETURN_CHECK;
int virFileMakePathWithMode(const char *path,
                            mode_t mode) ATTRIBUTE_RETURN_CHECK;
275
int virFileMakeParentPath(const char *path) ATTRIBUTE_RETURN_CHECK;
276 277 278 279 280 281

char *virFileBuildPath(const char *dir,
                       const char *name,
                       const char *ext) ATTRIBUTE_RETURN_CHECK;


282
#ifdef WIN32
283 284 285 286
/* On Win32, the canonical directory separator is the backslash, and
 * the search path separator is the semicolon. Note that also the
 * (forward) slash works as directory separator.
 */
287 288 289 290 291
# define VIR_FILE_DIR_SEPARATOR '\\'
# define VIR_FILE_DIR_SEPARATOR_S "\\"
# define VIR_FILE_IS_DIR_SEPARATOR(c) ((c) == VIR_FILE_DIR_SEPARATOR || (c) == '/')
# define VIR_FILE_PATH_SEPARATOR ';'
# define VIR_FILE_PATH_SEPARATOR_S ";"
292

293
#else  /* !WIN32 */
294

295 296 297 298 299
# define VIR_FILE_DIR_SEPARATOR '/'
# define VIR_FILE_DIR_SEPARATOR_S "/"
# define VIR_FILE_IS_DIR_SEPARATOR(c) ((c) == VIR_FILE_DIR_SEPARATOR)
# define VIR_FILE_PATH_SEPARATOR ':'
# define VIR_FILE_PATH_SEPARATOR_S ":"
300

301
#endif /* !WIN32 */
302 303 304 305 306

bool virFileIsAbsPath(const char *path);
int virFileAbsPath(const char *path,
                   char **abspath) ATTRIBUTE_RETURN_CHECK;
const char *virFileSkipRoot(const char *path);
307
void virFileRemoveLastComponent(char *path);
308 309 310 311 312 313 314 315

int virFileOpenTty(int *ttymaster,
                   char **ttyName,
                   int rawmode);

char *virFileFindMountPoint(const char *type);

/* NB: this should be combined with virFileBuildPath */
316
#define virBuildPath(path, ...) \
317 318 319
    virBuildPathInternal(path, __VA_ARGS__, NULL)
int virBuildPathInternal(char **path, ...) ATTRIBUTE_SENTINEL;

320 321 322
int virFilePrintf(FILE *fp, const char *msg, ...)
    ATTRIBUTE_FMT_PRINTF(2, 3);

323 324 325 326 327 328 329 330 331 332 333 334
typedef struct _virHugeTLBFS virHugeTLBFS;
typedef virHugeTLBFS *virHugeTLBFSPtr;
struct _virHugeTLBFS {
    char *mnt_dir;                  /* Where the FS is mount to */
    unsigned long long size;        /* page size in kibibytes */
    bool deflt;                     /* is this the default huge page size */
};

int virFileGetHugepageSize(const char *path,
                           unsigned long long *size);
int virFileFindHugeTLBFS(virHugeTLBFSPtr *ret_fs,
                         size_t *ret_nfs);
335

336 337 338
virHugeTLBFSPtr virFileGetDefaultHugepage(virHugeTLBFSPtr fs,
                                          size_t nfs);

339 340 341 342 343
int virFileSetupDev(const char *path,
                    const char *mount_options);

int virFileBindMountDevice(const char *src,
                           const char *dst);
M
Michal Privoznik 已提交
344

345 346 347
int virFileMoveMount(const char *src,
                     const char *dst);

M
Michal Privoznik 已提交
348 349 350 351 352 353 354 355 356 357
int virFileGetACLs(const char *file,
                   void **acl);

int virFileSetACLs(const char *file,
                   void *acl);

void virFileFreeACLs(void **acl);

int virFileCopyACLs(const char *src,
                    const char *dst);
358 359

int virFileComparePaths(const char *p1, const char *p2);
360

361 362 363 364 365 366 367 368 369 370 371
int virFileReadValueInt(int *value, const char *format, ...)
 ATTRIBUTE_FMT_PRINTF(2, 3);
int virFileReadValueUint(unsigned int *value, const char *format, ...)
 ATTRIBUTE_FMT_PRINTF(2, 3);
int virFileReadValueBitmap(virBitmapPtr *value, const char *format, ...)
 ATTRIBUTE_FMT_PRINTF(2, 3);
int virFileReadValueScaledInt(unsigned long long *value, const char *format, ...)
 ATTRIBUTE_FMT_PRINTF(2, 3);
int virFileReadValueString(char **value, const char *format, ...)
 ATTRIBUTE_FMT_PRINTF(2, 3);

372 373
int virFileWaitForExists(const char *path, size_t ms, size_t tries);

374

M
Michal Privoznik 已提交
375 376 377 378
int virFileInData(int fd,
                  int *inData,
                  long long *length);

379
VIR_DEFINE_AUTOPTR_FUNC(virFileWrapperFd, virFileWrapperFdFree);
380

381 382
int virFileGetXAttr(const char *path,
                    const char *name,
383 384
                    char **value)
    ATTRIBUTE_NOINLINE;
385

386 387 388 389 390
int virFileGetXAttrQuiet(const char *path,
                         const char *name,
                         char **value)
    ATTRIBUTE_NOINLINE;

391 392
int virFileSetXAttr(const char *path,
                    const char *name,
393 394
                    const char *value)
    ATTRIBUTE_NOINLINE;
395 396

int virFileRemoveXAttr(const char *path,
397 398
                       const char *name)
    ATTRIBUTE_NOINLINE;