conky-config/drawing/processor.lua

203 lines
5.7 KiB
Lua
Raw Normal View History

2021-07-29 22:37:30 -04:00
local compounddial = require 'compounddial'
local line = require 'line'
local texttable = require 'texttable'
2021-07-17 23:06:30 -04:00
local Util = require 'Util'
local common = require 'common'
local geometry = require 'geometry'
2021-07-17 21:22:17 -04:00
local CPU = require 'CPU'
2021-07-23 01:41:06 -04:00
local func = require 'func'
2019-09-01 15:34:10 -04:00
2021-07-13 01:01:21 -04:00
local __math_floor = math.floor
2021-07-12 23:49:52 -04:00
2021-07-17 23:06:30 -04:00
return function(update_freq)
local MODULE_Y = 614
local DIAL_INNER_RADIUS = 30
local DIAL_OUTER_RADIUS = 42
local DIAL_THICKNESS = 5.5
local SEPARATOR_SPACING = 20
local TEXT_SPACING = 22
local PLOT_SECTION_BREAK = 23
local PLOT_HEIGHT = 56
local TABLE_SECTION_BREAK = 20
local TABLE_HEIGHT = 114
-----------------------------------------------------------------------------
-- header
local header = common.Header(
geometry.LEFT_X,
2021-07-17 23:06:30 -04:00
MODULE_Y,
geometry.SECTION_WIDTH,
2021-07-17 23:06:30 -04:00
'PROCESSOR'
)
2017-07-19 00:36:15 -04:00
2021-07-17 23:06:30 -04:00
-----------------------------------------------------------------------------
-- cores (loads and temps)
2021-07-17 21:22:17 -04:00
local cpu_loads = CPU.init_cpu_loads()
local ncpus = CPU.get_cpu_number()
local ncores = CPU.get_core_number()
local nthreads = ncpus / ncores
local hwp_paths = CPU.get_hwp_paths()
local coretemp_paths = CPU.get_coretemp_paths()
2021-07-17 23:06:30 -04:00
CPU.read_cpu_loads(cpu_loads) -- prime load matrix by side effect
2021-07-17 21:22:17 -04:00
local cores = {}
2021-07-17 23:06:30 -04:00
local create_core = function(x, y)
return {
loads = common.compound_dial(
2021-07-17 23:06:30 -04:00
x,
y,
DIAL_OUTER_RADIUS,
DIAL_INNER_RADIUS,
DIAL_THICKNESS,
0.8,
nthreads
),
2021-07-29 22:37:30 -04:00
coretemp = common.inittextRing(
2021-07-17 23:06:30 -04:00
x,
y,
DIAL_INNER_RADIUS - 2,
'%s°C',
90
)
}
end
2021-07-17 21:22:17 -04:00
for c = 1, ncores do
local dial_x = geometry.LEFT_X + DIAL_OUTER_RADIUS +
(geometry.SECTION_WIDTH - 2 * DIAL_OUTER_RADIUS) * (c - 1) / 3
2021-07-17 23:06:30 -04:00
local dial_y = header.bottom_y + DIAL_OUTER_RADIUS
cores[c] = create_core(dial_x, dial_y)
2021-07-17 21:22:17 -04:00
end
2021-07-17 23:06:30 -04:00
-----------------------------------------------------------------------------
-- HWP status
local HWP_Y = header.bottom_y + DIAL_OUTER_RADIUS * 2 + PLOT_SECTION_BREAK
2021-07-29 22:37:30 -04:00
local cpu_status = common.inittextRows(
geometry.LEFT_X,
2021-07-17 23:06:30 -04:00
HWP_Y,
geometry.SECTION_WIDTH,
2021-07-17 23:06:30 -04:00
TEXT_SPACING,
{'HWP Preference', 'Ave Freq'}
)
-----------------------------------------------------------------------------
-- frequency
local SEP_Y = HWP_Y + TEXT_SPACING + SEPARATOR_SPACING
local separator = common.initSeparator(
geometry.LEFT_X,
2021-07-17 23:06:30 -04:00
SEP_Y,
geometry.SECTION_WIDTH
2021-07-17 23:06:30 -04:00
)
-----------------------------------------------------------------------------
-- total load plot
local LOAD_Y = SEP_Y + SEPARATOR_SPACING
local total_load = common.initPercentPlot(
geometry.LEFT_X,
2021-07-17 23:06:30 -04:00
LOAD_Y,
geometry.SECTION_WIDTH,
2021-07-17 23:06:30 -04:00
PLOT_HEIGHT,
PLOT_SECTION_BREAK,
"Total Load",
update_freq
)
2021-07-17 23:06:30 -04:00
local PLOT_Y = LOAD_Y + PLOT_SECTION_BREAK
-----------------------------------------------------------------------------
-- cpu top table
local NUM_ROWS = 5
2021-07-23 01:41:06 -04:00
local TABLE_CONKY = func.map(
function(i) return {pid = '${top pid '..i..'}', cpu = '${top cpu '..i..'}'} end,
func.seq(NUM_ROWS)
)
2021-07-17 23:06:30 -04:00
2021-07-29 22:37:30 -04:00
local tbl = common.inittable(
geometry.LEFT_X,
2021-07-17 23:06:30 -04:00
PLOT_Y + PLOT_HEIGHT + TABLE_SECTION_BREAK,
geometry.SECTION_WIDTH,
2021-07-17 23:06:30 -04:00
TABLE_HEIGHT,
NUM_ROWS,
{'Name', 'PID', 'CPU (%)'}
)
-----------------------------------------------------------------------------
-- main functions
2021-07-26 23:45:54 -04:00
local update = function(trigger)
local conky = Util.conky
local load_sum = 0
2021-07-17 21:22:17 -04:00
cpu_loads = CPU.read_cpu_loads(cpu_loads)
for _, load_data in pairs(cpu_loads) do
local cur = load_data.percent_active
load_sum = load_sum + cur
2021-07-29 22:37:30 -04:00
compounddial.set(cores[load_data.conky_core_id].loads, load_data.conky_thread_id, cur)
2021-07-17 21:22:17 -04:00
end
2021-07-17 22:45:30 -04:00
for conky_core_id, path in pairs(coretemp_paths) do
2021-07-17 21:22:17 -04:00
local temp = __math_floor(0.001 * Util.read_file(path, nil, '*n'))
common.text_ring_set(cores[conky_core_id].coretemp, temp)
end
2018-01-05 23:36:50 -05:00
-- For some reason this call is slow (querying anything with pstate in
-- general seems slow), but I also don't need to see an update every cycle,
-- hence the trigger
if trigger == 0 then
common.text_rows_set(cpu_status, 1, CPU.read_hwp(hwp_paths))
end
common.text_rows_set(cpu_status, 2, CPU.read_freq())
common.percent_plot_set(total_load, load_sum / ncpus * 100)
for r = 1, NUM_ROWS do
local pid = conky(TABLE_CONKY[r].pid, '(%d+)') -- may have leading spaces
if pid ~= '' then
2021-07-29 22:37:30 -04:00
texttable.set(tbl, 1, r, Util.read_file('/proc/'..pid..'/comm', '(%C+)'))
texttable.set(tbl, 2, r, pid)
texttable.set(tbl, 3, r, conky(TABLE_CONKY[r].cpu))
end
2019-09-01 15:34:10 -04:00
end
end
local draw_static = function(cr)
common.drawHeader(cr, header)
2021-07-17 23:06:30 -04:00
for i = 1, #cores do
common.text_ring_draw_static(cores[i].coretemp, cr)
2021-07-29 22:37:30 -04:00
compounddial.draw_static(cores[i].loads, cr)
end
2018-08-05 11:56:11 -04:00
common.text_rows_draw_static(cpu_status, cr)
2021-07-29 22:37:30 -04:00
line.draw(separator, cr)
common.percent_plot_draw_static(total_load, cr)
2018-01-05 23:36:50 -05:00
2021-07-29 22:37:30 -04:00
texttable.draw_static(tbl, cr)
2018-08-05 11:08:37 -04:00
end
2018-01-05 23:36:50 -05:00
local draw_dynamic = function(cr)
2021-07-17 23:06:30 -04:00
for i = 1, #cores do
2021-07-29 22:37:30 -04:00
compounddial.draw_dynamic(cores[i].loads, cr)
common.text_ring_draw_dynamic(cores[i].coretemp, cr)
end
common.text_rows_draw_dynamic(cpu_status, cr)
common.percent_plot_draw_dynamic(total_load, cr)
2021-07-29 22:37:30 -04:00
texttable.draw_dynamic(tbl, cr)
end
2017-07-19 00:36:15 -04:00
return {static = draw_static, dynamic = draw_dynamic, update = update}
end