summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-app-irqbalance/htdocs
diff options
context:
space:
mode:
Diffstat (limited to 'applications/luci-app-irqbalance/htdocs')
-rw-r--r--applications/luci-app-irqbalance/htdocs/luci-static/resources/view/irqbalance.js116
1 files changed, 116 insertions, 0 deletions
diff --git a/applications/luci-app-irqbalance/htdocs/luci-static/resources/view/irqbalance.js b/applications/luci-app-irqbalance/htdocs/luci-static/resources/view/irqbalance.js
new file mode 100644
index 0000000000..280b6f19c7
--- /dev/null
+++ b/applications/luci-app-irqbalance/htdocs/luci-static/resources/view/irqbalance.js
@@ -0,0 +1,116 @@
+'use strict';
+'require view';
+'require fs';
+'require form';
+'require ui';
+'require rpc';
+
+const callServiceList = rpc.declare({
+ object: 'service',
+ method: 'list',
+ params: ['name'],
+ expect: { '': {} },
+});
+
+function getServiceStatus() {
+ return L.resolveDefault(callServiceList('irqbalance'), {}).then(function (res) {
+ try {
+ return res['irqbalance']['instances']['irqbalance']['running'];
+ } catch (e) {
+ return false;
+ }
+ });
+}
+
+function renderStatus(isRunning) {
+ const spanTemp = '<span style="color:%s"><strong>%s</strong></span>';
+
+ return isRunning
+ ? String.format(spanTemp, 'green', _('RUNNING'))
+ : String.format(spanTemp, 'red', _('NOT RUNNING'));
+}
+
+return view.extend({
+ load() {
+ return L.resolveDefault(fs.read_direct('/proc/interrupts'));
+ },
+
+ render(data) {
+ const cpuNum = data.match(/\bCPU\d+\b/g).map(i => i.slice(3)), // cpuNum = data.match(/(?<=\bCPU)\d+\b/g), // Safari did not support RegExp lookbehind assertion before version 16.4.
+ irqNum = data.match(/\b\d+(?=: )/g);
+ let m, s, o;
+
+ m = new form.Map('irqbalance', _('irqbalance'), _('The purpose of irqbalance is to distribute hardware interrupts across processors/cores on a multiprocessor/multicore system in order to increase performance.'));
+
+ s = m.section(form.NamedSection);
+ s.anonymous = true;
+ s.render = function () {
+ L.Poll.add(function () {
+ return L.resolveDefault(getServiceStatus()).then(function (res) {
+ const view = document.getElementById('status');
+ view.innerHTML = renderStatus(res);
+ });
+ });
+
+ return E('div', { class: 'cbi-section' }, [
+ E('p', { id: 'status' }, _('Loading...'))
+ ]);
+ }
+
+ s = m.section(form.TypedSection, 'irqbalance', _('Snapshot of current IRQs'));
+ s.anonymous = true;
+
+ s = m.section(form.NamedSection);
+ s.anonymous = true;
+ s.render = function () {
+ const snapshot = new ui.Textarea(data.slice(0, -1), {
+ readonly: true,
+ placeholder: _('Loading...'),
+ monospace: true,
+ rows: data.split('\n').length - 1,
+ });
+ return snapshot.render();
+ }
+
+ s = m.section(form.TypedSection, 'irqbalance', _('General settings'));
+ s.anonymous = true;
+
+ o = s.option(form.Flag, 'enabled', _('Enable'));
+ o.default = '0';
+ o.rmempty = false;
+
+ o = s.option(form.Value, 'deepestcache', _('Deepest cache'), _('Cache level at which irqbalance partitions cache domains.'));
+ o.placeholder = '2';
+ o.datatype = 'uinteger';
+ o.optional = true;
+
+ o = s.option(form.Value, 'interval', _('Interval'), _('Value in seconds.'));
+ o.placeholder = '10';
+ o.datatype = 'uinteger';
+ o.optional = true;
+
+ o = s.option(form.Value, 'banned_cpulist', _('Exclude CPUs'), _('List of CPUs to ignore, can be an integer or integers separated by commas.') + '<br />' + _('Valid values: %s.').format(cpuNum.join(', ')));
+ o.placeholder = '0';
+ o.optional = true;
+ o.validate = function (section_id, value) {
+ for (const i of value.split(',')) {
+ if (!cpuNum.includes(i) && i != '') {
+ return _('Invalid');
+ }
+ }
+ return true;
+ }
+
+ o = s.option(form.DynamicList, 'banirq', _('Exclude IRQs'), _('List of IRQs to ignore.') + '<br />' + _('Valid values: %s.').format(irqNum.join(', ')));
+ o.placeholder = '36';
+ o.datatype = 'uinteger';
+ o.optional = true;
+ o.validate = function (section_id, value) {
+ return !irqNum.includes(value) && value != ''
+ ? _('Invalid')
+ : true;
+ }
+
+ return m.render();
+ }
+});