IMX6ULL-开机启动ssh卡顿

发表时间:2023-11-07 17:55


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 权限登录。


武汉万象奥科电子有限公司
服务热线:027-59610091
销售邮箱:sales@vanxoak.com
主营产品:ARM核心板、ARM工控板
工业网关、软硬件定制设计
地址:武汉东湖新技术开发区大学园路长城园路8号海容基孵化园B5

扫描二维码
关注公众号
产品及方案咨询
专业专注   合作共赢
移动电话:181 2058 0511 (武汉)
移动电话:186 6503 9557 (广东)
移动电话:133 0386 9667 (江苏)
移动电话:187 3812 7320 (全国)