4

我想找到一种方法来从 .bbappend 文件对 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

这种事情是否可以在 .bbappend 文件(或其他分隔方式)中进行?我找到了一种在 .inc 文件中使用ROOTFS_POSTPROCESS_COMMAND我的核心图像执行此操作的方法,但这种方法会导致组织结构不佳。

4

2 回答 2

2

也许将操作移至.bbappend 中的安装后功能适合您的情况?

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 操作在首次启动时执行,而不是在构建期间执行。

于 2015-12-21T22:21:07.003 回答
1

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

于 2016-01-12T15:56:20.330 回答