发现问题
在用buildroot 构建 imx6ull 根文件系统添加 ssh 的时候,发现 sshd 在开机自启的时候占用了很长的一段时间,仔细观察打印信息发现,sshd 一定要等待直到
random: nonblocking pool is initialized
初始化结束后才能正常启动,而 nonblocking pool 的初始化要 2 分钟。
解决问题
加速 nonblocking pool的初始化速度从而解决 sshd 启动过慢的问题。具体做法是修改内核代码,
在 kernel_code/drivers/char/random.c 约 900 行处的void add_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 可以正常启动。详见:
https://lore.kernel.org/patchwork/patch/578584/
另外,记得在 /etc/ssh/sshd_config 下打开 PermitRootLogin yes 释放 root 权限登录。
注意:本文内核版本是4.1.15
产品介绍
https://seeker.taobao.com/?spm=a1z10.1-c.0.0.7d5168c7uuY6Si