|  | # syslinux.bbclass | 
|  | # Copyright (C) 2004-2006, Advanced Micro Devices, Inc.  All Rights Reserved | 
|  | # Released under the MIT license (see packages/COPYING) | 
|  |  | 
|  | # Provide syslinux specific functions for building bootable images. | 
|  |  | 
|  | # External variables | 
|  | # ${INITRD} - indicates a list of filesystem images to concatenate and use as an initrd (optional) | 
|  | # ${ROOTFS} - indicates a filesystem image to include as the root filesystem (optional) | 
|  | # ${AUTO_SYSLINUXMENU} - set this to 1 to enable creating an automatic menu | 
|  | # ${LABELS} - a list of targets for the automatic config | 
|  | # ${APPEND} - an override list of append strings for each label | 
|  | # ${SYSLINUX_OPTS} - additional options to add to the syslinux file ';' delimited | 
|  | # ${SYSLINUX_SPLASH} - A background for the vga boot menu if using the boot menu | 
|  | # ${SYSLINUX_DEFAULT_CONSOLE} - set to "console=ttyX" to change kernel boot default console | 
|  | # ${SYSLINUX_SERIAL} - Set an alternate serial port or turn off serial with empty string | 
|  | # ${SYSLINUX_SERIAL_TTY} - Set alternate console=tty... kernel boot argument | 
|  | # ${SYSLINUX_KERNEL_ARGS} - Add additional kernel arguments | 
|  |  | 
|  | do_bootimg[depends] += "${MLPREFIX}syslinux:do_populate_sysroot \ | 
|  | syslinux-native:do_populate_sysroot" | 
|  |  | 
|  | ISOLINUXDIR ?= "/isolinux" | 
|  | SYSLINUXDIR = "/" | 
|  | # The kernel has an internal default console, which you can override with | 
|  | # a console=...some_tty... | 
|  | SYSLINUX_DEFAULT_CONSOLE ?= "" | 
|  | SYSLINUX_SERIAL ?= "0 115200" | 
|  | SYSLINUX_SERIAL_TTY ?= "console=ttyS0,115200" | 
|  | SYSLINUX_PROMPT ?= "0" | 
|  | SYSLINUX_TIMEOUT ?= "50" | 
|  | AUTO_SYSLINUXMENU ?= "1" | 
|  | SYSLINUX_ROOT ?= "${ROOT}" | 
|  | SYSLINUX_CFG_VM  ?= "${S}/syslinux_vm.cfg" | 
|  | SYSLINUX_CFG_LIVE ?= "${S}/syslinux_live.cfg" | 
|  | APPEND ?= "" | 
|  |  | 
|  | # Need UUID utility code. | 
|  | inherit fs-uuid | 
|  |  | 
|  | syslinux_populate() { | 
|  | DEST=$1 | 
|  | BOOTDIR=$2 | 
|  | CFGNAME=$3 | 
|  |  | 
|  | install -d ${DEST}${BOOTDIR} | 
|  |  | 
|  | # Install the config files | 
|  | install -m 0644 ${SYSLINUX_CFG} ${DEST}${BOOTDIR}/${CFGNAME} | 
|  | if [ "${AUTO_SYSLINUXMENU}" = 1 ] ; then | 
|  | install -m 0644 ${STAGING_DATADIR}/syslinux/vesamenu.c32 ${DEST}${BOOTDIR}/vesamenu.c32 | 
|  | install -m 0444 ${STAGING_DATADIR}/syslinux/libcom32.c32 ${DEST}${BOOTDIR}/libcom32.c32 | 
|  | install -m 0444 ${STAGING_DATADIR}/syslinux/libutil.c32 ${DEST}${BOOTDIR}/libutil.c32 | 
|  | if [ "${SYSLINUX_SPLASH}" != "" ] ; then | 
|  | install -m 0644 ${SYSLINUX_SPLASH} ${DEST}${BOOTDIR}/splash.lss | 
|  | fi | 
|  | fi | 
|  | } | 
|  |  | 
|  | syslinux_iso_populate() { | 
|  | iso_dir=$1 | 
|  | syslinux_populate $iso_dir ${ISOLINUXDIR} isolinux.cfg | 
|  | install -m 0644 ${STAGING_DATADIR}/syslinux/isolinux.bin $iso_dir${ISOLINUXDIR} | 
|  | install -m 0644 ${STAGING_DATADIR}/syslinux/ldlinux.c32 $iso_dir${ISOLINUXDIR} | 
|  | } | 
|  |  | 
|  | syslinux_hddimg_populate() { | 
|  | hdd_dir=$1 | 
|  | syslinux_populate $hdd_dir ${SYSLINUXDIR} syslinux.cfg | 
|  | install -m 0444 ${STAGING_DATADIR}/syslinux/ldlinux.sys $hdd_dir${SYSLINUXDIR}/ldlinux.sys | 
|  | } | 
|  |  | 
|  | syslinux_hddimg_install() { | 
|  | syslinux ${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.hddimg | 
|  | } | 
|  |  | 
|  | syslinux_hdddirect_install() { | 
|  | DEST=$1 | 
|  | syslinux $DEST | 
|  | } | 
|  |  | 
|  | python build_syslinux_cfg () { | 
|  | import copy | 
|  | import sys | 
|  |  | 
|  | workdir = d.getVar('WORKDIR', True) | 
|  | if not workdir: | 
|  | bb.error("WORKDIR not defined, unable to package") | 
|  | return | 
|  |  | 
|  | labels = d.getVar('LABELS', True) | 
|  | if not labels: | 
|  | bb.debug(1, "LABELS not defined, nothing to do") | 
|  | return | 
|  |  | 
|  | if labels == []: | 
|  | bb.debug(1, "No labels, nothing to do") | 
|  | return | 
|  |  | 
|  | cfile = d.getVar('SYSLINUX_CFG', True) | 
|  | if not cfile: | 
|  | raise bb.build.FuncFailed('Unable to read SYSLINUX_CFG') | 
|  |  | 
|  | try: | 
|  | cfgfile = file(cfile, 'w') | 
|  | except OSError: | 
|  | raise bb.build.funcFailed('Unable to open %s' % (cfile)) | 
|  |  | 
|  | cfgfile.write('# Automatically created by OE\n') | 
|  |  | 
|  | opts = d.getVar('SYSLINUX_OPTS', True) | 
|  |  | 
|  | if opts: | 
|  | for opt in opts.split(';'): | 
|  | cfgfile.write('%s\n' % opt) | 
|  |  | 
|  | cfgfile.write('ALLOWOPTIONS 1\n'); | 
|  | syslinux_default_console = d.getVar('SYSLINUX_DEFAULT_CONSOLE', True) | 
|  | syslinux_serial_tty = d.getVar('SYSLINUX_SERIAL_TTY', True) | 
|  | syslinux_serial = d.getVar('SYSLINUX_SERIAL', True) | 
|  | if syslinux_serial: | 
|  | cfgfile.write('SERIAL %s\n' % syslinux_serial) | 
|  |  | 
|  | menu = (d.getVar('AUTO_SYSLINUXMENU', True) == "1") | 
|  |  | 
|  | if menu and syslinux_serial: | 
|  | cfgfile.write('DEFAULT Graphics console %s\n' % (labels.split()[0])) | 
|  | else: | 
|  | cfgfile.write('DEFAULT %s\n' % (labels.split()[0])) | 
|  |  | 
|  | timeout = d.getVar('SYSLINUX_TIMEOUT', True) | 
|  |  | 
|  | if timeout: | 
|  | cfgfile.write('TIMEOUT %s\n' % timeout) | 
|  | else: | 
|  | cfgfile.write('TIMEOUT 50\n') | 
|  |  | 
|  | prompt = d.getVar('SYSLINUX_PROMPT', True) | 
|  | if prompt: | 
|  | cfgfile.write('PROMPT %s\n' % prompt) | 
|  | else: | 
|  | cfgfile.write('PROMPT 1\n') | 
|  |  | 
|  | if menu: | 
|  | cfgfile.write('ui vesamenu.c32\n') | 
|  | cfgfile.write('menu title Select kernel options and boot kernel\n') | 
|  | cfgfile.write('menu tabmsg Press [Tab] to edit, [Return] to select\n') | 
|  | splash = d.getVar('SYSLINUX_SPLASH', True) | 
|  | if splash: | 
|  | cfgfile.write('menu background splash.lss\n') | 
|  |  | 
|  | for label in labels.split(): | 
|  | localdata = bb.data.createCopy(d) | 
|  |  | 
|  | overrides = localdata.getVar('OVERRIDES', True) | 
|  | if not overrides: | 
|  | raise bb.build.FuncFailed('OVERRIDES not defined') | 
|  |  | 
|  | localdata.setVar('OVERRIDES', label + ':' + overrides) | 
|  | bb.data.update_data(localdata) | 
|  |  | 
|  | btypes = [ [ "", syslinux_default_console ] ] | 
|  | if menu and syslinux_serial: | 
|  | btypes = [ [ "Graphics console ", syslinux_default_console  ], | 
|  | [ "Serial console ", syslinux_serial_tty ] ] | 
|  |  | 
|  | root= d.getVar('SYSLINUX_ROOT', True) | 
|  | if not root: | 
|  | raise bb.build.FuncFailed('SYSLINUX_ROOT not defined') | 
|  |  | 
|  | for btype in btypes: | 
|  | cfgfile.write('LABEL %s%s\nKERNEL /vmlinuz\n' % (btype[0], label)) | 
|  |  | 
|  | exargs = d.getVar('SYSLINUX_KERNEL_ARGS', True) | 
|  | if exargs: | 
|  | btype[1] += " " + exargs | 
|  |  | 
|  | append = localdata.getVar('APPEND', True) | 
|  | initrd = localdata.getVar('INITRD', True) | 
|  |  | 
|  | append = root + " " + append | 
|  | cfgfile.write('APPEND ') | 
|  |  | 
|  | if initrd: | 
|  | cfgfile.write('initrd=/initrd ') | 
|  |  | 
|  | cfgfile.write('LABEL=%s '% (label)) | 
|  | append = replace_rootfs_uuid(d, append) | 
|  | cfgfile.write('%s %s\n' % (append, btype[1])) | 
|  |  | 
|  | cfgfile.close() | 
|  | } |