浙江网站制作Wordpress网格插件
- 作者: 五速梦信息网
- 时间: 2026年04月20日 03:43
当前位置: 首页 > news >正文
浙江网站制作,Wordpress网格插件,高端网站开发培训,sem是什么显微镜初始化整个内存 OsSysMemInitOsMainmain从 main() 跟踪可看内存部分初始化是在 OsSysMemInit() 中完成的。 UINT32 OsSysMemInit(VOID) {STATUS_T ret;OsKSpaceInit();//内核空间初始化ret OsKHeapInit(OS_KHEAP_BLOCK_SIZE);// 内核动态内存初始化 512K if (ret ! LOS_OK…初始化整个内存 OsSysMemInitOsMainmain从 main() 跟踪可看内存部分初始化是在 OsSysMemInit() 中完成的。 UINT32 OsSysMemInit(VOID) {STATUS_T ret;OsKSpaceInit();//内核空间初始化ret OsKHeapInit(OS_KHEAP_BLOCK_SIZE);// 内核动态内存初始化 512K if (ret ! LOS_OK) {VM_ERR(OsKHeapInit fail);return LOS_NOK;}OsVmPageStartup();// page初始化OsInitMappingStartUp();// 映射初始化ret ShmInit();// 共享内存初始化if (ret 0) {VM_ERR(ShmInit fail); return LOS_NOK;}return LOS_OK; }鸿蒙虚拟内存整体布局图 [图片上传失败…(image-6e54a-1712499300486)] // HarmonyOS 内核空间包含以下各段: extern CHAR __int_stack_start; // 运行系统函数栈的开始地址 extern CHAR __rodata_start; // ROM开始地址 只读 extern CHAR __rodata_end; // ROM结束地址 extern CHAR __bss_start; // bss开始地址 extern CHAR __bss_end; // bss结束地址 extern CHAR __text_start; // 代码区开始地址 extern CHAR __text_end; // 代码区结束地址 extern CHAR __ram_data_start; // RAM开始地址 可读可写 extern CHAR __ram_data_end; // RAM结束地址 extern UINT32 __heap_start; // 堆区开始地址 extern UINT32 __heap_end; // 堆区结束地址内存一开始一张白纸这些 extern 就是给它画大界线的从哪到哪是属于什么段。这些值大小取决实际项目内存条的大小不同的内存条地址肯定会不一样所以必须由外部提供鸿蒙内核采用了 Linux 的段管理方式。结合上图对比以下的解释自行理解下位置。 BSS 段 bss segment通常是指用来存放程序中未初始化的全局变量的一块内存区域。BSS 是英文 Block Started by Symbol 的简称。BSS 段属于静态内存分配。该段用于存储未初始化的全局变量或者是默认初始化为 0 的全局变量它不占用程序文件的大小但是占用程序运行时的内存空间。 data 段 该段用于存储初始化的全局变量初始化为 0 的全局变量出于编译优化的策略还是被保存在 BSS 段。 细心的读者可能发现了鸿蒙内核几乎所有的全局变量都没有赋初始化值或 NULL这些变量经过编译后是放在了 BSS 段的运行时占用内存空间如此编译出来的 ELF 包就变小了。 .rodata 段该段也叫常量区用于存放常量数据ro 就是 Read Only 之意。 text 段 是用于存放程序代码的编译时确定只读。更进一步讲是存放处理器的机器指令当各个源文件单独编译之后生成目标文件经连接器链接各个目标文件并解决各个源文件之间函数的引用与此同时还得将所有目标文件中的.text 段合在一起。 stack 栈段是由系统负责申请释放用于存储参数变量及局部变量以及函数的执行。 heap 段 它由用户申请和释放申请时至少分配虚存当真正存储数据时才分配相应的实存释放时也并非立即释放实存而是可能被重复利用。 内核空间是怎么初始化的 LosMux g_vmSpaceListMux;//虚拟空间互斥锁一般和g_vmSpaceList配套使用 LOS_DL_LIST_HEAD(g_vmSpaceList);//g_vmSpaceList把所有虚拟空间挂在一起 LosVmSpace g_kVmSpace; //内核空间地址 LosVmSpace g_vMallocSpace;//虚拟分配空间地址//鸿蒙内核空间有两个(内核进程空间和内核动态分配空间)共用一张L1页表 VOID OsKSpaceInit(VOID) {OsVmMapInit();// 初始化互斥量OsKernVmSpaceInit(g_kVmSpace OsGFirstTableGet());// 初始化内核虚拟空间OsGFirstTableGet 为L1表基地址OsVMallocSpaceInit(g_vMallocSpace OsGFirstTableGet());// 初始化动态分配区虚拟空间OsGFirstTableGet 为L1表基地址 }//g_kVmSpace g_vMallocSpace 共用一个L1页表 //初始化内核堆空间 STATUS_T OsKHeapInit(size_t size) {STATUS_T ret;VOID ptr NULL;/** roundup to MB aligned in order to set kernel attributes. kernel text/code/data attributes should page mapping remaining region should section mapping. so the boundary should be* MB aligned.*///向上舍入到MB对齐是为了设置内核属性。内核文本/代码/数据属性应该是页映射其余区域应该是段映射所以边界应该对齐。UINTPTR end ROUNDUP(g_vmBootMemBase size MB);//用M是因为采用section mapping 鸿蒙内核源码分析(内存映射篇)有阐述size end - g_vmBootMemBase;//ROUNDUP(0x000002005121024) 1024 ROUNDUP(0x000002015121024) 2048 此处需细品! ptr OsVmBootMemAlloc(size);//因刚开机使用引导分配器分配if (!ptr) {PRINT_ERR(vmm_kheap_init boot_alloc_mem failed! %d\n size);return -1;}m_aucSysMem0 m_aucSysMem1 ptr;//内存池基地址取名auc还用0和1来标识有何深意一直没整明白 哪位大神能告诉下?ret LOS_MemInit(m_aucSysMem0 size);//初始化内存池if (ret ! LOS_OK) {PRINT_ERR(vmm_kheap_init LOS_MemInit failed!\n);g_vmBootMemBase - size;//分配失败时需归还size g_vmBootMemBase是很野蛮粗暴的return ret;}LOS_MemExpandEnable(OS_SYS_MEM_ADDR);//地址可扩展return LOS_OK; }内核空间用了三个全局变量其中一个是互斥 LosMuxIPC 部分会详细讲这里先不展开。 比较有意思的是 LOS_DL_LIST_HEAD看内核源码过程中经常会为这样的代码点头称赞会心一笑。点赞 #define LOS_DL_LIST_HEAD(list) LOS_DL_LIST list { (list) (list) }Page 是如何初始化的 page 是映射的最小单位是物理地址 — 虚拟地址映射的数据结构的基础 // page初始化 VOID OsVmPageStartup(VOID) {struct VmPhysSeg *seg NULL;LosVmPage *page NULL;paddr_t pa;UINT32 nPage;INT32 segID;OsVmPhysAreaSizeAdjust(ROUNDUP((g_vmBootMemBase - KERNEL_ASPACE_BASE) PAGE_SIZE));//校正 g_physArea sizenPage OsVmPhysPageNumGet();//得到 g_physArea 总页数g_vmPageArraySize nPage * sizeof(LosVmPage);//页表总大小g_vmPageArray (LosVmPage *)OsVmBootMemAlloc(g_vmPageArraySize);//申请页表存放区域OsVmPhysAreaSizeAdjust(ROUNDUP(g_vmPageArraySize PAGE_SIZE));// g_physArea 变小OsVmPhysSegAdd();// 段页绑定OsVmPhysInit();// 加入空闲链表和设置置换算法LRU(最近最久未使用)算法for (segID 0; segID g_vmPhysSegNum; segID) {seg g_vmPhysSeg[segID];nPage seg-size PAGE_SHIFT;for (page seg-pageBase pa seg-start; page seg-pageBase nPage;page pa PAGE_SIZE) {OsVmPageInit(page pa segID);//page初始化}OsVmPageOrderListInit(seg-pageBase nPage);// 页面分配的排序} }进程是如何申请内存的 进程的主体是来自进程池进程池是统一分配的怎么创建进程池的去翻系列篇里的文章所以创建一个进程的时候只需要分配虚拟内存 LosVmSpace这里要分内核模式和用户模式下的申请。 //初始化进程的 用户空间 或 内核空间 //初始化PCB块 STATIC UINT32 OsInitPCB(LosProcessCB *processCB UINT32 mode UINT16 priority UINT16 policy const CHAR *name) {UINT32 count;LosVmSpace *space NULL;LosVmPage *vmPage NULL;status_t status;BOOL retVal FALSE;processCB-processMode mode;//用户态进程还是内核态进程processCB-processStatus OS_PROCESS_STATUS_INIT;//进程初始状态processCB-parentProcessID OS_INVALID_VALUE;//爸爸进程外面指定processCB-threadGroupID OS_INVALID_VALUE;//所属线程组processCB-priority priority;//优先级processCB-policy policy;//调度算法 LOS_SCHED_RRprocessCB-umask OS_PROCESS_DEFAULT_UMASK;//掩码processCB-timerID (timer_t)(UINTPTR)MAX_INVALID_TIMER_VID;LOS_ListInit(processCB-threadSiblingList);//初始化任务/线程链表LOS_ListInit(processCB-childrenList); //初始化孩子链表LOS_ListInit(processCB-exitChildList); //初始化记录哪些孩子退出了的链表 LOS_ListInit((processCB-waitList)); //初始化等待链表for (count 0; count OS_PRIORITY_QUEUE_NUM; count) { //根据 priority数 创建对应个数的队列LOS_ListInit(processCB-threadPriQueueList[count]); }if (OsProcessIsUserMode(processCB)) {// 是否为用户态进程space LOS_MemAlloc(m_aucSysMem0 sizeof(LosVmSpace));if (space NULL) {PRINT_ERR(%s %d alloc space failed\n FUNCTION LINE);return LOS_ENOMEM;}VADDR_T *ttb LOS_PhysPagesAllocContiguous(1);//分配一个物理页用于存储L1页表 4G虚拟内存分成 4096*1Mif (ttb NULL) {//这里直接获取物理页ttbPRINT_ERR(%s %d alloc ttb or space failed\n FUNCTION LINE);(VOID)LOS_MemFree(m_aucSysMem0 space);return LOS_ENOMEM;}(VOID)memset_s(ttb PAGE_SIZE 0 PAGE_SIZE);retVal OsUserVmSpaceInit(space ttb);//初始化虚拟空间和本进程 mmuvmPage OsVmVaddrToPage(ttb);//通过虚拟地址拿到pageif ((retVal FALSE) || (vmPage NULL)) {//异常处理PRINT_ERR(create space failed! ret: %d vmPage: %#x\n retVal vmPage);processCB-processStatus OS_PROCESS_FLAG_UNUSED;//进程未使用干净(VOID)LOS_MemFree(m_aucSysMem0 space);//释放虚拟空间LOS_PhysPagesFreeContiguous(ttb 1);//释放物理页4Kreturn LOS_EAGAIN;}processCB-vmSpace space;//设为进程虚拟空间LOS_ListAdd(processCB-vmSpace-archMmu.ptList (vmPage-node));//将空间映射页表挂在 空间的mmu L1页表 L1为表头} else {processCB-vmSpace LOS_GetKVmSpace();//内核共用一个虚拟空间内核进程 常驻内存}#ifdef LOSCFG_SECURITY_VIDstatus VidMapListInit(processCB);if (status ! LOS_OK) {PRINT_ERR(VidMapListInit failed!\n);return LOS_ENOMEM;} #endif #ifdef LOSCFG_SECURITY_CAPABILITYOsInitCapability(processCB); #endifif (OsSetProcessName(processCB name) ! LOS_OK) {return LOS_ENOMEM;}return LOS_OK; } LosVmSpace *LOS_GetKVmSpace(VOID) {return g_kVmSpace; }从代码可以看出内核空间固定只有一个 g_kVmSpace而每个用户进程的虚拟内存空间都是独立的。请细品 task 是如何申请内存的 task 的主体是来自进程池task 池是统一分配的怎么创建 task 池的去翻系列篇里的文章。这里 task 只需要申请 stack 空间还是直接上看源码吧用 OsUserInitProcess 函数看应用程序的 main () 是如何被内核创建任务和运行的。 //所有的用户进程都是使用同一个用户代码段描述符和用户数据段描述符它们是USER_CS和USER_DS也就是每个进程处于用户态时它们的CS寄存器和DS寄存器中的值是相同的。当任何进程或者中断异常进入内核后都是使用相同的内核代码段描述符和内核数据段描述符它们是KERNEL_CS和KERNEL_DS。这里要明确记得内核数据段实际上就是内核态堆栈段。 LITE_OS_SEC_TEXT_INIT UINT32 OsUserInitProcess(VOID) {INT32 ret;UINT32 size;TSK_INIT_PARAM_S param { 0 };VOID *stack NULL;VOID *userText NULL;CHAR *userInitTextStart (CHAR *)user_init_entry;//代码区开始位置 所有进程CHAR *userInitBssStart (CHAR *)user_init_bss;// 未初始化数据区BSS。在运行时改变其值CHAR *userInitEnd (CHAR *)user_init_end;// 结束地址UINT32 initBssSize userInitEnd - userInitBssStart;UINT32 initSize userInitEnd - userInitTextStart;LosProcessCB *processCB OS_PCB_FROM_PID(g_userInitProcess);ret OsProcessCreateInit(processCB OS_USER_MODE Init OS_PROCESS_USERINIT_PRIORITY);// 初始化用户进程它将是所有应用程序的父进程if (ret ! LOS_OK) {return ret;}userText LOS_PhysPagesAllocContiguous(initSize PAGE_SHIFT);// 分配连续的物理页if (userText NULL) {ret LOS_NOK;goto ERROR;}(VOID)memcpy_s(userText initSize (VOID *)user_init_load_addr initSize);// 安全copy 经加载器load的结果 __user_init_load_addr - userTextret LOS_VaddrToPaddrMmap(processCB-vmSpace (VADDR_T)(UINTPTR)userInitTextStart LOS_PaddrQuery(userText)initSize VM_MAP_REGION_FLAG_PERM_READ | VM_MAP_REGION_FLAG_PERM_WRITE |VM_MAP_REGION_FLAG_PERM_EXECUTE | VM_MAP_REGION_FLAG_PERM_USER);// 虚拟地址与物理地址的映射if (ret 0) {goto ERROR;}(VOID)memset_s((VOID *)((UINTPTR)userText userInitBssStart - userInitTextStart) initBssSize 0 initBssSize);// 除了代码段其余都清0stack OsUserInitStackAlloc(g_userInitProcess size);// 初始化堆栈区if (stack NULL) {PRINTK(user init process malloc user stack failed!\n);ret LOS_NOK;goto ERROR;}param.pfnTaskEntry (TSK_ENTRY_FUNC)userInitTextStart;// 从代码区开始执行也就是应用程序main 函数的位置param.userParam.userSP (UINTPTR)stack size;// 指向栈底param.userParam.userMapBase (UINTPTR)stack;// 栈顶param.userParam.userMapSize size;// 栈大小param.uwResved OS_TASK_FLAG_PTHREAD_JOIN;// 可结合的joinable能够被其他线程收回其资源和杀死ret OsUserInitProcessStart(g_userInitProcess param);// 创建一个任务来运行main函数if (ret ! LOS_OK) {(VOID)OsUnMMap(processCB-vmSpace param.userParam.userMapBase param.userParam.userMapSize);goto ERROR;}return LOS_OK;ERROR:(VOID)LOS_PhysPagesFreeContiguous(userText initSize PAGE_SHIFT);//释放物理内存块OsDeInitPCB(processCB);//删除PCB块return ret; }所有的用户进程都是通过 init 进程 fork 来的 可以看到创建进程的同时创建了一个 task 入口函数就是代码区的第一条指令也就是应用程序 main 函数。这里再说下 stack 的大小不同空间下的 task 栈空间是不一样的鸿蒙内核中有三种栈空间 size如下 #define LOSCFG_BASE_CORE_TSK_IDLE_STACK_SIZE SIZE(0x800)//内核进程运行在内核空间2K #define OS_USER_TASK_SYSCALL_SATCK_SIZE 0x3000 //用户进程通过系统调用创建的task运行在内核空间的 12K #define OS_USER_TASK_STACK_SIZE 0x100000//用户进程运行在用户空间的1M为了能让大家更好的学习鸿蒙HarmonyOS NEXT开发技术这边特意整理了《鸿蒙开发学习手册》共计890页希望对大家有所帮助https://qr21.cn/FV7h05 《鸿蒙开发学习手册》 如何快速入门https://qr21.cn/FV7h05 基本概念构建第一个ArkTS应用…… 开发基础知识https://qr21.cn/FV7h05 应用基础知识配置文件应用数据管理应用安全管理应用隐私保护三方应用调用管控机制资源分类与访问学习ArkTS语言…… 基于ArkTS 开发https://qr21.cn/FV7h05 Ability开发UI开发公共事件与通知窗口管理媒体安全网络与链接电话服务数据管理后台任务(Background Task)管理设备管理设备使用信息统计DFX国际化开发折叠屏系列…… 鸿蒙开发面试真题含参考答案https://qr18.cn/F781PH 鸿蒙开发面试大盘集篇共计319页https://qr18.cn/F781PH 1.项目开发必备面试题 2.性能优化方向 3.架构方向 4.鸿蒙开发系统底层方向 5.鸿蒙音视频开发方向 6.鸿蒙车载开发方向 7.鸿蒙南向开发方向
- 上一篇: 浙江网站怎么做推广什么网站可以接设计方案
- 下一篇: 浙江网站制作公司哪些网站可以做外部锚文本
相关文章
-
浙江网站怎么做推广什么网站可以接设计方案
浙江网站怎么做推广什么网站可以接设计方案
- 技术栈
- 2026年04月20日
-
浙江网站建设与维护书外贸soho建站
浙江网站建设与维护书外贸soho建站
- 技术栈
- 2026年04月20日
-
浙江网站建设与维护书能做外链的产品网站
浙江网站建设与维护书能做外链的产品网站
- 技术栈
- 2026年04月20日
-
浙江网站制作公司哪些网站可以做外部锚文本
浙江网站制作公司哪些网站可以做外部锚文本
- 技术栈
- 2026年04月20日
-
浙江新华建设有限公司官方网站受欢迎的网站建设教程
浙江新华建设有限公司官方网站受欢迎的网站建设教程
- 技术栈
- 2026年04月20日
-
浙江新中环建设有限公司 网站厦门seo代运营
浙江新中环建设有限公司 网站厦门seo代运营
- 技术栈
- 2026年04月20日






