virutil.h 11.5 KB
Newer Older
1
/*
2
 * virutil.h: common, generic utility functions
3
 *
4
 * Copyright (C) 2010-2013 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16 17 18
 * Copyright (C) 2006, 2007 Binary Karma
 * Copyright (C) 2006 Shuveb Hussain
 *
 * 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
19
 * License along with this library.  If not, see
O
Osier Yang 已提交
20
 * <http://www.gnu.org/licenses/>.
21 22 23 24
 *
 * File created Jul 18, 2007 - Shuveb Hussain <shuveb@binarykarma.com>
 */

25
#ifndef __VIR_UTIL_H__
26
# define __VIR_UTIL_H__
27

28 29 30 31 32
# include "verify.h"
# include "internal.h"
# include <unistd.h>
# include <sys/select.h>
# include <sys/types.h>
E
Eric Blake 已提交
33
# include <stdarg.h>
34

35 36 37
# ifndef MIN
#  define MIN(a, b) ((a) < (b) ? (a) : (b))
# endif
L
Laine Stump 已提交
38 39 40
# ifndef MAX
#  define MAX(a, b) ((a) > (b) ? (a) : (b))
# endif
41

E
Eric Blake 已提交
42
ssize_t saferead(int fd, void *buf, size_t count) ATTRIBUTE_RETURN_CHECK;
43 44
ssize_t safewrite(int fd, const void *buf, size_t count)
    ATTRIBUTE_RETURN_CHECK;
E
Eric Blake 已提交
45
int safezero(int fd, off_t offset, off_t len)
46
    ATTRIBUTE_RETURN_CHECK;
D
Daniel P. Berrange 已提交
47

48
int virSetBlocking(int fd, bool blocking) ATTRIBUTE_RETURN_CHECK;
49
int virSetNonBlock(int fd) ATTRIBUTE_RETURN_CHECK;
E
Eric Blake 已提交
50
int virSetInherit(int fd, bool inherit) ATTRIBUTE_RETURN_CHECK;
51
int virSetCloseExec(int fd) ATTRIBUTE_RETURN_CHECK;
52

53 54
int virPipeReadUntilEOF(int outfd, int errfd,
                        char **outbuf, char **errbuf);
55

L
Laine Stump 已提交
56
int virSetUIDGID(uid_t uid, gid_t gid);
57 58
int virSetUIDGIDWithCaps(uid_t uid, gid_t gid, unsigned long long capBits,
                         bool clearExistingCaps);
L
Laine Stump 已提交
59

60
int virFileReadLimFD(int fd, int maxlen, char **buf) ATTRIBUTE_RETURN_CHECK;
61

62
int virFileReadAll(const char *path, int maxlen, char **buf) ATTRIBUTE_RETURN_CHECK;
63

64 65
int virFileWriteStr(const char *path, const char *str, mode_t mode)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
M
Mark McLoughlin 已提交
66

67 68 69 70 71 72 73
int virFileMatchesNameSuffix(const char *file,
                             const char *name,
                             const char *suffix);

int virFileHasSuffix(const char *str,
                     const char *suffix);

74
int virFileStripSuffix(char *str,
75
                       const char *suffix) ATTRIBUTE_RETURN_CHECK;
76

77 78
int virFileLinkPointsTo(const char *checkLink,
                        const char *checkDest);
79

D
Daniel P. Berrange 已提交
80
int virFileResolveLink(const char *linkpath,
81
                       char **resultpath) ATTRIBUTE_RETURN_CHECK;
82 83
int virFileResolveAllLinks(const char *linkpath,
                           char **resultpath) ATTRIBUTE_RETURN_CHECK;
D
Daniel P. Berrange 已提交
84

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

88 89
char *virFindFileInPath(const char *file);

90
bool virFileIsDir (const char *file) ATTRIBUTE_NONNULL(1);
91 92
bool virFileExists(const char *file) ATTRIBUTE_NONNULL(1);
bool virFileIsExecutable(const char *file) ATTRIBUTE_NONNULL(1);
93

94 95
char *virFileSanitizePath(const char *path);

96
enum {
97
    VIR_FILE_OPEN_NONE        = 0,
L
Laine Stump 已提交
98 99 100 101
    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),
102
};
103 104 105
int virFileAccessibleAs(const char *path, int mode,
                        uid_t uid, gid_t gid)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
106 107 108
int virFileOpenAs(const char *path, int openflags, mode_t mode,
                  uid_t uid, gid_t gid,
                  unsigned int flags)
109
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
110

111 112 113 114 115 116
enum {
    VIR_DIR_CREATE_NONE        = 0,
    VIR_DIR_CREATE_AS_UID      = (1 << 0),
    VIR_DIR_CREATE_FORCE_PERMS = (1 << 1),
    VIR_DIR_CREATE_ALLOW_EXIST = (1 << 2),
};
117 118
int virDirCreate(const char *path, mode_t mode, uid_t uid, gid_t gid,
                 unsigned int flags) ATTRIBUTE_RETURN_CHECK;
119
int virFileMakePath(const char *path) ATTRIBUTE_RETURN_CHECK;
120 121
int virFileMakePathWithMode(const char *path,
                            mode_t mode) ATTRIBUTE_RETURN_CHECK;
122

123 124 125
char *virFileBuildPath(const char *dir,
                       const char *name,
                       const char *ext) ATTRIBUTE_RETURN_CHECK;
126

127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149

# ifdef WIN32
/* 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.
 */
#  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 ";"

# else  /* !WIN32 */

#  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 ":"

# endif /* !WIN32 */

bool virFileIsAbsPath(const char *path);
A
Amy Griffis 已提交
150
int virFileAbsPath(const char *path,
151
                   char **abspath) ATTRIBUTE_RETURN_CHECK;
152
const char *virFileSkipRoot(const char *path);
A
Amy Griffis 已提交
153

154 155 156
int virFileOpenTty(int *ttymaster,
                   char **ttyName,
                   int rawmode);
157

158 159
char *virArgvToString(const char *const *argv);

D
Daniel P. Berrange 已提交
160
int virStrToLong_i(char const *s,
161 162 163 164 165 166 167 168
                     char **end_ptr,
                     int base,
                     int *result);

int virStrToLong_ui(char const *s,
                    char **end_ptr,
                    int base,
                    unsigned int *result);
169 170 171 172 173 174 175 176
int virStrToLong_l(char const *s,
                   char **end_ptr,
                   int base,
                   long *result);
int virStrToLong_ul(char const *s,
                    char **end_ptr,
                    int base,
                    unsigned long *result);
177 178 179 180
int virStrToLong_ll(char const *s,
                    char **end_ptr,
                    int base,
                    long long *result);
D
Daniel P. Berrange 已提交
181 182 183 184
int virStrToLong_ull(char const *s,
                     char **end_ptr,
                     int base,
                     unsigned long long *result);
185 186 187
int virStrToDouble(char const *s,
                   char **end_ptr,
                   double *result);
D
Daniel P. Berrange 已提交
188

189 190 191 192
int virScaleInteger(unsigned long long *value, const char *suffix,
                    unsigned long long scale, unsigned long long limit)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

193 194
int virHexToBin(unsigned char c);

E
Eric Blake 已提交
195 196 197 198 199 200
void virSkipSpaces(const char **str) ATTRIBUTE_NONNULL(1);
void virSkipSpacesAndBackslash(const char **str) ATTRIBUTE_NONNULL(1);
void virTrimSpaces(char *str, char **endp) ATTRIBUTE_NONNULL(1);
void virSkipSpacesBackwards(const char *str, char **endp)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

201
int virParseNumber(const char **str);
202 203
int virParseVersionString(const char *str, unsigned long *version,
                          bool allowMissing);
E
Eric Blake 已提交
204
int virAsprintf(char **strp, const char *fmt, ...)
205 206
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_FMT_PRINTF(2, 3)
    ATTRIBUTE_RETURN_CHECK;
E
Eric Blake 已提交
207
int virVasprintf(char **strp, const char *fmt, va_list list)
208 209
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_FMT_PRINTF(2, 0)
    ATTRIBUTE_RETURN_CHECK;
C
Chris Lalancette 已提交
210 211 212 213
char *virStrncpy(char *dest, const char *src, size_t n, size_t destbytes)
    ATTRIBUTE_RETURN_CHECK;
char *virStrcpy(char *dest, const char *src, size_t destbytes)
    ATTRIBUTE_RETURN_CHECK;
214
# define virStrcpyStatic(dest, src) virStrcpy((dest), (src), sizeof(dest))
215

216
int virDoubleToStr(char **strp, double number)
D
Daniel P. Berrange 已提交
217 218 219 220
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;

char *virFormatIntDecimal(char *buf, size_t buflen, int val)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK;
221

222
int virDiskNameToIndex(const char* str);
223
char *virIndexToDiskName(int idx, const char *prefix);
224 225 226 227 228 229 230 231 232

int virEnumFromString(const char *const*types,
                      unsigned int ntypes,
                      const char *type);

const char *virEnumToString(const char *const*types,
                            unsigned int ntypes,
                            int type);

233
# define VIR_ENUM_IMPL(name, lastVal, ...)                               \
234
    static const char *const name ## TypeList[] = { __VA_ARGS__ };      \
E
Eric Blake 已提交
235
    verify(ARRAY_CARDINALITY(name ## TypeList) == lastVal);             \
236 237 238 239 240 241 242 243 244 245 246
    const char *name ## TypeToString(int type) {                        \
        return virEnumToString(name ## TypeList,                        \
                               ARRAY_CARDINALITY(name ## TypeList),     \
                               type);                                   \
    }                                                                   \
    int name ## TypeFromString(const char *type) {                      \
        return virEnumFromString(name ## TypeList,                      \
                                 ARRAY_CARDINALITY(name ## TypeList),   \
                                 type);                                 \
    }

247
# define VIR_ENUM_DECL(name)                             \
248 249 250
    const char *name ## TypeToString(int type);         \
    int name ## TypeFromString(const char*type);

251
# ifndef HAVE_GETUID
D
Daniel P. Berrange 已提交
252
static inline int getuid (void) { return 0; }
253
# endif
D
Daniel P. Berrange 已提交
254

255 256 257 258
# ifndef HAVE_GETEUID
static inline int geteuid (void) { return 0; }
# endif

259
# ifndef HAVE_GETGID
D
Daniel P. Berrange 已提交
260
static inline int getgid (void) { return 0; }
261
# endif
D
Daniel P. Berrange 已提交
262

263
char *virGetHostname(virConnectPtr conn);
264

265 266 267 268
char *virGetUserDirectory(void);
char *virGetUserConfigDirectory(void);
char *virGetUserCacheDirectory(void);
char *virGetUserRuntimeDirectory(void);
269
char *virGetUserName(uid_t uid);
270
char *virGetGroupName(gid_t gid);
271
int virGetUserID(const char *name,
272
                 uid_t *uid) ATTRIBUTE_RETURN_CHECK;
273
int virGetGroupID(const char *name,
274
                  gid_t *gid) ATTRIBUTE_RETURN_CHECK;
275

276 277
char *virFileFindMountPoint(const char *type);

278
void virFileWaitForDevices(void);
D
Daniel P. Berrange 已提交
279

280
# define virBuildPath(path, ...) virBuildPathInternal(path, __VA_ARGS__, NULL)
281 282
int virBuildPathInternal(char **path, ...) ATTRIBUTE_SENTINEL;

283
bool virIsDevMapperDevice(const char *dev_name) ATTRIBUTE_NONNULL(1);
284

O
Osier Yang 已提交
285 286
bool virValidateWWN(const char *wwn);

287
bool virStrIsPrint(const char *str);
288 289 290 291 292 293 294 295 296 297

int virGetDeviceID(const char *path,
                   int *maj,
                   int *min);
int virSetDeviceUnprivSGIO(const char *path,
                           const char *sysfs_dir,
                           int unpriv_sgio);
int virGetDeviceUnprivSGIO(const char *path,
                           const char *sysfs_dir,
                           int *unpriv_sgio);
298 299
char *virGetUnprivSGIOSysfsPath(const char *path,
                                const char *sysfs_dir);
300 301 302 303 304
int virReadFCHost(const char *sysfs_prefix,
                  int host,
                  const char *entry,
                  char **result)
    ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(4);
305

O
Osier Yang 已提交
306 307 308
int virIsCapableFCHost(const char *sysfs_prefix, int host);
int virIsCapableVport(const char *sysfs_prefix, int host);

309 310 311 312 313 314 315 316
enum {
    VPORT_CREATE,
    VPORT_DELETE,
};

int virManageVport(const int parent_host,
                   const char *wwpn,
                   const char *wwnn,
317
                   int operation)
318 319
    ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

320 321 322 323 324
char *virGetFCHostNameByWWN(const char *sysfs_prefix,
                            const char *wwnn,
                            const char *wwpn)
    ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

325 326
char *virFindFCHostCapableVport(const char *sysfs_prefix);

327
#endif /* __VIR_UTIL_H__ */