On Tue, Aug 08, 2023 at 11:33:59AM +0800, Kefeng Wang wrote: > It is better to not expose too many internal variables of memtest, > add a helper memtest_report_meminfo() to show memtest results. > > Signed-off-by: Kefeng Wang <wangkefeng.wang@xxxxxxxxxx> Acked-by: Mike Rapoport (IBM) <rppt@xxxxxxxxxx> > --- > v2: add CONFIG_PROC_FS check, per Matthew > > fs/proc/meminfo.c | 12 +----------- > include/linux/memblock.h | 10 ++++------ > mm/memtest.c | 22 ++++++++++++++++++++-- > 3 files changed, 25 insertions(+), 19 deletions(-) > > diff --git a/fs/proc/meminfo.c b/fs/proc/meminfo.c > index 74e3c3815696..45af9a989d40 100644 > --- a/fs/proc/meminfo.c > +++ b/fs/proc/meminfo.c > @@ -133,17 +133,7 @@ static int meminfo_proc_show(struct seq_file *m, void *v) > show_val_kb(m, "VmallocChunk: ", 0ul); > show_val_kb(m, "Percpu: ", pcpu_nr_pages()); > > -#ifdef CONFIG_MEMTEST > - if (early_memtest_done) { > - unsigned long early_memtest_bad_size_kb; > - > - early_memtest_bad_size_kb = early_memtest_bad_size>>10; > - if (early_memtest_bad_size && !early_memtest_bad_size_kb) > - early_memtest_bad_size_kb = 1; > - /* When 0 is reported, it means there actually was a successful test */ > - seq_printf(m, "EarlyMemtestBad: %5lu kB\n", early_memtest_bad_size_kb); > - } > -#endif > + memtest_report_meminfo(m); > > #ifdef CONFIG_MEMORY_FAILURE > seq_printf(m, "HardwareCorrupted: %5lu kB\n", > diff --git a/include/linux/memblock.h b/include/linux/memblock.h > index 0d031fbfea25..1c1072e3ca06 100644 > --- a/include/linux/memblock.h > +++ b/include/linux/memblock.h > @@ -594,13 +594,11 @@ extern int hashdist; /* Distribute hashes across NUMA nodes? */ > #endif > > #ifdef CONFIG_MEMTEST > -extern phys_addr_t early_memtest_bad_size; /* Size of faulty ram found by memtest */ > -extern bool early_memtest_done; /* Was early memtest done? */ > -extern void early_memtest(phys_addr_t start, phys_addr_t end); > +void early_memtest(phys_addr_t start, phys_addr_t end); > +void memtest_report_meminfo(struct seq_file *m); > #else > -static inline void early_memtest(phys_addr_t start, phys_addr_t end) > -{ > -} > +static inline void early_memtest(phys_addr_t start, phys_addr_t end) { } > +static inline void memtest_report_meminfo(struct seq_file *m) { } > #endif > > > diff --git a/mm/memtest.c b/mm/memtest.c > index 57149dfee438..32f3e9dda837 100644 > --- a/mm/memtest.c > +++ b/mm/memtest.c > @@ -3,9 +3,10 @@ > #include <linux/types.h> > #include <linux/init.h> > #include <linux/memblock.h> > +#include <linux/seq_file.h> > > -bool early_memtest_done; > -phys_addr_t early_memtest_bad_size; > +static bool early_memtest_done; > +static phys_addr_t early_memtest_bad_size; > > static u64 patterns[] __initdata = { > /* The first entry has to be 0 to leave memtest with zeroed memory */ > @@ -117,3 +118,20 @@ void __init early_memtest(phys_addr_t start, phys_addr_t end) > do_one_pass(patterns[idx], start, end); > } > } > + > +void memtest_report_meminfo(struct seq_file *m) > +{ > + unsigned long early_memtest_bad_size_kb; > + > + if (!IS_ENABLED(CONFIG_PROC_FS)) > + return; > + > + if (!early_memtest_done) > + return; > + > + early_memtest_bad_size_kb = early_memtest_bad_size >> 10; > + if (early_memtest_bad_size && !early_memtest_bad_size_kb) > + early_memtest_bad_size_kb = 1; > + /* When 0 is reported, it means there actually was a successful test */ > + seq_printf(m, "EarlyMemtestBad: %5lu kB\n", early_memtest_bad_size_kb); > +} > -- > 2.41.0 > -- Sincerely yours, Mike.