我应该如何在Yocto生成的rootfs上使用sed文件



我想找到一种方法,从.bappend文件在Yocto生成的操作系统中的文件上运行sed脚本。我的操作系统有一个只读的rootfs,它似乎可以阻止安装后脚本的任何可能性。具体来说,我需要对/etc/default/ssh(在引导生成的操作系统后运行)进行以下更改:

sed -i 's/var/run/etc/' /etc/default/ssh 
sed -i 's/_readonly//' /etc/default/ssh

这是我为解决这些问题而创建的openssh_7.1p1.bbappend

FILESEXTRAPATHS_prepend := "${THISDIR}/files:"
SRC_URI += " 
    file://ssh_host_dsa_key.pub  
    file://ssh_host_rsa_key.pub  
    ...
    "
do_install_append() {
    sed -i 's/var/run/etc/' ${D}${sysconfdir}/default/ssh
    sed -i 's/_readonly//' ${D}${sysconfdir}/default/ssh
    # these lines work fine
    install -m 0755 ${WORKDIR}/ssh_host_dsa_key          ${D}/etc/ssh
    install -m 0755 ${WORKDIR}/ssh_host_dsa_key.pub      ${D}/etc/ssh
    ...
}
FILES_${PN} += "${sysconfdir}/default/ssh"
#these lines work
FILES_${PN} += "${sysconfdir}/ssh/ssh_host_dsa_key"
FILES_${PN} += "${sysconfdir}/ssh/ssh_host_dsa_key.pub"
...

BitBake在执行do_install_append()时失败,出现以下错误:

sed: can't read ${TMPDIR}/work/x86-poky-linux/openssh/image/etc/default/ssh: No such file or directory

(其中TMPDIR是我实际的tmp目录)显然,这个文件不存在,因为正确的副本是由image.bbclass.在一个单独的MULTIMACH_TARGET_SYS目录(即不是x86-poky-linux)中创建的

这类事情可以在.bappend文件(或其他分区方式)中完成吗?我已经找到了一种方法,可以在我的core-image中使用ROOTFS_POSTPROCESS_COMMAND的.inc文件中实现这一点,但这种方法会导致较差的组织结构。

也许将操作转移到.bappend中的安装后函数适合您的情况?

pkg_postinst_${PN} () {
    #!/bin/sh
    if [ x"$D" = "x" ]; then
        sed -i 's/var/run/etc/' /etc/default/ssh 
        sed -i 's/_readonly//' /etc/default/ssh
    else
        exit 1
    fi
}

上面的函数将导致sed操作在第一次启动时执行,而不是在构建期间执行。

在SRC_URI变量中包含您尝试sed的文件。

最新更新