提交 e4b980c8 编写于 作者: D Daniel P. Berrange

Prevent more compiler optimization of mockable functions

Currently all mockable functions are annotated with the 'noinline'
attribute. This is insufficient to guarantee that a function can
be reliably mocked with an LD_PRELOAD. The C language spec allows
the compiler to assume there is only a single implementation of
each function. It can thus do things like propagating constant
return values into the caller at compile time, or creating
multiple specialized copies of the function body each optimized
for a different caller. To prevent these optimizations we must
also set the 'noclone' and 'weak' attributes.

This fixes the test suite when libvirt.so is built with CLang
with optimization enabled.
Signed-off-by: NDaniel P. Berrange <berrange@redhat.com>
上级 1dbbcb62
...@@ -43,7 +43,7 @@ sub scan_annotations { ...@@ -43,7 +43,7 @@ sub scan_annotations {
} elsif (/^\s*$/) { } elsif (/^\s*$/) {
$func = undef; $func = undef;
} }
if (/ATTRIBUTE_NOINLINE/) { if (/ATTRIBUTE_MOCKABLE/) {
if (defined $func) { if (defined $func) {
$noninlined{$func} = 1; $noninlined{$func} = 1;
} }
......
...@@ -52,7 +52,7 @@ foreach my $elflib (@elflibs) { ...@@ -52,7 +52,7 @@ foreach my $elflib (@elflibs) {
open NM, "-|", "nm", $elflib or die "cannot run 'nm $elflib': $!"; open NM, "-|", "nm", $elflib or die "cannot run 'nm $elflib': $!";
while (<NM>) { while (<NM>) {
next unless /^\S+\s(?:[TBD])\s(\S+)\s*$/; next unless /^\S+\s(?:[TBDW])\s(\S+)\s*$/;
$gotsyms{$1} = 1; $gotsyms{$1} = 1;
} }
......
...@@ -113,13 +113,26 @@ ...@@ -113,13 +113,26 @@
# endif # endif
/** /**
* ATTRIBUTE_NOINLINE: * ATTRIBUTE_MOCKABLE:
*
* Ensure that the symbol can be overridden in a mock
* library preload. This implies a number of attributes
*
* - noinline: prevents the body being inlined to
* callers,
* - noclone: prevents specialized copies of the
* function body being created for different
* callers
* - weak: prevents the compiler making optimizations
* such as constant return value propagation
* *
* Force compiler not to inline a method. Should be used if
* the method need to be overridable by test mocks.
*/ */
# ifndef ATTRIBUTE_NOINLINE # ifndef ATTRIBUTE_MOCKABLE
# define ATTRIBUTE_NOINLINE __attribute__((__noinline__)) # if __GNUC_PREREQ(4, 5)
# define ATTRIBUTE_MOCKABLE __attribute__((__noinline__, __noclone__, __weak__))
# else
# define ATTRIBUTE_MOCKABLE __attribute__((__noinline__, __weak__))
# endif
# endif # endif
/** /**
......
...@@ -95,7 +95,7 @@ virQEMUCapsSetCPUModelInfo(virQEMUCapsPtr qemuCaps, ...@@ -95,7 +95,7 @@ virQEMUCapsSetCPUModelInfo(virQEMUCapsPtr qemuCaps,
virCPUDefPtr virCPUDefPtr
virQEMUCapsProbeHostCPUForEmulator(virCapsPtr caps, virQEMUCapsProbeHostCPUForEmulator(virCapsPtr caps,
virQEMUCapsPtr qemuCaps, virQEMUCapsPtr qemuCaps,
virDomainVirtType type) ATTRIBUTE_NOINLINE; virDomainVirtType type) ATTRIBUTE_MOCKABLE;
void void
virQEMUCapsSetGICCapabilities(virQEMUCapsPtr qemuCaps, virQEMUCapsSetGICCapabilities(virQEMUCapsPtr qemuCaps,
......
...@@ -137,10 +137,10 @@ int virNetSocketGetUNIXIdentity(virNetSocketPtr sock, ...@@ -137,10 +137,10 @@ int virNetSocketGetUNIXIdentity(virNetSocketPtr sock,
gid_t *gid, gid_t *gid,
pid_t *pid, pid_t *pid,
unsigned long long *timestamp) unsigned long long *timestamp)
ATTRIBUTE_NOINLINE; ATTRIBUTE_MOCKABLE;
int virNetSocketGetSELinuxContext(virNetSocketPtr sock, int virNetSocketGetSELinuxContext(virNetSocketPtr sock,
char **context) char **context)
ATTRIBUTE_NOINLINE; ATTRIBUTE_MOCKABLE;
int virNetSocketSetBlocking(virNetSocketPtr sock, int virNetSocketSetBlocking(virNetSocketPtr sock,
bool blocking); bool blocking);
......
...@@ -58,7 +58,7 @@ enum { ...@@ -58,7 +58,7 @@ enum {
void virCommandPassFD(virCommandPtr cmd, void virCommandPassFD(virCommandPtr cmd,
int fd, int fd,
unsigned int flags) ATTRIBUTE_NOINLINE; unsigned int flags) ATTRIBUTE_MOCKABLE;
void virCommandPassListenFDs(virCommandPtr cmd); void virCommandPassListenFDs(virCommandPtr cmd);
......
...@@ -55,6 +55,6 @@ int virCryptoEncryptData(virCryptoCipher algorithm, ...@@ -55,6 +55,6 @@ int virCryptoEncryptData(virCryptoCipher algorithm,
ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(6) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(6)
ATTRIBUTE_NONNULL(8) ATTRIBUTE_NONNULL(9) ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_NONNULL(8) ATTRIBUTE_NONNULL(9) ATTRIBUTE_RETURN_CHECK;
uint8_t *virCryptoGenerateRandom(size_t nbytes) ATTRIBUTE_NOINLINE; uint8_t *virCryptoGenerateRandom(size_t nbytes) ATTRIBUTE_MOCKABLE;
#endif /* __VIR_CRYPTO_H__ */ #endif /* __VIR_CRYPTO_H__ */
...@@ -188,7 +188,7 @@ void virFileActivateDirOverride(const char *argv0) ...@@ -188,7 +188,7 @@ void virFileActivateDirOverride(const char *argv0)
off_t virFileLength(const char *path, int fd) ATTRIBUTE_NONNULL(1); off_t virFileLength(const char *path, int fd) ATTRIBUTE_NONNULL(1);
bool virFileIsDir (const char *file) ATTRIBUTE_NONNULL(1); bool virFileIsDir (const char *file) ATTRIBUTE_NONNULL(1);
bool virFileExists(const char *file) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NOINLINE; bool virFileExists(const char *file) ATTRIBUTE_NONNULL(1) ATTRIBUTE_MOCKABLE;
bool virFileIsExecutable(const char *file) ATTRIBUTE_NONNULL(1); bool virFileIsExecutable(const char *file) ATTRIBUTE_NONNULL(1);
enum { enum {
......
...@@ -38,7 +38,7 @@ bool virHostCPUHasBitmap(void); ...@@ -38,7 +38,7 @@ bool virHostCPUHasBitmap(void);
virBitmapPtr virHostCPUGetPresentBitmap(void); virBitmapPtr virHostCPUGetPresentBitmap(void);
virBitmapPtr virHostCPUGetOnlineBitmap(void); virBitmapPtr virHostCPUGetOnlineBitmap(void);
int virHostCPUGetCount(void); int virHostCPUGetCount(void);
int virHostCPUGetThreadsPerSubcore(virArch arch) ATTRIBUTE_NOINLINE; int virHostCPUGetThreadsPerSubcore(virArch arch) ATTRIBUTE_MOCKABLE;
int virHostCPUGetMap(unsigned char **cpumap, int virHostCPUGetMap(unsigned char **cpumap,
unsigned int *online, unsigned int *online,
...@@ -51,7 +51,7 @@ int virHostCPUGetInfo(virArch hostarch, ...@@ -51,7 +51,7 @@ int virHostCPUGetInfo(virArch hostarch,
unsigned int *cores, unsigned int *cores,
unsigned int *threads); unsigned int *threads);
int virHostCPUGetKVMMaxVCPUs(void) ATTRIBUTE_NOINLINE; int virHostCPUGetKVMMaxVCPUs(void) ATTRIBUTE_MOCKABLE;
int virHostCPUStatsAssign(virNodeCPUStatsPtr param, int virHostCPUStatsAssign(virNodeCPUStatsPtr param,
const char *name, const char *name,
......
...@@ -48,7 +48,7 @@ void virMacAddrGetRaw(const virMacAddr *src, unsigned char dst[VIR_MAC_BUFLEN]); ...@@ -48,7 +48,7 @@ void virMacAddrGetRaw(const virMacAddr *src, unsigned char dst[VIR_MAC_BUFLEN]);
const char *virMacAddrFormat(const virMacAddr *addr, const char *virMacAddrFormat(const virMacAddr *addr,
char *str); char *str);
void virMacAddrGenerate(const unsigned char prefix[VIR_MAC_PREFIX_BUFLEN], void virMacAddrGenerate(const unsigned char prefix[VIR_MAC_PREFIX_BUFLEN],
virMacAddrPtr addr) ATTRIBUTE_NOINLINE; virMacAddrPtr addr) ATTRIBUTE_MOCKABLE;
int virMacAddrParse(const char* str, int virMacAddrParse(const char* str,
virMacAddrPtr addr) ATTRIBUTE_RETURN_CHECK; virMacAddrPtr addr) ATTRIBUTE_RETURN_CHECK;
int virMacAddrParseHex(const char* str, int virMacAddrParseHex(const char* str,
......
...@@ -156,7 +156,7 @@ int virNetDevExists(const char *brname) ...@@ -156,7 +156,7 @@ int virNetDevExists(const char *brname)
int virNetDevSetOnline(const char *ifname, int virNetDevSetOnline(const char *ifname,
bool online) bool online)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
int virNetDevGetOnline(const char *ifname, int virNetDevGetOnline(const char *ifname,
bool *online) bool *online)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
...@@ -164,7 +164,7 @@ int virNetDevGetOnline(const char *ifname, ...@@ -164,7 +164,7 @@ int virNetDevGetOnline(const char *ifname,
int virNetDevSetMAC(const char *ifname, int virNetDevSetMAC(const char *ifname,
const virMacAddr *macaddr) const virMacAddr *macaddr)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
int virNetDevGetMAC(const char *ifname, int virNetDevGetMAC(const char *ifname,
virMacAddrPtr macaddr) virMacAddrPtr macaddr)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
...@@ -303,8 +303,8 @@ int virNetDevSysfsFile(char **pf_sysfs_device_link, ...@@ -303,8 +303,8 @@ int virNetDevSysfsFile(char **pf_sysfs_device_link,
const char *ifname, const char *ifname,
const char *file) const char *file)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
int virNetDevRunEthernetScript(const char *ifname, const char *script) int virNetDevRunEthernetScript(const char *ifname, const char *script)
ATTRIBUTE_NOINLINE; ATTRIBUTE_MOCKABLE;
#endif /* __VIR_NETDEV_H__ */ #endif /* __VIR_NETDEV_H__ */
...@@ -67,7 +67,7 @@ int virNetDevIPAddrAdd(const char *ifname, ...@@ -67,7 +67,7 @@ int virNetDevIPAddrAdd(const char *ifname,
virSocketAddr *addr, virSocketAddr *addr,
virSocketAddr *peer, virSocketAddr *peer,
unsigned int prefix) unsigned int prefix)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
int virNetDevIPRouteAdd(const char *ifname, int virNetDevIPRouteAdd(const char *ifname,
virSocketAddrPtr addr, virSocketAddrPtr addr,
unsigned int prefix, unsigned int prefix,
......
...@@ -59,6 +59,6 @@ int virNetDevOpenvswitchInterfaceStats(const char *ifname, ...@@ -59,6 +59,6 @@ int virNetDevOpenvswitchInterfaceStats(const char *ifname,
int virNetDevOpenvswitchGetVhostuserIfname(const char *path, int virNetDevOpenvswitchGetVhostuserIfname(const char *path,
char **ifname) char **ifname)
ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
#endif /* __VIR_NETDEV_OPENVSWITCH_H__ */ #endif /* __VIR_NETDEV_OPENVSWITCH_H__ */
...@@ -39,7 +39,7 @@ int virNetDevTapCreate(char **ifname, ...@@ -39,7 +39,7 @@ int virNetDevTapCreate(char **ifname,
int *tapfd, int *tapfd,
size_t tapfdSize, size_t tapfdSize,
unsigned int flags) unsigned int flags)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
int virNetDevTapDelete(const char *ifname, int virNetDevTapDelete(const char *ifname,
const char *tunpath) const char *tunpath)
...@@ -49,7 +49,7 @@ int virNetDevTapGetName(int tapfd, char **ifname) ...@@ -49,7 +49,7 @@ int virNetDevTapGetName(int tapfd, char **ifname)
ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
char* virNetDevTapGetRealDeviceName(char *ifname) char* virNetDevTapGetRealDeviceName(char *ifname)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
typedef enum { typedef enum {
VIR_NETDEV_TAP_CREATE_NONE = 0, VIR_NETDEV_TAP_CREATE_NONE = 0,
...@@ -89,7 +89,7 @@ int virNetDevTapCreateInBridgePort(const char *brname, ...@@ -89,7 +89,7 @@ int virNetDevTapCreateInBridgePort(const char *brname,
unsigned int *actualMTU, unsigned int *actualMTU,
unsigned int flags) unsigned int flags)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
int virNetDevTapInterfaceStats(const char *ifname, int virNetDevTapInterfaceStats(const char *ifname,
virDomainInterfaceStatsPtr stats) virDomainInterfaceStatsPtr stats)
......
...@@ -34,20 +34,20 @@ int virNumaSetupMemoryPolicy(virDomainNumatuneMemMode mode, ...@@ -34,20 +34,20 @@ int virNumaSetupMemoryPolicy(virDomainNumatuneMemMode mode,
virBitmapPtr nodeset); virBitmapPtr nodeset);
virBitmapPtr virNumaGetHostMemoryNodeset(void); virBitmapPtr virNumaGetHostMemoryNodeset(void);
bool virNumaNodesetIsAvailable(virBitmapPtr nodeset) ATTRIBUTE_NOINLINE; bool virNumaNodesetIsAvailable(virBitmapPtr nodeset) ATTRIBUTE_MOCKABLE;
bool virNumaIsAvailable(void) ATTRIBUTE_NOINLINE; bool virNumaIsAvailable(void) ATTRIBUTE_MOCKABLE;
int virNumaGetMaxNode(void) ATTRIBUTE_NOINLINE; int virNumaGetMaxNode(void) ATTRIBUTE_MOCKABLE;
bool virNumaNodeIsAvailable(int node) ATTRIBUTE_NOINLINE; bool virNumaNodeIsAvailable(int node) ATTRIBUTE_MOCKABLE;
int virNumaGetDistances(int node, int virNumaGetDistances(int node,
int **distances, int **distances,
int *ndistances) ATTRIBUTE_NOINLINE; int *ndistances) ATTRIBUTE_MOCKABLE;
int virNumaGetNodeMemory(int node, int virNumaGetNodeMemory(int node,
unsigned long long *memsize, unsigned long long *memsize,
unsigned long long *memfree) ATTRIBUTE_NOINLINE; unsigned long long *memfree) ATTRIBUTE_MOCKABLE;
unsigned int virNumaGetMaxCPUs(void); unsigned int virNumaGetMaxCPUs(void);
int virNumaGetNodeCPUs(int node, virBitmapPtr *cpus) ATTRIBUTE_NOINLINE; int virNumaGetNodeCPUs(int node, virBitmapPtr *cpus) ATTRIBUTE_MOCKABLE;
int virNumaGetPageInfo(int node, int virNumaGetPageInfo(int node,
unsigned int page_size, unsigned int page_size,
...@@ -59,7 +59,7 @@ int virNumaGetPages(int node, ...@@ -59,7 +59,7 @@ int virNumaGetPages(int node,
unsigned int **pages_avail, unsigned int **pages_avail,
unsigned int **pages_free, unsigned int **pages_free,
size_t *npages) size_t *npages)
ATTRIBUTE_NONNULL(5) ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(5) ATTRIBUTE_MOCKABLE;
int virNumaSetPagePoolSize(int node, int virNumaSetPagePoolSize(int node,
unsigned int page_size, unsigned int page_size,
unsigned long long page_count, unsigned long long page_count,
......
...@@ -24,11 +24,11 @@ ...@@ -24,11 +24,11 @@
# include "internal.h" # include "internal.h"
uint64_t virRandomBits(int nbits) ATTRIBUTE_NOINLINE; uint64_t virRandomBits(int nbits) ATTRIBUTE_MOCKABLE;
double virRandom(void); double virRandom(void);
uint32_t virRandomInt(uint32_t max); uint32_t virRandomInt(uint32_t max);
int virRandomBytes(unsigned char *buf, size_t buflen) int virRandomBytes(unsigned char *buf, size_t buflen)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NOINLINE; ATTRIBUTE_NONNULL(1) ATTRIBUTE_RETURN_CHECK ATTRIBUTE_MOCKABLE;
int virRandomGenerateWWN(char **wwn, const char *virt_type) ATTRIBUTE_NOINLINE; int virRandomGenerateWWN(char **wwn, const char *virt_type) ATTRIBUTE_MOCKABLE;
#endif /* __VIR_RANDOM_H__ */ #endif /* __VIR_RANDOM_H__ */
...@@ -37,7 +37,7 @@ char *virSCSIDeviceGetSgName(const char *sysfs_prefix, ...@@ -37,7 +37,7 @@ char *virSCSIDeviceGetSgName(const char *sysfs_prefix,
const char *adapter, const char *adapter,
unsigned int bus, unsigned int bus,
unsigned int target, unsigned int target,
unsigned long long unit) ATTRIBUTE_NOINLINE; unsigned long long unit) ATTRIBUTE_MOCKABLE;
char *virSCSIDeviceGetDevName(const char *sysfs_prefix, char *virSCSIDeviceGetDevName(const char *sysfs_prefix,
const char *adapter, const char *adapter,
unsigned int bus, unsigned int bus,
......
...@@ -61,6 +61,6 @@ void virSCSIVHostDeviceGetUsedBy(virSCSIVHostDevicePtr dev, ...@@ -61,6 +61,6 @@ void virSCSIVHostDeviceGetUsedBy(virSCSIVHostDevicePtr dev,
const char **drv_name, const char **drv_name,
const char **dom_name); const char **dom_name);
void virSCSIVHostDeviceFree(virSCSIVHostDevicePtr dev); void virSCSIVHostDeviceFree(virSCSIVHostDevicePtr dev);
int virSCSIVHostOpenVhostSCSI(int *vhostfd) ATTRIBUTE_NOINLINE; int virSCSIVHostOpenVhostSCSI(int *vhostfd) ATTRIBUTE_MOCKABLE;
#endif /* __VIR_SCSIHOST_H__ */ #endif /* __VIR_SCSIHOST_H__ */
...@@ -22,6 +22,6 @@ ...@@ -22,6 +22,6 @@
#ifndef __VIR_TPM_H__ #ifndef __VIR_TPM_H__
# define __VIR_TPM_H__ # define __VIR_TPM_H__
char *virTPMCreateCancelPath(const char *devpath) ATTRIBUTE_NOINLINE; char *virTPMCreateCancelPath(const char *devpath) ATTRIBUTE_MOCKABLE;
#endif /* __VIR_TPM_H__ */ #endif /* __VIR_TPM_H__ */
...@@ -139,8 +139,8 @@ char *virGetUserConfigDirectory(void); ...@@ -139,8 +139,8 @@ char *virGetUserConfigDirectory(void);
char *virGetUserCacheDirectory(void); char *virGetUserCacheDirectory(void);
char *virGetUserRuntimeDirectory(void); char *virGetUserRuntimeDirectory(void);
char *virGetUserShell(uid_t uid); char *virGetUserShell(uid_t uid);
char *virGetUserName(uid_t uid) ATTRIBUTE_NOINLINE; char *virGetUserName(uid_t uid) ATTRIBUTE_MOCKABLE;
char *virGetGroupName(gid_t gid) ATTRIBUTE_NOINLINE; char *virGetGroupName(gid_t gid) ATTRIBUTE_MOCKABLE;
int virGetGroupList(uid_t uid, gid_t group, gid_t **groups) int virGetGroupList(uid_t uid, gid_t group, gid_t **groups)
ATTRIBUTE_NONNULL(3); ATTRIBUTE_NONNULL(3);
int virGetUserID(const char *name, int virGetUserID(const char *name,
...@@ -201,12 +201,12 @@ verify((int)VIR_TRISTATE_BOOL_ABSENT == (int)VIR_TRISTATE_SWITCH_ABSENT); ...@@ -201,12 +201,12 @@ verify((int)VIR_TRISTATE_BOOL_ABSENT == (int)VIR_TRISTATE_SWITCH_ABSENT);
unsigned int virGetListenFDs(void); unsigned int virGetListenFDs(void);
long virGetSystemPageSize(void) ATTRIBUTE_NOINLINE; long virGetSystemPageSize(void) ATTRIBUTE_MOCKABLE;
long virGetSystemPageSizeKB(void) ATTRIBUTE_NOINLINE; long virGetSystemPageSizeKB(void) ATTRIBUTE_MOCKABLE;
unsigned long long virMemoryLimitTruncate(unsigned long long value); unsigned long long virMemoryLimitTruncate(unsigned long long value);
bool virMemoryLimitIsSet(unsigned long long value); bool virMemoryLimitIsSet(unsigned long long value);
unsigned long long virMemoryMaxValue(bool ulong) ATTRIBUTE_NOINLINE; unsigned long long virMemoryMaxValue(bool ulong) ATTRIBUTE_MOCKABLE;
/** /**
* VIR_ASSIGN_IS_OVERFLOW: * VIR_ASSIGN_IS_OVERFLOW:
......
...@@ -49,7 +49,7 @@ int virGetHostUUID(unsigned char *host_uuid) ATTRIBUTE_NONNULL(1); ...@@ -49,7 +49,7 @@ int virGetHostUUID(unsigned char *host_uuid) ATTRIBUTE_NONNULL(1);
int virUUIDIsValid(unsigned char *uuid); int virUUIDIsValid(unsigned char *uuid);
int virUUIDGenerate(unsigned char *uuid) ATTRIBUTE_NOINLINE; int virUUIDGenerate(unsigned char *uuid) ATTRIBUTE_MOCKABLE;
int virUUIDParse(const char *uuidstr, int virUUIDParse(const char *uuidstr,
unsigned char *uuid) unsigned char *uuid)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册