diff options
author | Jackie Huang <jackie.huang@windriver.com> | 2016-01-06 14:42:48 +0800 |
---|---|---|
committer | Joe MacDonald <joe_macdonald@mentor.com> | 2016-03-02 14:47:23 -0500 |
commit | fe4106ca0d81fb0dd30c82a2c4a45c38f9694ad6 (patch) | |
tree | 1554ed17cc6dd03d6e0e517acbbf3785f1d8db44 /meta-oe/classes/waf-samba.bbclass | |
parent | 0762fdd1f57e68374454cc43e7047bd99063e683 (diff) | |
download | meta-openembedded-fe4106ca0d81fb0dd30c82a2c4a45c38f9694ad6.tar.gz |
waf-samba.bbclass: add cross-answers option and files
--cross-execute uses qemu to run cross-compiled binaries,
it works fine for qemu supported targets, but it definitely
will fail if the target is not supported by qemu. So we need
to use the cross-answers option.
Added three methods and set 'answer' as default:
1. answers:
Only --cross-answers - try the cross-answers file, and if
there's no corresponding answer, add to the file and mark
the configure process as unfinished.
2. exec:
Only --cross-execute - get the answer from cross-execute,
an emulator (qemu) is used to run cross-compiled binaries.
3. both:
Try the cross-answers file first, and if there is no
corresponding answer, use cross-execute to get an answer,
and add that answer to the file.
The cross files in are all generated by qemu when the 'both'
mode is enabled, and are placed in a common directory
LAYERDIR/files/waf-cross-answers which is set as
WAF_CROSS_ANSWERS_PATH in layer.conf of meta-oe,
so that we don't have to put copies of them for each
package (there are 5 packages inerit waf-samba for now)
Signed-off-by: Jackie Huang <jackie.huang@windriver.com>
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
Signed-off-by: Joe MacDonald <joe_macdonald@mentor.com>
Diffstat (limited to 'meta-oe/classes/waf-samba.bbclass')
-rw-r--r-- | meta-oe/classes/waf-samba.bbclass | 43 |
1 files changed, 42 insertions, 1 deletions
diff --git a/meta-oe/classes/waf-samba.bbclass b/meta-oe/classes/waf-samba.bbclass index a8b3b9529..45fbcc342 100644 --- a/meta-oe/classes/waf-samba.bbclass +++ b/meta-oe/classes/waf-samba.bbclass | |||
@@ -20,7 +20,38 @@ CONFIGUREOPTS = " --prefix=${prefix} \ | |||
20 | --mandir=${mandir} \ | 20 | --mandir=${mandir} \ |
21 | " | 21 | " |
22 | 22 | ||
23 | # Three methods for waf cross compile: | ||
24 | # 1. answers: | ||
25 | # Only --cross-answers - try the cross-answers file, and if | ||
26 | # there's no corresponding answer, add to the file and mark | ||
27 | # the configure process as unfinished. | ||
28 | # 2. exec: | ||
29 | # Only --cross-execute - get the answer from cross-execute, | ||
30 | # an emulator (qemu) is used to run cross-compiled binaries. | ||
31 | # 3. both: | ||
32 | # (notes: not supported in lower version of some packages, | ||
33 | # please check buildtools/wafsamba/samba_cross.py in the | ||
34 | # package source) | ||
35 | # Try the cross-answers file first, and if there is no | ||
36 | # corresponding answer, use cross-execute to get an answer, | ||
37 | # and add that answer to the file. | ||
38 | # | ||
39 | # The first one is preferred since it may fail with 2 or 3 if | ||
40 | # the target board is not suported by qemu, but we can use 2 or 3 | ||
41 | # to help generate the cross answer when adding new board support. | ||
42 | CROSS_METHOD ?= "answer" | ||
43 | |||
23 | do_configure() { | 44 | do_configure() { |
45 | |||
46 | # Prepare the cross-answers file | ||
47 | CROSS_ANSWERS="${B}/cross-answers-${TARGET_ARCH}.txt" | ||
48 | if [ -e ${CROSS_ANSWERS} ]; then | ||
49 | rm -f ${CROSS_ANSWERS} | ||
50 | fi | ||
51 | echo 'Checking uname machine type: "${TARGET_ARCH}"' >> ${CROSS_ANSWERS} | ||
52 | echo 'Checking uname release type: "${OLDEST_KERNEL}"' >> ${CROSS_ANSWERS} | ||
53 | cat ${WAF_CROSS_ANSWERS_PATH}/cross-answers-${TARGET_ARCH}.txt >> ${CROSS_ANSWERS} | ||
54 | |||
24 | qemu_binary="${@qemu_target_binary(d)}" | 55 | qemu_binary="${@qemu_target_binary(d)}" |
25 | if [ "${qemu_binary}" = "qemu-allarch" ]; then | 56 | if [ "${qemu_binary}" = "qemu-allarch" ]; then |
26 | qemu_binary="qemuwrapper" | 57 | qemu_binary="qemuwrapper" |
@@ -42,7 +73,17 @@ do_configure() { | |||
42 | export STAGING_INCDIR=${STAGING_INCDIR} | 73 | export STAGING_INCDIR=${STAGING_INCDIR} |
43 | export PYTHONPATH=${STAGING_DIR_HOST}${PYTHON_SITEPACKAGES_DIR} | 74 | export PYTHONPATH=${STAGING_DIR_HOST}${PYTHON_SITEPACKAGES_DIR} |
44 | 75 | ||
45 | ./configure ${CONFIGUREOPTS} ${EXTRA_OECONF} --cross-compile --cross-execute="${CROSS_EXEC}" | 76 | CONFIG_CMD="./configure ${CONFIGUREOPTS} ${EXTRA_OECONF} --cross-compile" |
77 | if [ "${CROSS_METHOD}" = "answer" ]; then | ||
78 | ${CONFIG_CMD} --cross-answers="${CROSS_ANSWERS}" | ||
79 | elif [ "${CROSS_METHOD}" = "exec" ]; then | ||
80 | ${CONFIG_CMD} --cross-exec="${CROSS_EXEC}" | ||
81 | elif [ "${CROSS_METHOD}" = "both" ]; then | ||
82 | ${CONFIG_CMD} --cross-answers="${CROSS_ANSWERS}" --cross-exec="${CROSS_EXEC}" | ||
83 | else | ||
84 | echo "ERROR: ${CROSS_METHOD} is not valid for cross-compile!" | ||
85 | exit 1 | ||
86 | fi | ||
46 | } | 87 | } |
47 | 88 | ||
48 | do_compile () { | 89 | do_compile () { |