linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
       [not found] ` <20160513015725.30223ee16a2a3860b4392b90@gmail.com>
@ 2016-05-18  8:51   ` Andrew Donnellan
  2016-05-18 10:33     ` Emese Revfy
  0 siblings, 1 reply; 8+ messages in thread
From: Andrew Donnellan @ 2016-05-18  8:51 UTC (permalink / raw)
  To: kernel-hardening, linux-kbuild
  Cc: pageexec, spender, mmarek, keescook, linux, fengguang.wu, dvyukov,
	linux-kernel, david.brown, yamada.masahiro, linuxppc-dev,
	Michael Ellerman, Daniel Axtens

On 13/05/16 09:57, Emese Revfy wrote:
> This patch allows to build the whole kernel with GCC plugins. It was ported from
> grsecurity/PaX. The infrastructure supports building out-of-tree modules and
> building in a separate directory. Cross-compilation is supported too.
> Currently the x86, arm, arm64 and uml architectures enable plugins.
>
> The directory of the gcc plugins is scripts/gcc-plugins. You can use a file or a directory
> there. The plugins compile with these options:
>   * -fno-rtti: gcc is compiled with this option so the plugins must use it too
>   * -fno-exceptions: this is inherited from gcc too
>   * -fasynchronous-unwind-tables: this is inherited from gcc too
>   * -ggdb: it is useful for debugging a plugin (better backtrace on internal
>      errors)
>   * -Wno-narrowing: to suppress warnings from gcc headers (ipa-utils.h)
>   * -Wno-unused-variable: to suppress warnings from gcc headers (gcc_version
>      variable, plugin-version.h)
>
> The infrastructure introduces a new Makefile target called gcc-plugins. It
> supports all gcc versions from 4.5 to 6.0. The scripts/gcc-plugin.sh script
> chooses the proper host compiler (gcc-4.7 can be built by either gcc or g++).
> This script also checks the availability of the included headers in
> scripts/gcc-plugins/gcc-common.h.
>
> The gcc-common.h header contains frequently included headers for GCC plugins
> and it has a compatibility layer for the supported gcc versions.
>
> The gcc-generate-*-pass.h headers automatically generate the registration
> structures for GIMPLE, SIMPLE_IPA, IPA and RTL passes.
>
> Note that 'make clean' keeps the *.so files (only the distclean or mrproper
> targets clean all) because they are needed for out-of-tree modules.
>
> The arm and arm64 architectures were tested by David Brown <david.brown@linaro.org>.
>
> Signed-off-by: Emese Revfy <re.emese@gmail.com>

I've done some basic sanity testing on powerpc with the cyclomatic 
complexity plugin (with LE native + cross-compilers) and it seems to 
work with the patch below.

Signed-off-by: Andrew Donnellan <andrew.donnellan@au1.ibm.com>

diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig
index a18a0dc..0cfed5b 100644
--- a/arch/powerpc/Kconfig
+++ b/arch/powerpc/Kconfig
@@ -97,6 +97,7 @@ config PPC
         select HAVE_DYNAMIC_FTRACE_WITH_REGS if MPROFILE_KERNEL
         select HAVE_FUNCTION_TRACER
         select HAVE_FUNCTION_GRAPH_TRACER
+       select HAVE_GCC_PLUGINS
         select SYSCTL_EXCEPTION_TRACE
         select ARCH_WANT_OPTIONAL_GPIOLIB
         select VIRT_TO_BUS if !PPC64

-- 
Andrew Donnellan              OzLabs, ADL Canberra
andrew.donnellan@au1.ibm.com  IBM Australia Limited

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
  2016-05-18  8:51   ` [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure Andrew Donnellan
@ 2016-05-18 10:33     ` Emese Revfy
  2016-05-18 21:14       ` Andrew Donnellan
  2016-05-19  6:22       ` Michael Ellerman
  0 siblings, 2 replies; 8+ messages in thread
From: Emese Revfy @ 2016-05-18 10:33 UTC (permalink / raw)
  To: kernel-hardening
  Cc: Andrew Donnellan, linux-kbuild, pageexec, spender, mmarek,
	keescook, linux, fengguang.wu, dvyukov, linux-kernel, david.brown,
	yamada.masahiro, linuxppc-dev, Michael Ellerman, Daniel Axtens

> I've done some basic sanity testing on powerpc with the cyclomatic 
> complexity plugin (with LE native + cross-compilers) and it seems to 
> work with the patch below.
> 
> Signed-off-by: Andrew Donnellan <andrew.donnellan@au1.ibm.com>
> 
> diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig
> index a18a0dc..0cfed5b 100644
> --- a/arch/powerpc/Kconfig
> +++ b/arch/powerpc/Kconfig
> @@ -97,6 +97,7 @@ config PPC
>          select HAVE_DYNAMIC_FTRACE_WITH_REGS if MPROFILE_KERNEL
>          select HAVE_FUNCTION_TRACER
>          select HAVE_FUNCTION_GRAPH_TRACER
> +       select HAVE_GCC_PLUGINS
>          select SYSCTL_EXCEPTION_TRACE
>          select ARCH_WANT_OPTIONAL_GPIOLIB
>          select VIRT_TO_BUS if !PPC64

Hi,

Did you test the plugins with all gcc versions (4.5-6)?

-- 
Emese

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
  2016-05-18 10:33     ` Emese Revfy
@ 2016-05-18 21:14       ` Andrew Donnellan
  2016-05-19  6:22       ` Michael Ellerman
  1 sibling, 0 replies; 8+ messages in thread
From: Andrew Donnellan @ 2016-05-18 21:14 UTC (permalink / raw)
  To: Emese Revfy, kernel-hardening
  Cc: linux-kbuild, pageexec, spender, mmarek, keescook, linux,
	fengguang.wu, dvyukov, linux-kernel, david.brown, yamada.masahiro,
	linuxppc-dev, Michael Ellerman, Daniel Axtens

On 18/05/16 20:33, Emese Revfy wrote:
> Did you test the plugins with all gcc versions (4.5-6)?

No, I tested with 4.8 and 5.2 as those are the toolchains I have on hand 
- I'll try to test with the rest of 4.5 - 6.1.

-- 
Andrew Donnellan              OzLabs, ADL Canberra
andrew.donnellan@au1.ibm.com  IBM Australia Limited

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
  2016-05-18 10:33     ` Emese Revfy
  2016-05-18 21:14       ` Andrew Donnellan
@ 2016-05-19  6:22       ` Michael Ellerman
  2016-05-19  6:30         ` Andrew Donnellan
  2016-05-19  8:24         ` PaX Team
  1 sibling, 2 replies; 8+ messages in thread
From: Michael Ellerman @ 2016-05-19  6:22 UTC (permalink / raw)
  To: Emese Revfy, kernel-hardening
  Cc: Andrew Donnellan, linux-kbuild, pageexec, spender, mmarek,
	keescook, linux, fengguang.wu, dvyukov, linux-kernel, david.brown,
	yamada.masahiro, linuxppc-dev, Daniel Axtens

On Wed, 2016-05-18 at 12:33 +0200, Emese Revfy wrote:

> > I've done some basic sanity testing on powerpc with the cyclomatic 
> > complexity plugin (with LE native + cross-compilers) and it seems to 
> > work with the patch below.
> > 
> > Signed-off-by: Andrew Donnellan <andrew.donnellan@au1.ibm.com>
> > 
> > diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig
> > index a18a0dc..0cfed5b 100644
> > --- a/arch/powerpc/Kconfig
> > +++ b/arch/powerpc/Kconfig
> > @@ -97,6 +97,7 @@ config PPC
> >          select HAVE_DYNAMIC_FTRACE_WITH_REGS if MPROFILE_KERNEL
> >          select HAVE_FUNCTION_TRACER
> >          select HAVE_FUNCTION_GRAPH_TRACER
> > +       select HAVE_GCC_PLUGINS
> >          select SYSCTL_EXCEPTION_TRACE
> >          select ARCH_WANT_OPTIONAL_GPIOLIB
> >          select VIRT_TO_BUS if !PPC64
> 
> Hi,
> 
> Did you test the plugins with all gcc versions (4.5-6)?

What's the concern about gcc versions? Just not breaking the build on old
compilers?

I'm pretty sure powerpc big endian still builds with gcc 4.4.

However if Andrew's only tested on little endian, then that select should be
guarded with an "if CPU_LITTLE_ENDIAN". And to build LE you need gcc >= 4.9.

cheers

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
  2016-05-19  6:22       ` Michael Ellerman
@ 2016-05-19  6:30         ` Andrew Donnellan
  2016-05-19  8:24         ` PaX Team
  1 sibling, 0 replies; 8+ messages in thread
From: Andrew Donnellan @ 2016-05-19  6:30 UTC (permalink / raw)
  To: Michael Ellerman, Emese Revfy, kernel-hardening
  Cc: linux-kbuild, pageexec, spender, mmarek, keescook, linux,
	fengguang.wu, dvyukov, linux-kernel, david.brown, yamada.masahiro,
	linuxppc-dev, Daniel Axtens

On 19/05/16 16:22, Michael Ellerman wrote:
>> Did you test the plugins with all gcc versions (4.5-6)?
>
> What's the concern about gcc versions? Just not breaking the build on old
> compilers?
> I'm pretty sure powerpc big endian still builds with gcc 4.4.

gcc's plugin support only landed in 4.5, so we don't care about <=4.4.

> However if Andrew's only tested on little endian, then that select should be
> guarded with an "if CPU_LITTLE_ENDIAN". And to build LE you need gcc >= 4.9.

I'm going to give BE a test too just to be sure.

-- 
Andrew Donnellan              OzLabs, ADL Canberra
andrew.donnellan@au1.ibm.com  IBM Australia Limited

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
  2016-05-19  6:22       ` Michael Ellerman
  2016-05-19  6:30         ` Andrew Donnellan
@ 2016-05-19  8:24         ` PaX Team
  2016-05-20  6:22           ` Andrew Donnellan
  2016-05-20 10:10           ` Michael Ellerman
  1 sibling, 2 replies; 8+ messages in thread
From: PaX Team @ 2016-05-19  8:24 UTC (permalink / raw)
  To: Emese Revfy, kernel-hardening, Michael Ellerman
  Cc: Andrew Donnellan, linux-kbuild, spender, mmarek, keescook, linux,
	fengguang.wu, dvyukov, linux-kernel, david.brown, yamada.masahiro,
	linuxppc-dev, Daniel Axtens

On 19 May 2016 at 16:22, Michael Ellerman wrote:

> On Wed, 2016-05-18 at 12:33 +0200, Emese Revfy wrote:
> > Did you test the plugins with all gcc versions (4.5-6)?
> 
> What's the concern about gcc versions? Just not breaking the build on old
> compilers?

the earlier plugin capable gcc versions used to install gcc headers in a somewhat
ad-hoc manner resulting in compile time breakage for plugins and since some of
those potentially missing headers are target specific, each target arch should
be verified before enabling plugin support on them. things have much improved with
gcc 5 (see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61176) though there's still
an occasional missing header but with wider use of plugins they will hopefully be
discovered earlier now. perhaps linux-arch should be cc'ed on the plugin infrastructure
so that arch maintainers are aware of this?

> I'm pretty sure powerpc big endian still builds with gcc 4.4.
> 
> However if Andrew's only tested on little endian, then that select should be
> guarded with an "if CPU_LITTLE_ENDIAN". And to build LE you need gcc >= 4.9.

i guess that's part of the target tuple so in general arch maintainers should test
the target tuples used on their arch with all the supported gcc versions (speaking
of CC, not HOSTCC/HOSTCXX).

cheers,
 PaX Team

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
  2016-05-19  8:24         ` PaX Team
@ 2016-05-20  6:22           ` Andrew Donnellan
  2016-05-20 10:10           ` Michael Ellerman
  1 sibling, 0 replies; 8+ messages in thread
From: Andrew Donnellan @ 2016-05-20  6:22 UTC (permalink / raw)
  To: pageexec, Emese Revfy, kernel-hardening, Michael Ellerman
  Cc: linux-kbuild, spender, mmarek, keescook, linux, fengguang.wu,
	dvyukov, linux-kernel, david.brown, yamada.masahiro, linuxppc-dev,
	Daniel Axtens

On 19/05/16 18:24, PaX Team wrote:
> the earlier plugin capable gcc versions used to install gcc headers in a somewhat
> ad-hoc manner resulting in compile time breakage for plugins and since some of
> those potentially missing headers are target specific, each target arch should
> be verified before enabling plugin support on them. things have much improved with
> gcc 5 (see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61176) though there's still
> an occasional missing header but with wider use of plugins they will hopefully be
> discovered earlier now. perhaps linux-arch should be cc'ed on the plugin infrastructure
> so that arch maintainers are aware of this?

Upon further testing it does seem we've got header issues as well as 
hitting a segfault on 4.7.0. Looking into it further...

-- 
Andrew Donnellan              OzLabs, ADL Canberra
andrew.donnellan@au1.ibm.com  IBM Australia Limited

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure
  2016-05-19  8:24         ` PaX Team
  2016-05-20  6:22           ` Andrew Donnellan
@ 2016-05-20 10:10           ` Michael Ellerman
  1 sibling, 0 replies; 8+ messages in thread
From: Michael Ellerman @ 2016-05-20 10:10 UTC (permalink / raw)
  To: pageexec, Emese Revfy, kernel-hardening
  Cc: Andrew Donnellan, linux-kbuild, spender, mmarek, keescook, linux,
	fengguang.wu, dvyukov, linux-kernel, david.brown, yamada.masahiro,
	linuxppc-dev, Daniel Axtens

On Thu, 2016-05-19 at 10:24 +0200, PaX Team wrote:
> On 19 May 2016 at 16:22, Michael Ellerman wrote:
> > On Wed, 2016-05-18 at 12:33 +0200, Emese Revfy wrote:
> > > Did you test the plugins with all gcc versions (4.5-6)?
> > 
> > What's the concern about gcc versions? Just not breaking the build on old
> > compilers?
> 
> the earlier plugin capable gcc versions used to install gcc headers in a somewhat
> ad-hoc manner resulting in compile time breakage for plugins and since some of
> those potentially missing headers are target specific, each target arch should
> be verified before enabling plugin support on them. things have much improved with
> gcc 5 (see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61176) though there's still
> an occasional missing header but with wider use of plugins they will hopefully be
> discovered earlier now. 

OK thanks.

> perhaps linux-arch should be cc'ed on the plugin infrastructure
> so that arch maintainers are aware of this?

linux-arch is still fairly high traffic, so it's no guarantee arch maintainers
will see it, but it's probably worth a try.

> > I'm pretty sure powerpc big endian still builds with gcc 4.4.
> > 
> > However if Andrew's only tested on little endian, then that select should be
> > guarded with an "if CPU_LITTLE_ENDIAN". And to build LE you need gcc >= 4.9.
> 
> i guess that's part of the target tuple so in general arch maintainers should test
> the target tuples used on their arch with all the supported gcc versions (speaking
> of CC, not HOSTCC/HOSTCXX).

Yeah. I think we'll probably enable it gradually as folks get time to test it.
ie. ppc64le first, then ppc64 (BE), and then 32-bit if someone is interested.

cheers

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2016-05-20 10:10 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <20160513015456.01415979f20a68eb7d2d9290@gmail.com>
     [not found] ` <20160513015725.30223ee16a2a3860b4392b90@gmail.com>
2016-05-18  8:51   ` [kernel-hardening] [PATCH v8 2/4] GCC plugin infrastructure Andrew Donnellan
2016-05-18 10:33     ` Emese Revfy
2016-05-18 21:14       ` Andrew Donnellan
2016-05-19  6:22       ` Michael Ellerman
2016-05-19  6:30         ` Andrew Donnellan
2016-05-19  8:24         ` PaX Team
2016-05-20  6:22           ` Andrew Donnellan
2016-05-20 10:10           ` Michael Ellerman

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).