bitbake.conf/tune files: Adjust PACKAGE_EXTEA_ARCHS
There is a problem with the current PACKAGE_EXTRA_ARCHS implementation since its impossible to control which extra architectures sort higher than TARGET_ARCH and which sort lower. In the x86 case for example, TARGET_ARCH might be "i586", i486 should be lower than this and i686 should be higher. There are also complications where its easy to inject duplicate entries into the variable. I tried various versions of this patch and concluded that it was simplest just to force the tune files to include TARGET_ARCH in the list in the right place if they're planning to customise it themselves. Other approaches with appends and prepends just complicated the code for no good reason. The TARGET_ARCH definitions should also move to the tune files but I'll leave this for a separate patch. (From OE-Core rev: d492ebf8b1801da99c679f465be98ce54fd3061a) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
3b49416fc7
commit
a295a0442e
|
@ -94,7 +94,8 @@ BASE_PACKAGE_ARCH = "${HOST_ARCH}"
|
|||
PACKAGE_ARCH = "${BASE_PACKAGE_ARCH}"
|
||||
MACHINE_ARCH = "${@[bb.data.getVar('BASE_PACKAGE_ARCH', d, 1), bb.data.getVar('MACHINE', d, 1)][bool(bb.data.getVar('MACHINE', d, 1))]}"
|
||||
MACHINE_ARCH_qemux86-64 = "qemux86_64"
|
||||
PACKAGE_ARCHS = "all any noarch ${TARGET_ARCH} ${PACKAGE_EXTRA_ARCHS} ${MACHINE_ARCH}"
|
||||
PACKAGE_EXTRA_ARCHS ??= "${TARGET_ARCH}"
|
||||
PACKAGE_ARCHS = "all any noarch ${PACKAGE_EXTRA_ARCHS} ${MACHINE_ARCH}"
|
||||
# MACHINE shouldn't be included here as a variable dependency since machine specific
|
||||
# packages are handled using multimachine
|
||||
PACKAGE_ARCHS[vardepsexclude] = "MACHINE"
|
||||
|
|
|
@ -4,6 +4,6 @@ FEED_ARCH = "armv6"
|
|||
BASE_PACKAGE_ARCH = "armv6"
|
||||
|
||||
ARM_INSTRUCTION_SET = "${@['thumb','arm'][bb.data.getVar('CPU_FEATURES', d, 1).find('thumb') == -1]}"
|
||||
PACKAGE_EXTRA_ARCHS += "armv4 armv4t armv5te armv6"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4 armv4t armv5te armv6"
|
||||
|
||||
require conf/machine/include/tune-thumb.inc
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
FEED_ARCH = "armv4t"
|
||||
BASE_PACKAGE_ARCH = "armv4t"
|
||||
TARGET_CC_ARCH = "-march=armv4t -mtune=arm920t"
|
||||
PACKAGE_EXTRA_ARCHS += "armv4 armv4t"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4 armv4t"
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
FEED_ARCH = "armv5te"
|
||||
PACKAGE_EXTRA_ARCHS += "armv4 armv4t armv5te"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4 armv4t armv5te"
|
||||
# For gcc 3.x you need:
|
||||
#TARGET_CC_ARCH = "-march=armv5te -mtune=arm926ejs"
|
||||
# For gcc 4.x you need:
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
FEED_ARCH = "armv4t"
|
||||
BASE_PACKAGE_ARCH = "armv4t"
|
||||
PACKAGE_EXTRA_ARCHS += "armv4 armv4t"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4 armv4t"
|
||||
TARGET_CC_ARCH = "-mcpu=arm9tdmi -mtune=arm9tdmi"
|
||||
|
|
|
@ -3,5 +3,5 @@
|
|||
# This will NOT compile programs in 'ARM' mode, which is what you really want
|
||||
TARGET_CC_ARCH = "-march=armv7 -mfpu=vfp -mfloat-abi=softfp"
|
||||
FEED_ARCH = "armv7"
|
||||
PACKAGE_EXTRA_ARCHS += "armv4 armv4t armv5te armv6 armv7"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4 armv4t armv5te armv6 armv7"
|
||||
BASE_PACKAGE_ARCH = "armv7"
|
||||
|
|
|
@ -2,7 +2,7 @@ BASE_PACKAGE_ARCH = "core2"
|
|||
TARGET_CC_ARCH = "-m32 -march=core2 -msse3 -mtune=generic -mfpmath=sse"
|
||||
#MOBLIN_CFLAGS = "-Os -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -fasynchronous-unwind-tables"
|
||||
|
||||
PACKAGE_EXTRA_ARCHS += "x86 i386 i486 core2"
|
||||
PACKAGE_EXTRA_ARCHS = "x86 i386 i486 i586 i686 core2"
|
||||
|
||||
# Work around a gcc bug for core2 which caused matchbox-panel to segfault
|
||||
# and possibly others.
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
TARGET_CC_ARCH = "-march=c3 -mtune=c3"
|
||||
PACKAGE_EXTRA_ARCHS += "i386 i486 i586"
|
||||
PACKAGE_EXTRA_ARCHS = "i386 i486 i586"
|
||||
BASE_PACKAGE_ARCH = "i586"
|
||||
FEED_ARCH = "i586"
|
||||
|
|
|
@ -10,4 +10,4 @@ TARGET_CC_ARCH = "-march=armv7-a -mtune=cortex-a8 -mfpu=neon -mfloat-abi=softfp
|
|||
|
||||
FEED_ARCH = "armv7a"
|
||||
BASE_PACKAGE_ARCH = "armv7a"
|
||||
PACKAGE_EXTRA_ARCHS += "armv4 armv4t armv5te armv6 armv7 armv7a"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4 armv4t armv5te armv6 armv7 armv7a"
|
||||
|
|
|
@ -2,7 +2,7 @@ TARGET_CC_ARCH = "-march=ep9312 -mtune=ep9312 -mcpu=ep9312"
|
|||
# add "-mfp=maverick" for newer gcc versions > 4.0
|
||||
|
||||
#set arch to ep9312 for all generated packages
|
||||
PACKAGE_EXTRA_ARCHS += "armv4t ep9312"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4t ep9312"
|
||||
BASE_PACKAGE_ARCH = "ep9312"
|
||||
FEED_ARCH = "ep9312"
|
||||
|
||||
|
|
|
@ -2,6 +2,6 @@
|
|||
# Please use tune-xscale for PXA255/PXA26x based processors.
|
||||
TARGET_CC_ARCH = "-march=iwmmxt -mcpu=iwmmxt -mtune=iwmmxt"
|
||||
BASE_PACKAGE_ARCH = "iwmmxt"
|
||||
PACKAGE_EXTRA_ARCHS += "armv4 armv4t armv5te iwmmxt"
|
||||
PACKAGE_EXTRA_ARCHS = "arm armv4 armv4t armv5te iwmmxt"
|
||||
FEED_ARCH = "iwmmxt"
|
||||
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
TARGET_CC_ARCH = "-mcpu=603e -mhard-float"
|
||||
BASE_PACKAGE_ARCH = "ppc603e"
|
||||
FEED_ARCH = "ppc603e"
|
||||
PACKAGE_EXTRA_ARCHS += "ppc603e"
|
||||
PACKAGE_EXTRA_ARCHS = "powerpc ppc603e"
|
||||
|
|
|
@ -1,3 +1,3 @@
|
|||
TARGET_CC_ARCH = "-mcpu=e300c2 -msoft-float"
|
||||
BASE_PACKAGE_ARCH = "ppce300"
|
||||
PACKAGE_EXTRA_ARCHS += "ppce300"
|
||||
PACKAGE_EXTRA_ARCHS = "powerpc ppce300"
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
TARGET_CC_ARCH = "-mcpu=8540"
|
||||
BASE_PACKAGE_ARCH = "ppce500"
|
||||
FEED_ARCH = "ppce500"
|
||||
PACKAGE_EXTRA_ARCHS += "ppce500"
|
||||
PACKAGE_EXTRA_ARCHS = "powerpc ppce500"
|
||||
|
|
|
@ -5,7 +5,7 @@ INHERIT += "siteinfo"
|
|||
TARGET_CC_ARCH = "-march=armv5te -mtune=xscale"
|
||||
TARGET_CC_KERNEL_ARCH = "-march=armv5te -mtune=xscale"
|
||||
BASE_PACKAGE_ARCH = "${@['armv5teb', 'armv5te'][bb.data.getVar('SITEINFO_ENDIANESS', d, 1) == 'le']}"
|
||||
PACKAGE_EXTRA_ARCHS += "${@['armv4b armv4tb armv5teb', 'armv4 armv4t armv5te'][bb.data.getVar('SITEINFO_ENDIANESS', d, 1) == 'le']}"
|
||||
PACKAGE_EXTRA_ARCHS = "${@['armeb armv4b armv4tb armv5teb', 'arm armv4 armv4t armv5te'][bb.data.getVar('SITEINFO_ENDIANESS', d, 1) == 'le']}"
|
||||
|
||||
# webkit-gtk has alignment issues with double instructions on armv5 so
|
||||
# disable them here
|
||||
|
|
Loading…
Reference in New Issue