[pve-devel] [PATCH] hdedit : add io throttle max burst
Alexandre Derumier
aderumier at odiso.com
Wed Dec 4 15:16:28 CET 2013
Signed-off-by: Alexandre Derumier <aderumier at odiso.com>
---
www/manager/qemu/HDEdit.js | 73 ++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 73 insertions(+)
diff --git a/www/manager/qemu/HDEdit.js b/www/manager/qemu/HDEdit.js
index af5427a..b1590e5 100644
--- a/www/manager/qemu/HDEdit.js
+++ b/www/manager/qemu/HDEdit.js
@@ -44,22 +44,49 @@ Ext.define('PVE.qemu.HDInputPanel', {
} else {
delete me.drive.mbps_rd;
}
+
+ if (values.mbps_rd_max && values.mbps_rd) {
+ me.drive.mbps_rd_max = values.mbps_rd_max;
+ } else {
+ delete me.drive.mbps_rd_max;
+ }
+
if (values.mbps_wr) {
me.drive.mbps_wr = values.mbps_wr;
} else {
delete me.drive.mbps_wr;
}
+
+ if (values.mbps_wr_max && values.mbps_wr) {
+ me.drive.mbps_wr_max = values.mbps_wr_max;
+ } else {
+ delete me.drive.mbps_wr_max;
+ }
+
if (values.iops_rd) {
me.drive.iops_rd = values.iops_rd;
} else {
delete me.drive.iops_rd;
}
+
+ if (values.iops_rd_max && values.iops_rd) {
+ me.drive.iops_rd_max = values.iops_rd_max;
+ } else {
+ delete me.drive.iops_rd_max;
+ }
+
if (values.iops_wr) {
me.drive.iops_wr = values.iops_wr;
} else {
delete me.drive.iops_wr;
}
+ if (values.iops_wr_max && values.iops_wr) {
+ me.drive.iops_wr_max = values.iops_wr_max;
+ } else {
+ delete me.drive.iops_wr_max;
+ }
+
var params = {};
params[confid] = PVE.Parser.printQemuDrive(me.drive);
@@ -106,6 +133,10 @@ Ext.define('PVE.qemu.HDInputPanel', {
values.mbps_wr = drive.mbps_wr;
values.iops_rd = drive.iops_rd;
values.iops_wr = drive.iops_wr;
+ values.mbps_rd_max = drive.mbps_rd_max;
+ values.mbps_wr_max = drive.mbps_wr_max;
+ values.iops_rd_max = drive.iops_rd_max;
+ values.iops_wr_max = drive.iops_wr_max;
me.setValues(values);
},
@@ -123,6 +154,7 @@ Ext.define('PVE.qemu.HDInputPanel', {
me.column1 = [];
me.column2 = [];
+ me.column3 = [];
if (!me.confid || me.unused) {
me.bussel = Ext.createWidget('PVE.form.ControllerSelector', {
@@ -252,6 +284,17 @@ Ext.define('PVE.qemu.HDInputPanel', {
});
me.column2.push(me.mbps_rd);
+ me.mbps_rd_max = Ext.widget('numberfield', {
+ name: 'mbps_rd_max',
+ minValue: 1,
+ step: 1,
+ fieldLabel: gettext('Read max burst') + ' (MB)',
+ labelWidth: width2,
+ emptyText: gettext('default')
+ });
+ me.column2.push(me.mbps_rd_max);
+
+
me.mbps_wr = Ext.widget('numberfield', {
name: 'mbps_wr',
minValue: 1,
@@ -262,6 +305,16 @@ Ext.define('PVE.qemu.HDInputPanel', {
});
me.column2.push(me.mbps_wr);
+ me.mbps_wr_max = Ext.widget('numberfield', {
+ name: 'mbps_wr_max',
+ minValue: 1,
+ step: 1,
+ fieldLabel: gettext('Write max burst') + ' (MB)',
+ labelWidth: width2,
+ emptyText: gettext('default')
+ });
+ me.column2.push(me.mbps_wr_max);
+
me.iops_rd = Ext.widget('numberfield', {
name: 'iops_rd',
minValue: 10,
@@ -272,6 +325,16 @@ Ext.define('PVE.qemu.HDInputPanel', {
});
me.column2.push(me.iops_rd);
+ me.iops_rd_max = Ext.widget('numberfield', {
+ name: 'iops_rd_max',
+ minValue: 10,
+ step: 10,
+ fieldLabel: gettext('Read max burst') + ' (ops)',
+ labelWidth: width2,
+ emptyText: gettext('default')
+ });
+ me.column2.push(me.iops_rd_max);
+
me.iops_wr = Ext.widget('numberfield', {
name: 'iops_wr',
minValue: 10,
@@ -282,6 +345,16 @@ Ext.define('PVE.qemu.HDInputPanel', {
});
me.column2.push(me.iops_wr);
+ me.iops_wr_max = Ext.widget('numberfield', {
+ name: 'iops_wr_max',
+ minValue: 10,
+ step: 10,
+ fieldLabel: gettext('Write max burst') + ' (ops)',
+ labelWidth: width2,
+ emptyText: gettext('default')
+ });
+ me.column2.push(me.iops_wr_max);
+
me.callParent();
}
});
--
1.7.10.4
More information about the pve-devel
mailing list