more build fixes

This commit is contained in:
BVK Chaitanya 2010-07-15 02:02:01 +05:30
parent c1c6e4c017
commit d9b78bce4a
4 changed files with 81 additions and 44 deletions

View file

@ -105,6 +105,8 @@ grub-core/configure.common
grub-core/depcomp grub-core/depcomp
grub-core/gentpl.py grub-core/gentpl.py
grub-core/conf/gcry.rmk grub-core/conf/gcry.rmk
grub-core/docs
grub-core/docs/man
grub-core/lib/libgcrypt-grub grub-core/lib/libgcrypt-grub
grub-core/include/grub/cpu grub-core/include/grub/cpu
grub-core/include/grub/machine grub-core/include/grub/machine

View file

@ -20,6 +20,9 @@ ln -svf ../config.rpath grub-core/
ln -svf ../gentpl.py grub-core/ ln -svf ../gentpl.py grub-core/
ln -svf ../configure.common grub-core/ ln -svf ../configure.common grub-core/
mkdir -vp grub-core/docs/man
ln -svf ../../../docs/man/grub-emu.h2m grub-core/docs/man
echo "Creating Makefile.tpl..." echo "Creating Makefile.tpl..."
python gentpl.py | sed -e '/^$/{N;/^\n$/D;}' > Makefile.tpl python gentpl.py | sed -e '/^$/{N;/^\n$/D;}' > Makefile.tpl
echo "Running autogen..." echo "Running autogen..."

View file

@ -83,38 +83,53 @@ def rule(target, source, cmd):
else: else:
return "\n" + target + ": " + source + "\n\t" + cmd.replace("\n", "\n\t") + "\n" return "\n" + target + ": " + source + "\n\t" + cmd.replace("\n", "\n\t") + "\n"
def if_platform_tagged(platform, tag, closure, c2=None): #
# Template for keys with platform names as values, for example:
#
# kernel = {
# nostrip = emu;
# nostrip = i386_pc;
# }
#
def if_platform_tagged(platform, tag, snippet_if, snippet_else=None):
r = "" r = ""
r += "[+ IF " + tag + " defined +]" r += "[+ IF " + tag + " defined +]"
r += "[+ FOR " + tag + " +][+ CASE " + tag + " +]" r += "[+ FOR " + tag + " +][+ CASE " + tag + " +]"
for group in RMAP[platform]: for group in RMAP[platform]:
r += "[+ = \"" + group + "\" +]" + closure() r += "[+ = \"" + group + "\" +]" + snippet_if
if snippet_else != None: r += "[+ * +]" + snippet_if
r += "[+ ESAC +][+ ENDFOR +]" r += "[+ ESAC +][+ ENDFOR +]"
if c2 == None: if snippet_else == None:
r += "[+ ENDIF +]" r += "[+ ENDIF +]"
return r return r
r += "[+ ELSE +]" + c2() + "[+ ENDIF +]" r += "[+ ELSE +]" + snippet_else + "[+ ENDIF +]"
return r return r
def platform_values(platform, group_tag, default_tag): #
# Template for handling platform specific values, for example:
#
# module = {
# cflags = '-Wall';
# emu_cflags = '-Wall -DGRUB_EMU=1';
# }
#
def foreach_platform_value(platform, tag, suffix, closure):
r = "" r = ""
for group in RMAP[platform]: for group in RMAP[platform]:
gtag = group + group_tag gtag = group + suffix
if group == RMAP[platform][0]: if group == RMAP[platform][0]:
r += "[+ IF " + gtag + " +]" r += "[+ IF " + gtag + " +]"
else: else:
r += "[+ ELIF " + gtag + " +]" r += "[+ ELIF " + gtag + " +]"
r += "[+ FOR " + gtag + " +][+ ." + gtag + " +] [+ ENDFOR +]" r += "[+ FOR " + gtag + " +]" + closure("[+ ." + gtag + " +]") + "[+ ENDFOR +]"
r += "[+ ELSE +][+ FOR " + default_tag + " +][+ ." + default_tag + " +] [+ ENDFOR +][+ ENDIF +]" r += "[+ ELSE +][+ FOR " + tag + " +]" + closure("[+ ." + tag + " +]") + "[+ ENDFOR +][+ ENDIF +]"
return r return r
def under_conditional(x):
return "[+ IF condition +]\nif [+ condition +]\n[+ ENDIF +]" + x + "[+ IF condition +]\nendif\n[+ ENDIF +]"
def each_platform(closure): def each_platform(closure):
r = "[+ IF - enable undefined +]" r = "[+ IF - enable undefined +]"
for platform in GRUB_PLATFORMS: for platform in GRUB_PLATFORMS:
@ -122,24 +137,33 @@ def each_platform(closure):
r += "[+ ELSE +]" r += "[+ ELSE +]"
for platform in GRUB_PLATFORMS: for platform in GRUB_PLATFORMS:
x = "\nif COND_" + platform + "\n" + closure(platform) + "endif\n" x = "\nif COND_" + platform + "\n" + closure(platform) + "endif\n"
r += if_platform_tagged(platform, "enable", lambda: x) r += if_platform_tagged(platform, "enable", x)
r += "[+ ENDIF +]" r += "[+ ENDIF +]"
return r; return r
def under_platform_specific_conditionals(platform, snippet):
r = foreach_platform_value(platform, "condition", "_condition", lambda cond: "if " + cond + "\n")
r += snippet
r += foreach_platform_value(platform, "condition", "_condition", lambda cond: "endif " + cond + "\n")
return r
def platform_specific_values(platform, tag, suffix):
return foreach_platform_value(platform, tag, suffix, lambda value: value + " ")
def shared_sources(): return "[+ FOR shared +][+ .shared +] [+ ENDFOR +]" def shared_sources(): return "[+ FOR shared +][+ .shared +] [+ ENDFOR +]"
def shared_nodist_sources(): return "[+ FOR nodist_shared +] [+ .nodist_shared +][+ ENDFOR +]" def shared_nodist_sources(): return "[+ FOR nodist_shared +] [+ .nodist_shared +][+ ENDFOR +]"
def platform_sources(p): return platform_values(p, "", "source") def platform_sources(p): return platform_specific_values(p, "source", "")
def platform_nodist_sources(p): return platform_values(p, "_nodist", "nodist") def platform_nodist_sources(p): return platform_specific_values(p, "nodist", "_nodist")
def platform_extra_dist(p): return platform_values(p, "_extra_dist", "extra_dist") def platform_extra_dist(p): return platform_specific_values(p, "extra_dist", "_extra_dist")
def platform_ldadd(p): return platform_values(p, "_ldadd", "ldadd") def platform_ldadd(p): return platform_specific_values(p, "ldadd", "_ldadd")
def platform_cflags(p): return platform_values(p, "_cflags", "cflags") def platform_cflags(p): return platform_specific_values(p, "cflags", "_cflags")
def platform_ldflags(p): return platform_values(p, "_ldflags", "ldflags") def platform_ldflags(p): return platform_specific_values(p, "ldflags", "_ldflags")
def platform_cppflags(p): return platform_values(p, "_cppflags", "cppflags") def platform_cppflags(p): return platform_specific_values(p, "cppflags", "_cppflags")
def platform_ccasflags(p): return platform_values(p, "_ccasflags", "ccasflags") def platform_ccasflags(p): return platform_specific_values(p, "ccasflags", "_ccasflags")
def platform_stripflags(p): return platform_values(p, "_stripflags", "stripflags") def platform_stripflags(p): return platform_specific_values(p, "stripflags", "_stripflags")
def platform_objcopyflags(p): return platform_values(p, "_objcopyflags", "objcopyflags") def platform_objcopyflags(p): return platform_specific_values(p, "objcopyflags", "_objcopyflags")
def module(platform): def module(platform):
r = set_canonical_name_suffix(".module") r = set_canonical_name_suffix(".module")
@ -254,8 +278,8 @@ def kernel(platform):
r += gvar_add("platform_DATA", "[+ name +].img") r += gvar_add("platform_DATA", "[+ name +].img")
r += gvar_add("CLEANFILES", "[+ name +].img") r += gvar_add("CLEANFILES", "[+ name +].img")
r += rule("[+ name +].img", "[+ name +].exec$(EXEEXT)", r += rule("[+ name +].img", "[+ name +].exec$(EXEEXT)",
if_platform_tagged(platform, "nostrip", lambda: "cp $< $@", if_platform_tagged(platform, "nostrip", "cp $< $@",
lambda: "$(STRIP) $(" + cname() + "_STRIPFLAGS) -o $@ $<")) "$(STRIP) $(" + cname() + "_STRIPFLAGS) -o $@ $<"))
return r return r
def image(platform): def image(platform):
@ -270,6 +294,7 @@ def image(platform):
r += var_set(cname() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_IMAGE) " + platform_ldflags(platform)) r += var_set(cname() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_IMAGE) " + platform_ldflags(platform))
r += var_set(cname() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_IMAGE) " + platform_cppflags(platform)) r += var_set(cname() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_IMAGE) " + platform_cppflags(platform))
r += var_set(cname() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_IMAGE) " + platform_ccasflags(platform)) r += var_set(cname() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_IMAGE) " + platform_ccasflags(platform))
r += var_set(cname() + "_OBJCOPYFLAGS", "$(OBJCOPYFLAGS_IMAGE) " + platform_objcopyflags(platform))
r += gvar_add("EXTRA_DIST", platform_extra_dist(platform)) r += gvar_add("EXTRA_DIST", platform_extra_dist(platform))
r += gvar_add("BUILT_SOURCES", "$(nodist_" + cname() + "_SOURCES)") r += gvar_add("BUILT_SOURCES", "$(nodist_" + cname() + "_SOURCES)")
@ -281,7 +306,7 @@ def image(platform):
if test x$(USE_APPLE_CC_FIXES) = xyes; then \ if test x$(USE_APPLE_CC_FIXES) = xyes; then \
$(MACHO2IMG) $< $@; \ $(MACHO2IMG) $< $@; \
else \ else \
$(OBJCOPY) """ + platform_objcopyflags(platform) + """ --strip-unneeded -R .note -R .comment -R .note.gnu.build-id -R .reginfo -R .rel.dyn $< $@; \ $(OBJCOPY) $(""" + cname() + """_OBJCOPYFLAGS) --strip-unneeded -R .note -R .comment -R .note.gnu.build-id -R .reginfo -R .rel.dyn $< $@; \
fi fi
""") """)
return r return r
@ -370,25 +395,32 @@ chmod a+x [+ name +]
return r return r
def module_rules(): def module_rules():
return "[+ FOR module +]" + under_conditional(each_platform(lambda p: module(p))) + "[+ ENDFOR +]" return "[+ FOR module +]" + each_platform(
lambda p: under_platform_specific_conditionals(p, module(p))) + "[+ ENDFOR +]"
def kernel_rules(): def kernel_rules():
return "[+ FOR kernel +]" + under_conditional(each_platform(lambda p: kernel(p))) + "[+ ENDFOR +]" return "[+ FOR kernel +]" + each_platform(
lambda p: under_platform_specific_conditionals(p, kernel(p))) + "[+ ENDFOR +]"
def image_rules(): def image_rules():
return "[+ FOR image +]" + under_conditional(each_platform(lambda p: image(p))) + "[+ ENDFOR +]" return "[+ FOR image +]" + each_platform(
lambda p: under_platform_specific_conditionals(p, image(p))) + "[+ ENDFOR +]"
def library_rules(): def library_rules():
return "[+ FOR library +]" + under_conditional(each_platform(lambda p: library(p))) + "[+ ENDFOR +]" return "[+ FOR library +]" + each_platform(
lambda p: under_platform_specific_conditionals(p, library(p))) + "[+ ENDFOR +]"
def program_rules(): def program_rules():
return "[+ FOR program +]" + under_conditional(each_platform(lambda p: program(p))) + "[+ ENDFOR +]" return "[+ FOR program +]" + each_platform(
lambda p: under_platform_specific_conditionals(p, program(p))) + "[+ ENDFOR +]"
def script_rules(): def script_rules():
return "[+ FOR script +]" + under_conditional(each_platform(lambda p: script(p))) + "[+ ENDFOR +]" return "[+ FOR script +]" + each_platform(
lambda p: under_platform_specific_conditionals(p, script(p))) + "[+ ENDFOR +]"
def data_rules(): def data_rules():
return "[+ FOR data +]" + under_conditional(each_platform(lambda p: data(p))) + "[+ ENDFOR +]" return "[+ FOR data +]" + each_platform(
lambda p: under_platform_specific_conditionals(p, data(p))) + "[+ ENDFOR +]"
print "[+ AutoGen5 template +]\n" print "[+ AutoGen5 template +]\n"
a = module_rules() a = module_rules()

View file

@ -141,6 +141,8 @@ kernel = {
i386_ieee1275 = kern/ieee1275/ieee1275.c; i386_ieee1275 = kern/ieee1275/ieee1275.c;
i386_ieee1275 = term/ieee1275/ofconsole.c; i386_ieee1275 = term/ieee1275/ofconsole.c;
i386_ieee1275 = disk/ieee1275/ofdisk.c; i386_ieee1275 = disk/ieee1275/ofdisk.c;
i386_ieee1275 = term/terminfo.c;
i386_ieee1275 = term/tparm.c;
x86_64_efi = kern/x86_64/efi/startup.S; x86_64_efi = kern/x86_64/efi/startup.S;
x86_64_efi = kern/x86_64/efi/callwrap.S; x86_64_efi = kern/x86_64/efi/callwrap.S;
@ -366,14 +368,6 @@ module = {
enable = mips_yeeloong; enable = mips_yeeloong;
}; };
module = {
name = pci;
source = bus/emu/pci.c;
source = commands/lspci.c;
enable = emu;
condition = COND_GRUB_EMU_PCI;
};
module = { module = {
name = usb; name = usb;
source = bus/usb/usb.c; source = bus/usb/usb.c;
@ -393,23 +387,29 @@ module = {
module = { module = {
name = uhci; name = uhci;
source = bus/usb/uhci.c; source = bus/usb/uhci.c;
enable = x86; enable = i386_pc;
}; };
module = { module = {
name = ohci; name = ohci;
source = bus/usb/ohci.c; source = bus/usb/ohci.c;
enable = x86; enable = i386_pc;
enable = mips_yeeloong; enable = mips_yeeloong;
}; };
module = { module = {
name = pci; name = pci;
source = bus/pci.c; source = bus/pci.c;
emu = bus/emu/pci.c;
emu = commands/lspci.c;
enable = emu;
enable = i386_pc; enable = i386_pc;
enable = i386_efi; enable = x86_efi;
enable = i386_ieee1275; enable = i386_ieee1275;
enable = i386_coreboot; enable = i386_coreboot;
emu_condition = COND_GRUB_EMU_PCI;
}; };
library = { library = {