一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

鴻蒙內(nèi)核源碼:內(nèi)核空間是怎么初始化的?

鴻蒙系統(tǒng)HarmonyOS ? 來(lái)源:my.oschina ? 作者:鴻蒙內(nèi)核源碼分析 ? 2021-04-26 14:43 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本文分析虛擬內(nèi)存模塊源碼初始化整個(gè)內(nèi)存

pIYBAGCGX72AVUXCAACyef9Mog4169.png

從main()跟蹤可看內(nèi)存部分初始化是在OsSysMemInit()中完成的。

UINT32 OsSysMemInit(VOID)
{
  STATUS_T ret;

  OsKSpaceInit();//內(nèi)核空間初始化

  ret = OsKHeapInit(OS_KHEAP_BLOCK_SIZE);// 內(nèi)核動(dòng)態(tài)內(nèi)存初始化 512K 
  if (ret != LOS_OK) {
    VM_ERR("OsKHeapInit fail");
    return LOS_NOK;
  }

  OsVmPageStartup();// page初始化
  OsInitMappingStartUp();// 映射初始化

  ret = ShmInit();// 共享內(nèi)存初始化
  if (ret < 0) {
? ? ? ? VM_ERR("ShmInit fail"); ?
? ? ? ? return LOS_NOK;
? ? }

? ? return LOS_OK;
}

鴻蒙虛擬內(nèi)存整體布局圖

o4YBAGCGX8-AOvvLAARSlpdTHOM760.png

// HarmonyOS 內(nèi)核空間包含以下各段:
extern CHAR __int_stack_start; // 運(yùn)行系統(tǒng)函數(shù)棧的開始地址
extern CHAR __rodata_start;  // ROM開始地址 只讀
extern CHAR __rodata_end;  // ROM結(jié)束地址
extern CHAR __bss_start;  // bss開始地址
extern CHAR __bss_end;   // bss結(jié)束地址
extern CHAR __text_start;  // 代碼區(qū)開始地址
extern CHAR __text_end;   // 代碼區(qū)結(jié)束地址
extern CHAR __ram_data_start; // RAM開始地址 可讀可寫
extern CHAR __ram_data_end;  // RAM結(jié)束地址
extern UINT32 __heap_start;  // 堆區(qū)開始地址
extern UINT32 __heap_end;  // 堆區(qū)結(jié)束地址

內(nèi)存一開始一張白紙,這些extern就是給它畫大界線的,從哪到哪是屬于什么段。這些值大小取決實(shí)際項(xiàng)目?jī)?nèi)存條的大小,不同的內(nèi)存條,地址肯定會(huì)不一樣,所以必須由外部提供,鴻蒙內(nèi)核采用了Linux的段管理方式。結(jié)合上圖對(duì)比以下的解釋自行理解下位置。

BSS段(bss segment)通常是指用來(lái)存放程序中未初始化的全局變量的一塊內(nèi)存區(qū)域。BSS是英文Block Started by Symbol的簡(jiǎn)稱。BSS段屬于靜態(tài)內(nèi)存分配。該段用于存儲(chǔ)未初始化的全局變量或者是默認(rèn)初始化為0的全局變量,它不占用程序文件的大小,但是占用程序運(yùn)行時(shí)的內(nèi)存空間。

data段 該段用于存儲(chǔ)初始化的全局變量,初始化為0的全局變量出于編譯優(yōu)化的策略還是被保存在BSS段。

細(xì)心的讀者可能發(fā)現(xiàn)了,鴻蒙內(nèi)核幾乎所有的全局變量都沒(méi)有賦初始化值或NULL,這些變量經(jīng)過(guò)編譯后是放在了BSS段的,運(yùn)行時(shí)占用內(nèi)存空間,如此編譯出來(lái)的ELF包就變小了。

.rodata段,該段也叫常量區(qū),用于存放常量數(shù)據(jù),ro就是Read Only之意。

text段 是用于存放程序代碼的,編譯時(shí)確定,只讀。更進(jìn)一步講是存放處理器的機(jī)器指令,當(dāng)各個(gè)源文件單獨(dú)編譯之后生成目標(biāo)文件,經(jīng)連接器鏈接各個(gè)目標(biāo)文件并解決各個(gè)源文件之間函數(shù)的引用,與此同時(shí),還得將所有目標(biāo)文件中的.text段合在一起。

stack棧段,是由系統(tǒng)負(fù)責(zé)申請(qǐng)釋放,用于存儲(chǔ)參數(shù)變量及局部變量以及函數(shù)的執(zhí)行。

heap段它由用戶申請(qǐng)和釋放,申請(qǐng)時(shí)至少分配虛存,當(dāng)真正存儲(chǔ)數(shù)據(jù)時(shí)才分配相應(yīng)的實(shí)存,釋放時(shí)也并非立即釋放實(shí)存,而是可能被重復(fù)利用。

內(nèi)核空間是怎么初始化的?

LosMux g_vmSpaceListMux;//虛擬空間互斥鎖,一般和g_vmSpaceList配套使用
LOS_DL_LIST_HEAD(g_vmSpaceList);//g_vmSpaceList把所有虛擬空間掛在一起,
LosVmSpace g_kVmSpace; //內(nèi)核空間地址
LosVmSpace g_vMallocSpace;//虛擬分配空間地址

//鴻蒙內(nèi)核空間有兩個(gè)(內(nèi)核進(jìn)程空間和內(nèi)核動(dòng)態(tài)分配空間),共用一張L1頁(yè)表
VOID OsKSpaceInit(VOID)
{
  OsVmMapInit();// 初始化互斥量
  OsKernVmSpaceInit(&g_kVmSpace, OsGFirstTableGet());// 初始化內(nèi)核虛擬空間,OsGFirstTableGet 為L(zhǎng)1表基地址
  OsVMallocSpaceInit(&g_vMallocSpace, OsGFirstTableGet());// 初始化動(dòng)態(tài)分配區(qū)虛擬空間,OsGFirstTableGet 為L(zhǎng)1表基地址
}//g_kVmSpace g_vMallocSpace 共用一個(gè)L1頁(yè)表
//初始化內(nèi)核堆空間
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對(duì)齊是為了設(shè)置內(nèi)核屬性。內(nèi)核文本/代碼/數(shù)據(jù)屬性應(yīng)該是頁(yè)映射,其余區(qū)域應(yīng)該是段映射,所以邊界應(yīng)該對(duì)齊。
  UINTPTR end = ROUNDUP(g_vmBootMemBase + size, MB);//用M是因?yàn)椴捎胹ection mapping 鴻蒙內(nèi)核源碼分析(內(nèi)存映射篇)有闡述
  size = end - g_vmBootMemBase;
 //ROUNDUP(0x00000200+512,1024) = 1024 ROUNDUP(0x00000201+512,1024) = 2048 此處需細(xì)品!
  ptr = OsVmBootMemAlloc(size);//因剛開機(jī),使用引導(dǎo)分配器分配
  if (!ptr) {
    PRINT_ERR("vmm_kheap_init boot_alloc_mem failed! %d\n", size);
    return -1;
  }

  m_aucSysMem0 = m_aucSysMem1 = ptr;//內(nèi)存池基地址,取名auc還用0和1來(lái)標(biāo)識(shí)有何深意,一直沒(méi)整明白, 哪位大神能告訴下?
  ret = LOS_MemInit(m_aucSysMem0, size);//初始化內(nèi)存池
  if (ret != LOS_OK) {
    PRINT_ERR("vmm_kheap_init LOS_MemInit failed!\n");
    g_vmBootMemBase -= size;//分配失敗時(shí)需歸還size, g_vmBootMemBase是很野蠻粗暴的
    return ret;
  }
  LOS_MemExpandEnable(OS_SYS_MEM_ADDR);//地址可擴(kuò)展
  return LOS_OK;
}

內(nèi)核空間用了三個(gè)全局變量,其中一個(gè)是互斥LosMux,IPC部分會(huì)詳細(xì)講,這里先不展開。比較有意思的是LOS_DL_LIST_HEAD,看內(nèi)核源碼過(guò)程中經(jīng)常會(huì)為這樣的代碼點(diǎn)頭稱贊,會(huì)心一笑。點(diǎn)贊!

#define LOS_DL_LIST_HEAD(list) LOS_DL_LIST list = { &(list), &(list) }

Page是如何初始化的?

page是映射的最小單位,是物理地址<--->虛擬地址映射的數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ)

// 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 size

  nPage = OsVmPhysPageNumGet();//得到 g_physArea 總頁(yè)數(shù)
  g_vmPageArraySize = nPage * sizeof(LosVmPage);//頁(yè)表總大小
  g_vmPageArray = (LosVmPage *)OsVmBootMemAlloc(g_vmPageArraySize);//申請(qǐng)頁(yè)表存放區(qū)域

  OsVmPhysAreaSizeAdjust(ROUNDUP(g_vmPageArraySize, PAGE_SIZE));// g_physArea 變小

  OsVmPhysSegAdd();// 段頁(yè)綁定
  OsVmPhysInit();// 加入空閑鏈表和設(shè)置置換算法,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);// 頁(yè)面分配的排序
  }
}

進(jìn)程是如何申請(qǐng)內(nèi)存的?

進(jìn)程的主體是來(lái)自進(jìn)程池,進(jìn)程池是統(tǒng)一分配的,怎么創(chuàng)建進(jìn)程池的去翻系列篇里的文章,所以創(chuàng)建一個(gè)進(jìn)程的時(shí)候只需要分配虛擬內(nèi)存LosVmSpace,這里要分內(nèi)核模式和用戶模式下的申請(qǐng)。

//初始化進(jìn)程的 用戶空間 或 內(nèi)核空間
//初始化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;//用戶態(tài)進(jìn)程還是內(nèi)核態(tài)進(jìn)程
  processCB->processStatus = OS_PROCESS_STATUS_INIT;//進(jìn)程初始狀態(tài)
  processCB->parentProcessID = OS_INVALID_VALUE;//爸爸進(jìn)程,外面指定
  processCB->threadGroupID = OS_INVALID_VALUE;//所屬線程組
  processCB->priority = priority;//優(yōu)先級(jí)
  processCB->policy = policy;//調(diào)度算法 LOS_SCHED_RR
  processCB->umask = OS_PROCESS_DEFAULT_UMASK;//掩碼
  processCB->timerID = (timer_t)(UINTPTR)MAX_INVALID_TIMER_VID;

  LOS_ListInit(&processCB->threadSiblingList);//初始化任務(wù)/線程鏈表
  LOS_ListInit(&processCB->childrenList);  //初始化孩子鏈表
  LOS_ListInit(&processCB->exitChildList); //初始化記錄哪些孩子退出了的鏈表 
  LOS_ListInit(&(processCB->waitList));  //初始化等待鏈表

  for (count = 0; count < OS_PRIORITY_QUEUE_NUM; ++count) { //根據(jù) priority數(shù) 創(chuàng)建對(duì)應(yīng)個(gè)數(shù)的隊(duì)列
? ? ? ? LOS_ListInit(&processCB->threadPriQueueList[count]); 
  }

  if (OsProcessIsUserMode(processCB)) {// 是否為用戶態(tài)進(jìn)程
    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);//分配一個(gè)物理頁(yè)用于存儲(chǔ)L1頁(yè)表 4G虛擬內(nèi)存分成 (4096*1M)
    if (ttb == NULL) {//這里直接獲取物理頁(yè)ttb
      PRINT_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);//初始化虛擬空間和本進(jìn)程 mmu
    vmPage = OsVmVaddrToPage(ttb);//通過(guò)虛擬地址拿到page
    if ((retVal == FALSE) || (vmPage == NULL)) {//異常處理
      PRINT_ERR("create space failed! ret: %d, vmPage: %#x\n", retVal, vmPage);
      processCB->processStatus = OS_PROCESS_FLAG_UNUSED;//進(jìn)程未使用,干凈
      (VOID)LOS_MemFree(m_aucSysMem0, space);//釋放虛擬空間
      LOS_PhysPagesFreeContiguous(ttb, 1);//釋放物理頁(yè),4K
      return LOS_EAGAIN;
    }
    processCB->vmSpace = space;//設(shè)為進(jìn)程虛擬空間
    LOS_ListAdd(&processCB->vmSpace->archMmu.ptList, &(vmPage->node));//將空間映射頁(yè)表掛在 空間的mmu L1頁(yè)表, L1為表頭
  } else {
    processCB->vmSpace = LOS_GetKVmSpace();//內(nèi)核共用一個(gè)虛擬空間,內(nèi)核進(jìn)程 常駐內(nèi)存
  }

#ifdef LOSCFG_SECURITY_VID
  status = VidMapListInit(processCB);
  if (status != LOS_OK) {
    PRINT_ERR("VidMapListInit failed!\n");
    return LOS_ENOMEM;
  }
#endif
#ifdef LOSCFG_SECURITY_CAPABILITY
  OsInitCapability(processCB);
#endif

  if (OsSetProcessName(processCB, name) != LOS_OK) {
    return LOS_ENOMEM;
  }

  return LOS_OK;
}
LosVmSpace *LOS_GetKVmSpace(VOID)
{
    return &g_kVmSpace;
}

從代碼可以看出,內(nèi)核空間固定只有一個(gè)g_kVmSpace,而每個(gè)用戶進(jìn)程的虛擬內(nèi)存空間都是獨(dú)立的。請(qǐng)細(xì)品!

task是如何申請(qǐng)內(nèi)存的?

task的主體是來(lái)自進(jìn)程池,task池是統(tǒng)一分配的,怎么創(chuàng)建task池的去翻系列篇里的文章。這里task只需要申請(qǐng)stack空間,還是直接上看源碼吧,用OsUserInitProcess函數(shù)看應(yīng)用程序的main()是如何被內(nèi)核創(chuàng)建任務(wù)和運(yùn)行的。

//所有的用戶進(jìn)程都是使用同一個(gè)用戶代碼段描述符和用戶數(shù)據(jù)段描述符,它們是__USER_CS和__USER_DS,也就是每個(gè)進(jìn)程處于用戶態(tài)時(shí),它們的CS寄存器和DS寄存器中的值是相同的。當(dāng)任何進(jìn)程或者中斷異常進(jìn)入內(nèi)核后,都是使用相同的內(nèi)核代碼段描述符和內(nèi)核數(shù)據(jù)段描述符,它們是__KERNEL_CS和__KERNEL_DS。這里要明確記得,內(nèi)核數(shù)據(jù)段實(shí)際上就是內(nèi)核態(tài)堆棧段。
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;//代碼區(qū)開始位置 ,所有進(jìn)程
  CHAR *userInitBssStart = (CHAR *)&__user_init_bss;// 未初始化數(shù)據(jù)區(qū)(BSS)。在運(yùn)行時(shí)改變其值
  CHAR *userInitEnd = (CHAR *)&__user_init_end;// 結(jié)束地址
  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);// 初始化用戶進(jìn)程,它將是所有應(yīng)用程序的父進(jìn)程
  if (ret != LOS_OK) {
    return ret;
  }

  userText = LOS_PhysPagesAllocContiguous(initSize >> PAGE_SHIFT);// 分配連續(xù)的物理頁(yè)
  if (userText == NULL) {
    ret = LOS_NOK;
    goto ERROR;
  }

  (VOID)memcpy_s(userText, initSize, (VOID *)&__user_init_load_addr, initSize);// 安全copy 經(jīng)加載器load的結(jié)果 __user_init_load_addr -> userText
  ret = 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);// 除了代碼段,其余都清0

? ? stack = OsUserInitStackAlloc(g_userInitProcess, &size);// 初始化堆棧區(qū)
? ? if (stack == NULL) {
? ? ? ? PRINTK("user init process malloc user stack failed!\n");
? ? ? ? ret = LOS_NOK;
? ? ? ? goto ERROR;
? ? }

? ? param.pfnTaskEntry = (TSK_ENTRY_FUNC)userInitTextStart;// 從代碼區(qū)開始執(zhí)行,也就是應(yīng)用程序main 函數(shù)的位置
? ? param.userParam.userSP = (UINTPTR)stack + size;// 指向棧底
? ? param.userParam.userMapBase = (UINTPTR)stack;// 棧頂
? ? param.userParam.userMapSize = size;// 棧大小
? ? param.uwResved = OS_TASK_FLAG_PTHREAD_JOIN;// 可結(jié)合的(joinable)能夠被其他線程收回其資源和殺死
? ? ret = OsUserInitProcessStart(g_userInitProcess, ¶m);// 創(chuàng)建一個(gè)任務(wù),來(lái)運(yùn)行main函數(shù)
? ? 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);//釋放物理內(nèi)存塊
  OsDeInitPCB(processCB);//刪除PCB塊
  return ret;
}

所有的用戶進(jìn)程都是通過(guò)init進(jìn)程 fork來(lái)的, 可以看到創(chuàng)建進(jìn)程的同時(shí)創(chuàng)建了一個(gè)task,入口函數(shù)就是代碼區(qū)的第一條指令,也就是應(yīng)用程序 main函數(shù)。這里再說(shuō)下stack的大小,不同空間下的task??臻g是不一樣的,鴻蒙內(nèi)核中有三種??臻gsize,如下

#define LOSCFG_BASE_CORE_TSK_IDLE_STACK_SIZE SIZE(0x800)//內(nèi)核進(jìn)程,運(yùn)行在內(nèi)核空間2K
#define OS_USER_TASK_SYSCALL_SATCK_SIZE 0x3000 //用戶進(jìn)程,通過(guò)系統(tǒng)調(diào)用創(chuàng)建的task運(yùn)行在內(nèi)核空間的 12K
#define OS_USER_TASK_STACK_SIZE         0x100000//用戶進(jìn)程運(yùn)行在用戶空間的1M

編輯:hfy

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 虛擬內(nèi)存
    +關(guān)注

    關(guān)注

    0

    文章

    78

    瀏覽量

    8258
  • 鴻蒙系統(tǒng)
    +關(guān)注

    關(guān)注

    183

    文章

    2642

    瀏覽量

    68091
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    鴻蒙內(nèi)核源碼Task/線程技術(shù)分析

    、使用內(nèi)存空間等系統(tǒng)資源,并獨(dú)立于其它線程運(yùn)行。 鴻蒙內(nèi)核每個(gè)進(jìn)程內(nèi)的線程獨(dú)立運(yùn)行、獨(dú)立調(diào)度,當(dāng)前進(jìn)程內(nèi)線程的調(diào)度不受其它進(jìn)程內(nèi)線程的影響。 鴻蒙內(nèi)
    的頭像 發(fā)表于 10-18 10:42 ?2575次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b>Task/線程技術(shù)分析

    【HarmonyOS】鴻蒙內(nèi)核源碼分析(內(nèi)存管理篇)

    詳見:../kernel/base/vm有了上篇鴻蒙內(nèi)核源碼分析(內(nèi)存概念篇)的基礎(chǔ),本篇講內(nèi)存管理部分,本章源碼超級(jí)多,很燒腦,但筆者關(guān)鍵處都加了注釋。廢話不多說(shuō),開始吧。目錄
    發(fā)表于 10-14 12:05

    鴻蒙內(nèi)核源碼分析:用通俗易懂的語(yǔ)言告訴你鴻蒙內(nèi)核發(fā)生了什么?

    鴻蒙虛擬內(nèi)存全景圖圖來(lái)自 鴻蒙內(nèi)核源碼注釋中文版 【Gitee倉(cāng) 】再看鴻蒙用戶空間全景圖圖來(lái)
    發(fā)表于 11-19 10:14

    鴻蒙內(nèi)核源碼分析(內(nèi)存管理篇):虛擬內(nèi)存和物理內(nèi)存是怎么管理的

    有了上篇鴻蒙內(nèi)核源碼分析(內(nèi)存概念篇)的基礎(chǔ),本篇講內(nèi)存管理部分,本章源碼超級(jí)多,很燒腦,但筆者關(guān)鍵處都加了注釋。廢話不多說(shuō),開始吧。初始化
    發(fā)表于 11-20 10:54

    LINUX系統(tǒng)引導(dǎo)和初始化-LINUX內(nèi)核解讀

    Linux 的系統(tǒng)引導(dǎo)和初始化 ----------Linux2.4.22內(nèi)核解讀之一 一、 系統(tǒng)引導(dǎo)和初始化概述 相關(guān)代碼(引導(dǎo)扇區(qū)的程序及其輔助程序,以 x86體系為例): \linux-2.4.22\arch\i386\b
    發(fā)表于 11-03 22:31 ?53次下載

    解析內(nèi)核初始化時(shí)根內(nèi)存盤的加載過(guò)程

    到內(nèi)存盤中作為根盤。 當(dāng)同時(shí)配置了初始化內(nèi)存盤(Initail RAM Disk)時(shí), 內(nèi)核初始化時(shí)可以在安裝主盤之前, 通過(guò)引導(dǎo)程序所加載的initrd文件建立一個(gè)內(nèi)存初始化盤,
    發(fā)表于 11-08 10:40 ?0次下載

    uboot和內(nèi)核里phy的初始化_內(nèi)核里的雙網(wǎng)絡(luò)配置及phy的初始化

    uboot 和內(nèi)核里 phy 的初始化,以及內(nèi)核里的雙網(wǎng)絡(luò)配置及 phy 的初始化。 本文以盈鵬飛嵌入式的CoM-335x(基于AM335x)核心板及網(wǎng)絡(luò)芯片LAN8720 為例,說(shuō)明
    的頭像 發(fā)表于 05-17 08:19 ?1.2w次閱讀

    Linux內(nèi)核初始化過(guò)程中的調(diào)用順序

    所有的__init函數(shù)在區(qū)段.initcall.init中還保存了一份函數(shù)指針,在初始化時(shí)內(nèi)核會(huì)通過(guò)這些函數(shù)指針調(diào)用這些__init函數(shù)指針,并在整個(gè)初始化完成后,釋放整個(gè)init區(qū)段(包括.init.text,.initcal
    發(fā)表于 05-12 08:40 ?1783次閱讀

    UCOS2系統(tǒng)內(nèi)核講述(五) _初始化TCB詳情

    UCOS2系統(tǒng)內(nèi)核講述(五)_初始化TCB詳情
    的頭像 發(fā)表于 03-25 09:39 ?2532次閱讀
    UCOS2系統(tǒng)<b class='flag-5'>內(nèi)核</b>講述(五) _<b class='flag-5'>初始化</b>TCB詳情

    UCOS2系統(tǒng)內(nèi)核講述(二)_ 初始化調(diào)用函數(shù)

    UCOS2系統(tǒng)內(nèi)核講述(二)_初始化調(diào)用函數(shù)
    的頭像 發(fā)表于 03-25 09:57 ?2054次閱讀
    UCOS2系統(tǒng)<b class='flag-5'>內(nèi)核</b>講述(二)_ <b class='flag-5'>初始化</b>調(diào)用函數(shù)

    鴻蒙內(nèi)核如何初始化物理內(nèi)存?

    鴻蒙內(nèi)核是如何實(shí)現(xiàn)賣肉算法的呢?
    的頭像 發(fā)表于 04-25 15:05 ?1888次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b>如何<b class='flag-5'>初始化</b>物理內(nèi)存?

    鴻蒙內(nèi)核源碼分析 :內(nèi)核最重要結(jié)構(gòu)體

    為何鴻蒙內(nèi)核源碼分析系列開篇就說(shuō) LOS_DL_LIST ? 因?yàn)樗?b class='flag-5'>鴻蒙 LOS 內(nèi)核中無(wú)處不在,在整個(gè)
    發(fā)表于 11-24 17:54 ?35次下載
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b>分析 :<b class='flag-5'>內(nèi)核</b>最重要結(jié)構(gòu)體

    Armlinux內(nèi)核移植及系統(tǒng)初始化過(guò)程分析

    Armlinux內(nèi)核移植及系統(tǒng)初始化過(guò)程分析說(shuō)明。
    發(fā)表于 04-06 15:53 ?11次下載

    華為鴻蒙系統(tǒng)內(nèi)核源碼分析上冊(cè)

    鴻蒙內(nèi)核源碼注釋中文版【 Gitee倉(cāng)】給 Harmoηy○S源碼逐行加上中文注解,詳細(xì)闡述設(shè)計(jì)細(xì)節(jié),助你快速精讀 Harmonyos內(nèi)核源碼
    發(fā)表于 04-09 14:40 ?17次下載

    OP-TEE的內(nèi)核初始化函數(shù)調(diào)用

    generic_boot_init_primary函數(shù)內(nèi)容 generic_boot_init_primary函數(shù)是OP-TEE建立系統(tǒng)運(yùn)行環(huán)境的入口函數(shù),該函數(shù)會(huì)進(jìn)行建立線程運(yùn)行空間、初始化
    的頭像 發(fā)表于 11-02 18:18 ?1148次閱讀
    OP-TEE的<b class='flag-5'>內(nèi)核</b><b class='flag-5'>初始化</b>函數(shù)調(diào)用