在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

eheap嵌入式堆的配置

星星科技指導員 ? 來源:嵌入式計算設計 ? 作者:Micro Digital ? 2022-06-22 10:51 ? 次閱讀

許多嵌入式系統不使用堆。許多確實使用堆的人使用必須按順序搜索的串行堆,因此可能非常慢。大多數其他嵌入式系統可能使用廣泛可用的dlmalloc,它以無法更改的固定結構為代價提供快速操作。

一個名為eheap的新嵌入式堆在這些極端情況之間提供了一個中間地帶。它為在 RTOS 上運行或獨立運行的嵌入式系統提供高性能、適應性和安全性。eheap 旨在為特定的嵌入式系統輕松定制。它符合 malloc()、free()、realloc() 和 calloc() 的 ANSI C 標準,并為堆控制和安全提供附加功能。

這是關于 eheap 的三篇文章系列中的第一篇:

? eheap 第 1 部分:配置

? eheap 第 2 部分:增強調試

? eheap 第 3 部分:自我修復

eheap 是一種 bin 類型的堆,類似于 dlmalloc。假設讀者熟悉這種類型的堆結構,或者對這些堆如何操作的細節不感興趣。因此,這篇文章和后續文章將討論 eheap 的獨特之處,而不是它的工作原理。對于那些想要更詳細信息的人,請參閱eheap 與 dlmalloc。

嵌入式系統特性

eheap 設計用于以下方面:

? 范圍廣泛的 RAM 大小,從非常小到大。

? 預計永遠運行。

? 需要高性能和確定性操作。

? 高優先級任務必須能夠搶占并快速運行。

? 小代碼量通常是必要的。

? 每個嵌入式系統的堆要求范圍相對較窄。

? 嵌入式系統有大量空閑時間。

? 嵌入式系統對自我修復的需求不斷增長。

bin 配置

與其他 bin 類型的堆一樣,eheap 有一個用于小塊的小型 bin 數組 (SBA) 和一個用于大塊的上部 bin 數組 (UBA)。SBA 就像一組塊池,但速度不快。與 dlmalloc 不同,UBA 中的 bin 大小是連續 2 字節的冪(256、512 等),eheap 允許選擇 bin 大小以適合應用程序。eheap bin 大小由一個恒定的bin 大小數組確定,由程序員指定。對于小 bin,bin 大小是 bin 的塊大小。[1] 對于大 bin,bin 大小是 bin 中的最小塊大小。一個 bin 的最大塊大小是下一個 bin 的大小 – 8.[2]

為了安全起見,bin 大小數組可以位于 ROM 中,也可以位于本地 RAM 中以獲得更高的性能。堆初始化函數使用它來創建 eheap 所需的 bin 和所有相關變量。可以通過更改 bin 大小數組中的值、重新編譯和重新啟動應用程序來快速重新配置堆。這種快速重新配置支持一種啟發式方法來調整 eheap 以獲得特定系統的最佳性能。

小型系統示例

小型系統可能有一個 bin 大小的數組,如圖 1 所示。

pYYBAGKyhAGAc-AEAABZzyaIZak584.png

[圖 1]

對于這個系統,SBA 由 bin 0、1 和 2 組成,分別保存大小為 24、32 和 40 的塊;bin3 包含從 48 到 120 的 10 個尺寸;bin4 是一個只包含大小為 128 的小 bin;bin 5 包含從 136 到 248 的 14 個尺寸;和 bin6 ,頂部 bin,包含從 264 開始的所有大小。-1 標記大小數組的結尾。在這個特定的嵌入式系統中,對小塊的需求是有限的,對中等塊有一些需求,而對 264 字節以上的大塊的需求很少。請注意,為 128 字節的塊添加了一個小 bin,這些塊在此系統中經常使用。

上垃圾箱搜索

eheap 和 dlmalloc 在 SBA 方面是相似的。兩者都針對非常快速的訪問進行了優化,這是面向對象程序通常需要的。主要區別在于 UBA,其中 dlmalloc 在 free() 操作期間構建樹以指導 malloc() 操作期間的最佳分配。樹節點鏈接巧妙地存儲在塊本身中。

對于 eheap,每個 bin 都有一個適合該 bin 的空閑塊列表。在 free() 操作期間,如果塊大于 bin 的第一個塊,則將其放在 bin 空閑列表的末尾;否則,將其放在 bin 空閑列表的開頭。在空閑時間,大的 bin 空閑列表按增加的塊大小進行排序。在 malloc() 操作期間,會在大的 bin 空閑列表中搜索第一個足夠大的塊,這也是最合適的。

eheap 最適合具有偏好塊大小并且不使用廣泛的塊大小的系統。如上例所示,可以在 UBA 中放入一個小 bin 以提供常用尺寸。實現此結果的另一種方法是使大的 bin 大小等于經常使用的塊大小。那么最適合的將始終是 bin 中的第一個塊,然后是更大的尺寸。

在某種程度上,大型垃圾箱就像已排序的迷你串行堆一樣運行。過多的搜索時間可能會受到箱大小與系統需求的明智選擇以及對合并的明智使用的限制,如下所述。堆設計的一個原則是處理更大的塊需要更長的時間,因此更長的 malloc() 時間不會降低平均性能。當然, malloc() 不能花費太長時間以致更高優先級的任務錯過它們的截止日期。

圖 2 顯示了一個 bin 堆示例。

pYYBAGKyhAiAE8Q1AAAX3WGbKqo284.png

【圖2】

在這種情況下,沒有SBA也沒有UBA,只有top bin。此堆接近串行類型堆,但仍比它具有優勢。

圖 3 顯示了一個沒有 SBA 堆的示例。

pYYBAGKyhA-ACI42AAA2dJGeeds495.png

[圖 3]

用 C 編寫的嵌入式系統可能對小塊幾乎沒有用處,或者,塊池可能更適合特定系統中的小塊。在這種情況下,bin 0 以 24 開頭,因為必須覆蓋 24 字節及以上的所有大小,但 bin 0 可能僅用于 64 字節及更大的塊。 [3]

圖 4 顯示了一個沒有 UBA 堆的示例。

pYYBAGKyhBWAJZukAABbZhFogQI272.png

[圖 4]

在這個堆中,SBA 覆蓋大小為 24 到 64 的塊,所有其他塊進入 bin 6,覆蓋 72 個字節及以上。

幾乎無限的堆配置是可能的。目前,為了獲得最佳性能,eheap 限制為 32 個 bin。如果更多的 bin 被證明對某些嵌入式系統有益,則可以增加此限制。

Donor chunk

eheap 有一個可選的donor chunk (dc),它類似于dlmalloc 的指定犧牲塊(dvc),但操作方式不同并且服務于不同的目的:

? 快速小塊分配的初始源。

? 將小塊分離到下堆,將大塊分離到上堆。

? 基于緩存的系統的小塊本地化。

如果啟用,則 dc 的空間將由程序員在頂部塊 (tc) 下方分配。通常,它只是總初始可用空間的一小部分,它是 dc 和 tc 的組合。如果用于分配小塊的選定 SBA 箱為空,則從 dc 中分割該塊,而不是從下一個較大的占用箱中取出它。這不僅更快,而且還避免了減少更大的垃圾箱。由于 dc 最初是堆的較低部分,因此小塊將來自較低的堆。這改善了小塊分配的本地化,并且還傾向于按塊大小隔離堆,以幫助減少使用中的小塊,以免阻塞大塊的合并。

在堆使用一段時間后,小塊分配將主要來自 SBA 箱,很少來自 dc。此時可以關閉使用 dc 并將剩余的內容釋放到垃圾箱中。或者,可以繼續使用 dc。當下面和相鄰的已釋放塊合并到其中時,它會增長,并且隨著從中分配塊,它會縮小。這將提高空 SBA 箱的性能。

塊合并和泄漏箱

dlmalloc 和 eheap 之間的一個重要區別是 dlmalloc 總是合并相鄰的空閑塊,而 eheap 允許延遲合并。eheap 合并由其cmerge 模式控制,應用程序可以打開或關閉該模式。在堆初始化之后它是關閉的。

延遲合并的原因是塊合并會產生泄漏的 bin。例如,假設一個 24 字節的塊被釋放到 bin 0,而物理上相鄰的 48 字節的空閑塊駐留在 bin 3。如果啟用合并,這些塊將被合并成一個 72 字節的塊,該塊將被放入bin 6。如果應用程序需要 24 和 48 字節的塊而不是 72 字節的塊,這不利于獲得最佳性能。此外,在 free() 操作期間,將 48 字節塊出列并合并它需要額外的時間。如果后續 malloc() 獲取 72 字節塊,將其拆分為 24 和 48 字節塊以獲取其中任何一個,然后將剩余部分重新排隊,則這是浪費時間。

與可能使用多種塊大小的一般處理不同,嵌入式系統傾向于使用有限的塊大小。因此,泄漏箱對于嵌入式系統來說不是最佳的。

cmerge可以直接控制也可以自動控制。如果自動模式amerge為 ON,則當可用空間低于下限時, cmerge 將打開,當可用空間高于上限時,它將關閉。限制由配置常數決定。或者,可以使用空閑塊的數量、平均空閑塊大小或 bin 中的總空間,這取決于在特定系統中最有效的方法。

概括

eheap 是一種新的嵌入式堆,可以通過調整 bin 大小數組,決定是否使用 dc 以及它應該多大,以及決定是否使用延遲合并以及如果使用,如何控制它。這些選項允許將eheap調整到特定系統,以實現最佳系統性能,而不會出現碎片導致分配失敗。eheap 可免費用于非商業用途。

審核編輯:郭婷

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

    關注

    5096

    文章

    19199

    瀏覽量

    308246
  • RTOS
    +關注

    關注

    22

    文章

    821

    瀏覽量

    119944
收藏 人收藏

    評論

    相關推薦

    嵌入式主板的概述與發展

    隨著科技的迅猛發展,嵌入式系統在現代電子產品中扮演著越來越重要的角色。嵌入式主板作為嵌入式系統的核心組件之一,承擔著控制、處理和通訊等多種功能。本文將對嵌入式主板的基本概念、構成部分、
    的頭像 發表于 01-13 16:30 ?358次閱讀
    <b class='flag-5'>嵌入式</b>主板的概述與發展

    ARM架構嵌入式主板特點

    嵌入式主板可以理解為嵌入在設備中用于控制和數據處理的CPU板,也就是設備的“大腦”。當主板嵌入到設備中,當然對主板的體積和功耗會有更嚴格的要求(嵌入式主板的散熱問題)。如今
    的頭像 發表于 12-31 16:03 ?442次閱讀
    ARM架構<b class='flag-5'>嵌入式</b>主板特點

    新手怎么學嵌入式?

    新手怎么學嵌入式? 在科技飛速發展的今天,嵌入式技術已經滲透到我們生活的各個角落,從智能手機到智能家居,從汽車電子到醫療設備。對于新手而言,嵌入式技術就像是一座充滿神秘和機遇的寶藏,等待著大家去挖掘
    發表于 12-12 10:51

    什么是嵌入式人工智能

    嵌入式人工智能是指將人工智能技術應用于嵌入式系統中的一種技術。嵌入式系統是嵌入到其他設備或系統中的計算機系統,通常用于控制、監測或執行特定任務,如智能手機、智能家居設備、智能汽車等中的
    的頭像 發表于 12-11 09:23 ?449次閱讀
    什么是<b class='flag-5'>嵌入式</b>人工智能

    嵌入式 Linux 操作系統配置

    隨著物聯網(IoT)和智能設備的快速發展,嵌入式系統在各個領域扮演著越來越重要的角色。Linux因其開源、靈活和穩定的特性,成為嵌入式系統的首選操作系統。 1. 硬件選擇 在配置嵌入式
    的頭像 發表于 11-06 10:22 ?660次閱讀

    什么是嵌入式?一文讀懂嵌入式主板

    在現代科技浪潮中,嵌入式技術已成為支撐各種智能設備和系統運行的核心力量。那么,究竟什么是嵌入式嵌入式系統,顧名思義,是將計算機的硬件和軟件嵌入到某種設備或系統中,以實現特定功能的計算
    的頭像 發表于 10-16 10:14 ?1698次閱讀

    AMD 面向嵌入式系統推出高能效 EPYC 嵌入式 8004 系列

    AMD 憑借其 EPYC? 嵌入式處理器不斷樹立行業標準,為網絡、存儲和工業應用提供卓越的性能、效率、連接與創新。今天,我們正以第四代 AMD EPYC 嵌入式 8004 系列處理器擴展這一
    發表于 10-11 13:58 ?773次閱讀

    嵌入式主板是什么意思?嵌入式主板全面解析

    嵌入式主板,通常被稱為嵌入式系統的核心組件,是一種用于控制和數據處理的計算機硬件,其設計旨在嵌入特定設備中執行專門任務。嵌入式主板如同是設備的“大腦”,主要功能是根據需要管理和控制設備
    的頭像 發表于 09-30 10:05 ?1066次閱讀

    嵌入式linux開發的基本步驟有哪些?

    嵌入式Linux開發是一個復雜的過程,涉及到硬件選擇、操作系統移植、驅動開發、應用程序開發等多個方面。以下是嵌入式Linux開發的基本步驟,以及每個步驟的說明。 硬件選擇 在開始嵌入式Linux開發
    的頭像 發表于 09-02 09:11 ?647次閱讀

    嵌入式開發前景怎么樣?

    嵌入式開發前景非常廣闊,這主要得益于物聯網、人工智能、大數據等技術的快速發展,以及嵌入式系統在各個領域的廣泛應用。以下是對嵌入式開發前景的詳細分析
    的頭像 發表于 07-10 09:00 ?3061次閱讀
    <b class='flag-5'>嵌入式</b>開發前景怎么樣?

    飛凌嵌入式Forlinx pinMux,更好用的MPU引腳復用配置工具

    飛凌嵌入式打造了一款專門針對ARM嵌入式MPU引腳復用的軟件工具——Forlinx pinMux
    的頭像 發表于 07-05 10:28 ?1975次閱讀
    飛凌<b class='flag-5'>嵌入式</b>Forlinx pinMux,更好用的MPU引腳復用<b class='flag-5'>配置</b>工具

    嵌入式主板,你了解多少?

    嵌入式主板,也稱為嵌入式計算機主板,是一種專門設計用于嵌入式系統的計算機主板。與臺式機和筆記本電腦中使用的常規主板不同,嵌入式主板設計用于集成到更大的電子設備中,例如汽車、醫療設備或自
    的頭像 發表于 04-17 15:11 ?1725次閱讀

    嵌入式fpga是什么意思

    嵌入式FPGA是指將FPGA技術集成到嵌入式系統中的一種解決方案。嵌入式系統是一種為特定應用而設計的計算機系統,它通常包括處理器、內存、外設接口等組件,并且被嵌入到更大的設備或系統中,
    的頭像 發表于 03-15 14:29 ?1446次閱讀

    fpga是嵌入式

    FPGA(現場可編程門陣列)不是嵌入式系統,但FPGA在嵌入式系統中有著重要的應用。
    的頭像 發表于 03-14 17:19 ?2606次閱讀

    fpga與嵌入式的區別 嵌入式和fpga開發有什么關系

    fpga與嵌入式的區別 FPGA與嵌入式系統在設計和應用上存在一些關鍵的區別,具體如下: 靈活性:FPGA具有高度的靈活性,可以根據需要重新編程以實現不同的功能。而嵌入式系統的硬件功能通常是固定
    的頭像 發表于 03-14 17:04 ?7135次閱讀
    主站蜘蛛池模板: 久久思re热9一区二区三区 | 亚洲精品美女在线观看 | 精品一区二区三区视频 | 高清一区二区三区免费 | 午夜精品久久久久蜜桃 | qvod高清在线成人观看 | 午夜精品福利在线 | 成 人色 网 站 欧美大片在线观看 | 天天做天天爱夜夜想毛片 | 中文字幕亚洲天堂 | 久久久久久久综合狠狠综合 | 岛国毛片一级一级特级毛片 | 狠狠干激情 | 午夜一级毛片 | 三级视频国产 | 色成人综合 | 扒开双腿疯狂进出爽爽爽 | 欧美色天使 | 黄色毛片网 | 精品国产成人系列 | 老色批影院 | 51久久| 4455ee日本高清免费观看 | 成年女人免费看一级人体片 | 一级特黄a大片免费 | 婷婷综合久久中文字幕蜜桃三 | 免费看黄在线 | 免费免费啪视频在线 | 日本黄色站 | 国产一级真人毛爱做毛片 | 日韩a视频 | 日本不卡视频免费的 | 在线视频亚洲一区 | 伊人久久大香线蕉综合爱婷婷 | 国内色综合精品视频在线 | 四虎永久精品视频在线 | 欧美色图亚洲激情 | 日本黄视频网站 | 午夜美女写真福利写视频 | 国产片无遮挡在线看床戏 | 免费看的一级毛片 |