Switch to the use of mutex wrappers that provide better error checking. Signed-off-by: Ian Rogers <irogers@google.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Alexandre Truong <alexandre.truong@arm.com> Cc: Alexey Bayduraev <alexey.v.bayduraev@linux.intel.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Andres Freund <andres@anarazel.de> Cc: Andrii Nakryiko <andrii@kernel.org> Cc: André Almeida <andrealmeid@igalia.com> Cc: Athira Jajeev <atrajeev@linux.vnet.ibm.com> Cc: Christophe JAILLET <christophe.jaillet@wanadoo.fr> Cc: Colin Ian King <colin.king@intel.com> Cc: Dario Petrillo <dario.pk1@gmail.com> Cc: Darren Hart <dvhart@infradead.org> Cc: Dave Marchevsky <davemarchevsky@fb.com> Cc: Davidlohr Bueso <dave@stgolabs.net> Cc: Fangrui Song <maskray@google.com> Cc: Hewenliang <hewenliang4@huawei.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: James Clark <james.clark@arm.com> Cc: Jason Wang <wangborong@cdjrlc.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Kajol Jain <kjain@linux.ibm.com> Cc: Kim Phillips <kim.phillips@amd.com> Cc: Leo Yan <leo.yan@linaro.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Martin Liška <mliska@suse.cz> Cc: Masami Hiramatsu <mhiramat@kernel.org> Cc: Nathan Chancellor <nathan@kernel.org> Cc: Nick Desaulniers <ndesaulniers@google.com> Cc: Pavithra Gurushankar <gpavithrasha@gmail.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Quentin Monnet <quentin@isovalent.com> Cc: Ravi Bangoria <ravi.bangoria@amd.com> Cc: Remi Bernon <rbernon@codeweavers.com> Cc: Riccardo Mancini <rickyman7@gmail.com> Cc: Song Liu <songliubraving@fb.com> Cc: Stephane Eranian <eranian@google.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Thomas Richter <tmricht@linux.ibm.com> Cc: Tom Rix <trix@redhat.com> Cc: Weiguo Li <liwg06@foxmail.com> Cc: Wenyu Liu <liuwenyu7@huawei.com> Cc: William Cohen <wcohen@redhat.com> Cc: Zechuan Chen <chenzechuan1@huawei.com> Cc: bpf@vger.kernel.org Cc: llvm@lists.linux.dev Cc: yaowenbin <yaowenbin1@huawei.com> Link: https://lore.kernel.org/r/20220826164242.43412-10-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
			
				
	
	
		
			88 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| #include <linux/kernel.h>
 | |
| #include "../progress.h"
 | |
| #include "../libslang.h"
 | |
| #include "../ui.h"
 | |
| #include "tui.h"
 | |
| #include "units.h"
 | |
| #include "../browser.h"
 | |
| 
 | |
| static void __tui_progress__init(struct ui_progress *p)
 | |
| {
 | |
| 	p->next = p->step = p->total / (SLtt_Screen_Cols - 2) ?: 1;
 | |
| }
 | |
| 
 | |
| static int get_title(struct ui_progress *p, char *buf, size_t size)
 | |
| {
 | |
| 	char buf_cur[20];
 | |
| 	char buf_tot[20];
 | |
| 	int ret;
 | |
| 
 | |
| 	ret  = unit_number__scnprintf(buf_cur, sizeof(buf_cur), p->curr);
 | |
| 	ret += unit_number__scnprintf(buf_tot, sizeof(buf_tot), p->total);
 | |
| 
 | |
| 	return ret + scnprintf(buf, size, "%s [%s/%s]",
 | |
| 			       p->title, buf_cur, buf_tot);
 | |
| }
 | |
| 
 | |
| static void tui_progress__update(struct ui_progress *p)
 | |
| {
 | |
| 	char buf[100], *title = (char *) p->title;
 | |
| 	int bar, y;
 | |
| 	/*
 | |
| 	 * FIXME: We should have a per UI backend way of showing progress,
 | |
| 	 * stdio will just show a percentage as NN%, etc.
 | |
| 	 */
 | |
| 	if (use_browser <= 0)
 | |
| 		return;
 | |
| 
 | |
| 	if (p->total == 0)
 | |
| 		return;
 | |
| 
 | |
| 	if (p->size) {
 | |
| 		get_title(p, buf, sizeof(buf));
 | |
| 		title = buf;
 | |
| 	}
 | |
| 
 | |
| 	ui__refresh_dimensions(false);
 | |
| 	mutex_lock(&ui__lock);
 | |
| 	y = SLtt_Screen_Rows / 2 - 2;
 | |
| 	SLsmg_set_color(0);
 | |
| 	SLsmg_draw_box(y, 0, 3, SLtt_Screen_Cols);
 | |
| 	SLsmg_gotorc(y++, 1);
 | |
| 	SLsmg_write_string(title);
 | |
| 	SLsmg_fill_region(y, 1, 1, SLtt_Screen_Cols - 2, ' ');
 | |
| 	SLsmg_set_color(HE_COLORSET_SELECTED);
 | |
| 	bar = ((SLtt_Screen_Cols - 2) * p->curr) / p->total;
 | |
| 	SLsmg_fill_region(y, 1, 1, bar, ' ');
 | |
| 	SLsmg_refresh();
 | |
| 	mutex_unlock(&ui__lock);
 | |
| }
 | |
| 
 | |
| static void tui_progress__finish(void)
 | |
| {
 | |
| 	int y;
 | |
| 
 | |
| 	if (use_browser <= 0)
 | |
| 		return;
 | |
| 
 | |
| 	ui__refresh_dimensions(false);
 | |
| 	mutex_lock(&ui__lock);
 | |
| 	y = SLtt_Screen_Rows / 2 - 2;
 | |
| 	SLsmg_set_color(0);
 | |
| 	SLsmg_fill_region(y, 0, 3, SLtt_Screen_Cols, ' ');
 | |
| 	SLsmg_refresh();
 | |
| 	mutex_unlock(&ui__lock);
 | |
| }
 | |
| 
 | |
| static struct ui_progress_ops tui_progress__ops = {
 | |
| 	.init   = __tui_progress__init,
 | |
| 	.update = tui_progress__update,
 | |
| 	.finish = tui_progress__finish,
 | |
| };
 | |
| 
 | |
| void tui_progress__init(void)
 | |
| {
 | |
| 	ui_progress__ops = &tui_progress__ops;
 | |
| }
 |