diff options
Diffstat (limited to 'meta-zephyr-core/classes/zephyr.bbclass')
-rw-r--r-- | meta-zephyr-core/classes/zephyr.bbclass | 59 |
1 files changed, 14 insertions, 45 deletions
diff --git a/meta-zephyr-core/classes/zephyr.bbclass b/meta-zephyr-core/classes/zephyr.bbclass index f3d16b7..4f4c88d 100644 --- a/meta-zephyr-core/classes/zephyr.bbclass +++ b/meta-zephyr-core/classes/zephyr.bbclass @@ -2,6 +2,7 @@ inherit terminal inherit python3native PYTHONPATH="${STAGING_DIR_HOST}${libdir}/${PYTHON_DIR}/site-packages" +DEPENDS += "python3-pyelftools-native python3-pyyaml-native python3-pykwalify-native ninja-native" OE_TERMINAL_EXPORTS += "HOST_EXTRACFLAGS HOSTLDFLAGS TERMINFO CROSS_CURSES_LIB CROSS_CURSES_INC" HOST_EXTRACFLAGS = "${BUILD_CFLAGS} ${BUILD_LDFLAGS}" @@ -11,6 +12,7 @@ CROSS_CURSES_INC = '-DCURSES_LOC="<curses.h>"' TERMINFO = "${STAGING_DATADIR_NATIVE}/terminfo" KCONFIG_CONFIG_COMMAND ??= "menuconfig" +KCONFIG_CONFIG_ROOTDIR ??= "${B}" ZEPHYR_BOARD ?= "${MACHINE}" # qemuboot writes into IMGDEPLOYDIR, force to write to DEPLOY_DIR_IMAGE @@ -24,60 +26,27 @@ python () { d.setVar('BOARD',board) } -do_get_zmods() { - - export PYTHONPATH="${RECIPE_SYSROOT_NATIVE}/${libdir}/${PYTHON_DIR}/site-packages:${RECIPE_SYSROOT_NATIVE}/${libdir}/${PYTHON_DIR}" - cd ${S} - - # I really dislike how tied in this is to west, but without reimplementing their script, this seems to be the - # easiest way to do this - rm -rf .west; mkdir .west - cat << EOF >> ${S}/.west/config -[manifest] -path = . -file = west.yml -EOF - - # Because of how we structure things, we need to either structure this more like a west workspace or just tweak - # the manifest in order to get access to the west extentions like build and whatnot. Tweaking the manifest is the - # easier path here and minimizes the amount of breakage that might occur. - - sed -i 's/path: zephyr/path: ./' west.yml - - # Get all available modules and add them to ZEPHYR_MODULES - for i in $(west list|awk 'NR>1 {print $2}'); do - ZEPHYR_MODULES="${S}/$i\;${ZEPHYR_MODULES}" - done - export ZEPHYR_MODULES -} - -do_get_zmods[nostamp] = "1" -do_get_zmods[dirs] = "${B}" - EXTRA_OECMAKE:append = " -DZEPHYR_MODULES=${ZEPHYR_MODULES}" -addtask get_zmods after do_patch before do_configure -do_get_zmods[depends] += "west-native:do_populate_sysroot" -do_get_zmods[depends] += "python3-pyyaml-native:do_populate_sysroot" -do_get_zmods[depends] += "python3-pykwalify-native:do_populate_sysroot" -do_get_zmods[depends] += "python3-colorama-native:do_populate_sysroot" -do_get_zmods[depends] += "python3-pyelftools-native:do_populate_sysroot" - python do_menuconfig() { - os.chdir(d.getVar('ZEPHYR_SRC_DIR', True)) - configdir = d.getVar('ZEPHYR_SRC_DIR', True) + '/outdir/' + d.getVar('BOARD', True) + import shutil + + config = d.getVar('KCONFIG_CONFIG_ROOTDIR', True) + '/zephyr/' + '.config' + configorig = d.getVar('KCONFIG_CONFIG_ROOTDIR', True) + '/zephyr/' + '.config.orig' + try: - mtime = os.path.getmtime(configdir +"/.config") + mtime = os.path.getmtime(config) + shutil.copy(config, configorig) except OSError: mtime = 0 - oe_terminal("${SHELL} -c \"ZEPHYR_BASE=%s make BOARD=%s %s; if [ \$? -ne 0 ]; then echo 'Command failed.'; \ + oe_terminal("sh -c \"ninja %s; if [ \\$? -ne 0 ]; then echo 'Command failed.'; \ printf 'Press any key to continue... '; \ - read r; fi\"" % (d.getVar('ZEPHYR_BASE', True), d.getVar('BOARD', True),d.getVar('KCONFIG_CONFIG_COMMAND', True)), - d.getVar('PN', True) + ' Configuration', d) + read r; fi\"" % d.getVar('KCONFIG_CONFIG_COMMAND'), \ + d.getVar('PN') + ' Configuration', d) try: - newmtime = os.path.getmtime(configdir +"/.config") + newmtime = os.path.getmtime(config) except OSError: newmtime = 0 @@ -87,7 +56,7 @@ python do_menuconfig() { } do_menuconfig[depends] += "ncurses-native:do_populate_sysroot" do_menuconfig[nostamp] = "1" -do_menuconfig[dirs] = "${B}" +do_menuconfig[dirs] = "${KCONFIG_CONFIG_ROOTDIR}" addtask menuconfig after do_configure python do_devshell:prepend () { |