internal.h 14.2 KB
Newer Older
1 2
/*
 * internal.h: internal definitions just used by code from the library
E
Eric Blake 已提交
3
 *
4
 * Copyright (C) 2006-2014 Red Hat, Inc.
E
Eric Blake 已提交
5 6 7 8 9 10 11 12 13 14 15 16 17 18
 *
 * 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
 * License along with this library.  If not, see
 * <http://www.gnu.org/licenses/>.
19 20
 */

21 22 23 24 25 26 27 28 29
#pragma once

#include <errno.h>
#include <limits.h>
#include <verify.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
30
#include <stdlib.h>
D
Daniel P. Berrangé 已提交
31
#include <glib.h>
32 33 34 35 36 37 38 39

#if STATIC_ANALYSIS
# undef NDEBUG /* Don't let a prior NDEBUG definition cause trouble.  */
# include <assert.h>
# define sa_assert(expr) assert (expr)
#else
# define sa_assert(expr) /* empty */
#endif
40

41 42 43 44
/* The library itself is allowed to use deprecated functions /
 * variables, so effectively undefine the deprecated attribute
 * which would otherwise be defined in libvirt.h.
 */
45 46
#undef VIR_DEPRECATED
#define VIR_DEPRECATED /*empty*/
47

48
/* The library itself needs to know enum sizes.  */
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
#define VIR_ENUM_SENTINELS

#ifdef HAVE_LIBINTL_H
# define DEFAULT_TEXT_DOMAIN PACKAGE
# include <libintl.h>
# define _(str) dgettext(PACKAGE, str)
#else /* HAVE_LIBINTL_H */
# define _(str) str
#endif /* HAVE_LIBINTL_H */
#define N_(str) str

#include "libvirt/libvirt.h"
#include "libvirt/libvirt-lxc.h"
#include "libvirt/libvirt-qemu.h"
#include "libvirt/libvirt-admin.h"
#include "libvirt/virterror.h"

#include "c-strcase.h"
67
#include "glibcompat.h"
68 69 70 71 72 73 74

/* Merely casting to (void) is not sufficient since the
 * introduction of the "warn_unused_result" attribute
 */
#define ignore_value(x) \
    (__extension__ ({ __typeof__ (x) __x = (x); (void) __x; }))

75

76
/* String equality tests, suggested by Jim Meyering. */
77 78 79 80 81 82 83 84 85 86 87 88
#define STREQ(a, b) (strcmp(a, b) == 0)
#define STRCASEEQ(a, b) (c_strcasecmp(a, b) == 0)
#define STRNEQ(a, b) (strcmp(a, b) != 0)
#define STRCASENEQ(a, b) (c_strcasecmp(a, b) != 0)
#define STREQLEN(a, b, n) (strncmp(a, b, n) == 0)
#define STRCASEEQLEN(a, b, n) (c_strncasecmp(a, b, n) == 0)
#define STRNEQLEN(a, b, n) (strncmp(a, b, n) != 0)
#define STRCASENEQLEN(a, b, n) (c_strncasecmp(a, b, n) != 0)
#define STRPREFIX(a, b) (strncmp(a, b, strlen(b)) == 0)
#define STRCASEPREFIX(a, b) (c_strncasecmp(a, b, strlen(b)) == 0)
#define STRSKIP(a, b) (STRPREFIX(a, b) ? (a) + strlen(b) : NULL)

89 90
#define STREQ_NULLABLE(a, b) (g_strcmp0(a, b) == 0)
#define STRNEQ_NULLABLE(a, b) (g_strcmp0(a, b) != 0)
91

92
#define NUL_TERMINATE(buf) do { (buf)[sizeof(buf)-1] = '\0'; } while (0)
93

94
/**
95
 * G_GNUC_NO_INLINE:
96
 *
97 98
 * Force compiler not to inline a method. Should be used if
 * the method need to be overridable by test mocks.
99 100
 *
 * TODO: Remove after upgrading to GLib >= 2.58
101
 */
102 103
#ifndef G_GNUC_NO_INLINE
# define G_GNUC_NO_INLINE __attribute__((__noinline__))
104
#endif
105

106 107 108 109 110 111 112 113 114
/**
 * ATTRIBUTE_PACKED
 *
 * force a structure to be packed, i.e. not following architecture and
 * compiler best alignments for its sub components. It's needed for example
 * for the network filetering code when defining the content of raw
 * ethernet packets.
 * Others compiler than gcc may use something different e.g. #pragma pack(1)
 */
115 116 117
#ifndef ATTRIBUTE_PACKED
# define ATTRIBUTE_PACKED __attribute__((packed))
#endif
118

119 120 121 122 123 124 125 126 127
/* gcc's handling of attribute nonnull is less than stellar - it does
 * NOT improve diagnostics, and merely allows gcc to optimize away
 * null code checks even when the caller manages to pass null in spite
 * of the attribute, leading to weird crashes.  Coverity, on the other
 * hand, knows how to do better static analysis based on knowing
 * whether a parameter is nonnull.  Make this attribute conditional
 * based on whether we are compiling for real or for analysis, while
 * still requiring correct gcc syntax when it is turned off.  See also
 * http://gcc.gnu.org/bugzilla/show_bug.cgi?id=17308 */
128 129 130 131 132
#ifndef ATTRIBUTE_NONNULL
# if STATIC_ANALYSIS
#  define ATTRIBUTE_NONNULL(m) __attribute__((__nonnull__(m)))
# else
#  define ATTRIBUTE_NONNULL(m) __attribute__(())
133
# endif
134
#endif
135

136 137
/**
 *
138
 * G_GNUC_FALLTHROUGH
139 140 141
 *
 * silence the compiler warning when falling through a switch case
 *
142
 * TODO: Remove after upgrading to GLib >= 2.60
143
 */
144
#ifndef G_GNUC_FALLTHROUGH
145
# if __GNUC_PREREQ (7, 0)
146
#  define G_GNUC_FALLTHROUGH __attribute__((fallthrough))
147
# else
148
#  define G_GNUC_FALLTHROUGH do {} while(0)
149
# endif
150
#endif
151

152
#define VIR_WARNINGS_NO_CAST_ALIGN \
153 154
    _Pragma ("GCC diagnostic push") \
    _Pragma ("GCC diagnostic ignored \"-Wcast-align\"")
155

156
#define VIR_WARNINGS_NO_DEPRECATED \
157 158 159
    _Pragma ("GCC diagnostic push") \
    _Pragma ("GCC diagnostic ignored \"-Wdeprecated-declarations\"")

160 161
#if HAVE_SUGGEST_ATTRIBUTE_FORMAT
# define VIR_WARNINGS_NO_PRINTF \
162 163
    _Pragma ("GCC diagnostic push") \
    _Pragma ("GCC diagnostic ignored \"-Wsuggest-attribute=format\"")
164 165
#else
# define VIR_WARNINGS_NO_PRINTF \
166
    _Pragma ("GCC diagnostic push")
167
#endif
168

169 170
/* Workaround bogus GCC 6.0 for logical 'or' equal expression warnings.
 * (GCC bz 69602) */
171 172
#if BROKEN_GCC_WLOGICALOP_EQUAL_EXPR
# define VIR_WARNINGS_NO_WLOGICALOP_EQUAL_EXPR \
173
     _Pragma ("GCC diagnostic push") \
174
     _Pragma ("GCC diagnostic ignored \"-Wlogical-op\"")
175
#else
176 177
# define VIR_WARNINGS_NO_WLOGICALOP_EQUAL_EXPR \
     _Pragma ("GCC diagnostic push")
178
#endif
179

180 181
#define VIR_WARNINGS_RESET \
    _Pragma ("GCC diagnostic pop")
182

183 184 185
/*
 * Use this when passing possibly-NULL strings to printf-a-likes.
 */
186
#define NULLSTR(s) ((s) ? (s) : "<null>")
187

188 189 190
/*
 * Turn a NULL string into an empty string
 */
191
#define NULLSTR_EMPTY(s) ((s) ? (s) : "")
192 193 194 195

/*
 * Turn a NULL string into a star
 */
196
#define NULLSTR_STAR(s) ((s) ? (s) : "*")
197 198 199 200

/*
 * Turn a NULL string into a minus sign
 */
201
#define NULLSTR_MINUS(s) ((s) ? (s) : "-")
202

203 204 205 206 207
/**
 * SWAP:
 *
 * In place exchange of two values
 */
208
#define SWAP(a, b) \
209 210 211 212
    do { \
        (a) = (a) ^ (b); \
        (b) = (a) ^ (b); \
        (a) = (a) ^ (b); \
213 214
    } while (0)

215 216 217 218 219 220 221 222 223 224 225
/**
 * virCheckFlags:
 * @supported: an OR'ed set of supported flags
 * @retval: return value in case unsupported flags were passed
 *
 * To avoid memory leaks this macro has to be used before any non-trivial
 * code which could possibly allocate some memory.
 *
 * Returns nothing. Exits the caller function if unsupported flags were
 * passed to it.
 */
226
#define virCheckFlags(supported, retval) \
227 228 229 230
    do { \
        unsigned long __unsuppflags = flags & ~(supported); \
        if (__unsuppflags) { \
            virReportInvalidArg(flags, \
231
                                _("unsupported flags (0x%lx) in function %s"), \
232 233 234
                                __unsuppflags, __FUNCTION__); \
            return retval; \
        } \
235 236
    } while (0)

237 238 239 240 241 242 243 244 245 246 247
/**
 * virCheckFlagsGoto:
 * @supported: an OR'ed set of supported flags
 * @label: label to jump to on error
 *
 * To avoid memory leaks this macro has to be used before any non-trivial
 * code which could possibly allocate some memory.
 *
 * Returns nothing. Jumps to a label if unsupported flags were
 * passed to it.
 */
248
#define virCheckFlagsGoto(supported, label) \
249 250 251 252
    do { \
        unsigned long __unsuppflags = flags & ~(supported); \
        if (__unsuppflags) { \
            virReportInvalidArg(flags, \
253
                                _("unsupported flags (0x%lx) in function %s"), \
254 255 256
                                __unsuppflags, __FUNCTION__); \
            goto label; \
        } \
257 258
    } while (0)

259 260 261 262 263 264 265 266 267 268 269 270 271 272 273
/* Macros to help dealing with mutually exclusive flags. */

/**
 * VIR_EXCLUSIVE_FLAGS_RET:
 *
 * @FLAG1: First flag to be checked.
 * @FLAG2: Second flag to be checked.
 * @RET: Return value.
 *
 * Reject mutually exclusive API flags.  The checked flags are compared
 * with flags variable.
 *
 * This helper does an early return and therefore it has to be called
 * before anything that would require cleanup.
 */
274
#define VIR_EXCLUSIVE_FLAGS_RET(FLAG1, FLAG2, RET) \
275 276 277 278 279 280 281 282
    do { \
        if ((flags & FLAG1) && (flags & FLAG2)) { \
            virReportInvalidArg(ctl, \
                                _("Flags '%s' and '%s' are mutually " \
                                  "exclusive"), \
                                #FLAG1, #FLAG2); \
            return RET; \
        } \
283 284 285 286 287 288 289 290 291 292 293 294 295 296 297
    } while (0)

/**
 * VIR_EXCLUSIVE_FLAGS_GOTO:
 *
 * @FLAG1: First flag to be checked.
 * @FLAG2: Second flag to be checked.
 * @LABEL: Label to jump to.
 *
 * Reject mutually exclusive API flags.  The checked flags are compared
 * with flags variable.
 *
 * Returns nothing.  Jumps to a label if unsupported flags were
 * passed to it.
 */
298
#define VIR_EXCLUSIVE_FLAGS_GOTO(FLAG1, FLAG2, LABEL) \
299 300 301 302 303 304 305 306
    do { \
        if ((flags & FLAG1) && (flags & FLAG2)) { \
            virReportInvalidArg(ctl, \
                                _("Flags '%s' and '%s' are mutually " \
                                  "exclusive"), \
                                #FLAG1, #FLAG2); \
            goto LABEL; \
        } \
307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323
    } while (0)

/* Macros to help dealing with flag requirements. */

/**
 * VIR_REQUIRE_FLAG_RET:
 *
 * @FLAG1: First flag to be checked.
 * @FLAG2: Second flag that is required by first flag.
 * @RET: Return value.
 *
 * Check whether required flag is set.  The checked flags are compared
 * with flags variable.
 *
 * This helper does an early return and therefore it has to be called
 * before anything that would require cleanup.
 */
324
#define VIR_REQUIRE_FLAG_RET(FLAG1, FLAG2, RET) \
325 326 327 328 329 330 331
    do { \
        if ((flags & FLAG1) && !(flags & FLAG2)) { \
            virReportInvalidArg(ctl, \
                                _("Flag '%s' is required by flag '%s'"), \
                                #FLAG2, #FLAG1); \
            return RET; \
        } \
332 333 334 335 336 337 338 339 340 341 342 343 344 345
    } while (0)

/**
 * VIR_REQUIRE_FLAG_GOTO:
 *
 * @FLAG1: First flag to be checked.
 * @FLAG2: Second flag that is required by first flag.
 * @LABEL: Label to jump to.
 *
 * Check whether required flag is set.  The checked flags are compared
 * with flags variable.
 *
 * Returns nothing.  Jumps to a label if required flag is not set.
 */
346
#define VIR_REQUIRE_FLAG_GOTO(FLAG1, FLAG2, LABEL) \
347 348 349 350 351 352 353
    do { \
        if ((flags & FLAG1) && !(flags & FLAG2)) { \
            virReportInvalidArg(ctl, \
                                _("Flag '%s' is required by flag '%s'"), \
                                #FLAG2, #FLAG1); \
            goto LABEL; \
        } \
354 355
    } while (0)

356
#define virCheckNonNullArgReturn(argname, retval) \
357 358 359 360 361
    do { \
        if (argname == NULL) { \
            virReportInvalidNonNullArg(argname); \
            return retval; \
        } \
362
    } while (0)
363
#define virCheckNullArgGoto(argname, label) \
364 365 366 367 368
    do { \
        if (argname != NULL) { \
            virReportInvalidNullArg(argname); \
            goto label; \
        } \
369
    } while (0)
370
#define virCheckNonNullArgGoto(argname, label) \
371 372 373 374 375
    do { \
        if (argname == NULL) { \
            virReportInvalidNonNullArg(argname); \
            goto label; \
        } \
376
    } while (0)
377
#define virCheckNonEmptyStringArgGoto(argname, label) \
378 379 380 381 382 383 384 385 386
    do { \
        if (argname == NULL) { \
            virReportInvalidNonNullArg(argname); \
            goto label; \
        } \
        if (*argname == '\0') { \
            virReportInvalidEmptyStringArg(argname); \
            goto label; \
        } \
387
    } while (0)
388
#define virCheckPositiveArgGoto(argname, label) \
389 390 391 392 393
    do { \
        if (argname <= 0) { \
            virReportInvalidPositiveArg(argname); \
            goto label; \
        } \
394
    } while (0)
395
#define virCheckPositiveArgReturn(argname, retval) \
396 397 398 399 400
    do { \
        if (argname <= 0) { \
            virReportInvalidPositiveArg(argname); \
            return retval; \
        } \
401
    } while (0)
402
#define virCheckNonZeroArgGoto(argname, label) \
403 404 405 406 407
    do { \
        if (argname == 0) { \
            virReportInvalidNonZeroArg(argname); \
            goto label; \
        } \
408
    } while (0)
409
#define virCheckZeroArgGoto(argname, label) \
410 411 412 413 414
    do { \
        if (argname != 0) { \
            virReportInvalidNonZeroArg(argname); \
            goto label; \
        } \
415
    } while (0)
416
#define virCheckNonNegativeArgGoto(argname, label) \
417 418 419 420 421
    do { \
        if (argname < 0) { \
            virReportInvalidNonNegativeArg(argname); \
            goto label; \
        } \
422
    } while (0)
423
#define virCheckReadOnlyGoto(flags, label) \
424 425
    do { \
        if ((flags) & VIR_CONNECT_RO) { \
426
            virReportRestrictedError(_("read only access prevents %s"), \
427 428 429
                                     __FUNCTION__); \
            goto label; \
        } \
430 431
    } while (0)

432 433 434 435 436 437 438 439 440 441 442 443 444
/* This check is intended to be used with legacy APIs only which expect the
 * caller to pre-allocate the target buffer.
 * We want to allow callers pass NULL arrays if the size is declared as 0 and
 * still succeed in calling the API.
 */
#define virCheckNonNullArrayArgGoto(argname, argsize, label) \
    do { \
        if (!argname && argsize > 0) { \
            virReportInvalidNonNullArg(argname); \
            goto label; \
        } \
    } while (0)

445

446 447 448 449 450 451
/* Count leading zeros in an unsigned int.
 *
 * Wrapper needed as __builtin_clz is undefined if value is zero
 */
#define VIR_CLZ(value) \
    (value ? __builtin_clz(value) : (8 * sizeof(unsigned)))
452

453
/* divide value by size, rounding up */
454
#define VIR_DIV_UP(value, size) (((value) + (size) - 1) / (size))
455

456
/* round up value to the closest multiple of size */
457
#define VIR_ROUND_UP(value, size) (VIR_DIV_UP(value, size) * (size))
458

459 460
/* Round up to the next closest power of 2. It will return rounded number or 0
 * for 0 or number more than 2^31 (for 32bit unsigned int). */
461
#define VIR_ROUND_UP_POWER_OF_TWO(value) \
462
    ((value) > 0 && (value) <= 1U << (sizeof(unsigned int) * 8 - 1) ? \
463
     1U << (sizeof(unsigned int) * 8 - VIR_CLZ((value) - 1)) : 0)
464

465

466 467 468 469 470 471 472
/* Specific error values for use in forwarding programs such as
 * virt-login-shell; these values match what GNU env does.  */
enum {
    EXIT_CANCELED = 125, /* Failed before attempting exec */
    EXIT_CANNOT_INVOKE = 126, /* Exists but couldn't exec */
    EXIT_ENOENT = 127, /* Could not find program to exec */
};
473

474 475 476
#ifndef ENODATA
# define ENODATA EIO
#endif