tag 标签: kernel

相关博文
  • 热度 3
    2023-9-26 17:14
    2078 次阅读|
    0 个评论
    1. Kernel 手动编译 1.1 kernel 查询帮助 使用./build.sh-hkernel查看kernel的详细编译命令如下所示。 图 1.1 编译内核 上图表示,单独编译kernel固件分为三步,进入kernel目录,选择默认配置文件,编译镜像。 1.2 kernel 默认配置 对应平台的默认配置文件由 ./build.shlunch 操作中选择的 mk 文件决定,如下所示。 图 1.2 选择 SDK 配置文件 配置完后,直接查看 device/rockchip/rk356x/BoardConfig-rk3568-evb1-ddr4-v10.mk 文件,由 RK_KERNEL_DEFCONFIG 和 RK_KERNEL_DEFCONFIG_FRAGMENT 决定,如下所示。 图 1.3 配置文件 Kernel 部分内容 另外还有 RK_KERNEL_DTS 指定配置的设备树。 1.3 kernel 修改配置 首先导入上面指定的默认配置,操作命令如下: cdkernel makeARCH=arm64rockchip_linux_defconfig 进入 menuconfig 修改内核,命令如下所示。 makeARCH=arm64menuconfig 进入配置界面如下所示。 图 1.4 内核配置 输入“ / ”可以进入 menuconfig 的搜索功能,如下所示。 图 1.5 内核查找配置 搜索功能可在复制的配置路径中快速寻找到所需的目标配置,例如输入“ dhcp ”查看该选项的描述,如下所示。 图 1.6 目标配置帮助 选项名为 IP_PNP_DHCP ,在 menuconfig 的名称由 Prompt 指定,选项配置的路径由 Location 指定,选项的依赖关系由 Dependson 指定。 使用空格键可以修改配置,按 ESC 键可以退出 menuconfig 。 1.4 kernel 保存默认配置 输入以下命令可以覆盖默认配置。 makeARCH=arm64savedefconfig cpdefconfigarch/arm64/configs/rockchip_linux_defconfig 注:建议覆盖前备份一下原始rockchip_linux_defconfig. 1.5 kernel 编译固件 进入 kernel 目录,输入以下命令单独编译内核固件。 makeARCH=arm64rk3568-evb1-ddr4-v10-linux.img-j12 内核的编译结果如下所示。 图 1.7 编译完成打印 由此看出,内核固件组成部件为: resource.img (由设备树文件 dtb 、 logo 图片组成的) +Image (内核代码)。 1.6 kernel 编译模块 输入以下命令可独立编译 ko 文件。 makeARCH=arm64modules
  • 热度 16
    2016-1-4 11:31
    1124 次阅读|
    0 个评论
    By Toradex Stefan Agner 有些应用对系统启动时间有着特殊的要求。在很多场合下,这些系统并不需要针对所有任务立即就位,但是针对某些关键任务(例如接收以太网命令或者显示用户界面)则必须能够应对。本文将提供一些方法和简单的步骤,以 Toradex 计算机模块为例去优化启动时间。 提示: 文中涉及到的部分方法需要重新编译 U-boot、内核以及文件系统。请参考Toradex 开发者中心网站 上的相关文章。 在开始动手优化之前, 我们需要一个合适的方法来测量启动时间。如果想要十分精准地测量启动时间,这甚至需要牵涉到硬件(例如 GPIO 和示波器)。在绝大多数场合下,通过监控系统串口控制台输出已经是相当准确了。Tim Bird 的 grabserial 是一个广泛使用的工具,可以用于查看串口控制台输出的时间信息。这个工具能够为收到的每一行信息添加上时间戳,如下面所示: ---------------------------------------------------------------------------- $ ./grabserial -d /dev/ttyUSB1 -t U-Boot 2015.04-00006-g6762920 (Oct 12 2015 - 15:35:50) CPU: Freescale Vybrid VF610 at 500 MHz Reset cause: POWER ON RESET DRAM:  256 MiB NAND:  512 MiB MMC:   FSL_SDHC: 0 ---------------------------------------------------------------------------- 第一列数字代表时间戳(从收到第一个字符算起),第二行代表的是收到当前一行和上一行信息之间的时间间隔。 该文章基本上适用于所有我们的模块产品。然而,这其中我所使用的方法和改进之处中确实有一些是针对基于 Freescale Vybrid 的 Colibri VF61 模块。 Linux 系统的启动,主要可以分为以下 3 个阶段,文章将逐一讨论。 Boot loader Linux kernel User space (init system)   Boot loader 实际上在 boot loader 启动之前,还有两个步骤:硬件初始化和 boot ROM。硬件初始化需要满足电源上电顺序以及总线和处理器芯片复位时序要求。这个阶段的耗时一般是固定的,在 10 ~ 200 ms。ARM 处理器从位于内部的 ROM 上启动固件。该固件从启动介质上加载 boot loader。该阶段的时间一般很短,取决于 boot loader 的大小。除了减小 boot loader 体积,很难做其他的优化。实际上能够做的优化和调整还是在 boot loader (U-Boot)。 目前Toradex发布Embedded Linux V2.5 Beta 1 版本,从第一个字符输出到内核启动的时间约为 1.85 秒。主要涉及以下过程: U-Boot 初始化(约 110ms,从接收到的第一个字符算起) Autoboot delay(1s) UBI 初始化和 UBIFS 挂载(约 300ms,得益于 Fastmap 功能,不使用该功能将耗时 1.6s) 内核加载(375ms) 加载和应用 device tree(约 35ms) 最后跳转至内核起始地址 --- Boot time to Kernel start: ~1850ms 首先最显著的优化就是降低 Autoboot delay 。这个值可以使用下面的命令设置为 0: ---------------------------------------------------------------------------- setenv bootdelay 0 saveenv ---------------------------------------------------------------------------- 这个也可以使用 CONFIG_BOOTDELAY 将其配置为默认值。在目前的发布版本中,如果将 bootdelay 设置为 0,那么将会没有办法直接进入 boot loader 的命令行模式。U-Boot 提供一个选项 CONFIG_ZERO_BOOTDELAY_CHECK,在 bootdelay 为 0 的情况下,用于检测一个字符。我们已经将其添加到下一个发布版本的默认配置中。 --- Boot time to Kernel start with this improvement: ~860ms 串口输出是同步发送的。这意味着 CPU 将等待,直到字符通过在串口线上发送完毕。因此,每一个输出的字符都将减慢 U-Boot 的启动。特别是 UBI 将会输出大量的信息,这是一个可以优化的地方。有一个配置符号 CONFIG_UBI_SILENCE_MSG 可以实现这个目的。 --- Boot time to Kernel start with this improvement: ~800ms 为了确保尽可能高效地使用硬件,需要深入了解硬件的功能以及目前实现的方法。目前还没有被使用的功能是 Level 2 Cache(仅 Colibri VF61)。在开启 Level 2 cache 后,启动时间可以提高 40 ms。 --- Boot time to Kernel start with this improvement: ~760ms 移除一些功能有助于减少分配时间和初始化这些功能的时间。例如可以移除显示支持 (DCU),EXT3 和 EXT4 支持以及 USB 外设驱动如 DFU 和 存储设备。这可以将 U-Boot 尺寸减小到 366 KB,同时节省 10 ms 时间。 --- Boot time to Kernel start with this improvement: ~750ms 根据显示的时间戳,绝大多数的时间被用于加载 UBI 和挂载 UBIFS 以及内核的加载(约 380ms)。显然内核大小和加载时间具有线性关系,因此,优化内核尺寸将可以进一步提高启动时间。   Kernel 为了只测量内核启动的时间,可以使用 grabserial 的匹配功能重置 boot loader 输出信息中的时间。 ---------------------------------------------------------------------------- ./grabserial -d /dev/ttyUSB1 -t -m "^Starting kernel.*" ---------------------------------------------------------------------------- 启动结束的时间多少有点难以确定,因为内核将会继续初始化硬件,即使文件系统已经挂载和第一个用户空间进程(init)开始运行(延时初始化)。 “Freeing unused kernel memory” 是 init 进程启动前发出的最后消息,因此将其标记为内核线性任务的结束(请查看 kernel_init in init/main.c)。我将会使用这个信息的时间戳来比较启动时间。我们模块上默认内核的压缩尺寸为 4316 KB,启动时间为 2.56 秒。 --- Kernel boot time to Init start: 2.56s 同 U-Boot 一样,Linux 内核也是同步地将信息发送到串口。具体的方法取决于所使用的串口,LPUART( Vybrid 的 console 驱动)会同步等待直到字符在串口上发送完毕。这个的优点在于,当内核崩溃的时候,那个时候的所有信息都是可见的。假如信息是异步输出,最后输出的信息将不 会指示内核所崩溃的地方。 内核中有一个参数,可以最大限度减少输出的信息:“Quiet”。然而,这也将屏蔽我们测试启动时间的字符信息(“Freeing unused kernel memory”)。最简单的方法输出这些信息是利用日志级别输出特定的信息。在 'mm/page_alloc.c' 中搜索 “Freeing %s memory”。我将使用 ‘pr_alert’ 输出信息。这个方法整整缩短了启动时间1.55 秒! --- Kernel boot time to Init start with this improvement: ~1.01s 进一步提高启动时间的另一个简单的方法是移除功能。Yocto 项目提供了一个方便的工具 ksize.py,这个需要在内核编译目录中运行。这个工具能够显示内核各个部分的大小。第一个表格显示了大致的概况(为了获得准确的概况, 编译之前使用 make clean)。 ---------------------------------------------------------------------------- Linux Kernel              total |       text       data        bss ------------------------------------------------------------------- vmlinux                 8305381 |    7882273     247732     175376 drivers/built-in.o      2010229 |    1881545     109796      18888 fs/built-in.o           1944926 |    1911100      19422      14404 net/built-in.o          1477404 |    1398316      44832      34256 kernel/built-in.o        628094 |     514935      17099      96060 sound/built-in.o         326322 |     316298       8248       1776 mm/built-in.o            288456 |     276492       8000       3964 lib/built-in.o           160209 |     157659        217       2333 block/built-in.o         137262 |     133614       2420       1228 crypto/built-in.o        104157 |     100063       4082         12 security/built-in.o       37391 |      36303        788        300 init/built-in.o           31064 |      16208      14772         84 ipc/built-in.o            29366 |      28640        722          4 usr/built-in.o              138 |        138          0          0 ------------------------------------------------------------------- sum                     7175018 |    6771311     230398     173309 delta                   1130363 |    1110962      17334       2067 ---------------------------------------------------------------------------- 可以被安全移除的一般是应用相关的功能。浏览各个第一层目录,有助于快速确定最可能移除的对象。为了文中的演示,我移除了部分文件系统(cifs, nfs, ext4, ntfs)、音频子系统、多媒体支持、USB 以及无线网络适配器支持。内核最后缩减到 3356 KB,比原来将近小了 1MB。这也减少了约 85ms 的内核加载时间。 --- Kernel boot time to Init start with this improvement: ~0.90s 另外一个提高启动时间的方法可以是使用不同的压缩算法,尽管目前我们内核配置中默认算法 LZO已经很高效了。   User Space 在 Linux 用户空间,初始化工作由 init 系统完成。 Toradex BSP 镜像使用 Ångströ标准启动 init 系统,其称为 Systemd。Systemd 目前已成成为桌面 Linux的标准 init 系统,具有丰富的功能,特别是为动态系统所设计。Systemd 同样会影响启动时间。多个守护进程可以用同时启动(利用现在的多核系统); socket activation支持延时加载服务,同时device activation支持按需启动服务。此外,集成的日志守护进程 journald 由于使用二进制日志文件和完善的日志文件管理可以节省空间。 根据实际应用,一个嵌入式系统可能是相当静态的。因此,并不需要 Systemd 的动态功能。不幸的是,Systemd 并不是一个很模块化的系统,各个模块之间由相互依赖关系。这使得精简 Systemd 变得困难。这一节将分文两部分,第一部分使用 Systemd 启动优化技术,第二部分会使用 System V 和其他技术。 在这两部分中,我们使用 “Freeing unused kernel memory” 作为测量基准时间。 ---------------------------------------------------------------------------- ./grabserial -d /dev/ttyUSB1 -t -m "^\ 0-9.]* Freeing unused kernel memory.*" ----------------------------------------------------------------------------   Systemd 在本文中,我们定义串口输出上的 login shell 作为关键任务。login shell 定义为 “Type=Idle”,根据定义它将在所有服务启动后立即运行。 为了启动一个没有界面或者基于 framebuffer 的应用,一般需要创建一个新的服务。Systemd 允许定义服务运行之前所需的条件(例如 Network 中 “Wants=network-online.target”)以及自动确保当所需的条件满足之后服务能够启动。然而,因为这些服务是同时启动的,所以 CPU 资源需要在它们之间共享。但是应用仍有可能在串口控制台可用之前就开始启动和运行。因此,下面的数字有可能更高。 --- User space boot time to Login without improvements: ~8.6s 内核参数中的 quiet,同样也适用于 Systemd。这个有助于减少 Systemd 的启动时间大约 1.6 秒。 --- User space boot time to Login with this improvement: ~6.5s Systemd 提供了 systemd-analyze 工具,当使用 “blame” 时,能够打印出各个服务以及其启动的时间。这个可以发现最消耗启动时间的服务。但是,其中的值可能具有迷惑性,因为测量的时间是实际流逝的时间。服务有可能处于睡眠状态,这时的 CPU 其实在处理其他任务。所以在列表顶部的服务不一定是最耗时的,特别是在单核心系统上。 服务可以使用 disable 命令来关闭。有些服务(特别是 Systemd 自身提供的)可能需要掩码才能关闭它们。另外有一些可能是系统运行所需的。因此,在关闭服务时需要特别小心,而且一次只能处理一个。在本文中,下面的服务已经被关闭: ---------------------------------------------------------------------------- systemctl disable usbg systemctl disable connman.service # replaced with networkd systemctl mask alsa-restore.service ---------------------------------------------------------------------------- --- User space boot time to Login with this improvement: ~6.1s Systemd 自带的系统日志守护进程为journald。这是一个不应该完全被禁用的组件之一。在启动的时候,日志守护进程需要管理和删除在磁盘上的旧文件,以及写入新文件。通过禁止将日志写入磁盘,可以提供启动时间,代价是日志文件将不会被保存。配置 /etc/systemd/journald.conf 中的 Storage=none,禁用日志保存。 --- User space boot time to Login with this improvement: ~5.6s   System V init 和其他方法 在很长一段时间内,Linux 也使用 SysV 作为标准的 init 系统。由于基于脚本模式,使得SysV是模块化的,并且可以相对容易进行精简,特别是针对不需要systemd的device activation或socket activation的相对静态的系统。此时,SysV 是另一个很好的选择。 在我另一篇博文《 The Yocto Project's Reference Distribution“Poky”on Toradex Hardware 》中提到的 Yocto 项目参考发布版本“Poky”就默认使用了 SysV。通过使用“minimal-console-image”和静态 IP 配置,Colibri VF61 上用户空间启动时间约为 2.3 s。 --- User space boot time to Shell with System V: ~2.3s meta-yocto 层同样提供“poky-tiny”,其使用 shell 脚本作为 init 系统。只要用 “poky-tiny” 替换Yocto标准发布版本并重新编译镜像,例如“console-image-minimal”。该版本原本用作 initramfs,然而,通过移除 conf/distro/poky-tiny.conf 文件中的 MACHINE_ESSENTIAL_EXTRA_RDEPENDS、IMAGE_FSTYPES 和 PREFERRED_PROVIDER_virtual/kernel,我们能够编译可用的 UBIFS 镜像。然后你需要创建新的distribution layer并复制配置文件,使得该版本拥有可烧写的root文件系统。这样之后,启动到 shell 的时间是相当快的(220ms),到可以执行简单命令的总体启动时间也要小于 2 秒。当然,这仅仅只提供了挂载 root file 系统、一些基本的虚拟文件支持和 shell 。根据你的项目所需功能的数量,可以以此作为一个优化的起点。 --- User space boot time to Shell with a Shell script only: ~0.2s   参考资料 http://free-electrons.com/doc/training/boot-time/boot-time-slides.pdf
  • 热度 28
    2012-4-4 12:12
    2492 次阅读|
    0 个评论
      作者:下家山 (转载,请注明作者,请尊重原创) 一:printk等级 Printk是一个带打印等级(loglevel)的内核打印语句。 Linux内核根据问题的严重程度定义了八种等级(loglevel) #define    KERN_EMERG     "0"     /* system is unusable                   */ #define    KERN_ALERT      "1"     /* action must be taken immediately     */ #define    KERN_CRIT  "2"     /* critical conditions                    */ #define    KERN_ERR   "3"     /* error conditions                */ #define    KERN_WARNING "4"     /* warning conditions                  */ #define    KERN_NOTICE    "5"     /* normal but significant condition       */ #define    KERN_INFO  "6"     /* informational                   */ #define    KERN_DEBUG     "7"     /* debug-level messages               */ 值越小等级越高。 (见include/linux/kernel.h linux2.6.15) 二:printk输出方式 Printk的输出方式有两种:syslog(日志)和console(控制台)。我们通常在调试驱动时一般 把控制台定向到了串口,然后通过串口显示到串口终端上。 2.1 通过console输出        当loglevel小于console_loglevel时,消息才能被打印到控制台上(也就能在串口终端看到内容了)。      2.2 通过日志查看        那么当loglevel大于console_loglevel,消息保存在哪里呢? 如果系统运行了klogd和syslogd,则无论console_loglevel为何值,内核消息都将追加到/var/log/messages中。如果klogd没有运行,消息不会传递到用户空间,只能查看/proc/kmsg。 也就是说messages或kmsg中会显示所有的打印信息。 三:console_loglevel值为多少        Console_loglevel同样定义在include/linux/kernel.h中 #define console_loglevel (console_printk ) #define default_message_loglevel (console_printk ) #define minimum_console_loglevel (console_printk ) #define default_console_loglevel (console_printk )        而console_printk定义在哪里呢?        (见kernel/printk.c) #define DEFAULT_MESSAGE_LOGLEVEL 4 /* KERN_WARNING */ /* We show everything that is MORE important than this.. */ #define MINIMUM_CONSOLE_LOGLEVEL 1 /* Minimum loglevel we let people use */ #define DEFAULT_CONSOLE_LOGLEVEL 7 /* anything MORE serious than KERN_DEBUG */ int console_printk = {        DEFAULT_CONSOLE_LOGLEVEL,       /* console_loglevel */        DEFAULT_MESSAGE_LOGLEVEL,       /* default_message_loglevel */        MINIMUM_CONSOLE_LOGLEVEL,/* minimum_console_loglevel */        DEFAULT_CONSOLE_LOGLEVEL,       /* default_console_loglevel */ };        这样 console_loglevel值就为7 四:测试程序        #include #include #define       PRINTM_MSG(msg)   printk(KERN_DEBUG msg) #define       PRINTM(level,msg...) PRINTM_##level(msg) #define pr_debug(arg) printk(KERN_INFO arg) static int printk_test_init(void) {           printk(KERN_EMERG "Hello0\n");             printk(KERN_ALERT "Hello1\n");     printk(KERN_CRIT "Hello2\n");        printk(KERN_ERR "Hello3\n");          printk(KERN_WARNING "Hello4\n");       printk(KERN_NOTICE "Hello5\n");            printk(KERN_INFO "Hello6\n");        printk(KERN_DEBUG "Hello7\n");             printk(KERN_DEBUG "Hello7\n");             printk(KERN_DEBUG "%s\n","Hello7-1");         PRINTM_MSG("No external FW image\n");     PRINTM(MSG, "No external FW image\n");     pr_debug("success!\n") ;     return 0; } static void printk_test_exit(void) {         printk(KERN_EMERG"Goodbye\n");      } module_init(printk_test_init); module_exit(printk_test_exit); 五:测试结果 转载:请注明,作者,下家山   请尊重原创!  
  • 热度 27
    2012-4-4 12:11
    1409 次阅读|
    0 个评论
    作者:下家山(转载,请注明) 六:kmsg查看结果 # ls /proc/ 1              6              diskstats      locks          stat 10             7              driver         meminfo        swaps 11             8              execdomains    misc           sys 12             9              filesystems    modules        sysrq-trigger 13             buddyinfo      fs             mounts         sysvipc 18             bus            interrupts     mtd            tty 2              cmdline        iomem          net            uptime 28             cpu            ioports        partitions     version 3              cpuinfo        kallsyms       schedstat      vmstat 4              crypto         kmsg           self           zoneinfo 5              devices        loadavg        slabinfo # cat proc/kmsg 5Linux version 2.6.15 (root@pc-ubuntu) (gcc version 3.4.1) #100 Tue Jan 13 13:44:09 CST 2009 4CPU: ARM920Tid(wb) revision 0 (ARMv4T) 4Machine: SMDK2410 4Warning: bad configuration page, trying to continue 4Memory policy: ECC disabled, Data cache writeback 7On node 0 totalpages: 4096 7  DMA zone: 4096 pages, LIFO batch:0 7  DMA32 zone: 0 pages, LIFO batch:0 7  Normal zone: 0 pages, LIFO batch:0 7  HighMem zone: 0 pages, LIFO batch:0 4to Call s3c_lookup_cpu 4Call s3c_lookup_cpu end 4CPU S3C2410A (id 0x32410002) 4S3C2410: core 202.800 MHz, memory 101.400 MHz, peripheral 50.700 MHz 6S3C2410 Clocks, (c) 2004 Simtec Electronics 4CLOCK: Slow mode (1.500 MHz), fast, MPLL on, UPLL on 4CPU0: D VIVT write-back cache 4CPU0: I cache: 16384 bytes, associativity 64, 32 byte lines, 8 sets 4CPU0: D cache: 16384 bytes, associativity 64, 32 byte lines, 8 sets 4Built 1 zonelists 5Kernel command line: noinitrd console=ttySAC0,115200 root=/dev/nfs rw nfsroot=10.128.34.77:/home/cgm/Linux/root_nfs ip=10.128.34.43:10.128.34.77:10.128.34.102:255.255.255.0:host:eth0:off 4irq: clearing subpending status 00000002 4PID hash table entries: 128 (order: 7, 2048 bytes) 4timer tcon=00500000, tcnt a509, tcfg 00000200,00000000, usec 00001e4c 4Console: colour dummy device 80x30 7selected clock c020e26c (pclk) quot 27, calc 113169 4Dentry cache hash table entries: 4096 (order: 2, 16384 bytes) 4Inode-cache hash table entries: 2048 (order: 1, 8192 bytes) 6Memory: 16MB = 16MB total 5Memory: 13820KB available (1899K code, 367K data, 100K init) 7Calibrating delay loop... 50.48 BogoMIPS (lpj=126208) 6io scheduler anticipatory registered 6io scheduler deadline registered 6io scheduler cfq registered 4S3C2410 RTC, (c) 2004 Simtec Electronics 4cs89x0.c: v2.4.3-pre1 Russell Nelson , Andrew Morton @uow.edu.au@crynwr.com 6eth0: cs8900 rev K found at 0xf1300300 6NET: Registered protocol family 2 4IP route cache hash table entries: 256 (order: -2, 1024 bytes) 4TCP established hash table entries: 1024 (order: 0, 4096 bytes) 4TCP bind hash table entries: 1024 (order: 0, 4096 bytes) 6TCP: Hash tables configured (established 1024 bind 1024) 6TCP reno registered 6TCP bic registered 6NET: Registered protocol family 1 6eth0: using half-duplex 10Base-T (RJ-45) 4IP-Config: Complete: 4      device=eth0, addr=10.128.34.43, mask=255.255.255.0, gw=10.128.34.102, 4     host=host, domain=, nis-domain=(none), 4     bootserver=10.128.34.77, rootserver=10.128.34.77, rootpath= 5Looking up port of RPC 100003/2 on 10.128.34.77 5Looking up port of RPC 100005/1 on 10.128.34.77 4VFS: Mounted root (nfs filesystem). 6Freeing init memory: 100K 7selected clock c020e26c (pclk) quot 27, calc 113169 7selected clock c020e26c (pclk) quot 27, calc 113169 7selected clock c020e26c (pclk) quot 27, calc 113169 7selected clock c020e26c (pclk) quot 27, calc 113169 7selected clock c020e26c (pclk) quot 27, calc 113169 7selected clock c020e26c (pclk) quot 27, calc 113169 7selected clock c020e26c (pclk) quot 27, calc 113169 4printk_test: module license 'unspecified' taints kernel. 0Hello0 1Hello1 2Hello2 3Hello3 4Hello4 5Hello5 6Hello6 7Hello7 7Hello7 7Hello7-1 7No external FW image 7No external FW image 6success! 转载:请注明,作者,下家山   请尊重原创! @uow.edu.au@crynwr.com          
  • 热度 25
    2012-4-4 12:09
    2387 次阅读|
    0 个评论
    作者:下家山(转载,请注明)   七:如何查看console_loglevel当前等级          命令:          # cat /proc/sys/kernel/printk 7       4       1       7 这四个数字分别对应:console_loglevel  default_message_loglevel  minimum_console_loglevel  default_console_loglevel 八:如何改变console_loglevel当前等级  九:结束   转载:请注明,作者,下家山   请尊重原创!  
相关资源