当前位置: 首页 > news >正文

国外视觉设计网站模具外发加工订单网

国外视觉设计网站,模具外发加工订单网,discuz可以做商城网站吗,网站的营销与推广接前一篇文章#xff1a;中移#xff08;苏州#xff09;软件技术有限公司面试问题与解答#xff08;1#xff09;—— 可信计算国密标准 本文参考以下文章#xff1a; 启动期间的内存管理之初始化过程概述----Linux内存管理(九) Linux初始化 特此致谢#xff01; 本…接前一篇文章中移苏州软件技术有限公司面试问题与解答1—— 可信计算国密标准 本文参考以下文章 启动期间的内存管理之初始化过程概述----Linux内存管理(九) Linux初始化 特此致谢 本文对于中移苏州软件技术有限公司面试问题中的“8Linux内核内存初始化的完整流程。”进行解答与解析。 实际上早有此心把Linux内核尤其是进程管理、内存管理和文件系统的代码都筛一遍。但是一直由于种种原因没有花大力气真正干。正好借着这个机会开始做这个事情。先从面试中问到的内存管理开始。 1. Linux系统启动过程中的内存初始化概述 在Linux系统初始化过程中必须建立内存管理的数据结构以及很多事务。因为Linux内核在内存管理完全初始化之前就需要使用内存。在系统启动期间使用了额外的简化的内存管理模块。随后在初始化完成后将旧的模块丢弃掉。 可以把Linux内核的内存管理分三个阶段 阶段起点终点过程描述第一阶段系统启动bootmem或者memblock初始化完成前此阶段只能使用memblock_reserve函数分配内存早期内核中使用init_bootmem_done1标识此阶段结束第二阶段bootmem或者memblock初始化完成buddy初始化完成前引导内存分配器bootmem或者memblock接受内存的管理工作早期内核中使用mem_init_done1标记此阶段的结束第三阶段buddy初始化完成系统停止运行可以用cache和buddy分配内存 2. start_kernel函数中的内存管理相关内容 首先我们来看看start_kernel()是如何初始化系统的。start_kerne函数在init/main.c中代码如下笔者使用的内核源码版本为6.7在这个时间点上是比较新的版本 asmlinkage __visible __init __no_sanitize_address __noreturn __no_stack_protector void start_kernel(void) {char *command_line;char *after_dashes;set_task_stack_end_magic(init_task);smp_setup_processor_id();debug_objects_early_init();init_vmlinux_build_id();cgroup_init_early();local_irq_disable();early_boot_irqs_disabled true;/** Interrupts are still disabled. Do necessary setups, then* enable them.*/boot_cpu_init();page_address_init();pr_notice(%s, linux_banner);early_security_init();setup_arch(command_line);setup_boot_config();setup_command_line(command_line);setup_nr_cpu_ids();setup_per_cpu_areas();smp_prepare_boot_cpu(); /* arch-specific boot-cpu hooks */boot_cpu_hotplug_init();pr_notice(Kernel command line: %s\n, saved_command_line);/* parameters may set static keys */jump_label_init();parse_early_param();after_dashes parse_args(Booting kernel,static_command_line, __start___param,__stop___param - __start___param,-1, -1, NULL, unknown_bootoption);print_unknown_bootoptions();if (!IS_ERR_OR_NULL(after_dashes))parse_args(Setting init args, after_dashes, NULL, 0, -1, -1,NULL, set_init_arg);if (extra_init_args)parse_args(Setting extra init args, extra_init_args,NULL, 0, -1, -1, NULL, set_init_arg);/* Architectural and non-timekeeping rng init, before allocator init */random_init_early(command_line);/** These use large bootmem allocations and must precede* initalization of page allocator*/setup_log_buf(0);vfs_caches_init_early();sort_main_extable();trap_init();mm_core_init();poking_init();ftrace_init();/* trace_printk can be enabled here */early_trace_init();/** Set up the scheduler prior starting any interrupts (such as the* timer interrupt). Full topology setup happens at smp_init()* time - but meanwhile we still have a functioning scheduler.*/sched_init();if (WARN(!irqs_disabled(),Interrupts were enabled *very* early, fixing it\n))local_irq_disable();radix_tree_init();maple_tree_init();/** Set up housekeeping before setting up workqueues to allow the unbound* workqueue to take non-housekeeping into account.*/housekeeping_init();/** Allow workqueue creation and work item queueing/cancelling* early. Work item execution depends on kthreads and starts after* workqueue_init().*/workqueue_init_early();rcu_init();/* Trace events are available after this */trace_init();if (initcall_debug)initcall_debug_enable();context_tracking_init();/* init some links before init_ISA_irqs() */early_irq_init();init_IRQ();tick_init();rcu_init_nohz();init_timers();srcu_init();hrtimers_init();softirq_init();timekeeping_init();time_init();/* This must be after timekeeping is initialized */random_init();/* These make use of the fully initialized rng */kfence_init();boot_init_stack_canary();perf_event_init();profile_init();call_function_init();WARN(!irqs_disabled(), Interrupts were enabled early\n);early_boot_irqs_disabled false;local_irq_enable();kmem_cache_init_late();/** HACK ALERT! This is early. Were enabling the console before* weve done PCI setups etc, and console_init() must be aware of* this. But we do want output early, in case something goes wrong.*/console_init();if (panic_later)panic(Too many boot %s vars at %s, panic_later,panic_param);lockdep_init();/** Need to run this when irqs are enabled, because it wants* to self-test [hard/soft]-irqs on/off lock inversion bugs* too:*/locking_selftest();#ifdef CONFIG_BLK_DEV_INITRDif (initrd_start !initrd_below_start_ok page_to_pfn(virt_to_page((void *)initrd_start)) min_low_pfn) {pr_crit(initrd overwritten (0x%08lx 0x%08lx) - disabling it.\n,page_to_pfn(virt_to_page((void *)initrd_start)),min_low_pfn);initrd_start 0;} #endifsetup_per_cpu_pageset();numa_policy_init();acpi_early_init();if (late_time_init)late_time_init();sched_clock_init();calibrate_delay();arch_cpu_finalize_init();pid_idr_init();anon_vma_init(); #ifdef CONFIG_X86if (efi_enabled(EFI_RUNTIME_SERVICES))efi_enter_virtual_mode(); #endifthread_stack_cache_init();cred_init();fork_init();proc_caches_init();uts_ns_init();key_init();security_init();dbg_late_init();net_ns_init();vfs_caches_init();pagecache_init();signals_init();seq_file_init();proc_root_init();nsfs_init();cpuset_init();cgroup_init();taskstats_init_early();delayacct_init();acpi_subsystem_init();arch_post_acpi_subsys_init();kcsan_init();/* Do the rest non-__inited, were now alive */arch_call_rest_init();/** Avoid stack canaries in callers of boot_init_stack_canary for gcc-10* and older.*/ #if !__has_attribute(__no_stack_protector__)prevent_tail_call_optimization(); #endif } 可以看到start_kernel函数代码很长有200行。在此只截取出其中与内存管理初始化相关的部分如下所示 asmlinkage __visible __init __no_sanitize_address __noreturn __no_stack_protector void start_kernel(void) {……setup_arch(command_line);……setup_per_cpu_areas();……mm_core_init();……kmem_cache_init_late();……setup_per_cpu_pageset();numa_policy_init();……anon_vma_init();……pagecache_init();……/* Do the rest non-__inited, were now alive */arch_call_rest_init(); } 函数功能备注 page_address_init 初始化内核用于查找物理页面地址的数据结构setup_arch是一个特定于体系结构的设置函数其中的一项任务是负责初始化自举分配器setup_per_cpu_areas给每个CPU分配内存并拷贝.data.percpu段的数据build_all_zonelists建立并初始化结点和内存域的数据结构已移至mm_core_init函数中mm_core_init建立了内核的内存分配器。其中通过mem_init函数停用bootmem分配器并迁移到实际的内存管理器比如伙伴系统 然后调用kmem_cache_init函数初始化内核内部用于小块内存区的分配器kmem_cache_init_late在kmem_cache_init函数之后完善分配器的缓存机制当前3个可用的内核内存分配器slab、slob、slub都会定义此函数 kmemleak_init 提供了一种可选的内核泄漏检测其方法类似于跟踪内存收集器。当独立的对象没有被释放时其报告记录在/sys/kernel/debug/kmemleak中kmemcheck()能够帮助定位大多数内存错误的上下文已移至mm_core_init函数中setup_per_cpu_pageset初始化CPU高速缓存行为pagesets的第一个数组元素分配内存换句话说其实就是第一个系统处理器分配numa_policy_init初始化NUMA策略anon_vma_init匿名虚拟内存域初始化创建anon_vma的slab缓存pagecache_init页高速缓存的初始化arch_call_rest_init用于在系统引导时调用平台特定的初始化函数 3. 内存初始化过程概述 在操作系统初始化的初期操作系统只是获取到了内存的基本信息内存管理的数据结构都没有建立。而这些数据结构创建的过程本身就是一个内存分配的过程。那么问题就来了内存管理数据结构需要分配到相应的内存才能完成做后续工作但是它所做的工作本身就是为了内存能够分配。此时还没有一个内存管理器去负责分配和回收内存而又不可能将所有的内存信息都静态地创建并初始化那么怎么分配内存管理器所需要的内存呢这就是一个典型的“鸡生蛋、蛋生鸡”的问题。不过甭管是先有鸡还是先有蛋总归要先有二者之一才能有后续的循环。 类比于鸡和蛋问题我们先要实现一个满足要求的但是可能效率不高的笨家伙内存管理器用它来负责系统初始化初期的内存管理最重要地用它来初始化我们内存的数据结构直到我们真正的内存管理器被初始化完成并能投入使用。之后就可以将旧的内存管理器丢掉。 因此在系统启动过程期间内核使用了一个额外的简化形式的内存管理模块早期的引导内存分配器boot memory allocator–bootmem分配器或者memblock用于在启动阶段早期分配内存。而在系统初始化完成后该分配器被内核抛弃然后初始化了一套新的更加完善的内存分配器。 系统启动 |    ----  第一阶段 bootmem或者memblock初始化完成 |    ----  第二阶段 伙伴系统以及slab cache初始化完成 |    ----  第三阶段 系统终止运行 从下一回开始对start_kernel()中的内存管理相关函数进行详细解析。
http://www.dnsts.com.cn/news/19694.html

相关文章:

  • 网站页面设计方案怎么写网站建设经费计划内容
  • 网站制作app沈阳做网站建设
  • 平面设计常用网站企业网站 制作
  • 网站上线需要哪些步骤深圳华强北电子城
  • 建设部网站 造价工程师做信息网站怎么样
  • 如果是创建的网站网站怎么做微信支付宝
  • 免费建自己的网站直通车关键词怎么优化
  • 石家庄招聘哪个网站做的好台商区住房和建设网站
  • 黄石网站建设哪家好装修设计网站免费
  • 网站建设费属于宣传费吗谈谈你对seo概念的理解
  • 优秀的设计网站推荐网站设计公司 深圳龙华
  • 苏州网站开发公司哪里济南兴田德润简介建立网站需要哪些费用
  • 电商网站seo网站特效js代码
  • 始兴县建设局网站电商平台如何做推广
  • 创建个人网站手机app 网站建设
  • 无锡网络公司可以制作网站拍摄宣传片收费标准
  • 返利网一类的网站怎么做网页建设制作
  • 制作网站软件app月嫂网站源码
  • 佛山网站建设熊掌号医疗网站开发
  • 手机网站 好处上海企业咨询公司
  • 佛山网站制作流程核酸造假7人枪毙
  • 做网站商业计划书范文百度seo关键词
  • 网站可以有二维码吗网站建站智能系统
  • 免费网站生成学平面设计怎么样啊
  • dedecms 建两个网站的问题免费网站app代码
  • 河南做外贸网站的公司简介flask做克隆网站
  • 怎么快速建网站教程wordpress输出文章标题
  • 厦门建行网站首页wordpress分类排序
  • 如何注册平台网站排名优化方法讲解
  • wordpress 单页模版广东工厂搜索seo