* [PATCH] x86, mtrr: mark range_new in mtrr_calc_range_state() as __initdata @ 2015-11-13 9:47 Rasmus Villemoes 2015-11-27 9:31 ` Ingo Molnar 0 siblings, 1 reply; 6+ messages in thread From: Rasmus Villemoes @ 2015-11-13 9:47 UTC (permalink / raw) To: Thomas Gleixner, Ingo Molnar, H. Peter Anvin, x86 Cc: Rasmus Villemoes, linux-kernel range_new doesn't seem to be used after init. It is only passed to memset, sum_ranges, memcmp and x86_get_mtrr_mem_range, the latter of which also only passes it on to various *range* library functions. So mark it __initdata to free up an extra page after init. nr_range_new is unconditionally assigned to before it is read, so there's no point in having it static. Signed-off-by: Rasmus Villemoes <linux@rasmusvillemoes.dk> --- arch/x86/kernel/cpu/mtrr/cleanup.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/arch/x86/kernel/cpu/mtrr/cleanup.c b/arch/x86/kernel/cpu/mtrr/cleanup.c index 70d7c93f4550..b1a9ad366f67 100644 --- a/arch/x86/kernel/cpu/mtrr/cleanup.c +++ b/arch/x86/kernel/cpu/mtrr/cleanup.c @@ -593,9 +593,9 @@ mtrr_calc_range_state(u64 chunk_size, u64 gran_size, unsigned long x_remove_base, unsigned long x_remove_size, int i) { - static struct range range_new[RANGE_NUM]; + static struct range range_new[RANGE_NUM] __initdata; unsigned long range_sums_new; - static int nr_range_new; + int nr_range_new; int num_reg; /* Convert ranges to var ranges state: */ -- 2.6.1 ^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH] x86, mtrr: mark range_new in mtrr_calc_range_state() as __initdata 2015-11-13 9:47 [PATCH] x86, mtrr: mark range_new in mtrr_calc_range_state() as __initdata Rasmus Villemoes @ 2015-11-27 9:31 ` Ingo Molnar 2015-12-01 11:58 ` Rasmus Villemoes 0 siblings, 1 reply; 6+ messages in thread From: Ingo Molnar @ 2015-11-27 9:31 UTC (permalink / raw) To: Rasmus Villemoes Cc: Thomas Gleixner, Ingo Molnar, H. Peter Anvin, x86, linux-kernel, Borislav Petkov, Toshi Kani * Rasmus Villemoes <linux@rasmusvillemoes.dk> wrote: > range_new doesn't seem to be used after init. It is only passed to > memset, sum_ranges, memcmp and x86_get_mtrr_mem_range, the latter of > which also only passes it on to various *range* library functions. So > mark it __initdata to free up an extra page after init. > > nr_range_new is unconditionally assigned to before it is read, so > there's no point in having it static. > > Signed-off-by: Rasmus Villemoes <linux@rasmusvillemoes.dk> > --- > arch/x86/kernel/cpu/mtrr/cleanup.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/arch/x86/kernel/cpu/mtrr/cleanup.c b/arch/x86/kernel/cpu/mtrr/cleanup.c > index 70d7c93f4550..b1a9ad366f67 100644 > --- a/arch/x86/kernel/cpu/mtrr/cleanup.c > +++ b/arch/x86/kernel/cpu/mtrr/cleanup.c > @@ -593,9 +593,9 @@ mtrr_calc_range_state(u64 chunk_size, u64 gran_size, > unsigned long x_remove_base, > unsigned long x_remove_size, int i) > { > - static struct range range_new[RANGE_NUM]; > + static struct range range_new[RANGE_NUM] __initdata; > unsigned long range_sums_new; > - static int nr_range_new; > + int nr_range_new; > int num_reg; > > /* Convert ranges to var ranges state: */ So this static variable actually surprised me - I never realized it was there - and it's not some simple 'once' flag, but something that is essential semantics. So marking it __initdata is correct, but please also move it out of function local variables scope, into file scope - and name it properly as well, like mtrr_new_range[] or so? Thanks, Ingo ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] x86, mtrr: mark range_new in mtrr_calc_range_state() as __initdata 2015-11-27 9:31 ` Ingo Molnar @ 2015-12-01 11:58 ` Rasmus Villemoes 2015-12-01 16:14 ` Ingo Molnar 0 siblings, 1 reply; 6+ messages in thread From: Rasmus Villemoes @ 2015-12-01 11:58 UTC (permalink / raw) To: Ingo Molnar Cc: Thomas Gleixner, Ingo Molnar, H. Peter Anvin, x86, linux-kernel, Borislav Petkov, Toshi Kani On Fri, Nov 27 2015, Ingo Molnar <mingo@kernel.org> wrote: > * Rasmus Villemoes <linux@rasmusvillemoes.dk> wrote: > >> range_new doesn't seem to be used after init. It is only passed to >> memset, sum_ranges, memcmp and x86_get_mtrr_mem_range, the latter of >> which also only passes it on to various *range* library functions. So >> mark it __initdata to free up an extra page after init. >> >> nr_range_new is unconditionally assigned to before it is read, so >> there's no point in having it static. >> >> Signed-off-by: Rasmus Villemoes <linux@rasmusvillemoes.dk> >> --- >> arch/x86/kernel/cpu/mtrr/cleanup.c | 4 ++-- >> 1 file changed, 2 insertions(+), 2 deletions(-) >> >> diff --git a/arch/x86/kernel/cpu/mtrr/cleanup.c b/arch/x86/kernel/cpu/mtrr/cleanup.c >> index 70d7c93f4550..b1a9ad366f67 100644 >> --- a/arch/x86/kernel/cpu/mtrr/cleanup.c >> +++ b/arch/x86/kernel/cpu/mtrr/cleanup.c >> @@ -593,9 +593,9 @@ mtrr_calc_range_state(u64 chunk_size, u64 gran_size, >> unsigned long x_remove_base, >> unsigned long x_remove_size, int i) >> { >> - static struct range range_new[RANGE_NUM]; >> + static struct range range_new[RANGE_NUM] __initdata; >> unsigned long range_sums_new; >> - static int nr_range_new; >> + int nr_range_new; >> int num_reg; >> >> /* Convert ranges to var ranges state: */ > > So this static variable actually surprised me - I never realized it was there - > and it's not some simple 'once' flag, but something that is essential semantics. > > So marking it __initdata is correct, but please also move it out of function local > variables scope, into file scope - and name it properly as well, like > mtrr_new_range[] or so? I can certainly do that, but isn't the usual preference to keep the scope as small as possible? IOW, why do you want to make this a file-scoped variable? Also, I don't really see how the 'static' has 'essential semantics'. AFAICT, the contents are wiped on every invocation of mtrr_calc_range_state, so the only reason it's static is to avoid blowing the stack. Rasmus ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] x86, mtrr: mark range_new in mtrr_calc_range_state() as __initdata 2015-12-01 11:58 ` Rasmus Villemoes @ 2015-12-01 16:14 ` Ingo Molnar 2015-12-01 20:44 ` [PATCH v2] " Rasmus Villemoes 0 siblings, 1 reply; 6+ messages in thread From: Ingo Molnar @ 2015-12-01 16:14 UTC (permalink / raw) To: Rasmus Villemoes Cc: Thomas Gleixner, Ingo Molnar, H. Peter Anvin, x86, linux-kernel, Borislav Petkov, Toshi Kani * Rasmus Villemoes <linux@rasmusvillemoes.dk> wrote: > On Fri, Nov 27 2015, Ingo Molnar <mingo@kernel.org> wrote: > > > * Rasmus Villemoes <linux@rasmusvillemoes.dk> wrote: > > > >> range_new doesn't seem to be used after init. It is only passed to > >> memset, sum_ranges, memcmp and x86_get_mtrr_mem_range, the latter of > >> which also only passes it on to various *range* library functions. So > >> mark it __initdata to free up an extra page after init. > >> > >> nr_range_new is unconditionally assigned to before it is read, so > >> there's no point in having it static. > >> > >> Signed-off-by: Rasmus Villemoes <linux@rasmusvillemoes.dk> > >> --- > >> arch/x86/kernel/cpu/mtrr/cleanup.c | 4 ++-- > >> 1 file changed, 2 insertions(+), 2 deletions(-) > >> > >> diff --git a/arch/x86/kernel/cpu/mtrr/cleanup.c b/arch/x86/kernel/cpu/mtrr/cleanup.c > >> index 70d7c93f4550..b1a9ad366f67 100644 > >> --- a/arch/x86/kernel/cpu/mtrr/cleanup.c > >> +++ b/arch/x86/kernel/cpu/mtrr/cleanup.c > >> @@ -593,9 +593,9 @@ mtrr_calc_range_state(u64 chunk_size, u64 gran_size, > >> unsigned long x_remove_base, > >> unsigned long x_remove_size, int i) > >> { > >> - static struct range range_new[RANGE_NUM]; > >> + static struct range range_new[RANGE_NUM] __initdata; > >> unsigned long range_sums_new; > >> - static int nr_range_new; > >> + int nr_range_new; > >> int num_reg; > >> > >> /* Convert ranges to var ranges state: */ > > > > So this static variable actually surprised me - I never realized it was there - > > and it's not some simple 'once' flag, but something that is essential semantics. > > > > So marking it __initdata is correct, but please also move it out of function local > > variables scope, into file scope - and name it properly as well, like > > mtrr_new_range[] or so? > > I can certainly do that, but isn't the usual preference to keep the scope as > small as possible? IOW, why do you want to make this a file-scoped variable? The preference is to keep code readable and obvious, and this one wasn't: relevant state/data was hidden via a non-commented local static variable. > Also, I don't really see how the 'static' has 'essential semantics'. AFAICT, the > contents are wiped on every invocation of mtrr_calc_range_state, so the only > reason it's static is to avoid blowing the stack. So this was another property that wasn't obvious from the limited context I saw in the patch, i.e. the variable definition. Another solution would be to add a comment explaining that this is a local variable to keep kernel stack size down, and explain why it's safe to do that. Thanks, Ingo ^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v2] x86, mtrr: mark range_new in mtrr_calc_range_state() as __initdata 2015-12-01 16:14 ` Ingo Molnar @ 2015-12-01 20:44 ` Rasmus Villemoes 2015-12-04 11:49 ` [tip:x86/mm] x86/mm/mtrr: Mark the 'range_new' static variable " tip-bot for Rasmus Villemoes 0 siblings, 1 reply; 6+ messages in thread From: Rasmus Villemoes @ 2015-12-01 20:44 UTC (permalink / raw) To: Thomas Gleixner, Ingo Molnar, H. Peter Anvin, x86 Cc: Toshi Kani, Borislav Petkov, Rasmus Villemoes, linux-kernel range_new doesn't seem to be used after init. It is only passed to memset, sum_ranges, memcmp and x86_get_mtrr_mem_range, the latter of which also only passes it on to various *range* library functions. So mark it __initdata to free up an extra page after init. Its contents are wiped at every call to mtrr_calc_range_state(), so it being static is not about preserving state between calls, but simply to avoid a 4k+ stack frame. While there, add a comment explaining this and why it's safe. We could also mark nr_range_new as __initdata, but since it's just a single int and also doesn't carry state between calls (it is unconditionally assigned to before it is read), we might as well make it an ordinary automatic variable. Signed-off-by: Rasmus Villemoes <linux@rasmusvillemoes.dk> --- Something like this, perhaps? v2: Add comment on range_new, per Ingo. arch/x86/kernel/cpu/mtrr/cleanup.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/arch/x86/kernel/cpu/mtrr/cleanup.c b/arch/x86/kernel/cpu/mtrr/cleanup.c index 70d7c93f4550..0d98503c2245 100644 --- a/arch/x86/kernel/cpu/mtrr/cleanup.c +++ b/arch/x86/kernel/cpu/mtrr/cleanup.c @@ -593,9 +593,16 @@ mtrr_calc_range_state(u64 chunk_size, u64 gran_size, unsigned long x_remove_base, unsigned long x_remove_size, int i) { - static struct range range_new[RANGE_NUM]; + /* + * range_new should really be an automatic variable, but + * putting 4096 bytes on the stack is frowned upon, to put it + * mildly. It is safe to make it a static __initdata variable, + * since mtrr_calc_range_state is only called during init and + * there's no way it will call itself recursively. + */ + static struct range range_new[RANGE_NUM] __initdata; unsigned long range_sums_new; - static int nr_range_new; + int nr_range_new; int num_reg; /* Convert ranges to var ranges state: */ -- 2.6.1 ^ permalink raw reply related [flat|nested] 6+ messages in thread
* [tip:x86/mm] x86/mm/mtrr: Mark the 'range_new' static variable in mtrr_calc_range_state() as __initdata 2015-12-01 20:44 ` [PATCH v2] " Rasmus Villemoes @ 2015-12-04 11:49 ` tip-bot for Rasmus Villemoes 0 siblings, 0 replies; 6+ messages in thread From: tip-bot for Rasmus Villemoes @ 2015-12-04 11:49 UTC (permalink / raw) To: linux-tip-commits Cc: hpa, toshi.kani, linux, linux-kernel, torvalds, peterz, tglx, mingo Commit-ID: c332813b51cbe807d539bb059b81235abf1e3fdd Gitweb: http://git.kernel.org/tip/c332813b51cbe807d539bb059b81235abf1e3fdd Author: Rasmus Villemoes <linux@rasmusvillemoes.dk> AuthorDate: Tue, 1 Dec 2015 21:44:50 +0100 Committer: Ingo Molnar <mingo@kernel.org> CommitDate: Fri, 4 Dec 2015 09:11:28 +0100 x86/mm/mtrr: Mark the 'range_new' static variable in mtrr_calc_range_state() as __initdata 'range_new' doesn't seem to be used after init. It is only passed to memset(), sum_ranges(), memcmp() and x86_get_mtrr_mem_range(), the latter of which also only passes it on to various *range* library functions. So mark it __initdata to free up an extra page after init. Its contents are wiped at every call to mtrr_calc_range_state(), so it being static is not about preserving state between calls, but simply to avoid a 4k+ stack frame. While there, add a comment explaining this and why it's safe. We could also mark nr_range_new as __initdata, but since it's just a single int and also doesn't carry state between calls (it is unconditionally assigned to before it is read), we might as well make it an ordinary automatic variable. Signed-off-by: Rasmus Villemoes <linux@rasmusvillemoes.dk> Cc: H. Peter Anvin <hpa@zytor.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Toshi Kani <toshi.kani@hp.com> Link: http://lkml.kernel.org/r/1449002691-20783-1-git-send-email-linux@rasmusvillemoes.dk Signed-off-by: Ingo Molnar <mingo@kernel.org> --- arch/x86/kernel/cpu/mtrr/cleanup.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/arch/x86/kernel/cpu/mtrr/cleanup.c b/arch/x86/kernel/cpu/mtrr/cleanup.c index 70d7c93..0d98503 100644 --- a/arch/x86/kernel/cpu/mtrr/cleanup.c +++ b/arch/x86/kernel/cpu/mtrr/cleanup.c @@ -593,9 +593,16 @@ mtrr_calc_range_state(u64 chunk_size, u64 gran_size, unsigned long x_remove_base, unsigned long x_remove_size, int i) { - static struct range range_new[RANGE_NUM]; + /* + * range_new should really be an automatic variable, but + * putting 4096 bytes on the stack is frowned upon, to put it + * mildly. It is safe to make it a static __initdata variable, + * since mtrr_calc_range_state is only called during init and + * there's no way it will call itself recursively. + */ + static struct range range_new[RANGE_NUM] __initdata; unsigned long range_sums_new; - static int nr_range_new; + int nr_range_new; int num_reg; /* Convert ranges to var ranges state: */ ^ permalink raw reply related [flat|nested] 6+ messages in thread
end of thread, other threads:[~2015-12-04 11:50 UTC | newest] Thread overview: 6+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2015-11-13 9:47 [PATCH] x86, mtrr: mark range_new in mtrr_calc_range_state() as __initdata Rasmus Villemoes 2015-11-27 9:31 ` Ingo Molnar 2015-12-01 11:58 ` Rasmus Villemoes 2015-12-01 16:14 ` Ingo Molnar 2015-12-01 20:44 ` [PATCH v2] " Rasmus Villemoes 2015-12-04 11:49 ` [tip:x86/mm] x86/mm/mtrr: Mark the 'range_new' static variable " tip-bot for Rasmus Villemoes
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox