mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-12 15:52:55 +00:00
c8238579fb
Historically, we declared pointer type to our types: typedef struct _virXXX virXXX; typedef virXXX *virXXXPtr; But usefulness of such declaration is questionable, at best. Unfortunately, we can't drop every such declaration - we have to carry some over, because they are part of public API (e.g. virDomainPtr). But for internal types - we can do drop them and use what every other C project uses 'virXXX *'. This change was generated by a very ugly shell script that generated sed script which was then called over each file in the repository. For the shell script refer to the cover letter: https://listman.redhat.com/archives/libvir-list/2021-March/msg00537.html Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Peter Krempa <pkrempa@redhat.com>
100 lines
2.4 KiB
C
100 lines
2.4 KiB
C
#include <config.h>
|
|
|
|
#include "testutils.h"
|
|
#include "virfilewrapper.h"
|
|
#define LIBVIRT_VIRRESCTRLPRIV_H_ALLOW
|
|
#include "virresctrlpriv.h"
|
|
|
|
|
|
#define VIR_FROM_THIS VIR_FROM_NONE
|
|
|
|
struct virResctrlData {
|
|
const char *filename;
|
|
bool fail;
|
|
};
|
|
|
|
|
|
static int
|
|
test_virResctrlGetUnused(const void *opaque)
|
|
{
|
|
struct virResctrlData *data = (struct virResctrlData *) opaque;
|
|
char *system_dir = NULL;
|
|
char *resctrl_dir = NULL;
|
|
int ret = -1;
|
|
virResctrlAlloc *alloc = NULL;
|
|
char *schemata_str = NULL;
|
|
char *schemata_file;
|
|
virCaps *caps = NULL;
|
|
|
|
system_dir = g_strdup_printf("%s/vircaps2xmldata/linux-%s/system", abs_srcdir,
|
|
data->filename);
|
|
|
|
resctrl_dir = g_strdup_printf("%s/vircaps2xmldata/linux-%s/resctrl",
|
|
abs_srcdir, data->filename);
|
|
|
|
schemata_file = g_strdup_printf("%s/virresctrldata/%s.schemata", abs_srcdir,
|
|
data->filename);
|
|
|
|
virFileWrapperAddPrefix("/sys/devices/system", system_dir);
|
|
virFileWrapperAddPrefix("/sys/fs/resctrl", resctrl_dir);
|
|
|
|
caps = virCapabilitiesNew(VIR_ARCH_X86_64, false, false);
|
|
if (!caps || virCapabilitiesInitCaches(caps) < 0) {
|
|
fprintf(stderr, "Could not initialize capabilities");
|
|
goto cleanup;
|
|
}
|
|
|
|
alloc = virResctrlAllocGetUnused(caps->host.resctrl);
|
|
|
|
virFileWrapperClearPrefixes();
|
|
|
|
if (!alloc) {
|
|
if (data->fail)
|
|
ret = 0;
|
|
goto cleanup;
|
|
} else if (data->fail) {
|
|
VIR_TEST_DEBUG("Error expected but there wasn't any.");
|
|
ret = -1;
|
|
goto cleanup;
|
|
}
|
|
|
|
schemata_str = virResctrlAllocFormat(alloc);
|
|
|
|
if (virTestCompareToFile(schemata_str, schemata_file) < 0)
|
|
goto cleanup;
|
|
|
|
ret = 0;
|
|
cleanup:
|
|
virObjectUnref(caps);
|
|
virObjectUnref(alloc);
|
|
VIR_FREE(system_dir);
|
|
VIR_FREE(resctrl_dir);
|
|
VIR_FREE(schemata_str);
|
|
VIR_FREE(schemata_file);
|
|
return ret;
|
|
}
|
|
|
|
|
|
static int
|
|
mymain(void)
|
|
{
|
|
struct virResctrlData data = {0};
|
|
int ret = 0;
|
|
|
|
#define DO_TEST_UNUSED(_filename) \
|
|
do { \
|
|
data = (struct virResctrlData) { .filename = _filename }; \
|
|
if (virTestRun("Free: " _filename, test_virResctrlGetUnused, &data) < 0) \
|
|
ret = -1; \
|
|
} while (0)
|
|
|
|
DO_TEST_UNUSED("resctrl");
|
|
DO_TEST_UNUSED("resctrl-cdp");
|
|
DO_TEST_UNUSED("resctrl-skx");
|
|
DO_TEST_UNUSED("resctrl-skx-twocaches");
|
|
|
|
return ret;
|
|
}
|
|
|
|
VIR_TEST_MAIN(mymain)
|