mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-16 19:04:41 +08:00
fa0d98462f
Remove the last unneeded use of cache.h in a header, we can check where it is really needed, i.e. we can remove it and be sure that it isn't being obtained indirectly. This is an old file, used by now incorrectly in many places, so it was providing includes needed indirectly, fixup this fallout. Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Link: https://lkml.kernel.org/n/tip-3x3l8gihoaeh7714os861ia7@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
48 lines
920 B
C
48 lines
920 B
C
// SPDX-License-Identifier: GPL-2.0
|
|
#include <linux/kernel.h>
|
|
#include "progress.h"
|
|
|
|
static void null_progress__update(struct ui_progress *p __maybe_unused)
|
|
{
|
|
}
|
|
|
|
static struct ui_progress_ops null_progress__ops =
|
|
{
|
|
.update = null_progress__update,
|
|
};
|
|
|
|
struct ui_progress_ops *ui_progress__ops = &null_progress__ops;
|
|
|
|
void ui_progress__update(struct ui_progress *p, u64 adv)
|
|
{
|
|
u64 last = p->curr;
|
|
|
|
p->curr += adv;
|
|
|
|
if (p->curr >= p->next) {
|
|
u64 nr = DIV_ROUND_UP(p->curr - last, p->step);
|
|
|
|
p->next += nr * p->step;
|
|
ui_progress__ops->update(p);
|
|
}
|
|
}
|
|
|
|
void __ui_progress__init(struct ui_progress *p, u64 total,
|
|
const char *title, bool size)
|
|
{
|
|
p->curr = 0;
|
|
p->next = p->step = total / 16 ?: 1;
|
|
p->total = total;
|
|
p->title = title;
|
|
p->size = size;
|
|
|
|
if (ui_progress__ops->init)
|
|
ui_progress__ops->init(p);
|
|
}
|
|
|
|
void ui_progress__finish(void)
|
|
{
|
|
if (ui_progress__ops->finish)
|
|
ui_progress__ops->finish();
|
|
}
|