[Buildroot] [PATCH] Permit building grub with an external toolchain.

Lionel Landwerlin llandwerlin at gmail.com
Mon Jan 4 13:09:08 UTC 2010


Why didn't you remove :

define GRUB_CONFIGURE_CMDS
	(cd $(GRUB_SRCDIR) && rm -rf config.cache && \
	$(TARGET_CONFIGURE_OPTS) \
	$(TARGET_CONFIGURE_ARGS) \
	$(GRUB_CONF_ENV) \
	./configure \
		--target=$(GNU_TARGET_NAME) \
		--host=$(GNU_TARGET_NAME) \
		--build=$(GNU_HOST_NAME) \
		--prefix=/ \
		--mandir=/usr/man \
		--infodir=/usr/info \
		$(DISABLE_DOCUMENTATION) \
		$(DISABLE_NLS) \
		$(DISABLE_LARGEFILE) \
		$(DISABLE_IPV6) \
		$(QUIET) $(GRUB_CONF_OPT) \
	)
endef

This might be handled by the autotool infrastructure.
Otherwise it looks good, thx !

--
Lionel Landwerlin

On Mon, Jan 4, 2010 at 2:01 PM, Clark Rawlins <clark.rawlins at escient.com>wrote:

> Here is my attempt to use the autotools macros.
> I look forward to any discussion, suggestions for improvement etc.
>
> I attach the whole file since it is effectively a rewrite.  If it is
> acceptable I will submit as a git diff against head.
>
> On Sun, 2010-01-03 at 08:43 -0500, Clark Rawlins wrote:
> > Okay,
> >
> > I've started looking at this but it isn't clear to me how to handle the
> > following:
> >
> > $(GRUB_DIR)/$(GRUB_BINARY): $(GRUB_DIR)/.configured
> >       $(MAKE) CC=$(TARGET_CC) -C $(GRUB_DIR)
> >       rm -f $(GRUB_DIR)/$(GRUB_BINARY)
> >       $(MAKE) CC=$(TARGET_CC) CFLAGS+=-static -C $(GRUB_DIR)/grub grub
> >       mkdir -p $(dir $(STAGING_DIR)/$(GRUB_TARGET_BINARY))
> >       mv $(GRUB_DIR)/$(GRUB_BINARY)
> $(STAGING_DIR)/$(GRUB_TARGET_BINARY).static
> >       $(MAKE) CC=$(TARGET_CC) -C $(GRUB_DIR)/grub
> >
> > This builds everything dynamically linked first then builds the grub
> binary statically.
> > Is the right way to do this to override the target after/before calling
> the autotools macro?
> >
> >
> > On Sun, 2010-01-03 at 05:08 +0100, Lionel Landwerlin wrote:
> > > Here is one example :
> > >
> > >
> http://git.buildroot.org/buildroot/commit/?id=21bab8862f3c2906af347e5a993ce4cd36c1b063
> > >
> > > You can find a lot like this in the recent git history.
> > > I'm think to the new infrastructure because it provides all the glue to
> > > configure the package, especially the 2 lines you added.
> > >
> > > Regards,
> > >
> > >
> > > Le samedi 02 janvier 2010 à 21:15 -0500, Clark Rawlins a écrit :
> > > > I could give that a shot.  I thought as a start I would go with the
> > > > smallest change possible.  Any suggestions for an example to look at
> for
> > > > switching grub to the autotools macros?
> > > >
> > > >
> > > > On Sun, 2010-01-03 at 01:13 +0100, Lionel Landwerlin wrote:
> > > > > Le samedi 02 janvier 2010 à 17:46 -0500, Clark Rawlins a écrit :
> > > > > > Grub build failed at the link stage because it
> > > > > > couldn't find libcurses. Adding these variable
> > > > > > invocations to the configure line make it work.
> > > > > >
> > > > > > Signed-off-by: Clark Rawlins <clark.rawlins at escient.com>
> > > > > > ---
> > > > > >  target/x86/grub/grub.mk |    2 ++
> > > > > >  1 files changed, 2 insertions(+), 0 deletions(-)
> > > > > >
> > > > > > diff --git a/target/x86/grub/grub.mk b/target/x86/grub/grub.mk
> > > > > > index af46244..21f089f 100644
> > > > > > --- a/target/x86/grub/grub.mk
> > > > > > +++ b/target/x86/grub/grub.mk
> > > > > > @@ -81,6 +81,8 @@ $(GRUB_DIR)/.unpacked: $(DL_DIR)/$(GRUB_SOURCE)
> $(DL_DIR)/$(GRUB_PATCH)
> > > > > >  $(GRUB_DIR)/.configured: $(GRUB_DIR)/.unpacked
> > > > > >       (cd $(GRUB_DIR); rm -rf config.cache; \
> > > > > >               $(TARGET_CONFIGURE_OPTS) \
> > > > > > +             $(TARGET_CONFIGURE_ARGS) \
> > > > > > +             $(TARGET_CONFIGURE_ENV) \
> > > > > >               CFLAGS="$(TARGET_CFLAGS)" \
> > > > > >               CPPFLAGS="$(GRUB_CFLAGS)" \
> > > > > >               ./configure $(QUIET) \
> > > > >
> > > > > Maybe you should consider switching grub to the autotool
> infrastructure.
> > > > >
> > > > > --
> > > > > Lionel Landwerlin
> > > > >
> > > > > _______________________________________________
> > > > > buildroot mailing list
> > > > > buildroot at busybox.net
> > > > > http://lists.busybox.net/mailman/listinfo/buildroot
> > > >
> > >
> >
> > _______________________________________________
> > buildroot mailing list
> > buildroot at busybox.net
> > http://lists.busybox.net/mailman/listinfo/buildroot
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.busybox.net/pipermail/buildroot/attachments/20100104/dce6253f/attachment.html>


More information about the buildroot mailing list