2017-07-25 16:03:11 +02:00
|
|
|
/*
|
|
|
|
* virresctrl.h:
|
|
|
|
*
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
2019-06-18 11:13:08 -05:00
|
|
|
#pragma once
|
2017-07-25 16:03:11 +02:00
|
|
|
|
2019-06-18 11:13:08 -05:00
|
|
|
#include "internal.h"
|
2017-07-25 16:03:11 +02:00
|
|
|
|
2019-10-04 17:14:10 +01:00
|
|
|
#include "virobject.h"
|
2019-06-18 11:13:08 -05:00
|
|
|
#include "virbitmap.h"
|
|
|
|
#include "virutil.h"
|
|
|
|
#include "virenum.h"
|
2017-07-25 16:03:11 +02:00
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
VIR_CACHE_TYPE_BOTH,
|
|
|
|
VIR_CACHE_TYPE_CODE,
|
|
|
|
VIR_CACHE_TYPE_DATA,
|
|
|
|
|
|
|
|
VIR_CACHE_TYPE_LAST
|
|
|
|
} virCacheType;
|
|
|
|
|
|
|
|
VIR_ENUM_DECL(virCache);
|
2018-02-08 15:55:09 +01:00
|
|
|
VIR_ENUM_DECL(virCacheKernel);
|
2017-07-25 16:03:11 +02:00
|
|
|
|
2018-09-20 18:10:50 +08:00
|
|
|
typedef enum {
|
|
|
|
VIR_RESCTRL_MONITOR_TYPE_UNSUPPORT,
|
|
|
|
VIR_RESCTRL_MONITOR_TYPE_CACHE,
|
|
|
|
VIR_RESCTRL_MONITOR_TYPE_MEMBW,
|
|
|
|
|
|
|
|
VIR_RESCTRL_MONITOR_TYPE_LAST
|
|
|
|
} virResctrlMonitorType;
|
|
|
|
|
|
|
|
VIR_ENUM_DECL(virResctrlMonitorPrefix);
|
|
|
|
|
2017-07-25 16:03:11 +02:00
|
|
|
|
2017-11-20 10:23:04 +01:00
|
|
|
typedef struct _virResctrlInfoPerCache virResctrlInfoPerCache;
|
|
|
|
typedef virResctrlInfoPerCache *virResctrlInfoPerCachePtr;
|
|
|
|
struct _virResctrlInfoPerCache {
|
2017-07-25 16:03:11 +02:00
|
|
|
/* Smallest possible increase of the allocation size in bytes */
|
|
|
|
unsigned long long granularity;
|
|
|
|
/* Minimal allocatable size in bytes (if different from granularity) */
|
|
|
|
unsigned long long min;
|
|
|
|
/* Type of the allocation */
|
|
|
|
virCacheType scope;
|
|
|
|
/* Maximum number of simultaneous allocations */
|
|
|
|
unsigned int max_allocation;
|
|
|
|
};
|
|
|
|
|
2018-07-30 11:12:41 +08:00
|
|
|
typedef struct _virResctrlInfoMemBWPerNode virResctrlInfoMemBWPerNode;
|
|
|
|
typedef virResctrlInfoMemBWPerNode *virResctrlInfoMemBWPerNodePtr;
|
|
|
|
struct _virResctrlInfoMemBWPerNode {
|
|
|
|
/* Smallest possible increase of the allocation bandwidth in percentage */
|
|
|
|
unsigned int granularity;
|
|
|
|
/* Minimal allocatable bandwidth in percentage */
|
|
|
|
unsigned int min;
|
|
|
|
/* Maximum number of simultaneous allocations */
|
|
|
|
unsigned int max_allocation;
|
|
|
|
};
|
|
|
|
|
2018-09-20 18:10:50 +08:00
|
|
|
typedef struct _virResctrlInfoMon virResctrlInfoMon;
|
|
|
|
typedef virResctrlInfoMon *virResctrlInfoMonPtr;
|
|
|
|
struct _virResctrlInfoMon {
|
|
|
|
/* Maximum number of simultaneous monitors */
|
|
|
|
unsigned int max_monitor;
|
|
|
|
/* null-terminal string list for monitor features */
|
|
|
|
char **features;
|
|
|
|
/* Number of monitor features */
|
|
|
|
size_t nfeatures;
|
|
|
|
/* Monitor type */
|
|
|
|
virResctrlMonitorType type;
|
|
|
|
/* This adjustable value affects the final reuse of resources used by
|
|
|
|
* monitor. After the action of removing a monitor, the kernel may not
|
|
|
|
* release all hardware resources that monitor used immediately if the
|
|
|
|
* cache occupancy value associated with 'removed' monitor is above this
|
|
|
|
* threshold. Once the cache occupancy is below this threshold, the
|
|
|
|
* underlying hardware resource will be reclaimed and be put into the
|
|
|
|
* resource pool for next reusing.*/
|
|
|
|
unsigned int cache_reuse_threshold;
|
|
|
|
/* The cache 'level' that has the monitor capability */
|
|
|
|
unsigned int cache_level;
|
|
|
|
};
|
|
|
|
|
2017-11-20 11:12:06 +01:00
|
|
|
typedef struct _virResctrlInfo virResctrlInfo;
|
|
|
|
typedef virResctrlInfo *virResctrlInfoPtr;
|
2017-07-25 16:03:11 +02:00
|
|
|
|
2017-11-20 11:12:06 +01:00
|
|
|
virResctrlInfoPtr
|
|
|
|
virResctrlInfoNew(void);
|
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlInfoGetCache(virResctrlInfoPtr resctrl,
|
|
|
|
unsigned int level,
|
|
|
|
unsigned long long size,
|
|
|
|
size_t *ncontrols,
|
|
|
|
virResctrlInfoPerCachePtr **controls);
|
|
|
|
|
2018-07-30 11:12:41 +08:00
|
|
|
int
|
|
|
|
virResctrlInfoGetMemoryBandwidth(virResctrlInfoPtr resctrl,
|
|
|
|
unsigned int level,
|
|
|
|
virResctrlInfoMemBWPerNodePtr control);
|
2017-10-16 17:17:32 +02:00
|
|
|
/* Alloc-related things */
|
|
|
|
typedef struct _virResctrlAlloc virResctrlAlloc;
|
|
|
|
typedef virResctrlAlloc *virResctrlAllocPtr;
|
|
|
|
|
2019-10-04 17:14:10 +01:00
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virResctrlAlloc, virObjectUnref);
|
|
|
|
|
|
|
|
|
2018-07-30 11:12:25 +08:00
|
|
|
typedef int virResctrlAllocForeachCacheCallback(unsigned int level,
|
|
|
|
virCacheType type,
|
|
|
|
unsigned int cache,
|
|
|
|
unsigned long long size,
|
|
|
|
void *opaque);
|
2017-10-16 17:17:32 +02:00
|
|
|
|
2018-07-30 11:12:33 +08:00
|
|
|
typedef int virResctrlAllocForeachMemoryCallback(unsigned int id,
|
|
|
|
unsigned int size,
|
|
|
|
void *opaque);
|
|
|
|
|
2017-10-16 17:17:32 +02:00
|
|
|
virResctrlAllocPtr
|
|
|
|
virResctrlAllocNew(void);
|
|
|
|
|
|
|
|
bool
|
2018-02-01 14:57:40 +01:00
|
|
|
virResctrlAllocIsEmpty(virResctrlAllocPtr alloc);
|
2017-10-16 17:17:32 +02:00
|
|
|
|
|
|
|
int
|
2018-07-30 11:12:25 +08:00
|
|
|
virResctrlAllocSetCacheSize(virResctrlAllocPtr alloc,
|
|
|
|
unsigned int level,
|
|
|
|
virCacheType type,
|
|
|
|
unsigned int cache,
|
|
|
|
unsigned long long size);
|
2017-10-16 17:17:32 +02:00
|
|
|
|
|
|
|
int
|
2018-07-30 11:12:25 +08:00
|
|
|
virResctrlAllocForeachCache(virResctrlAllocPtr alloc,
|
|
|
|
virResctrlAllocForeachCacheCallback cb,
|
|
|
|
void *opaque);
|
2017-10-16 17:17:32 +02:00
|
|
|
|
2018-07-30 11:12:34 +08:00
|
|
|
int
|
|
|
|
virResctrlAllocSetMemoryBandwidth(virResctrlAllocPtr alloc,
|
|
|
|
unsigned int id,
|
|
|
|
unsigned int memory_bandwidth);
|
|
|
|
|
2018-07-30 11:12:33 +08:00
|
|
|
int
|
|
|
|
virResctrlAllocForeachMemory(virResctrlAllocPtr resctrl,
|
|
|
|
virResctrlAllocForeachMemoryCallback cb,
|
|
|
|
void *opaque);
|
|
|
|
|
2017-10-16 17:17:32 +02:00
|
|
|
int
|
|
|
|
virResctrlAllocSetID(virResctrlAllocPtr alloc,
|
|
|
|
const char *id);
|
|
|
|
const char *
|
|
|
|
virResctrlAllocGetID(virResctrlAllocPtr alloc);
|
|
|
|
|
|
|
|
char *
|
|
|
|
virResctrlAllocFormat(virResctrlAllocPtr alloc);
|
|
|
|
|
2018-01-30 23:57:42 +01:00
|
|
|
int
|
|
|
|
virResctrlAllocDeterminePath(virResctrlAllocPtr alloc,
|
|
|
|
const char *machinename);
|
|
|
|
|
2017-10-16 17:17:32 +02:00
|
|
|
int
|
|
|
|
virResctrlAllocCreate(virResctrlInfoPtr r_info,
|
|
|
|
virResctrlAllocPtr alloc,
|
|
|
|
const char *machinename);
|
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlAllocAddPID(virResctrlAllocPtr alloc,
|
|
|
|
pid_t pid);
|
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlAllocRemove(virResctrlAllocPtr alloc);
|
|
|
|
|
2018-09-20 18:10:50 +08:00
|
|
|
void
|
|
|
|
virResctrlInfoMonFree(virResctrlInfoMonPtr mon);
|
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlInfoGetMonitorPrefix(virResctrlInfoPtr resctrl,
|
|
|
|
const char *prefix,
|
|
|
|
virResctrlInfoMonPtr *monitor);
|
2018-11-12 21:31:33 +08:00
|
|
|
|
|
|
|
/* Monitor-related things */
|
|
|
|
|
|
|
|
typedef struct _virResctrlMonitor virResctrlMonitor;
|
|
|
|
typedef virResctrlMonitor *virResctrlMonitorPtr;
|
|
|
|
|
2018-11-12 21:31:41 +08:00
|
|
|
typedef struct _virResctrlMonitorStats virResctrlMonitorStats;
|
|
|
|
typedef virResctrlMonitorStats *virResctrlMonitorStatsPtr;
|
|
|
|
struct _virResctrlMonitorStats {
|
2019-06-11 11:31:13 +08:00
|
|
|
/* The system assigned cache ID associated with statistical record */
|
|
|
|
unsigned int id;
|
|
|
|
/* @features is a NULL terminal string list tracking the statistical record
|
|
|
|
* name.*/
|
|
|
|
char **features;
|
|
|
|
/* @vals store the statistical record values and @val[0] is the value for
|
|
|
|
* @features[0], @val[1] for@features[1] ... respectively */
|
|
|
|
unsigned int *vals;
|
|
|
|
/* The length of @vals array */
|
|
|
|
size_t nvals;
|
2018-11-12 21:31:41 +08:00
|
|
|
};
|
|
|
|
|
2018-11-12 21:31:33 +08:00
|
|
|
virResctrlMonitorPtr
|
|
|
|
virResctrlMonitorNew(void);
|
2018-11-12 21:31:35 +08:00
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlMonitorDeterminePath(virResctrlMonitorPtr monitor,
|
|
|
|
const char *machinename);
|
2018-11-12 21:31:37 +08:00
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlMonitorAddPID(virResctrlMonitorPtr monitor,
|
|
|
|
pid_t pid);
|
2018-11-12 21:31:39 +08:00
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlMonitorCreate(virResctrlMonitorPtr monitor,
|
|
|
|
const char *machinename);
|
2018-11-12 21:31:41 +08:00
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlMonitorSetID(virResctrlMonitorPtr monitor,
|
|
|
|
const char *id);
|
|
|
|
|
|
|
|
const char *
|
|
|
|
virResctrlMonitorGetID(virResctrlMonitorPtr monitor);
|
|
|
|
|
|
|
|
void
|
|
|
|
virResctrlMonitorSetAlloc(virResctrlMonitorPtr monitor,
|
|
|
|
virResctrlAllocPtr alloc);
|
|
|
|
|
|
|
|
int
|
|
|
|
virResctrlMonitorRemove(virResctrlMonitorPtr monitor);
|
|
|
|
|
2019-06-11 11:31:14 +08:00
|
|
|
int
|
|
|
|
virResctrlMonitorGetStats(virResctrlMonitorPtr monitor,
|
|
|
|
const char **resources,
|
|
|
|
virResctrlMonitorStatsPtr **stats,
|
|
|
|
size_t *nstats);
|
|
|
|
|
2018-11-27 01:56:15 +08:00
|
|
|
void
|
2019-06-11 11:31:12 +08:00
|
|
|
virResctrlMonitorStatsFree(virResctrlMonitorStatsPtr stats);
|