chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

Linux如何防止內(nèi)存沖突?

jf_44130326 ? 來源:Linux1024 ? 2026-01-30 16:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在聊這個話題之前,我們先回憶一下單片機系統(tǒng)中是如何分配內(nèi)存的?如果沒有bootloader,那硬件環(huán)境起來之后就直接進入主程序運行,如果有引導程序bootloader,那就需要設置好跳轉地址,否則設置不對,系統(tǒng)就無法啟動了。

文章bootloader介紹

那么對于linux系統(tǒng)來說,何嘗不是這樣呢?因為linux系統(tǒng)包含的文件比較多,啟動也分幾個階段,每個階段也都是通過跳轉執(zhí)行的。如何管理好內(nèi)存是系統(tǒng)穩(wěn)定運行的前提。

原生的uboot只能管理自己所在的內(nèi)存塊,無法管理整塊空間。于是rk引入了bidram和sysmem,用于管理uboot之外的地址空間,RK平臺就把系統(tǒng)所有內(nèi)存通過sysmem + bidram + malloc管理起來了,防止出現(xiàn)內(nèi)存沖突等問題。

bidram:管理u-boot、kernel階段不可用、需要剔除的內(nèi)存塊,例如:ATF、OP-TEE 占用的空間;sysmem:管理kernel 可見、可用的內(nèi)存塊。例如:fdt、ramdisk、kernel、fastboot 占用的空間。

相關代碼:

./lib/sysmem.c./lib/bidram.c./include/memblk.h./arch/arm/mach-rockchip/memblk.c

先來大概預覽一下源文件吧:

intsysmem_init(void){  struct sysmem *sysmem = &plat_sysmem;  phys_addr_t mem_start;  phys_size_t mem_size;  int ret;
  lmb_init(&sysmem->lmb);  INIT_LIST_HEAD(&sysmem->allocated_head);  INIT_LIST_HEAD(&sysmem->kmem_resv_head);  sysmem->allocated_cnt = 0;  sysmem->kmem_resv_cnt = 0;
  if (gd->flags & GD_FLG_RELOC) {    sysmem->has_initr = true;  } else {    SYSMEM_I("initn");    sysmem->has_initf = true;  }
  /* Add all available system memory */#ifdef CONFIG_NR_DRAM_BANKS  int i;
  for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) {    if (!gd->bd->bi_dram[i].size)      continue;          ret = sysmem_add(gd->bd->bi_dram[i].start,         gd->bd->bi_dram[i].size);    if (ret) {      SYSMEM_E("Failed to add sysmem from bi_dram[%d]n", i);      goto fail;    }  }#else  mem_start = env_get_bootm_low();  mem_size = env_get_bootm_size();  ret = sysmem_add(mem_start, mem_size);  if (ret) {    SYSMEM_E("Failed to add sysmem from bootm_low/sizen");    goto fail;  }#endif  /* Reserved for board */  ret = board_sysmem_reserve(sysmem);  if (ret) {    SYSMEM_E("Failed to reserve sysmem for boardn");    goto fail;  }
  /* Reserved for U-boot framework: 'reserve_xxx()' */  mem_start = gd->start_addr_sp;  mem_size = gd->ram_top - mem_start;  if (!sysmem_alloc_base(MEM_UBOOT, mem_start, mem_size)) {    SYSMEM_E("Failed to reserve sysmem for U-Boot frameworkn");    ret = -ENOMEM;    goto fail;  }    /* Reserved for U-Boot stack */  mem_start = gd->start_addr_sp - CONFIG_SYS_STACK_SIZE;  mem_size = CONFIG_SYS_STACK_SIZE;  if (!sysmem_alloc_base(MEM_STACK, mem_start, mem_size)) {    SYSMEM_E("Failed to reserve sysmem for stackn");    ret = -ENOMEM;    goto fail;}return0;fail:  if (ret && !(gd->flags & GD_FLG_RELOC)) {    sysmem_dump();    SYSMEM_W("Maybe malloc size %d MiB is too large?nn",       SIZE_MB(CONFIG_SYS_MALLOC_LEN));}  return ret;}

wKgZO2kaoBuAZ_V-AAI2mYVdcis437.png

sysmem 內(nèi)存信息表:

sysmem_dump_all:--------------------------------------------------------------------// <1> 這里是sysmem可管理的總內(nèi)存容量,即bidram<3>之外的可用ddr容量,對kernel可見。memory.rgn[0].addr = 0x00200000 - 0x08400000 (size: 0x08200000)memory.rgn[1].addr = 0x0a200000 - 0x80000000 (size: 0x75e00000)memory.total = 0x7e000000 (2016 MiB. 0 KiB)--------------------------------------------------------------------// <2> 這里顯示了各個固件alloc走的內(nèi)存塊信息allocated.rgn[0].name = "U-Boot".addr = 0x71dd6140 - 0x80000000 (size: 0x0e229ec0)allocated.rgn[1].name = "STACK"  // 表明棧溢出.addr = 0x71bd6140 - 0x71dd6140 (size: 0x00200000)allocated.rgn[2].name = "FDT".addr = 0x08300000 - 0x08316204 (size: 0x00016204)allocated.rgn[3].name = "KERNEL"  // 表明內(nèi)存塊溢出.addr = 0x00280000 - 0x014ce204 (size: 0x0124e204)allocated.rgn[4].name = "RAMDISK".addr = 0x0a200000 - 0x0a3e6804 (size: 0x001e6804)// <3> malloc_r/f的大小malloc_r: 192 MiB, malloc_f: 16 KiBallocated.total = 0x0f874acc (248 MiB. 466 KiB)--------------------------------------------------------------------// <4> 這里是核心算法對上述<2>進行的信息整理,顯示被占用走的內(nèi)存塊信息LMB.reserved[0].addr = 0x00280000 - 0x014ce204 (size: 0x0124e204)LMB.reserved[1].addr = 0x08300000 - 0x08316204 (size: 0x00016204)LMB.reserved[2].addr = 0x0a200000 - 0x0a3e6804 (size: 0x001e6804)LMB.reserved[3].addr = 0x71bd6140 - 0x80000000 (size: 0x0e429ec0)reserved.core.total = 0x0f874acc (248 MiB. 466 KiB)--------------------------------------------------------------------

wKgZO2kaoByAKD5mAAJLI4NkLSo384.png

bidram 內(nèi)存信息表:

bidram_dump_all:--------------------------------------------------------------------// <1> 這里顯示了U-Boot從前級loader獲取的ddr的總容量信息,一共有2GBmemory.rgn[0].addr = 0x00000000 - 0x80000000 (size: 0x80000000)memory.total = 0x80000000 (2048 MiB. 0 KiB)--------------------------------------------------------------------// <2> 這里顯示了被預留起來的各固件內(nèi)存信息,這些空間對kernel不可見reserved.rgn[0].name = "ATF".addr = 0x00000000 - 0x00100000 (size: 0x00100000)reserved.rgn[1].name = "SHM".addr = 0x00100000 - 0x00200000 (size: 0x00100000)reserved.rgn[2].name = "OP-TEE".addr = 0x08400000 - 0x0a200000 (size: 0x01e00000)reserved.total = 0x02000000 (32 MiB. 0 KiB)--------------------------------------------------------------------// <3> 這里是核心算法對上述<2>進行的預留信息整理,例如:會對相鄰塊進行合并LMB.reserved[0].addr = 0x00000000 - 0x00200000 (size: 0x00200000)LMB.reserved[1].addr = 0x08400000 - 0x0a200000 (size: 0x01e00000)reserved.core.total = 0x02000000 (32 MiB. 0 KiB)--------------------------------------------------------------------
通過上述內(nèi)存管理,調(diào)試中在出現(xiàn)問題時,可以結合分析表去分析問題,如:

wKgZO2kaoByAXx1tAADnSWIwWq8282.png


原文標題:Linux如何防止內(nèi)存沖突?

文章出處:【微信公眾號:Linux1024】歡迎添加關注!文章轉載請注明出處。

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

    關注

    88

    文章

    11806

    瀏覽量

    219487
  • 內(nèi)存
    +關注

    關注

    9

    文章

    3229

    瀏覽量

    76489
  • bootloader
    +關注

    關注

    2

    文章

    245

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    Linux內(nèi)存管理是什么,Linux內(nèi)存管理詳解

    Linux內(nèi)存管理 Linux內(nèi)存管理是一個非常復雜的過程,主要分成兩個大的部分:內(nèi)核的內(nèi)存管理和進程虛擬
    的頭像 發(fā)表于 05-11 17:54 ?7429次閱讀
    <b class='flag-5'>Linux</b>的<b class='flag-5'>內(nèi)存</b>管理是什么,<b class='flag-5'>Linux</b>的<b class='flag-5'>內(nèi)存</b>管理詳解

    linux內(nèi)存相關知識科普

    linux 內(nèi)存組織結構和頁面布局,內(nèi)存碎片產(chǎn)生原因和優(yōu)化算法。
    發(fā)表于 08-08 10:57 ?713次閱讀

    走進Linux內(nèi)存系統(tǒng)探尋內(nèi)存管理的機制和奧秘

    Linux 內(nèi)存是后臺開發(fā)人員,需要深入了解的計算機資源。合理的使用內(nèi)存,有助于提升機器的性能和穩(wěn)定性。本文主要介紹Linux 內(nèi)存組織結構
    的頭像 發(fā)表于 01-05 09:47 ?2513次閱讀

    關于Linux內(nèi)存管理的詳細介紹

    Linux內(nèi)存管理是指對系統(tǒng)內(nèi)存的分配、釋放、映射、管理、交換、壓縮等一系列操作的管理。在Linux中,內(nèi)存被劃分為多個區(qū)域,每個區(qū)域有不同
    發(fā)表于 03-06 09:28 ?1479次閱讀

    Linux內(nèi)存相關知識科普

    Linux 內(nèi)存是后臺開發(fā)人員,需要深入了解的計算機資源。合理的使用內(nèi)存,有助于提升機器的性能和穩(wěn)定性。本文主要介紹**Linu****x 內(nèi)存組織結構和頁面布局,
    發(fā)表于 07-25 14:43 ?1213次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)存</b>相關知識科普

    Linux內(nèi)核的內(nèi)存管理詳解

    內(nèi)存管理的主要工作就是對物理內(nèi)存進行組織,然后對物理內(nèi)存的分配和回收。但是Linux引入了虛擬地址的概念。
    發(fā)表于 08-31 14:46 ?1440次閱讀
    <b class='flag-5'>Linux</b>內(nèi)核的<b class='flag-5'>內(nèi)存</b>管理詳解

    請問如何對多中斷使用防止沖突

    在STM32中,如何對多中斷使用,防止沖突
    發(fā)表于 04-10 01:22

    Linux中的沖突問題及其應對策略

    Linux服務器系統(tǒng)是不存在沖突的,然而些許時候該系統(tǒng)的沖突、停滯問題的確存在。對于應用軟件層面的沖突或者停滯問題,與內(nèi)核層面有何不同呢?
    發(fā)表于 05-16 11:41 ?1059次閱讀

    linux內(nèi)存管理機制淺析

    本內(nèi)容介紹了arm linux內(nèi)存管理機制,詳細說明了linux內(nèi)核內(nèi)存管理,linux虛擬內(nèi)存
    發(fā)表于 12-19 14:09 ?73次下載
    <b class='flag-5'>linux</b><b class='flag-5'>內(nèi)存</b>管理機制淺析

    linux內(nèi)存管理

    linux內(nèi)存管理
    發(fā)表于 10-24 11:12 ?3次下載
    <b class='flag-5'>linux</b><b class='flag-5'>內(nèi)存</b>管理

    你知道linux內(nèi)存管理基礎及方法?

    linux內(nèi)存管理采取的分頁存取機制,會將內(nèi)存中不經(jīng)常使用的數(shù)據(jù)塊交換到虛擬內(nèi)存中。linux會不時地進行頁面交換操作,以保持盡可能多的空
    發(fā)表于 04-28 17:12 ?1644次閱讀

    一文解析Linux內(nèi)存系統(tǒng)

    Linux 內(nèi)存是后臺開發(fā)人員,需要深入了解的計算機資源。合理的使用內(nèi)存,有助于提升機器的性能和穩(wěn)定性。本文主要介紹Linux 內(nèi)存組織結構
    的頭像 發(fā)表于 09-01 10:46 ?3186次閱讀
    一文解析<b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)存</b>系統(tǒng)

    深入剖析Linux共享內(nèi)存原理

    Linux系統(tǒng)中,每個進程都有獨立的虛擬內(nèi)存空間,也就是說不同的進程訪問同一段虛擬內(nèi)存地址所得到的數(shù)據(jù)是不一樣的,這是因為不同進程相同的虛擬內(nèi)存地址會映射到不同的物理
    的頭像 發(fā)表于 10-30 09:52 ?3008次閱讀
    深入剖析<b class='flag-5'>Linux</b>共享<b class='flag-5'>內(nèi)存</b>原理

    Linux系統(tǒng)的共享內(nèi)存的使用

    但有時候為了讓不同進程之間進行通信,需要讓不同進程共享相同的物理內(nèi)存,Linux通過 共享內(nèi)存 來實現(xiàn)這個功能。下面先來介紹一下Linux系統(tǒng)的共享
    的頭像 發(fā)表于 11-14 11:55 ?2194次閱讀

    Linux 內(nèi)存管理總結

    一、Linux內(nèi)存管理概述 Linux內(nèi)存管理是指對系統(tǒng)內(nèi)存的分配、釋放、映射、管理、交換、壓縮等一系列操作的管理。在
    的頭像 發(fā)表于 11-10 14:58 ?1426次閱讀
    <b class='flag-5'>Linux</b> <b class='flag-5'>內(nèi)存</b>管理總結