storage_backend.h 11.6 KB
Newer Older
1 2 3
/*
 * storage_backend.h: internal storage driver backend contract
 *
4
 * Copyright (C) 2007-2010, 2012-2014 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 23 24
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */

#ifndef __VIR_STORAGE_BACKEND_H__
25
# define __VIR_STORAGE_BACKEND_H__
26

E
Eric Blake 已提交
27 28
# include <sys/stat.h>

29 30
# include "internal.h"
# include "storage_conf.h"
31
# include "vircommand.h"
32
# include "storage_driver.h"
33

34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
typedef char * (*virStorageBackendFindPoolSources)(virConnectPtr conn,
                                                   const char *srcSpec,
                                                   unsigned int flags);
typedef int (*virStorageBackendCheckPool)(virConnectPtr conn,
                                          virStoragePoolObjPtr pool,
                                          bool *active);
typedef int (*virStorageBackendStartPool)(virConnectPtr conn,
                                          virStoragePoolObjPtr pool);
typedef int (*virStorageBackendBuildPool)(virConnectPtr conn,
                                          virStoragePoolObjPtr pool,
                                          unsigned int flags);
typedef int (*virStorageBackendRefreshPool)(virConnectPtr conn,
                                            virStoragePoolObjPtr pool);
typedef int (*virStorageBackendStopPool)(virConnectPtr conn,
                                         virStoragePoolObjPtr pool);
typedef int (*virStorageBackendDeletePool)(virConnectPtr conn,
                                           virStoragePoolObjPtr pool,
                                           unsigned int flags);
52
typedef int (*virStorageBackendBuildVol)(virConnectPtr conn,
53 54
                                         virStoragePoolObjPtr pool,
                                         virStorageVolDefPtr vol,
55
                                         unsigned int flags);
56 57 58 59 60 61 62 63 64 65 66 67 68 69
typedef int (*virStorageBackendCreateVol)(virConnectPtr conn,
                                          virStoragePoolObjPtr pool,
                                          virStorageVolDefPtr vol);
typedef int (*virStorageBackendRefreshVol)(virConnectPtr conn,
                                           virStoragePoolObjPtr pool,
                                           virStorageVolDefPtr vol);
typedef int (*virStorageBackendDeleteVol)(virConnectPtr conn,
                                          virStoragePoolObjPtr pool,
                                          virStorageVolDefPtr vol,
                                          unsigned int flags);
typedef int (*virStorageBackendBuildVolFrom)(virConnectPtr conn,
                                             virStoragePoolObjPtr pool,
                                             virStorageVolDefPtr origvol,
                                             virStorageVolDefPtr newvol,
70
                                             unsigned int flags);
71 72 73 74 75
typedef int (*virStorageBackendVolumeResize)(virConnectPtr conn,
                                             virStoragePoolObjPtr pool,
                                             virStorageVolDefPtr vol,
                                             unsigned long long capacity,
                                             unsigned int flags);
76 77 78 79 80 81 82 83 84 85 86 87 88 89
typedef int (*virStorageBackendVolumeDownload)(virConnectPtr conn,
                                               virStoragePoolObjPtr obj,
                                               virStorageVolDefPtr vol,
                                               virStreamPtr stream,
                                               unsigned long long offset,
                                               unsigned long long length,
                                               unsigned int flags);
typedef int (*virStorageBackendVolumeUpload)(virConnectPtr conn,
                                             virStoragePoolObjPtr obj,
                                             virStorageVolDefPtr vol,
                                             virStreamPtr stream,
                                             unsigned long long offset,
                                             unsigned long long len,
                                             unsigned int flags);
90

91 92
/* File creation/cloning functions used for cloning between backends */
int virStorageBackendCreateRaw(virConnectPtr conn,
93
                               virStoragePoolObjPtr pool,
94
                               virStorageVolDefPtr vol,
95 96 97
                               virStorageVolDefPtr inputvol,
                               unsigned int flags);
virStorageBackendBuildVolFrom
98
virStorageBackendGetBuildVolFromFunction(virStorageVolDefPtr vol,
99 100
                                         virStorageVolDefPtr inputvol);
int virStorageBackendFindFSImageTool(char **tool);
101
virStorageBackendBuildVolFrom
102
virStorageBackendFSImageToolTypeToFunc(int tool_type);
103

104 105 106 107
int virStorageBackendFindGlusterPoolSources(const char *host,
                                            int pooltype,
                                            virStoragePoolSourceListPtr list);

108 109 110 111 112 113 114 115 116 117 118 119 120 121
int virStorageBackendVolUploadLocal(virConnectPtr conn,
                                    virStoragePoolObjPtr pool,
                                    virStorageVolDefPtr vol,
                                    virStreamPtr stream,
                                    unsigned long long offset,
                                    unsigned long long len,
                                    unsigned int flags);
int virStorageBackendVolDownloadLocal(virConnectPtr conn,
                                      virStoragePoolObjPtr pool,
                                      virStorageVolDefPtr vol,
                                      virStreamPtr stream,
                                      unsigned long long offset,
                                      unsigned long long len,
                                      unsigned int flags);
122 123 124 125

typedef struct _virStorageBackend virStorageBackend;
typedef virStorageBackend *virStorageBackendPtr;

126 127
/* Callbacks are optional unless documented otherwise; but adding more
 * callbacks provides better pool support.  */
128 129 130
struct _virStorageBackend {
    int type;

131
    virStorageBackendFindPoolSources findPoolSources;
132
    virStorageBackendCheckPool checkPool;
133 134
    virStorageBackendStartPool startPool;
    virStorageBackendBuildPool buildPool;
135
    virStorageBackendRefreshPool refreshPool; /* Must be non-NULL */
136 137 138
    virStorageBackendStopPool stopPool;
    virStorageBackendDeletePool deletePool;

139
    virStorageBackendBuildVol buildVol;
140
    virStorageBackendBuildVolFrom buildVolFrom;
141 142 143
    virStorageBackendCreateVol createVol;
    virStorageBackendRefreshVol refreshVol;
    virStorageBackendDeleteVol deleteVol;
144
    virStorageBackendVolumeResize resizeVol;
145 146
    virStorageBackendVolumeUpload uploadVol;
    virStorageBackendVolumeDownload downloadVol;
147 148 149
};

virStorageBackendPtr virStorageBackendForType(int type);
150

151 152
/* VolOpenCheckMode flags */
enum {
153 154 155 156 157 158
    VIR_STORAGE_VOL_OPEN_NOERROR = 1 << 0, /* don't error if unexpected type
                                            * encountered, just warn */
    VIR_STORAGE_VOL_OPEN_REG     = 1 << 1, /* regular files okay */
    VIR_STORAGE_VOL_OPEN_BLOCK   = 1 << 2, /* block files okay */
    VIR_STORAGE_VOL_OPEN_CHAR    = 1 << 3, /* char files okay */
    VIR_STORAGE_VOL_OPEN_DIR     = 1 << 4, /* directories okay */
159 160
};

161
# define VIR_STORAGE_VOL_OPEN_DEFAULT (VIR_STORAGE_VOL_OPEN_REG      |\
162
                                       VIR_STORAGE_VOL_OPEN_BLOCK)
163

164 165
int virStorageBackendVolOpen(const char *path, struct stat *sb,
                             unsigned int flags)
E
Eric Blake 已提交
166 167
    ATTRIBUTE_RETURN_CHECK
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
168

169
int virStorageBackendUpdateVolInfo(virStorageVolDefPtr vol,
170
                                   bool updateCapacity,
171
                                   bool withBlockVolFormat,
172
                                   unsigned int openflags);
173
int virStorageBackendUpdateVolTargetInfo(virStorageSourcePtr target,
174
                                         bool updateCapacity,
175
                                         bool withBlockVolFormat,
176
                                         unsigned int openflags);
177
int virStorageBackendUpdateVolTargetInfoFD(virStorageSourcePtr target,
178
                                           int fd,
179 180
                                           struct stat *sb,
                                           bool updateCapacity);
181

182
char *virStorageBackendStablePath(virStoragePoolObjPtr pool,
183
                                  const char *devpath,
184
                                  bool loop);
185

186 187 188 189 190 191 192 193
virCommandPtr
virStorageBackendCreateQemuImgCmd(virConnectPtr conn,
                                  virStoragePoolObjPtr pool,
                                  virStorageVolDefPtr vol,
                                  virStorageVolDefPtr inputvol,
                                  unsigned int flags,
                                  const char *create_tool,
                                  int imgformat);
194

195
/* ------- virStorageFile backends ------------ */
196 197 198 199 200 201
typedef struct _virStorageFileBackend virStorageFileBackend;
typedef virStorageFileBackend *virStorageFileBackendPtr;

struct _virStorageDriverData {
    virStorageFileBackendPtr backend;
    void *priv;
202 203 204

    uid_t uid;
    gid_t gid;
205 206
};

207
typedef int
208
(*virStorageFileBackendInit)(virStorageSourcePtr src);
209 210

typedef void
211
(*virStorageFileBackendDeinit)(virStorageSourcePtr src);
212 213

typedef int
214
(*virStorageFileBackendCreate)(virStorageSourcePtr src);
215 216

typedef int
217
(*virStorageFileBackendUnlink)(virStorageSourcePtr src);
218 219

typedef int
220
(*virStorageFileBackendStat)(virStorageSourcePtr src,
221 222
                             struct stat *st);

223 224 225 226 227
typedef ssize_t
(*virStorageFileBackendReadHeader)(virStorageSourcePtr src,
                                   ssize_t max_len,
                                   char **buf);

228 229
typedef const char *
(*virStorageFileBackendGetUniqueIdentifier)(virStorageSourcePtr src);
230

231 232 233 234
typedef int
(*virStorageFileBackendAccess)(virStorageSourcePtr src,
                               int mode);

235
virStorageFileBackendPtr virStorageFileBackendForType(int type, int protocol);
236 237 238
virStorageFileBackendPtr virStorageFileBackendForTypeInternal(int type,
                                                              int protocol,
                                                              bool report);
239 240


241 242 243 244 245 246 247 248 249 250
struct _virStorageFileBackend {
    int type;
    int protocol;

    /* All storage file callbacks may be omitted if not implemented */

    /* The following group of callbacks is expected to set a libvirt
     * error on failure. */
    virStorageFileBackendInit backendInit;
    virStorageFileBackendDeinit backendDeinit;
251
    virStorageFileBackendReadHeader storageFileReadHeader;
252
    virStorageFileBackendGetUniqueIdentifier storageFileGetUniqueIdentifier;
253 254 255 256 257 258

    /* The following group of callbacks is expected to set errno
     * and return -1 on error. No libvirt error shall be reported */
    virStorageFileBackendCreate storageFileCreate;
    virStorageFileBackendUnlink storageFileUnlink;
    virStorageFileBackendStat   storageFileStat;
259
    virStorageFileBackendAccess storageFileAccess;
260 261
};

262
#endif /* __VIR_STORAGE_BACKEND_H__ */