mirror of https://gitee.com/openkylin/libvirt.git
virnetdev: move virNetDevSetRootQDisc to virnetdevbandwidth
The function in question uses "tc" binary so virnetdevbandwidth feels like better place for it. Signed-off-by: Pavel Hrdina <phrdina@redhat.com> Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
parent
50a021df33
commit
18882ea776
|
@ -2714,7 +2714,6 @@ virNetDevSetOnline;
|
||||||
virNetDevSetPromiscuous;
|
virNetDevSetPromiscuous;
|
||||||
virNetDevSetRcvAllMulti;
|
virNetDevSetRcvAllMulti;
|
||||||
virNetDevSetRcvMulti;
|
virNetDevSetRcvMulti;
|
||||||
virNetDevSetRootQDisc;
|
|
||||||
virNetDevSetupControl;
|
virNetDevSetupControl;
|
||||||
virNetDevSysfsFile;
|
virNetDevSysfsFile;
|
||||||
virNetDevValidateConfig;
|
virNetDevValidateConfig;
|
||||||
|
@ -2728,6 +2727,7 @@ virNetDevBandwidthEqual;
|
||||||
virNetDevBandwidthFree;
|
virNetDevBandwidthFree;
|
||||||
virNetDevBandwidthPlug;
|
virNetDevBandwidthPlug;
|
||||||
virNetDevBandwidthSet;
|
virNetDevBandwidthSet;
|
||||||
|
virNetDevBandwidthSetRootQDisc;
|
||||||
virNetDevBandwidthUnplug;
|
virNetDevBandwidthUnplug;
|
||||||
virNetDevBandwidthUpdateFilter;
|
virNetDevBandwidthUpdateFilter;
|
||||||
virNetDevBandwidthUpdateRate;
|
virNetDevBandwidthUpdateRate;
|
||||||
|
|
|
@ -50,6 +50,7 @@
|
||||||
#include "domain_event.h"
|
#include "domain_event.h"
|
||||||
#include "domain_validate.h"
|
#include "domain_validate.h"
|
||||||
#include "virtime.h"
|
#include "virtime.h"
|
||||||
|
#include "virnetdevbandwidth.h"
|
||||||
#include "virnetdevopenvswitch.h"
|
#include "virnetdevopenvswitch.h"
|
||||||
#include "virstoragefile.h"
|
#include "virstoragefile.h"
|
||||||
#include "storage_source.h"
|
#include "storage_source.h"
|
||||||
|
@ -11571,7 +11572,7 @@ qemuDomainInterfaceSetDefaultQDisc(virQEMUDriver *driver,
|
||||||
actualType == VIR_DOMAIN_NET_TYPE_NETWORK ||
|
actualType == VIR_DOMAIN_NET_TYPE_NETWORK ||
|
||||||
actualType == VIR_DOMAIN_NET_TYPE_BRIDGE ||
|
actualType == VIR_DOMAIN_NET_TYPE_BRIDGE ||
|
||||||
actualType == VIR_DOMAIN_NET_TYPE_DIRECT) {
|
actualType == VIR_DOMAIN_NET_TYPE_DIRECT) {
|
||||||
if (virNetDevSetRootQDisc(net->ifname, "noqueue") < 0)
|
if (virNetDevBandwidthSetRootQDisc(net->ifname, "noqueue") < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3507,52 +3507,6 @@ virNetDevRunEthernetScript(const char *ifname, const char *script)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* virNetDevSetRootQDisc:
|
|
||||||
* @ifname: the interface name
|
|
||||||
* @qdisc: queueing discipline to set
|
|
||||||
*
|
|
||||||
* For given interface @ifname set its root queueing discipline
|
|
||||||
* to @qdisc. This can be used to replace the default qdisc
|
|
||||||
* (usually pfifo_fast or whatever is set in
|
|
||||||
* /proc/sys/net/core/default_qdisc) with different qdisc.
|
|
||||||
*
|
|
||||||
* Returns: 0 on success,
|
|
||||||
* -1 if failed to exec tc (with error reported)
|
|
||||||
* -2 if tc failed (with no error reported)
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
virNetDevSetRootQDisc(const char *ifname,
|
|
||||||
const char *qdisc)
|
|
||||||
{
|
|
||||||
g_autoptr(virCommand) cmd = NULL;
|
|
||||||
g_autofree char *outbuf = NULL;
|
|
||||||
g_autofree char *errbuf = NULL;
|
|
||||||
int status;
|
|
||||||
|
|
||||||
/* Ideally, we would have a netlink implementation and just
|
|
||||||
* call it here. But honestly, I tried and failed miserably.
|
|
||||||
* Fallback to spawning tc. */
|
|
||||||
cmd = virCommandNewArgList(TC, "qdisc", "add", "dev", ifname,
|
|
||||||
"root", "handle", "0:", qdisc,
|
|
||||||
NULL);
|
|
||||||
|
|
||||||
virCommandAddEnvString(cmd, "LC_ALL=C");
|
|
||||||
virCommandSetOutputBuffer(cmd, &outbuf);
|
|
||||||
virCommandSetErrorBuffer(cmd, &errbuf);
|
|
||||||
|
|
||||||
if (virCommandRun(cmd, &status) < 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (status != 0) {
|
|
||||||
VIR_DEBUG("Setting qdisc failed: output='%s' err='%s'", outbuf, errbuf);
|
|
||||||
return -2;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* virNetDevReserveName:
|
* virNetDevReserveName:
|
||||||
* @name: name of an existing network device
|
* @name: name of an existing network device
|
||||||
|
|
|
@ -333,10 +333,6 @@ int virNetDevSysfsFile(char **pf_sysfs_device_link,
|
||||||
int virNetDevRunEthernetScript(const char *ifname, const char *script)
|
int virNetDevRunEthernetScript(const char *ifname, const char *script)
|
||||||
G_GNUC_NO_INLINE;
|
G_GNUC_NO_INLINE;
|
||||||
|
|
||||||
int virNetDevSetRootQDisc(const char *ifname,
|
|
||||||
const char *qdisc)
|
|
||||||
G_GNUC_NO_INLINE;
|
|
||||||
|
|
||||||
int virNetDevVFInterfaceStats(virPCIDeviceAddress *vfAddr,
|
int virNetDevVFInterfaceStats(virPCIDeviceAddress *vfAddr,
|
||||||
virDomainInterfaceStatsPtr stats)
|
virDomainInterfaceStatsPtr stats)
|
||||||
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
|
||||||
|
|
|
@ -23,11 +23,14 @@
|
||||||
#include "vircommand.h"
|
#include "vircommand.h"
|
||||||
#include "viralloc.h"
|
#include "viralloc.h"
|
||||||
#include "virerror.h"
|
#include "virerror.h"
|
||||||
|
#include "virlog.h"
|
||||||
#include "virstring.h"
|
#include "virstring.h"
|
||||||
#include "virutil.h"
|
#include "virutil.h"
|
||||||
|
|
||||||
#define VIR_FROM_THIS VIR_FROM_NONE
|
#define VIR_FROM_THIS VIR_FROM_NONE
|
||||||
|
|
||||||
|
VIR_LOG_INIT("util.netdevbandwidth");
|
||||||
|
|
||||||
void
|
void
|
||||||
virNetDevBandwidthFree(virNetDevBandwidth *def)
|
virNetDevBandwidthFree(virNetDevBandwidth *def)
|
||||||
{
|
{
|
||||||
|
@ -749,3 +752,50 @@ virNetDevBandwidthUpdateFilter(const char *ifname,
|
||||||
VIR_FREE(class_id);
|
VIR_FREE(class_id);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virNetDevBandwidthSetRootQDisc:
|
||||||
|
* @ifname: the interface name
|
||||||
|
* @qdisc: queueing discipline to set
|
||||||
|
*
|
||||||
|
* For given interface @ifname set its root queueing discipline
|
||||||
|
* to @qdisc. This can be used to replace the default qdisc
|
||||||
|
* (usually pfifo_fast or whatever is set in
|
||||||
|
* /proc/sys/net/core/default_qdisc) with different qdisc.
|
||||||
|
*
|
||||||
|
* Returns: 0 on success,
|
||||||
|
* -1 if failed to exec tc (with error reported)
|
||||||
|
* -2 if tc failed (with no error reported)
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
virNetDevBandwidthSetRootQDisc(const char *ifname,
|
||||||
|
const char *qdisc)
|
||||||
|
{
|
||||||
|
g_autoptr(virCommand) cmd = NULL;
|
||||||
|
g_autofree char *outbuf = NULL;
|
||||||
|
g_autofree char *errbuf = NULL;
|
||||||
|
int status;
|
||||||
|
|
||||||
|
/* Ideally, we would have a netlink implementation and just
|
||||||
|
* call it here. But honestly, I tried and failed miserably.
|
||||||
|
* Fallback to spawning tc. */
|
||||||
|
cmd = virCommandNewArgList(TC, "qdisc", "add", "dev", ifname,
|
||||||
|
"root", "handle", "0:", qdisc,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
virCommandAddEnvString(cmd, "LC_ALL=C");
|
||||||
|
virCommandSetOutputBuffer(cmd, &outbuf);
|
||||||
|
virCommandSetErrorBuffer(cmd, &errbuf);
|
||||||
|
|
||||||
|
if (virCommandRun(cmd, &status) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if (status != 0) {
|
||||||
|
VIR_DEBUG("Setting qdisc failed: output='%s' err='%s'", outbuf, errbuf);
|
||||||
|
return -2;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
|
@ -74,3 +74,7 @@ int virNetDevBandwidthUpdateFilter(const char *ifname,
|
||||||
unsigned int id)
|
unsigned int id)
|
||||||
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
|
||||||
G_GNUC_WARN_UNUSED_RESULT;
|
G_GNUC_WARN_UNUSED_RESULT;
|
||||||
|
|
||||||
|
int virNetDevBandwidthSetRootQDisc(const char *ifname,
|
||||||
|
const char *qdisc)
|
||||||
|
G_GNUC_NO_INLINE;
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "virmock.h"
|
#include "virmock.h"
|
||||||
#include "virlog.h"
|
#include "virlog.h"
|
||||||
#include "virnetdev.h"
|
#include "virnetdev.h"
|
||||||
|
#include "virnetdevbandwidth.h"
|
||||||
#include "virnetdevip.h"
|
#include "virnetdevip.h"
|
||||||
#include "virnetdevtap.h"
|
#include "virnetdevtap.h"
|
||||||
#include "virnetdevopenvswitch.h"
|
#include "virnetdevopenvswitch.h"
|
||||||
|
@ -277,8 +278,8 @@ qemuBuildTPMOpenBackendFDs(const char *tpmdev G_GNUC_UNUSED,
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
virNetDevSetRootQDisc(const char *ifname G_GNUC_UNUSED,
|
virNetDevBandwidthSetRootQDisc(const char *ifname G_GNUC_UNUSED,
|
||||||
const char *qdisc G_GNUC_UNUSED)
|
const char *qdisc G_GNUC_UNUSED)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue