香橙派5plus单独编译内核安装时的报错记录

1.问题描述

  • 香橙派核编译和安装分为如下四部:

    bash 复制代码
    #  第1步:配置内核(orangepi5plus_linux_defconfig是我自己保存的配置文件)
    make orangepi5plus_linux_defconfig
    #  第2步:编译内核
    make -j10
    #  第3部:安装内核模块
    sudo make modules_install
    #  第4部:安装内核镜像
    sudo make install
  • 在执行到第4步时出现如下报错

    bash 复制代码
    orangepi@orangepi5plus:~/work/linux-orangepi$ sudo make install
    INSTALL /boot
    run-parts: executing /etc/kernel/postinst.d/dkms 6.1.99 /boot/vmlinuz-6.1.99
    * dkms: running auto installation service for kernel 6.1.99                                               	[ OK ] 
    run-parts: executing /etc/kernel/postinst.d/initramfs-tools 6.1.99 /boot/vmlinuz-6.1.99
    update-initramfs: Generating /boot/initrd.img-6.1.99
    update-initramfs: Converting to u-boot format
    run-parts: executing /etc/kernel/postinst.d/unattended-upgrades 6.1.99 /boot/vmlinuz-6.1.99
    run-parts: executing /etc/kernel/postinst.d/xx-initramfs-cleanup 6.1.99 /boot/vmlinuz-6.1.99
    run-parts: executing /etc/kernel/postinst.d/xx-update-initrd-links 6.1.99 /boot/vmlinuz-6.1.99
    run-parts: /etc/kernel/postinst.d/xx-update-initrd-links exited with return code 1
    make: *** [arch/arm64/Makefile:169: install] Error 1
  • 从报错信息可以看出 是在执行脚本 /etc/kernel/postinst.d/xx-update-initrd-links 时返回1并退出

2.问题分析和解决

  • 通过在脚本中加打印的方式发现是在执行 tmp=$(lsblk -f | grep "boot" | grep "vfat")时退出

  • tmp=$(lsblk -f | grep "boot" | grep "vfat") 是查看/boot是否为 vfat 文件系统,如果是则保存分区信息到 tmp变量,否则 tmp变量为空,单独运行一下 lsblk -f,会发现 /boot并没有挂在独立的分区上,也没有 vfat文件系统,这会导致 grep 命令找不带匹配项,从而返回1;又因为脚本中存在 set -e 导致任何命令在返回非零状态都会终止运行。

    bash 复制代码
    orangepi@orangepi5plus:~/work/linux-orangepi$ lsblk -f
    NAME         FSTYPE FSVER LABEL          UUID                                 FSAVAIL FSUSE% MOUNTPOINTS
    mtdblock0                                                                                    
    mmcblk1                                                                                      
    └─mmcblk1p1  ext4   1.0   opi_root       246cb637-ef48-45eb-b006-7e1a612b1b33   51.3G    10% /var/log.hdd
                                                                                             /
    mmcblk0                                                                                      
    └─mmcblk0p1  ext4   1.0   desktop-rootfs 1883fc13-4793-4474-ac53-5209e822531b                
    mmcblk0boot0                                                                                 
    mmcblk0boot1                                                                                 
    zram0                                                                                        [SWAP]
    zram1                                                                          171.2M     1% /var/log
  • 解决办法 :依据前后文 tmp=$(lsblk -f | grep "boot" | grep "vfat")即使没有匹配到合适的内容,将tmp赋空值即可,不应该立即退出,j经验证将set -e删除即可正常安装,如下:

    bash 复制代码
    orangepi@orangepi5plus:~/work/linux-orangepi$ sudo make install
    INSTALL /boot
    run-parts: executing /etc/kernel/postinst.d/dkms 6.1.99 /boot/vmlinuz-6.1.99
    * dkms: running auto installation service for kernel 6.1.99                                               [ OK ] 
    run-parts: executing /etc/kernel/postinst.d/initramfs-tools 6.1.99 /boot/vmlinuz-6.1.99
    update-initramfs: Generating /boot/initrd.img-6.1.99
    update-initramfs: Converting to u-boot format
    run-parts: executing /etc/kernel/postinst.d/unattended-upgrades 6.1.99 /boot/vmlinuz-6.1.99
    run-parts: executing /etc/kernel/postinst.d/xx-initramfs-cleanup 6.1.99 /boot/vmlinuz-6.1.99
    run-parts: executing /etc/kernel/postinst.d/xx-update-initrd-links 6.1.99 /boot/vmlinuz-6.1.99
相关推荐
bush432 分钟前
linux开发板连接virtualbox虚拟机ubuntu的usb网卡,访问外网方法。
linux·运维·ubuntu
小明同学011 小时前
C++后端项目:统一大模型接入 SDK(一)
linux·c++·chatgpt
码农编程录1 小时前
【notes10】spi
linux
楼兰公子2 小时前
网络子系统学习与开发教程
rk3588·net
米高梅狮子2 小时前
03.OpenStack使用
linux·前端·云原生·容器·架构·kubernetes·openstack
实心儿儿2 小时前
Linux —— Linux进程信号 - 信号产生
linux·运维·服务器
楼兰公子2 小时前
RK3588 + Linux 7.0.3 内核网络子系统高阶进阶全解
linux·网络
海天鹰2 小时前
Linux系统4399云游戏无法进入
linux·游戏
文静小土豆2 小时前
CentOS 7 / Kylin Linux V10 升级 OpenSSL 3.6.1 详细教程
linux·centos·kylin
哎呦,帅小伙哦3 小时前
pthread 互斥锁属性:type、pshared 与 robust
linux