ошибка компиляции ядра после обновления - PullRequest
0 голосов
/ 09 июля 2019

Я использовал 'linux-toradex-4.1-2.0.x-imx' на yocto morty, и все было хорошо. но после обновления всех слоев и версий до 'Thud', я получаю сообщение об ошибке do_compile ядра:

Sstate summary: Wanted 624 Found 66 Missed 558 Current 689 (10% match, 57% complete)
NOTE: Executing SetScene Tasks
WARNING: Variable key RDEPENDS_${KERNEL_PACKAGE_NAME}-base (${KERNEL_PACKAGE_NAME}-image) replaces original key RDEPENDS_kernel-base ( kernel-devicetree kernel-image).
ERROR: linux-toradex-samim-4.1-2.0.x-r0 do_compile: oe_runmake failed
ERROR: linux-toradex-samim-4.1-2.0.x-r0 do_compile: Function failed: do_compile (log file is located at /opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/temp/log.do_compile.23716)
ERROR: Logfile of failure stored in: /opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/temp/log.do_compile.23716
Log data follows:
| DEBUG: Executing shell function do_compile
| NOTE: make -j 8 HOSTCC=gcc  -isystem/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native/usr/include -O2 -pipe -L/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native/usr/lib -L/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native/lib -Wl,-rpath-link,/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native/usr/lib -Wl,-rpath-link,/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native/lib -Wl,-rpath,/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native/usr/lib -Wl,-rpath,/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native/lib -Wl,-O1 HOSTCPP=gcc  -E uImage CC=arm-angstrom-linux-gnueabi-gcc  -mno-thumb-interwork -marm -fuse-ld=bfd -fdebug-prefix-map=/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0=/usr/src/debug/linux-toradex-samim/4.1-2.0.x-r0 -fdebug-prefix-map=/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot= -fdebug-prefix-map=/opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-r0/recipe-sysroot-native=  -fdebug-prefix-map=/opt/yocto/toradex-morty/poky/build/tmp-glibc/work-shared/colibri-imx6/kernel-source=/usr/src/kernel   LD=arm-angstrom-linux-gnueabi-ld.bfd   LOADADDR=0x10008000
|   GEN     ./Makefile
| scripts/kconfig/conf  --silentoldconfig Kconfig
|   CHK     include/config/kernel.release
|   UPD     include/config/kernel.release
|   GEN     ./Makefile
|   WRAP    arch/arm/include/generated/asm/bitsperlong.h
|   WRAP    arch/arm/include/generated/asm/cputime.h
|   WRAP    arch/arm/include/generated/asm/current.h

.
.
.
...after some warnings...
.
.
|                  from /opt/yocto/toradex-morty/poky/build/tmp-glibc/work-shared/colibri-imx6/kernel-source/include/linux/crypto.h:21,
|                  from /opt/yocto/toradex-morty/poky/build/tmp-glibc/work-shared/colibri-imx6/kernel-source/include/crypto/algapi.h:15,
|                  from /opt/yocto/toradex-morty/poky/build/tmp-glibc/work-shared/colibri-imx6/kernel-source/crypto/ghash-generic.c:15:
| /opt/yocto/toradex-morty/poky/build/tmp-glibc/work-shared/colibri-imx6/kernel-source/include/linux/log2.h:22:1: warning: ignoring attribute 'noreturn' because it conflicts with attribute 'const' [-Wattributes]
|  int ____ilog2_NaN(void);
|  ^~~
|   LD      crypto/crypto_blkcipher.o
|   LD      crypto/crypto_hash.o
|   LD      crypto/cryptomgr.o
|   LD      crypto/built-in.o
| Makefile:146: recipe for target 'sub-make' failed
| make[1]: *** [sub-make] Error 2
| Makefile:24: recipe for target '__sub-make' failed
| make: *** [__sub-make] Error 2
| ERROR: oe_runmake failed
| WARNING: exit code 1 from a shell command.
| ERROR: Function failed: do_compile (log file is located at /opt/yocto/toradex-morty/poky/build/tmp-glibc/work/colibri_imx6-angstrom-linux-gnueabi/linux-toradex-samim/4.1-2.0.x-0/temp/log.do_compile.10534)

Рецепт ядра:

require recipes-kernel/linux/linux-imx.inc
include conf/tdx_version.conf

SUMMARY = "Linux kernel for Toradex Freescale i.MX based modules"

SRC_URI = "git://git@git.myco.int/kernel/linux-toradex-4.1-2.0.x-imx.git;protocol=ssh;branch=${SRCBRANCH} \
        file://defconfig \
        file://0002-Add-APP-K7-board-support.patch \
        "

# Load USB functions configurable through configfs (CONFIG_USB_CONFIGFS)
KERNEL_MODULE_AUTOLOAD += "${@bb.utils.contains('COMBINED_FEATURES', 'usbgadget', ' libcomposite', '',d)}"

LOCALVERSION = "-${TDX_VER_ITEM}"
# PV_append = "+git${SRCPV}"

SRCREV = "e420b7a49300560485af191ec63887d27da577db"
SRCBRANCH = "toradex_4.1-2.0.x-imx"

DEPENDS += "lzop-native bc-native"
COMPATIBLE_MACHINE = "(mx7|mx6)"

# defaults
TDX_VER_ITEM ??= "0"

inherit kernel

В слое 'meta-toradex-nxp' я только что увидел 'linux-toradex_4.9-2.3.x.bb', а не 4.1-2.0.x, это важно? мне нужно добавить что-то еще в мой рецепт компиляции с 'Thud' тоже?

Мой bblayers.conf также:

# LAYER_CONF_VERSION is increased each time build/conf/bblayers.conf
# changes incompatibly
LCONF_VERSION = "7"

BBPATH = "${TOPDIR}"
BBFILES ?= ""

BBLAYERS ?= " \
  ${TOPDIR}/../meta-myproj \
  \
  ${TOPDIR}/../meta-angstrom \
  \
  ${TOPDIR}/../meta-toradex-nxp \
  ${TOPDIR}/../meta-freescale \
  ${TOPDIR}/../meta-freescale-3rdparty \
  \
  ${TOPDIR}/../meta-toradex-bsp-common \
  \
  ${TOPDIR}/../meta-snappy \
  \
  ${TOPDIR}/../meta-linaro/meta-linaro-toolchain \
  ${TOPDIR}/../meta-openembedded/meta-oe \
  ${TOPDIR}/../meta-openembedded/meta-gnome \
  ${TOPDIR}/../meta-openembedded/meta-initramfs \
  ${TOPDIR}/../meta-openembedded/meta-networking \
  ${TOPDIR}/../meta-openembedded/meta-multimedia \
  ${TOPDIR}/../meta-openembedded/meta-python \
  ${TOPDIR}/../meta-openembedded/meta-webserver \
  \
  ${TOPDIR}/../meta-openembedded/meta-filesystems \
  \
  ${TOPDIR}/../meta-lxde \
  ${TOPDIR}/../meta-qt5 \
  ${TOPDIR}/../meta-qt5-extra \
  ${TOPDIR}/../meta-toradex-demos \
  ${TOPDIR}/../meta-freescale-distro \
  ${TOPDIR}/../meta-poky \
  ${TOPDIR}/../meta-browser \
  ${TOPDIR}/../meta-swupdate \
  \
  \
  ${TOPDIR}/../meta \
"

Заранее большое спасибо.

Обновление : спасибо @Marcel, я проверил Руководство yocto и там написано: «GNU Compiler Collection версии 8.2 теперь используется по умолчанию для компиляции. Если вам все еще нужно скомпилировать с версией 7.x также предоставляется GCC 7.3. Вы можете выбрать эту версию, задав и выбрав ее, установив для переменной GCCVERSION значение "7.%" в вашей конфигурации. "

и затем я вставляю 'GCCVERSION = "7.%"' в файл conf / local.conf, но, к сожалению, он по-прежнему не работает.

1 Ответ

3 голосов
/ 10 июля 2019

Обратите внимание, что Thud использует более поздний компилятор gcc (8.3, если быть точным). К сожалению, устаревшее ядро ​​Linux 4.1 не скомпилируется с таким gcc 8.3, и вам нужно было бы скопировать несколько патчей, чтобы эта комбинация работала. Кроме того, обратите внимание, что OpenEmbedded обычно рассматривает любое предупреждение как ошибку, которую вы также можете отключить с помощью флагов компиляции, так как в противном случае количество требуемых исправлений будет весьма бесконечным. В целом, лучшим подходом может быть также правильное использование более позднего ядра Linux, такого как toradex_4.14-2.0.x-imx, к которому мы теперь официально переходим в BSP 3.0b2.

...