[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20090227001757.GE27240@localdomain>
Date: Thu, 26 Feb 2009 16:17:57 -0800
From: Ravikiran G Thirumalai <kiran@...lex86.org>
To: Ingo Molnar <mingo@...e.hu>
Cc: Yinghai Lu <yinghai@...nel.org>,
Thomas Gleixner <tglx@...utronix.de>,
"H. Peter Anvin" <hpa@...or.com>,
Andrew Morton <akpm@...ux-foundation.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
shai@...lex86.org
Subject: Re: [PATCH] x86: don't compile vsmp_64 for 32bit
On Thu, Feb 26, 2009 at 12:44:57PM +0100, Ingo Molnar wrote:
>
>* Ravikiran G Thirumalai <kiran@...lex86.org> wrote:
>
>> On Wed, Feb 25, 2009 at 09:20:50PM -0800, Yinghai Lu wrote:
>> >
>> >Impact: cleanup
>> >
>> >that is only needed when CONFIG_X86_VSMP is defined with 64bit
>> >also remove dead code about PCI, because CONFIG_X86_VSMP depends on PCI
>> >
>> >Signed-off-by: Yinghai Lu <yinghai@...nel.org>
>> >
>>
>> NAK!
>> vsmp64.c is compiled unconditionally for a reason. There are ifdefs in the
>> file to avoid code compilation based on config options. is_vsmp_box() is
>> needed even when CONFIG_X86_VSMP is not enabled, since distro kernels don't ship
>> with CONFIG_X86_VSMP, and since is_vsmp_box() is used to determine whether
>> tsc's can be considered synced or not, this is needed.
>
>is_vsmp_box() is always available:
Yes. But it does not really detect if the machine is vsmp. It is just a
'return 0'.
>
>> >+#ifdef CONFIG_X86_VSMP
>> > extern int is_vsmp_box(void);
>> >+#else
>> >+static inline int is_vsmp_box(void)
>> >+{
>> >+ return 0;
>> >+}
>> >+#endif
>
>What this patch does is it reduces the kernel's size when
>CONFIG_X86_VSMP is turned off and also makes the code arguably
>cleaner.
True, but by how much? 212 bytes, out of 7285943 bytes which is very
very small percentage wise.
-bash-3.1$ size results/2.6.29-rc6-defconfig/vmlinux
text data bss dec hex filename
7285943 1482684 812968 9581595 92341b results/2.6.29-rc6-defconfig/vmlinux
-bash-3.1$ size results/2.6.29-rc6-defconfig+patch/vmlinux
text data bss dec hex filename
7285731 1482684 812968 9581383 923347 results/2.6.29-rc6-defconfig+patch/vmlinux
Note that most of the code within vsmp64.c is dependent on PARAVIRT and
won't get compiled if PARAVIRT is not enabled.
We made this code dependent on PARAVIRT rather than CONFIG_X86_VSMP because,
vsmp support has two aspects to it. One is a minimal paravirtualization part
and the other is internode cacheline support. While CONFIG_X86_VSMP enables
both, all that is needed for the paravirtualization part is PARAVIRT. And
it is not heavy or penalizing like the internode cacheline setting. This will
mean installation of distros with the distro provided installer kernels can be done
relatively easily if paravirt is enabled. That's all!
>
>> In the future, I would appreciate if you copy me on
>> cleanups/changes involving vsmp64.c
>
>That is what i did when i queued up the change. That is how you
>became aware of this commit.
>
Thanks for that. But I started replying to the message before
the patch was queued/received your email. But the patch was
queued by the time i finished replying.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists