Buildroot Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Cyril Bur <cyrilbur@gmail.com>
To: buildroot@busybox.net
Subject: [Buildroot] [PATCH] linux: Build and install kernel selftests
Date: Mon, 21 Dec 2015 16:44:01 +1100	[thread overview]
Message-ID: <20151221164401.4007ce33@camb691> (raw)
In-Reply-To: <20151217180735.GA3653@free.fr>

On Thu, 17 Dec 2015 19:07:35 +0100
"Yann E. MORIN" <yann.morin.1998@free.fr> wrote:

> Cyril, All,
> 

Hi Yann,

Totally agreed will address everything you mention. I should have mentioned a
few in more detail, my bad for not going over it in more detail before posting,
you're correct that a few things in there are actually non obvious.

Just one more thing below,

> On 2015-12-17 12:45 +1100, Cyril Bur spake thusly:
> > On Mon, 14 Dec 2015 23:18:46 +0100
> > "Yann E. MORIN" <yann.morin.1998@free.fr> wrote:  
> > > On 2015-11-25 10:53 +1100, Cyril Bur spake thusly:  
> > > > This patch simply adds the ability to compile and install the kernel
> > > > selftests into the target.
> > > > 
> > > > This is likely to be a rarely used debugging/performance feature for
> > > > development and unlikely to be used in a production configuration.
> > > > 
> > > > Signed-off-by: Cyril Bur <cyrilbur@gmail.com>
> > > > ---
> > > >  linux/Config.tools.in         | 12 ++++++++++++
> > > >  linux/linux-tool-selftests.mk | 40 ++++++++++++++++++++++++++++++++++++++++
> > > >  2 files changed, 52 insertions(+)
> > > >  create mode 100644 linux/linux-tool-selftests.mk
> > > > 
> > > > diff --git a/linux/Config.tools.in b/linux/Config.tools.in
> > > > index 24ef8cd..68655dc 100644
> > > > --- a/linux/Config.tools.in
> > > > +++ b/linux/Config.tools.in
> > > > @@ -26,4 +26,16 @@ config BR2_LINUX_KERNEL_TOOL_PERF
> > > >  
> > > >  	  https://perf.wiki.kernel.org/
> > > >  
> > > > +config BR2_LINUX_KERNEL_TOOL_SELFTESTS
> > > > +	bool "selftests"    
> > > 
> > > Since the .mk has:
> > >     SELFTESTS_DEPENDENCIES = bash
> > > 
> > > then you must either depend on bash or select it here. I think a select
> > > is better, so:
> > > 
> > >     depends on BR2_USE_MMU  # bash
> > >     select BR2_PACKAGE_BASH
> > >   
> > > > +	help
> > > > +	  Build and install (to /usr/lib/selftests) kernel selftests.    
> > > 
> > > Why do you install in there?
> > >   
> > 
> > I was really quite a bit random, don't have any preferred place myself.
> >   
> > > I'm not sure what the kernel selftests are, but two options:
> > >   - if they are executables, they should go into /usr/sbin
> > >   - if they are libraries, they should go in /usr/lib  
> > 
> > So I think I initially put them in /bin for testing but its odd because they
> > have quite a directory structure to them, so /bin/selftests/x/y/z felt odd.
> > Theres a runtests script that expects that too otherwise all the binaries
> > *could* be dumped into /usr/sbin.
> > 
> > They aren't libraries either though I agree but then its not like the
> > executables really do anything, in a way they are more like a 'library of
> > tests'
> > 
> > Happy to defer to you on that one.  
> 
> OK, your explanations is good for me. Still, the directory is not
> completely to my taste, since it does not refer to the kernel. What
> about either of:
>     /usr/lib/linux-selftests
>     /usr/lib/kselftests
> 
> My preference would be for the second, but if you have a better idea,
> feel free to improvise! ;-)
> 
> That should probably be explained in the commit log.
> 
> [--SNIP--]
> > > > +ifeq ($(KERNEL_ARCH),x86_64)
> > > > +SELFTESTS_ARCH=x86
> > > > +else
> > > > +SELFTESTS_ARCH=$(KERNEL_ARCH)
> > > > +endif    
> > > 
> > > Not related to your patch, but I wonder if we should not make that a
> > > common conditional, so that all tools do not have to repeat it.
> > > 
> > > Since there are only two such tool (with selftests) that do it, it can
> > > be put aside for now, and we can revisit it later.  
> > That does make sense, totally agreed. I'll ponder too :)  
> 
> Really, just let that as-is for now. Two packages doing exactly the same
> think is OK. We try to commonalise stuff when a lot of packages want to
> do the same thing. 2 is not "a lot". ;-)
> 
> > > > +SELFTESTS_DEPENDENCIES = bash
> > > > +
> > > > +SELFTESTS_INSTALL_STAGING = YES    
> > > 
> > > Why install it in staging?  
> > 
> > I actually hadn't initially but I did get to a point in my work where I had
> > to objdump a test binary. So, since I needed it, it stayed.  
> 
> But can't you objdump the binaries that are installed in target/ instead?
> 

I think I tried that initially but IIRC they get stripped when put into target/
which proved annoying when objdumping.

Thanks,

Cyril

> > > > +SELFTESTS_MAKE_FLAGS = \
> > > > +	$(LINUX_MAKE_FLAGS) \
> > > > +	ARCH=$(SELFTESTS_ARCH)
> > > > +
> > > > +# O must be redefined here to overwrite the one used by Buildroot for
> > > > +# out of tree build. We build the selftests in $(@D)/tools/selftests and
> > > > +# not just $(@D) so that it isn't built in the root directory of the kernel
> > > > +# sources.
> > > > +define SELFTESTS_BUILD_CMDS
> > > > +	$(TARGET_MAKE_ENV) $(MAKE1) -C $(@D) headers_install    
> [--SNIP--]
> > > Why are headers needed?  
> > 
> > Unfortunately a few of the Makefiles do:
> > CFLAGS += -I../../../../usr/include/
> > 
> > There are other ways around the problem but this was the easiest.  
> 
> OK, your solution is acceptable. But please add a comment just above,
> tha texplains why this is needed, like so;
> 
>     # Lots of selftests use hard-coded CFLAGS to find the headers
>     # like:  CFLAGS += -I../../../../usr/include/
>     # So we insall them locally *inside* the kernel source tree
>     make blabla headers_install
> 
> Basically, add a comment whenever what you do, or the reason why you do
> it, is not obvious. And it also probably warrants some explanations in
> the commit log as well.
> 
> Regards,
> Yann E. MORIN.
> 

  reply	other threads:[~2015-12-21  5:44 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-11-24 23:53 [Buildroot] [PATCH] Add Linux kernel selftests building Cyril Bur
2015-11-24 23:53 ` [Buildroot] [PATCH] linux: Build and install kernel selftests Cyril Bur
2015-12-14 22:18   ` Yann E. MORIN
2015-12-15  6:37     ` Baruch Siach
2015-12-15 17:31       ` Yann E. MORIN
2015-12-17  1:25         ` Cyril Bur
2015-12-17  1:45     ` Cyril Bur
2015-12-17 18:07       ` Yann E. MORIN
2015-12-21  5:44         ` Cyril Bur [this message]
2015-12-21  9:25           ` Yann E. MORIN
2015-12-21 22:18             ` Cyril Bur
2015-12-21 22:25               ` Yann E. MORIN

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20151221164401.4007ce33@camb691 \
    --to=cyrilbur@gmail.com \
    --cc=buildroot@busybox.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox