virstoragefile.h 21.2 KB
Newer Older
1
/*
2
 * virstoragefile.h: file utility functions for FS storage backend
3
 *
4
 * Copyright (C) 2007-2009, 2012-2016 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16 17
 * Copyright (C) 2007-2008 Daniel P. Berrange
 *
 * 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
18
 * License along with this library.  If not, see
O
Osier Yang 已提交
19
 * <http://www.gnu.org/licenses/>.
20 21
 */

22
#pragma once
23

24
#include <sys/stat.h>
25

26 27 28 29 30 31
#include "virbitmap.h"
#include "virobject.h"
#include "virseclabel.h"
#include "virstorageencryption.h"
#include "virsecret.h"
#include "virenum.h"
32
#include "virpci.h"
33

34 35 36 37 38 39
/* Minimum header size required to probe all known formats with
 * virStorageFileProbeFormat, or obtain metadata from a known format.
 * Rounded to multiple of 512 (ISO has a 5-byte magic at offset
 * 32769).  Some formats can be probed with fewer bytes.  Although
 * some formats theoretically permit metadata that can rely on offsets
 * beyond this size, in practice that doesn't matter.  */
40
#define VIR_STORAGE_MAX_HEADER 0x8200
41

E
Eric Blake 已提交
42

43 44 45 46
/* Types of disk backends (host resource).  Comparable to the public
 * virStorageVolType, except we have an undetermined state, don't have
 * a netdir type, and add a volume type for reference through a
 * storage pool.  */
47
typedef enum {
48
    VIR_STORAGE_TYPE_NONE,
E
Eric Blake 已提交
49
    VIR_STORAGE_TYPE_FILE,
50
    VIR_STORAGE_TYPE_BLOCK,
E
Eric Blake 已提交
51 52 53
    VIR_STORAGE_TYPE_DIR,
    VIR_STORAGE_TYPE_NETWORK,
    VIR_STORAGE_TYPE_VOLUME,
54
    VIR_STORAGE_TYPE_NVME,
E
Eric Blake 已提交
55 56

    VIR_STORAGE_TYPE_LAST
57
} virStorageType;
E
Eric Blake 已提交
58

59
VIR_ENUM_DECL(virStorage);
E
Eric Blake 已提交
60 61


62
typedef enum {
63
    VIR_STORAGE_FILE_AUTO_SAFE = -2,
64
    VIR_STORAGE_FILE_AUTO = -1,
E
Eric Blake 已提交
65 66
    VIR_STORAGE_FILE_NONE = 0,
    VIR_STORAGE_FILE_RAW,
67 68 69 70 71
    VIR_STORAGE_FILE_DIR,
    VIR_STORAGE_FILE_BOCHS,
    VIR_STORAGE_FILE_CLOOP,
    VIR_STORAGE_FILE_DMG,
    VIR_STORAGE_FILE_ISO,
72 73 74 75 76 77
    VIR_STORAGE_FILE_VPC,
    VIR_STORAGE_FILE_VDI,

    /* Not direct file formats, but used for various drivers */
    VIR_STORAGE_FILE_FAT,
    VIR_STORAGE_FILE_VHD,
78
    VIR_STORAGE_FILE_PLOOP,
79 80 81 82 83 84

    /* Not a format, but a marker: all formats below this point have
     * libvirt support for following a backing chain */
    VIR_STORAGE_FILE_BACKING,

    VIR_STORAGE_FILE_COW = VIR_STORAGE_FILE_BACKING,
85 86
    VIR_STORAGE_FILE_QCOW,
    VIR_STORAGE_FILE_QCOW2,
A
Adam Litke 已提交
87
    VIR_STORAGE_FILE_QED,
88
    VIR_STORAGE_FILE_VMDK,
E
Eric Blake 已提交
89

90
    VIR_STORAGE_FILE_LAST,
91
} virStorageFileFormat;
92 93 94

VIR_ENUM_DECL(virStorageFileFormat);

95
typedef enum {
96
    VIR_STORAGE_FILE_FEATURE_LAZY_REFCOUNTS = 0,
97 98

    VIR_STORAGE_FILE_FEATURE_LAST
99
} virStorageFileFeature;
100 101 102

VIR_ENUM_DECL(virStorageFileFeature);

E
Eric Blake 已提交
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
typedef struct _virStoragePerms virStoragePerms;
typedef virStoragePerms *virStoragePermsPtr;
struct _virStoragePerms {
    mode_t mode;
    uid_t uid;
    gid_t gid;
    char *label;
};


typedef struct _virStorageTimestamps virStorageTimestamps;
typedef virStorageTimestamps *virStorageTimestampsPtr;
struct _virStorageTimestamps {
    struct timespec atime;
    struct timespec btime; /* birth time unknown if btime.tv_nsec == -1 */
    struct timespec ctime;
    struct timespec mtime;
};


123
/* Information related to network storage */
124
typedef enum {
125
    VIR_STORAGE_NET_PROTOCOL_NONE,
126 127 128 129 130 131 132 133 134 135
    VIR_STORAGE_NET_PROTOCOL_NBD,
    VIR_STORAGE_NET_PROTOCOL_RBD,
    VIR_STORAGE_NET_PROTOCOL_SHEEPDOG,
    VIR_STORAGE_NET_PROTOCOL_GLUSTER,
    VIR_STORAGE_NET_PROTOCOL_ISCSI,
    VIR_STORAGE_NET_PROTOCOL_HTTP,
    VIR_STORAGE_NET_PROTOCOL_HTTPS,
    VIR_STORAGE_NET_PROTOCOL_FTP,
    VIR_STORAGE_NET_PROTOCOL_FTPS,
    VIR_STORAGE_NET_PROTOCOL_TFTP,
136
    VIR_STORAGE_NET_PROTOCOL_SSH,
137
    VIR_STORAGE_NET_PROTOCOL_VXHS,
138 139

    VIR_STORAGE_NET_PROTOCOL_LAST
140
} virStorageNetProtocol;
141

142
VIR_ENUM_DECL(virStorageNetProtocol);
143 144


145
typedef enum {
146 147 148 149 150
    VIR_STORAGE_NET_HOST_TRANS_TCP,
    VIR_STORAGE_NET_HOST_TRANS_UNIX,
    VIR_STORAGE_NET_HOST_TRANS_RDMA,

    VIR_STORAGE_NET_HOST_TRANS_LAST
151
} virStorageNetHostTransport;
152

153
VIR_ENUM_DECL(virStorageNetHostTransport);
154 155 156 157 158

typedef struct _virStorageNetHostDef virStorageNetHostDef;
typedef virStorageNetHostDef *virStorageNetHostDefPtr;
struct _virStorageNetHostDef {
    char *name;
159
    unsigned int port;
160
    int transport; /* virStorageNetHostTransport */
161 162 163
    char *socket;  /* path to unix socket */
};

164 165 166 167 168 169 170 171 172 173 174
typedef struct _virStorageNetCookieDef virStorageNetCookieDef;
typedef virStorageNetCookieDef *virStorageNetCookieDefPtr;
struct _virStorageNetCookieDef {
    char *name;
    char *value;
};

void virStorageNetCookieDefFree(virStorageNetCookieDefPtr def);

G_DEFINE_AUTOPTR_CLEANUP_FUNC(virStorageNetCookieDef, virStorageNetCookieDefFree);

175 176 177 178 179 180
/* Information for a storage volume from a virStoragePool */

/*
 * Used for volume "type" disk to indicate how to represent
 * the disk source if the specified "pool" is of iscsi type.
 */
181
typedef enum {
182 183 184 185 186 187 188 189 190 191 192 193 194
    VIR_STORAGE_SOURCE_POOL_MODE_DEFAULT = 0,

    /* Use the path as it shows up on host, e.g.
     * /dev/disk/by-path/ip-$ip-iscsi-$iqn:iscsi.iscsi-pool0-lun-1
     */
    VIR_STORAGE_SOURCE_POOL_MODE_HOST,

    /* Use the URI from the storage pool source element host attribute. E.g.
     * file=iscsi://demo.org:6000/iqn.1992-01.com.example/1.
     */
    VIR_STORAGE_SOURCE_POOL_MODE_DIRECT,

    VIR_STORAGE_SOURCE_POOL_MODE_LAST
195
} virStorageSourcePoolMode;
196

197
VIR_ENUM_DECL(virStorageSourcePoolMode);
198 199 200 201 202

typedef struct _virStorageSourcePoolDef virStorageSourcePoolDef;
struct _virStorageSourcePoolDef {
    char *pool; /* pool name */
    char *volume; /* volume name */
203
    int voltype; /* virStorageVolType, internal only */
204
    int pooltype; /* virStoragePoolType from storage_conf.h, internal only */
205
    int actualtype; /* virStorageType, internal only */
206
    int mode; /* virStorageSourcePoolMode, currently makes sense only for iscsi pool */
207 208 209
};
typedef virStorageSourcePoolDef *virStorageSourcePoolDefPtr;

210

211 212 213 214 215 216 217
typedef enum {
    VIR_STORAGE_AUTH_TYPE_NONE,
    VIR_STORAGE_AUTH_TYPE_CHAP,
    VIR_STORAGE_AUTH_TYPE_CEPHX,

    VIR_STORAGE_AUTH_TYPE_LAST,
} virStorageAuthType;
218
VIR_ENUM_DECL(virStorageAuth);
219 220 221 222 223 224 225

typedef struct _virStorageAuthDef virStorageAuthDef;
typedef virStorageAuthDef *virStorageAuthDefPtr;
struct _virStorageAuthDef {
    char *username;
    char *secrettype; /* <secret type='%s' for disk source */
    int authType;     /* virStorageAuthType */
226
    virSecretLookupTypeDef seclookupdef;
227 228
};

229 230 231 232 233
typedef struct _virStoragePRDef virStoragePRDef;
typedef virStoragePRDef *virStoragePRDefPtr;
struct _virStoragePRDef {
    int managed; /* enum virTristateBool */
    char *path;
234 235 236

    /* manager object alias */
    char *mgralias;
237 238
};

239 240 241 242 243 244
typedef struct _virStorageSourceInitiatorDef virStorageSourceInitiatorDef;
typedef virStorageSourceInitiatorDef *virStorageSourceInitiatorDefPtr;
struct _virStorageSourceInitiatorDef {
    char *iqn; /* Initiator IQN */
};

245 246 247
typedef struct _virStorageSourceNVMeDef virStorageSourceNVMeDef;
typedef virStorageSourceNVMeDef *virStorageSourceNVMeDefPtr;
struct _virStorageSourceNVMeDef {
248
    unsigned long long namespc;
249 250 251 252 253 254
    int managed; /* enum virTristateBool */
    virPCIDeviceAddress pciAddr;

    /* Don't forget to update virStorageSourceNVMeDefCopy */
};

255 256 257 258 259 260 261 262 263 264

typedef struct _virStorageSourceSlice virStorageSourceSlice;
typedef virStorageSourceSlice *virStorageSourceSlicePtr;
struct _virStorageSourceSlice {
    unsigned long long offset;
    unsigned long long size;
    char *nodename;
};


265 266
typedef struct _virStorageDriverData virStorageDriverData;
typedef virStorageDriverData *virStorageDriverDataPtr;
267

268 269 270
typedef struct _virStorageSource virStorageSource;
typedef virStorageSource *virStorageSourcePtr;

271 272 273 274 275
/* Stores information related to a host resource.  In the case of backing
 * chains, multiple source disks join to form a single guest view.
 *
 * IMPORTANT: When adding fields to this struct it's also necessary to add
 * appropriate code to the virStorageSourceCopy deep copy function */
276
struct _virStorageSource {
277 278
    virObject parent;

279
    unsigned int id; /* backing chain identifier, 0 is unset */
280
    int type; /* virStorageType */
281
    char *path;
282
    int protocol; /* virStorageNetProtocol */
283
    char *volume; /* volume name for remote storage */
284
    char *snapshot; /* for storage systems supporting internal snapshots */
285 286
    char *configFile; /* some storage systems use config file as part of
                         the source definition */
287
    char *query; /* query string for HTTP based protocols */
288 289
    size_t nhosts;
    virStorageNetHostDefPtr hosts;
290 291
    size_t ncookies;
    virStorageNetCookieDefPtr *cookies;
292
    virStorageSourcePoolDefPtr srcpool;
293
    virStorageAuthDefPtr auth;
294
    bool authInherited;
295
    virStorageEncryptionPtr encryption;
296
    bool encryptionInherited;
297
    virStoragePRDefPtr pr;
298
    virTristateBool sslverify;
299 300 301
    /* both values below have 0 as default value */
    unsigned long long readahead; /* size of the readahead buffer in bytes */
    unsigned long long timeout; /* connection timeout in seconds */
E
Eric Blake 已提交
302

303 304
    virStorageSourceNVMeDefPtr nvme; /* type == VIR_STORAGE_TYPE_NVME */

305 306
    virStorageSourceInitiatorDef initiator;

307 308
    virObjectPtr privateData;

309 310
    int format; /* virStorageFileFormat in domain backing chains, but
                 * pool-specific enum for storage volumes */
E
Eric Blake 已提交
311 312
    virBitmapPtr features;
    char *compat;
C
Chunyan Liu 已提交
313
    bool nocow;
314
    bool sparse;
315

316 317
    virStorageSourceSlicePtr sliceStorage;

E
Eric Blake 已提交
318 319
    virStoragePermsPtr perms;
    virStorageTimestampsPtr timestamps;
320
    unsigned long long capacity; /* in bytes, 0 if unknown */
321 322
    unsigned long long allocation; /* in bytes, 0 if unknown */
    unsigned long long physical; /* in bytes, 0 if unknown */
323 324
    bool has_allocation; /* Set to true when provided in XML */

325 326
    size_t nseclabels;
    virSecurityDeviceLabelDefPtr *seclabels;
327

328 329 330 331 332 333
    /* Don't ever write to the image */
    bool readonly;

    /* image is shared across hosts */
    bool shared;

334
    /* backing chain of the storage source */
335
    virStorageSourcePtr backingStore;
336

337 338
    /* metadata for storage driver access to remote and local volumes */
    virStorageDriverDataPtr drv;
339 340

    /* metadata about storage image which need separate fields */
341 342
    /* Relative name by which this image was opened from its parent, or NULL
     * if this image was opened by absolute name */
343 344 345 346
    char *relPath;
    /* Name of the child backing store recorded in metadata of the
     * current file.  */
    char *backingStoreRaw;
347
    virStorageFileFormat backingStoreRawFormat;
348 349 350

    /* metadata that allows identifying given storage source */
    char *nodeformat;  /* name of the format handler object */
351
    char *nodestorage; /* name of the storage object */
352 353 354 355 356 357 358

    /* An optional setting to enable usage of TLS for the storage source */
    int haveTLS; /* enum virTristateBool */

    /* Indication whether the haveTLS value was altered due to qemu.conf
     * setting when haveTLS is missing from the domain config file */
    bool tlsFromConfig;
359 360 361 362 363 364

    /* If TLS is used, then mgmt of the TLS credentials occurs via an
     * object that is generated using a specific alias for a specific
     * certificate directory with listen and verify bools. */
    char *tlsAlias;
    char *tlsCertdir;
365 366

    bool detected; /* true if this entry was not provided by the user */
367 368 369

    unsigned int debugLevel;
    bool debug;
370

371
    /* Libvirt currently stores the following properties in virDomainDiskDef.
372 373 374 375 376 377
     * These instances are currently just copies from the parent definition and
     * are not mapped back to the XML */
    int iomode; /* enum virDomainDiskIo */
    int cachemode; /* enum virDomainDiskCache */
    int discard; /* enum virDomainDiskDiscard */
    int detect_zeroes; /* enum virDomainDiskDetectZeroes */
378 379 380

    bool floppyimg; /* set to true if the storage source is going to be used
                       as a source for floppy drive */
381 382

    bool hostcdrom; /* backing device is a cdrom */
383 384 385 386 387

    /* passthrough variables for the ssh driver which we don't handle properly */
    /* these must not be used apart from formatting the output JSON in the qemu driver */
    char *ssh_user;
    bool ssh_host_key_check_disabled;
388 389
};

390 391
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virStorageSource, virObjectUnref);

392

393 394 395
#ifndef DEV_BSIZE
# define DEV_BSIZE 512
#endif
396

397
int virStorageFileProbeFormat(const char *path, uid_t uid, gid_t gid);
398

399 400
virStorageSourcePtr virStorageFileGetMetadataFromFD(const char *path,
                                                    int fd,
401
                                                    int format);
402 403 404
virStorageSourcePtr virStorageFileGetMetadataFromBuf(const char *path,
                                                     char *buf,
                                                     size_t len,
405
                                                     int format)
406
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
407
int virStorageFileChainGetBroken(virStorageSourcePtr chain,
408
                                 char **broken_file);
409

410 411 412 413 414
int virStorageFileParseChainIndex(const char *diskTarget,
                                  const char *name,
                                  unsigned int *chainIndex)
    ATTRIBUTE_NONNULL(3);

415 416 417 418 419
int virStorageFileParseBackingStoreStr(const char *str,
                                       char **target,
                                       unsigned int *chainIndex)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(3);

420
virStorageSourcePtr virStorageFileChainLookup(virStorageSourcePtr chain,
421
                                              virStorageSourcePtr startFrom,
422
                                              const char *name,
423
                                              unsigned int idx,
424
                                              virStorageSourcePtr *parent)
425
    ATTRIBUTE_NONNULL(1);
426

427 428 429
int virStorageFileResize(const char *path,
                         unsigned long long capacity,
                         bool pre_allocate);
430

431
int virStorageFileIsClusterFS(const char *path);
432
bool virStorageIsFile(const char *path);
433
bool virStorageIsRelative(const char *backing);
434

435 436 437
int virStorageFileGetLVMKey(const char *path,
                            char **key);
int virStorageFileGetSCSIKey(const char *path,
438 439
                             char **key,
                             bool ignoreError);
440 441
int virStorageFileGetNPIVKey(const char *path,
                             char **key);
442

443 444
void virStorageAuthDefFree(virStorageAuthDefPtr def);
virStorageAuthDefPtr virStorageAuthDefCopy(const virStorageAuthDef *src);
445 446
virStorageAuthDefPtr virStorageAuthDefParse(xmlNodePtr node,
                                            xmlXPathContextPtr ctxt);
447
void virStorageAuthDefFormat(virBufferPtr buf, virStorageAuthDefPtr authdef);
448

449 450 451
void virStoragePRDefFree(virStoragePRDefPtr prd);
virStoragePRDefPtr virStoragePRDefParseXML(xmlXPathContextPtr ctxt);
void virStoragePRDefFormat(virBufferPtr buf,
452 453
                           virStoragePRDefPtr prd,
                           bool migratable);
454 455
bool virStoragePRDefIsEqual(virStoragePRDefPtr a,
                            virStoragePRDefPtr b);
456
bool virStoragePRDefIsManaged(virStoragePRDefPtr prd);
457

458 459 460
bool
virStorageSourceChainHasManagedPR(virStorageSourcePtr src);

461 462 463
void virStorageSourceNVMeDefFree(virStorageSourceNVMeDefPtr def);
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virStorageSourceNVMeDef, virStorageSourceNVMeDefFree);

464 465
bool virStorageSourceChainHasNVMe(const virStorageSource *src);

466 467 468 469
virSecurityDeviceLabelDefPtr
virStorageSourceGetSecurityLabelDef(virStorageSourcePtr src,
                                    const char *model);

470 471 472 473 474
void virStorageNetHostDefClear(virStorageNetHostDefPtr def);
void virStorageNetHostDefFree(size_t nhosts, virStorageNetHostDefPtr hosts);
virStorageNetHostDefPtr virStorageNetHostDefCopy(size_t nhosts,
                                                 virStorageNetHostDefPtr hosts);

475 476 477
int virStorageSourceInitChainElement(virStorageSourcePtr newelem,
                                     virStorageSourcePtr old,
                                     bool force);
478 479
void virStorageSourcePoolDefFree(virStorageSourcePoolDefPtr def);
void virStorageSourceClear(virStorageSourcePtr def);
480
int virStorageSourceGetActualType(const virStorageSource *def);
481
bool virStorageSourceIsLocalStorage(const virStorageSource *src);
482
bool virStorageSourceIsEmpty(virStorageSourcePtr src);
483
bool virStorageSourceIsBlockLocal(const virStorageSource *src);
484
virStorageSourcePtr virStorageSourceNew(void);
485
void virStorageSourceBackingStoreClear(virStorageSourcePtr def);
486 487
int virStorageSourceUpdatePhysicalSize(virStorageSourcePtr src,
                                       int fd, struct stat const *sb);
488 489
int virStorageSourceUpdateBackingSizes(virStorageSourcePtr src,
                                       int fd, struct stat const *sb);
490
int virStorageSourceUpdateCapacity(virStorageSourcePtr src,
491
                                   char *buf, ssize_t len);
492

493 494 495
int virStorageSourceNewFromBacking(virStorageSourcePtr parent,
                                   virStorageSourcePtr *backing);

496 497
int virStorageSourceNetCookiesValidate(virStorageSourcePtr src);

498 499 500
virStorageSourcePtr virStorageSourceCopy(const virStorageSource *src,
                                         bool backingChain)
    ATTRIBUTE_NONNULL(1);
501 502 503
bool virStorageSourceIsSameLocation(virStorageSourcePtr a,
                                    virStorageSourcePtr b)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
504

505 506 507 508
int virStorageSourceParseRBDColonString(const char *rbdstr,
                                        virStorageSourcePtr src)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

509 510 511 512 513 514 515
typedef int
(*virStorageFileSimplifyPathReadlinkCallback)(const char *path,
                                              char **link,
                                              void *data);
char *virStorageFileCanonicalizePath(const char *path,
                                     virStorageFileSimplifyPathReadlinkCallback cb,
                                     void *cbdata);
516

517 518 519 520 521
int virStorageFileGetRelativeBackingPath(virStorageSourcePtr from,
                                         virStorageSourcePtr to,
                                         char **relpath)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

522
int virStorageFileCheckCompat(const char *compat);
523

524 525
int virStorageSourceNewFromBackingAbsolute(const char *path,
                                           virStorageSourcePtr *src);
526

527 528
bool virStorageSourceIsRelative(virStorageSourcePtr src);

529 530 531 532 533 534
virStorageSourcePtr
virStorageSourceFindByNodeName(virStorageSourcePtr top,
                               const char *nodeName,
                               unsigned int *index)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

535
void
536 537
virStorageSourceNetworkAssignDefaultPorts(virStorageSourcePtr src)
    ATTRIBUTE_NONNULL(1);
538

539 540 541 542 543 544
bool
virStorageSourceIsBacking(const virStorageSource *src);
bool
virStorageSourceHasBacking(const virStorageSource *src);


545 546 547 548 549 550 551
int
virStorageSourcePrivateDataParseRelPath(xmlXPathContextPtr ctxt,
                                        virStorageSourcePtr src);
int
virStorageSourcePrivateDataFormatRelPath(virStorageSourcePtr src,
                                         virBufferPtr buf);

552 553 554 555 556 557 558 559 560 561 562 563 564 565 566
void
virStorageSourceInitiatorParseXML(xmlXPathContextPtr ctxt,
                                  virStorageSourceInitiatorDefPtr initiator);

void
virStorageSourceInitiatorFormatXML(virStorageSourceInitiatorDefPtr initiator,
                                   virBufferPtr buf);

int
virStorageSourceInitiatorCopy(virStorageSourceInitiatorDefPtr dest,
                              const virStorageSourceInitiatorDef *src);

void
virStorageSourceInitiatorClear(virStorageSourceInitiatorDefPtr initiator);

567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583
int virStorageFileInit(virStorageSourcePtr src);
int virStorageFileInitAs(virStorageSourcePtr src,
                         uid_t uid, gid_t gid);
void virStorageFileDeinit(virStorageSourcePtr src);

int virStorageFileCreate(virStorageSourcePtr src);
int virStorageFileUnlink(virStorageSourcePtr src);
int virStorageFileStat(virStorageSourcePtr src,
                       struct stat *stat);
ssize_t virStorageFileRead(virStorageSourcePtr src,
                           size_t offset,
                           size_t len,
                           char **buf);
const char *virStorageFileGetUniqueIdentifier(virStorageSourcePtr src);
int virStorageFileAccess(virStorageSourcePtr src, int mode);
int virStorageFileChown(const virStorageSource *src, uid_t uid, gid_t gid);

584 585
int virStorageFileSupportsSecurityDriver(const virStorageSource *src);
int virStorageFileSupportsAccess(const virStorageSource *src);
586
int virStorageFileSupportsCreate(const virStorageSource *src);
587
int virStorageFileSupportsBackingChainTraversal(const virStorageSource *src);
588 589 590 591 592 593

int virStorageFileGetMetadata(virStorageSourcePtr src,
                              uid_t uid, gid_t gid,
                              bool report_broken)
    ATTRIBUTE_NONNULL(1);

594 595 596
int virStorageFileGetBackingStoreStr(virStorageSourcePtr src,
                                     char **backing)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
597 598 599 600

void virStorageFileReportBrokenChain(int errcode,
                                     virStorageSourcePtr src,
                                     virStorageSourcePtr parent);
601

602
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virStorageAuthDef, virStorageAuthDefFree);