mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 04:25:18 +00:00
virsh: Create macros to add IOTUNE values
Rework the repetitive lines to add iotune values into easier to read macros. One to handle the SCALED values and one to handle the non scaled values. Signed-off-by: John Ferlan <jferlan@redhat.com>
This commit is contained in:
parent
2db108c766
commit
49d01f9e3f
@ -1300,122 +1300,43 @@ cmdBlkdeviotune(vshControl *ctl, const vshCmd *cmd)
|
|||||||
if (vshCommandOptStringReq(ctl, cmd, "device", &disk) < 0)
|
if (vshCommandOptStringReq(ctl, cmd, "device", &disk) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if ((rv = vshCommandOptScaledInt(ctl, cmd, "total-bytes-sec", &value, 1, ULLONG_MAX)) < 0) {
|
#define VSH_ADD_IOTUNE_SCALED(PARAM, CONST) \
|
||||||
goto interror;
|
if ((rv = vshCommandOptScaledInt(ctl, cmd, #PARAM, &value, \
|
||||||
} else if (rv > 0) {
|
1, ULLONG_MAX)) < 0) { \
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
goto interror; \
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_BYTES_SEC,
|
} else if (rv > 0) { \
|
||||||
value) < 0)
|
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams, \
|
||||||
goto save_error;
|
VIR_DOMAIN_BLOCK_IOTUNE_##CONST, \
|
||||||
}
|
value) < 0) \
|
||||||
|
goto save_error; \
|
||||||
|
} \
|
||||||
|
|
||||||
if ((rv = vshCommandOptScaledInt(ctl, cmd, "read-bytes-sec", &value, 1, ULLONG_MAX)) < 0) {
|
VSH_ADD_IOTUNE_SCALED(total-bytes-sec, TOTAL_BYTES_SEC);
|
||||||
goto interror;
|
VSH_ADD_IOTUNE_SCALED(read-bytes-sec, READ_BYTES_SEC);
|
||||||
} else if (rv > 0) {
|
VSH_ADD_IOTUNE_SCALED(write-bytes-sec, WRITE_BYTES_SEC);
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
VSH_ADD_IOTUNE_SCALED(total-bytes-sec-max, TOTAL_BYTES_SEC_MAX);
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_READ_BYTES_SEC,
|
VSH_ADD_IOTUNE_SCALED(read-bytes-sec-max, READ_BYTES_SEC_MAX);
|
||||||
value) < 0)
|
VSH_ADD_IOTUNE_SCALED(write-bytes-sec-max, WRITE_BYTES_SEC_MAX);
|
||||||
goto save_error;
|
#undef VSH_ADD_IOTUNE_SCALED
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptScaledInt(ctl, cmd, "write-bytes-sec", &value, 1, ULLONG_MAX)) < 0) {
|
#define VSH_ADD_IOTUNE(PARAM, CONST) \
|
||||||
goto interror;
|
if ((rv = vshCommandOptULongLong(ctl, cmd, #PARAM, &value)) < 0) { \
|
||||||
} else if (rv > 0) {
|
goto interror; \
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
} else if (rv > 0) { \
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_BYTES_SEC,
|
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams, \
|
||||||
value) < 0)
|
VIR_DOMAIN_BLOCK_IOTUNE_##CONST, \
|
||||||
goto save_error;
|
value) < 0) \
|
||||||
}
|
goto save_error; \
|
||||||
|
} \
|
||||||
|
|
||||||
if ((rv = vshCommandOptScaledInt(ctl, cmd, "total-bytes-sec-max", &value, 1, ULLONG_MAX)) < 0) {
|
VSH_ADD_IOTUNE(total-iops-sec, TOTAL_IOPS_SEC);
|
||||||
goto interror;
|
VSH_ADD_IOTUNE(read-iops-sec, READ_IOPS_SEC);
|
||||||
} else if (rv > 0) {
|
VSH_ADD_IOTUNE(write-iops-sec, WRITE_IOPS_SEC);
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
VSH_ADD_IOTUNE(total-iops-sec-max, TOTAL_IOPS_SEC_MAX);
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_BYTES_SEC_MAX,
|
VSH_ADD_IOTUNE(read-iops-sec-max, READ_IOPS_SEC_MAX);
|
||||||
value) < 0)
|
VSH_ADD_IOTUNE(write-iops-sec-max, WRITE_IOPS_SEC_MAX);
|
||||||
goto save_error;
|
VSH_ADD_IOTUNE(size-iops-sec, SIZE_IOPS_SEC);
|
||||||
}
|
#undef VSH_ADD_IOTUNE
|
||||||
|
|
||||||
if ((rv = vshCommandOptScaledInt(ctl, cmd, "read-bytes-sec-max", &value, 1, ULLONG_MAX)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_READ_BYTES_SEC_MAX,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptScaledInt(ctl, cmd, "write-bytes-sec-max", &value, 1, ULLONG_MAX)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_BYTES_SEC_MAX,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptULongLong(ctl, cmd, "total-iops-sec", &value)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_IOPS_SEC,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptULongLong(ctl, cmd, "read-iops-sec", &value)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_READ_IOPS_SEC,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptULongLong(ctl, cmd, "write-iops-sec", &value)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_IOPS_SEC,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptULongLong(ctl, cmd, "write-iops-sec-max", &value)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_IOPS_SEC_MAX,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptULongLong(ctl, cmd, "read-iops-sec-max", &value)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_READ_IOPS_SEC_MAX,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptULongLong(ctl, cmd, "total-iops-sec-max", &value)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_IOPS_SEC_MAX,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((rv = vshCommandOptULongLong(ctl, cmd, "size-iops-sec", &value)) < 0) {
|
|
||||||
goto interror;
|
|
||||||
} else if (rv > 0) {
|
|
||||||
if (virTypedParamsAddULLong(¶ms, &nparams, &maxparams,
|
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_SIZE_IOPS_SEC,
|
|
||||||
value) < 0)
|
|
||||||
goto save_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (nparams == 0) {
|
if (nparams == 0) {
|
||||||
if (virDomainGetBlockIoTune(dom, NULL, NULL, &nparams, flags) != 0) {
|
if (virDomainGetBlockIoTune(dom, NULL, NULL, &nparams, flags) != 0) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user