首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux内核启动参数详解

1.环境: Ubuntu 16.04 Linux linuxidc 4.4.0-89-generic #112-Ubuntu SMP Mon Jul 31 19:38:41 UTC 2017 x86_64...x86_64 x86_64 GNU/Linux 2.查看当前linux内核启动参数: cat /proc/cmdline 笔者的输出内容如下: BOOT_IMAGE=/boot/vmlinuz-4.4.0...-4202-4513-b39b-cde6a5d9753f :这一串可以用root=/dev/sda1(假如根文件系统在第一个分区)来代替,但是不能用root=(hd0,msdos1)来代替 ro : 启动时以只读方式挂载根文件系统...所以去掉此项将会迎来很多打印信息 splash: 显示开机动画 vt.handoff=7 : 图形界面会去使用tty7,此项用来禁止splash占用tty7,因此如果将splash参数去掉,此项就无效了 4.添加新的启动参数...update-grub命令无法满足更细致的内核参数修改需求

5.5K20

linux内核移植步骤「建议收藏」

2016.6.8 经过一个多星期的内核折磨,今天终于可以写下自己移植内核的一些心得,网上有很多博客论坛都有谈到,但是这些又说的方式有些模糊,这里我综合的几个博客在重新说下内核替换编译的步骤、以及如何更新启动项.../grub 将hidden两行代码注释掉,这样开机启动的grub就会出现,可以由你选择改启动哪个内核版本。.../grub.cfg 手动修改,按照原来内核的格式进行修改,只用修改新内核的名字而已。 12、重启电脑,在previous version中选择启动新编译的内核,成功进入系统。...方式二:下载内核安装包deb,进行升级替换 首先必须说明的是,这种方式我尝试了两台电脑,两个不同的内核升级,均为成功,原因不详: 具体步骤简单如下: 1.下载deb包 在 http://kernel.ubuntu.com...3.更新启动项grub 按照上述的步骤9开始,与上面一样。更新完了grub.cfg,然后重新启动,进行新的内核即可 测试按照这种步骤进行,但是开机进入之后直接紫屏,没有任何现象,原因不明!!!

4.1K31
您找到你想要的搜索结果了吗?
是的
没有找到

Linux系统修改默认内核启动顺序

grub2-set-default "CentOS Linux (3.10.0-123.9.3.el7.x86_64) 7 (Core)" 3、执行如下命令,确认配置成功。...2、在grub.conf文件中决定开机使用哪个内核版本做启动的参数是default,默认值为0,代表从最新的内核启动。代表启动内核版本从上往下依次是0、1、2等。...3、如果要选择从旧版内核,即系统最开始的内核启动,则把default值改为1 ,然后重启服务器从新的内核进行引导。...三、centos8修改内核启动顺序 1、查看默认内核 grubby --default-kernel 2、 查看所有内核 grubby --info=ALL 3、修改默认启动内核 grubby --set-default...=0 ##修改为 GRUB_DEFAULT="Advanced options for Ubuntu>Ubuntu, with Linux 4.4.0-31-generic" 3、更新修改后的grub

8.5K20

linux内核离线升级步骤详解【亲测可用】

由于种种原因,linux内核版本需要升级,但由于生产原因往往不能在线升级,在此记录笔者本人昨晚的的离线升级步骤,亲测可用。 我们知道,红帽和CentOS同源同宗,内核升级步骤也是一样的。...■ Red Hat / CentOS 7最新内核下载 内核版本 5.4.214 于 2022-9-18 发布,lt 是指长期支持版本 long term wget https://mirrors.aliyun.com...Linux (0-rescue-6d425900e59b4ef18c98680ce9a348dd) 7 (Core) 可见已有多个内核,包括原内核 1 与新安装的内核 0 ■ 内核配置 新内核安装后,需修改...os已有的内核启动顺序,默认启动的顺序应该为1,升级以后内核是往前面插入为0,则需设置GRUB_DEFAULT=0。...5.4.214-1.el7.elrepo.x86_64 ■ 在 CentOS 7.6 测试内核升级 root@node3:0 ~# cat /etc/*release CentOS Linux release

2.4K20

linux内核启动流程分析 - efi_main

上一篇文章 linux内核启动流程分析 - efi_stub_entry 中,为了叙述方便,我们只是粗略的讲了下efi_main函数,这里我们再具体看下。 ?...有关boot_params的创建及其hdr的初始化,我们在 linux内核启动流程分析 - efi_pe_entry 中有讲到,这里就不再赘述。 继续看该函数的其余部分。 ?...而710行中的image_offset是kernel在内存的起始地址到compressed部分起始地址(startup_32的地址)的偏移量,这个在 linux内核启动流程分析 - efi_pe_entry...linux内核构建结束后,最终生成的文件是 arch/x86/boot/bzImage,这其实是个压缩过的内核,在kernel启动过程中,还要在内存中对内核进行解压,进而得到真正的内核。...综上可知,712行中的buffer_end表示的是kernel在启动过程中,需要使用的内存的结束地址。 714到717行是一些条件判断,在这些条件下,需要拷贝内存中的内核到合适的位置上。

3.6K30

Linux启动时间优化-内核和用户空间启动优化实践

启动时间的优化,分为两大部分,分别是内核部分和用户空间两大部分。...从内核timestamp 0.000000作为内核启动起点,到free_initmem()输出"Freeing init memory"作为内核启动的终点。...内核启动优化 在内核源码中自带了一个工具(scripts/bootgraph.pl)用于分析启动时间,这个工具生成output.svg。...1.1.3 对bootgraph.py的改进 1.1.3.1 划分内核启动的起点终点 界定内核启动的起点很容易,从时间0开始。...Linux启动从进入内核那一刻开始,到用户空间达到可用状态。 这个可用状态定义可能不一致,有的是进入shell,有的是弹出登陆框。但只要有一个固定的终点,就有了优化目标。

61430

Linux启动引导程序(GRUB)加载内核的过程

我们知道启动引导程序(Boot Loader,也就是 GRUB)会在启动过程中加载内核,之后内核才能取代 BIOS 接管启动过程。如果没有启动引导程,那么内核是不能被加载的。...本节,我们就来看看启动引导程序加载内核的过程,当然 initramfs 这个虚拟文件系统也是要靠启动引导程序调用的。...GRUB加载内核的过程GRUB 的作用有以下几个:加载操作系统的内核;拥有一个可以让用户选择的的菜单,来选择到底启动哪个系统;可以调用其他的启动引导程序,来实现多系统引导。...那么 Linux 的解决办法是把 GRUB 的程序分成了三个阶段来执行。...接下来内核就可以接管启动过程,继续自检与加载硬件模块了。

31620

linux内核启动流程(文章最后流程图)

原文:linux内核启动流程 本文以Linux3.14版本源码为例分析其启动流程。各版本启动代码略有不同,但核心流程与思想万变不离其宗。 内核映像被加载到内存并获得控制权之后,内核启动流程开始。...通过linux/arch/arm/boot/compressed目录下的Makefile寻找到vmlinux文件的链接脚本(vmlinux.lds),从中查找系统启动入口函数。...得到内核入口函数为 stext(linux/arch/arm/kernel/head.S) 内核引导阶段 ENTRY(stext) 。 。 。...部分书籍介绍的内核启动流程基于经典的2.6版本,kernel_init函数还会调用init_post函数专门负责_init进程的启动,现版本已经被整合到了一起。...当内核被引导并进行初始化后,内核启动了自己的第一个用户空间应用程序_init,这是调用的第一个使用标准C库编译的程序,其进程编号时钟为1.

1.6K30

linux内核启动流程分析 - efistub的入口函数

最近打算写一个系列文章,主要讲linux内核启动流程。 网上类似标题的文章很多,但大都是从start_kernel讲起,我觉得这是远远不够的。...linux内核启动方式有非常多种,大方向来看分为bios和uefi,在此基础上又有各种各样的boot loader,比如我们常见的grub,它们会根据配置信息,加载linux内核到内存,并通过一定的协议来启动...它的实现原理是,按照 uefi 指定的 pecoff 格式,将内核伪装成一个 uefi application,这样在支持 uefi 的各种硬件上,就可以按照 uefi 协议,直接启动linux内核了。...这样,当linux内核以 uefi application 的形式,被 uefi 直接启动时,被执行的第一行代码就是这个方法。...或者说,在 uefi 平台上,以 efi stub形式启动内核时,开机后内核执行的第一个方法就是该方法。 以这里为起点,我们就可以开始探索linux内核的完整启动流程了。

3.3K30

ARM Linux 启动时的自解压过程 | Linux 内核

OK,Let's go. ---- ARM Linux 一般都使用压缩的内核,例如 zImage。 这样做有两个主要原因: 1、节省存放内核的闪存或其他存储介质的空间。...例如从 NAND Flash 加载内核,就是一种很典型的情况。 本文将对 ARM Linux 的自解压过程进行一个简单介绍。...2002 年,Russell King 就在 Booting ARM Linux 文档中定义了 Booloader 引导 Linux 内核的 ABI。...另外还需要额外的空间,是因为当内核最终启动时,它将从该地址中减去 0x4000(或 LPAE 的 0x5000),并将初始内核页表 (initial kernel page table) 存储在那里。...这意味着将再次设置栈和 malloc() 区域并查找附加的 DTB,一切看起来就像内核第一次加载到此位置一样开始。(但有一个区别:我们已经用 ATAG 扩充了 DTB,因此不会再重复次步骤了。)

2.7K10

Linux】《how linux work》第五章 Linux内核启动过程

How the Linux Kernel Boots(第5章 Linux内核启动过程) You now know the physical and logical structure of a Linux...你现在已经了解了Linux系统的物理和逻辑结构,知道了内核是什么,以及如何处理进程。 本章将教你内核是如何启动的。换句话说,你将学习内核如何将自己加载到内存中,直到第一个用户进程开始运行的过程。...当遇到无法理解的参数时,Linux内核会保存该参数。内核在执行用户空间启动时会将该参数传递给init。例如,如果您添加了-s到内核参数中,内核会将-s传递给init程序,表示应该以单用户模式启动。...您会发现grub.cfg文件由一系列GRUB命令组成,通常以一系列初始化步骤开始,然后是一系列不同内核和引导配置的菜单条目。...GRUB 执行启动命令,加载并执行配置的 linux 命令指定的内核

27010
领券