mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-18 18:45:16 +00:00
nodedev: driver: Create a generic mdevctl command translator
Currently there are dedicated wrappers to construct mdevctl command. These are mostly fine except for the one that translates both "start" and "define" commands, only because mdevctl takes the same set of arguments. Instead, keep the wrappers, but let them call a single global translator that handles all the mdevctl command differences and commonalities. Signed-off-by: Erik Skultety <eskultet@redhat.com> Signed-off-by: Jonathon Jongsma <jjongsma@redhat.com> Reviewed-by: Laine Stump <laine@redhat.com>
This commit is contained in:
parent
92fdc1f0cb
commit
87b31fe8a2
@ -717,18 +717,39 @@ nodeDeviceFindAddressByName(const char *name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* the mdevctl 'start' and 'define' commands accept almost the exact same
|
static virCommand *
|
||||||
* arguments, so provide a common implementation that can be wrapped by a more
|
nodeDeviceGetMdevctlCommand(virNodeDeviceDef *def,
|
||||||
* specific function */
|
virMdevctlCommand cmd_type,
|
||||||
static virCommand*
|
char **outbuf,
|
||||||
nodeDeviceGetMdevctlDefineCreateCommand(virNodeDeviceDef *def,
|
char **errbuf)
|
||||||
const char *subcommand,
|
|
||||||
char **uuid_out,
|
|
||||||
char **errmsg)
|
|
||||||
{
|
{
|
||||||
virCommand *cmd;
|
g_autofree char *parent_addr = NULL;
|
||||||
g_autofree char *json = NULL;
|
virCommand *cmd = NULL;
|
||||||
g_autofree char *parent_addr = nodeDeviceFindAddressByName(def->parent);
|
const char *subcommand = virMdevctlCommandTypeToString(cmd_type);
|
||||||
|
g_autofree char *inbuf = NULL;
|
||||||
|
|
||||||
|
switch (cmd_type) {
|
||||||
|
case MDEVCTL_CMD_CREATE:
|
||||||
|
/* now is the time to make sure "create" is replaced with "start" on
|
||||||
|
* mdevctl cmdline */
|
||||||
|
cmd = virCommandNewArgList(MDEVCTL, "start", NULL);
|
||||||
|
break;
|
||||||
|
case MDEVCTL_CMD_STOP:
|
||||||
|
case MDEVCTL_CMD_START:
|
||||||
|
case MDEVCTL_CMD_DEFINE:
|
||||||
|
case MDEVCTL_CMD_UNDEFINE:
|
||||||
|
cmd = virCommandNewArgList(MDEVCTL, subcommand, NULL);
|
||||||
|
break;
|
||||||
|
case MDEVCTL_CMD_LAST:
|
||||||
|
default:
|
||||||
|
/* SHOULD NEVER HAPPEN */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (cmd_type) {
|
||||||
|
case MDEVCTL_CMD_CREATE:
|
||||||
|
case MDEVCTL_CMD_DEFINE:
|
||||||
|
parent_addr = nodeDeviceFindAddressByName(def->parent);
|
||||||
|
|
||||||
if (!parent_addr) {
|
if (!parent_addr) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
@ -736,23 +757,35 @@ nodeDeviceGetMdevctlDefineCreateCommand(virNodeDeviceDef *def,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nodeDeviceDefToMdevctlConfig(def, &json) < 0) {
|
if (nodeDeviceDefToMdevctlConfig(def, &inbuf) < 0) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||||
_("couldn't convert node device def to mdevctl JSON"));
|
_("couldn't convert node device def to mdevctl JSON"));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd = virCommandNewArgList(MDEVCTL, subcommand, NULL);
|
|
||||||
virCommandAddArgPair(cmd, "--parent", parent_addr);
|
virCommandAddArgPair(cmd, "--parent", parent_addr);
|
||||||
virCommandAddArgPair(cmd, "--jsonfile", "/dev/stdin");
|
virCommandAddArgPair(cmd, "--jsonfile", "/dev/stdin");
|
||||||
|
|
||||||
virCommandSetInputBuffer(cmd, json);
|
virCommandSetInputBuffer(cmd, inbuf);
|
||||||
|
virCommandSetOutputBuffer(cmd, outbuf);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case MDEVCTL_CMD_UNDEFINE:
|
||||||
|
case MDEVCTL_CMD_STOP:
|
||||||
|
case MDEVCTL_CMD_START:
|
||||||
|
/* No special handling here, we only need to pass UUID with these */
|
||||||
|
break;
|
||||||
|
case MDEVCTL_CMD_LAST:
|
||||||
|
default:
|
||||||
|
/* SHOULD NEVER HAPPEN */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fill in UUID for commands that need it */
|
||||||
if (def->caps->data.mdev.uuid)
|
if (def->caps->data.mdev.uuid)
|
||||||
virCommandAddArgPair(cmd, "--uuid", def->caps->data.mdev.uuid);
|
virCommandAddArgPair(cmd, "--uuid", def->caps->data.mdev.uuid);
|
||||||
|
|
||||||
virCommandSetOutputBuffer(cmd, uuid_out);
|
virCommandSetErrorBuffer(cmd, errbuf);
|
||||||
virCommandSetErrorBuffer(cmd, errmsg);
|
|
||||||
|
|
||||||
return cmd;
|
return cmd;
|
||||||
}
|
}
|
||||||
@ -762,8 +795,7 @@ nodeDeviceGetMdevctlCreateCommand(virNodeDeviceDef *def,
|
|||||||
char **uuid_out,
|
char **uuid_out,
|
||||||
char **errmsg)
|
char **errmsg)
|
||||||
{
|
{
|
||||||
return nodeDeviceGetMdevctlDefineCreateCommand(def, "start", uuid_out,
|
return nodeDeviceGetMdevctlCommand(def, MDEVCTL_CMD_CREATE, uuid_out, errmsg);
|
||||||
errmsg);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virCommand*
|
virCommand*
|
||||||
@ -771,8 +803,7 @@ nodeDeviceGetMdevctlDefineCommand(virNodeDeviceDef *def,
|
|||||||
char **uuid_out,
|
char **uuid_out,
|
||||||
char **errmsg)
|
char **errmsg)
|
||||||
{
|
{
|
||||||
return nodeDeviceGetMdevctlDefineCreateCommand(def, "define", uuid_out,
|
return nodeDeviceGetMdevctlCommand(def, MDEVCTL_CMD_DEFINE, uuid_out, errmsg);
|
||||||
errmsg);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -906,31 +937,24 @@ nodeDeviceCreateXML(virConnectPtr conn,
|
|||||||
|
|
||||||
|
|
||||||
virCommand *
|
virCommand *
|
||||||
nodeDeviceGetMdevctlStopCommand(const char *uuid, char **errmsg)
|
nodeDeviceGetMdevctlStopCommand(virNodeDeviceDef *def,
|
||||||
|
char **errmsg)
|
||||||
{
|
{
|
||||||
virCommand *cmd = virCommandNewArgList(MDEVCTL, "stop", NULL);
|
return nodeDeviceGetMdevctlCommand(def, MDEVCTL_CMD_STOP, NULL, errmsg);
|
||||||
virCommandAddArgPair(cmd, "--uuid", uuid);
|
|
||||||
virCommandSetErrorBuffer(cmd, errmsg);
|
|
||||||
return cmd;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virCommand *
|
virCommand *
|
||||||
nodeDeviceGetMdevctlUndefineCommand(const char *uuid, char **errmsg)
|
nodeDeviceGetMdevctlUndefineCommand(virNodeDeviceDef *def,
|
||||||
|
char **errmsg)
|
||||||
{
|
{
|
||||||
virCommand *cmd = virCommandNewArgList(MDEVCTL, "undefine", NULL);
|
return nodeDeviceGetMdevctlCommand(def, MDEVCTL_CMD_UNDEFINE, NULL, errmsg);
|
||||||
virCommandAddArgPair(cmd, "--uuid", uuid);
|
|
||||||
virCommandSetErrorBuffer(cmd, errmsg);
|
|
||||||
return cmd;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virCommand *
|
virCommand *
|
||||||
nodeDeviceGetMdevctlStartCommand(const char *uuid, char **errmsg)
|
nodeDeviceGetMdevctlStartCommand(virNodeDeviceDef *def,
|
||||||
|
char **errmsg)
|
||||||
{
|
{
|
||||||
virCommand *cmd = virCommandNewArgList(MDEVCTL, "start", NULL);
|
return nodeDeviceGetMdevctlCommand(def, MDEVCTL_CMD_START, NULL, errmsg);
|
||||||
virCommandAddArgPair(cmd, "--uuid", uuid);
|
|
||||||
virCommandSetErrorBuffer(cmd, errmsg);
|
|
||||||
return cmd;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -939,7 +963,7 @@ virMdevctlStop(virNodeDeviceDef *def, char **errmsg)
|
|||||||
int status;
|
int status;
|
||||||
g_autoptr(virCommand) cmd = NULL;
|
g_autoptr(virCommand) cmd = NULL;
|
||||||
|
|
||||||
cmd = nodeDeviceGetMdevctlStopCommand(def->caps->data.mdev.uuid, errmsg);
|
cmd = nodeDeviceGetMdevctlStopCommand(def, errmsg);
|
||||||
|
|
||||||
if (virCommandRun(cmd, &status) < 0 || status != 0)
|
if (virCommandRun(cmd, &status) < 0 || status != 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -954,8 +978,7 @@ virMdevctlUndefine(virNodeDeviceDef *def, char **errmsg)
|
|||||||
int status;
|
int status;
|
||||||
g_autoptr(virCommand) cmd = NULL;
|
g_autoptr(virCommand) cmd = NULL;
|
||||||
|
|
||||||
cmd = nodeDeviceGetMdevctlUndefineCommand(def->caps->data.mdev.uuid,
|
cmd = nodeDeviceGetMdevctlUndefineCommand(def, errmsg);
|
||||||
errmsg);
|
|
||||||
|
|
||||||
if (virCommandRun(cmd, &status) < 0 || status != 0)
|
if (virCommandRun(cmd, &status) < 0 || status != 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -970,7 +993,7 @@ virMdevctlStart(virNodeDeviceDef *def, char **errmsg)
|
|||||||
int status;
|
int status;
|
||||||
g_autoptr(virCommand) cmd = NULL;
|
g_autoptr(virCommand) cmd = NULL;
|
||||||
|
|
||||||
cmd = nodeDeviceGetMdevctlStartCommand(def->caps->data.mdev.uuid, errmsg);
|
cmd = nodeDeviceGetMdevctlStartCommand(def, errmsg);
|
||||||
|
|
||||||
if (virCommandRun(cmd, &status) < 0 || status != 0)
|
if (virCommandRun(cmd, &status) < 0 || status != 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -152,11 +152,11 @@ nodeDeviceGetMdevctlDefineCommand(virNodeDeviceDef *def,
|
|||||||
char **errmsg);
|
char **errmsg);
|
||||||
|
|
||||||
virCommand *
|
virCommand *
|
||||||
nodeDeviceGetMdevctlStopCommand(const char *uuid,
|
nodeDeviceGetMdevctlStopCommand(virNodeDeviceDef *def,
|
||||||
char **errmsg);
|
char **errmsg);
|
||||||
|
|
||||||
virCommand *
|
virCommand *
|
||||||
nodeDeviceGetMdevctlUndefineCommand(const char *uuid,
|
nodeDeviceGetMdevctlUndefineCommand(virNodeDeviceDef *def,
|
||||||
char **errmsg);
|
char **errmsg);
|
||||||
|
|
||||||
virCommand *
|
virCommand *
|
||||||
@ -181,7 +181,7 @@ bool nodeDeviceDefCopyFromMdevctl(virNodeDeviceDef *dst,
|
|||||||
virNodeDeviceDef *src);
|
virNodeDeviceDef *src);
|
||||||
|
|
||||||
virCommand*
|
virCommand*
|
||||||
nodeDeviceGetMdevctlStartCommand(const char *uuid,
|
nodeDeviceGetMdevctlStartCommand(virNodeDeviceDef *def,
|
||||||
char **errmsg);
|
char **errmsg);
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -115,7 +115,7 @@ testMdevctlCreateOrDefineHelper(const void *data)
|
|||||||
mdevxml, cmdlinefile, jsonfile);
|
mdevxml, cmdlinefile, jsonfile);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef virCommand* (*GetStopUndefineCmdFunc)(const char *uuid, char **errbuf);
|
typedef virCommand* (*GetStopUndefineCmdFunc)(virNodeDeviceDef *def, char **errbuf);
|
||||||
struct UuidCommandTestInfo {
|
struct UuidCommandTestInfo {
|
||||||
const char *filename;
|
const char *filename;
|
||||||
virMdevctlCommand command;
|
virMdevctlCommand command;
|
||||||
@ -136,7 +136,7 @@ testMdevctlUuidCommand(GetStopUndefineCmdFunc func,
|
|||||||
if (!(def = virNodeDeviceDefParseFile(mdevxml, EXISTING_DEVICE, "QEMU")))
|
if (!(def = virNodeDeviceDefParseFile(mdevxml, EXISTING_DEVICE, "QEMU")))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
cmd = func(def->caps->data.mdev.uuid, &errmsg);
|
cmd = func(def, &errmsg);
|
||||||
|
|
||||||
if (!cmd)
|
if (!cmd)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user