IMX6ULL-开机启动ssh卡顿

1. 问题现象

i.MX6ULL平台,在调试过程中出现sshd在开机自启动的过程中卡顿现象(等待时间较久),观察打印信息发现,sshd一定等待直到以下代码出现才能正常启动。

random:nonblocking pool is initialized

在此过程中,nonblocking pool 的初始化要 2 分钟。而启动sshd并不需要等待nonblockingpool 初始化。

2. 问题解决

可以通过加速nonblockingpool的初始化速度从而解决sshd启动过慢的问题,具体做法修改内核代码。

在kernel_code/drivers/char/random.c 约 900 行处的voidadd_interrupt_randomness(int irq, int irq_flags) 中有一处判断。

if((fast_pool->count < 64) &&

!time_after(now, fast_pool->last + HZ))

return;

在此基础上加上nonblocking_pool.initialized判断。

if((fast_pool->count < 64) &&

!time_after(now, fast_pool->last + HZ)&&

nonblocking_pool.initialized)

return;

内核加上以上修改后重新编译内核并烧写,开机时sshd就可以正常启动了。

另外,记得在/etc/ssh/sshd_config 下打开PermitRootLogin yes 释放 root 权限登录。

相关推荐
哼?~6 小时前
Linux文件操作--IO
linux
JHC_binge7 小时前
国内Ubuntu 22.04 LTS安装Milvus向量数据库
java·linux·ubuntu
wxmtwfx7 小时前
Linux内核GPIO工具概述
linux·驱动开发·gpio
松涛和鸣7 小时前
DAY69 Practical Guide to Linux Character Device Drivers
linux·服务器·arm开发·数据库·单片机·嵌入式硬件
程序猿编码7 小时前
实战Linux内核模块:终止ptrace跟踪程序与被跟踪进程
linux·网络·内核·内核模块·ptrace
GHL2842710907 小时前
TeamTalk-msg_server学习
运维·服务器·c++·学习
咩咩不吃草7 小时前
Linux环境下MySQL的安装与使用与Navicat
linux·运维·数据库·mysql·navicat
李钢蛋7 小时前
使用 SSH 隧道安全连接远程 MongoDB
安全·mongodb·ssh
好好学习天天向上~~7 小时前
3_Linux学习总结_基础指令
linux·服务器·学习
星夜落月7 小时前
从零部署Wallos:打造专属预算管理平台
服务器·前端·网络·建站