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

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

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

數(shù)據(jù)指針遞減功能簡(jiǎn)化了重疊內(nèi)存緩沖區(qū)的復(fù)制操作

星星科技指導(dǎo)員 ? 來(lái)源:ADI ? 作者:ADI ? 2023-06-13 16:33 ? 次閱讀

利用Maxim高速微控制器系列中的數(shù)據(jù)指針遞減功能,可以簡(jiǎn)化存儲(chǔ)器管理。本應(yīng)用筆記探討了該系列微控制器在DS80C400、DS5250、DS89C430和其他產(chǎn)品中使用MOVX操作。 示例代碼在執(zhí)行內(nèi)存?zhèn)鬏敳僮鲿r(shí)突出顯示 DPTR。

概述

任何微控制器的基本操作之一是能夠存儲(chǔ)和檢索數(shù)據(jù)到內(nèi)存/從內(nèi)存檢索數(shù)據(jù)。MOVX 操作為在 8051 架構(gòu)上執(zhí)行此操作提供了一個(gè)工具。應(yīng)用通常需要微控制器在其MOVX地址空間內(nèi)復(fù)制和移動(dòng)數(shù)據(jù)存儲(chǔ)器塊。當(dāng)源地址和目標(biāo)地址范圍不重疊時(shí),此內(nèi)存?zhèn)鬏敳僮鞣浅:?jiǎn)單,即迭代讀/寫(xiě)循環(huán)。但是,當(dāng)范圍重疊時(shí),該過(guò)程需要一些智能來(lái)避免在傳輸原始數(shù)據(jù)之前覆蓋(損壞)原始數(shù)據(jù)。本應(yīng)用筆記將提供兩種在源緩沖區(qū)和目標(biāo)緩沖區(qū)之間傳輸數(shù)據(jù)(重疊)的可能解決方案,并解釋Dallas的數(shù)據(jù)指針遞減功能如何簡(jiǎn)化解決方案。

重疊內(nèi)存問(wèn)題

大多數(shù)通用內(nèi)存復(fù)制例程不能確定源復(fù)制范圍和目標(biāo)復(fù)制范圍是否重疊。如果在執(zhí)行復(fù)制例程之前不進(jìn)行此評(píng)估,復(fù)制到與原始源范圍重疊的預(yù)期目標(biāo)范圍的字節(jié)可能會(huì)覆蓋和損壞原始數(shù)據(jù)。圖 1 給出了如何發(fā)生這種情況的簡(jiǎn)單說(shuō)明??梢钥闯觯繕?biāo)地址范圍從地址 = 0104h 開(kāi)始,這也恰好是原始源字節(jié)數(shù)組范圍內(nèi)的地址。如前所述,在這種情況下,標(biāo)準(zhǔn) memcpy() 例程不會(huì)生成所需的目標(biāo)數(shù)據(jù)數(shù)組。當(dāng)必須為此類傳輸維護(hù)數(shù)據(jù)完整性時(shí),通常使用 memmove() 操作來(lái)確保在復(fù)制到目標(biāo)時(shí)不會(huì)覆蓋源數(shù)組中的字節(jié)。

wKgZomSIKeiAb0EBAAAsOUagSpY621.gif

圖1.問(wèn)題:內(nèi)存副本重疊。

可能的解決方案

通過(guò)一些觀察,可以看到源數(shù)組(在復(fù)制之前)發(fā)生的覆蓋可以通過(guò)幾種方式避免:1) 確定重疊并首先傳輸源緩沖區(qū)中與所需目標(biāo)緩沖區(qū)重疊的字節(jié),或 2) 確定重疊并以相反的順序?qū)⒆止?jié)從源緩沖區(qū)傳輸?shù)侥繕?biāo)緩沖區(qū)。這兩種解決方案如圖 2 和圖 3 所示。請(qǐng)注意,相反方向的重疊(將源數(shù)組復(fù)制到內(nèi)存中較低的目標(biāo))對(duì)于按地址升序傳輸數(shù)據(jù)的標(biāo)準(zhǔn)復(fù)制循環(huán)沒(méi)有問(wèn)題。

給定下面的兩個(gè)視覺(jué)對(duì)象(圖 2 和圖 3),人們還應(yīng)該能夠看到解決方案 #1 在為多個(gè)復(fù)制操作計(jì)算、存儲(chǔ)和傳遞不同的源、目標(biāo)和長(zhǎng)度變量時(shí)遭受了額外的開(kāi)銷,而第二個(gè)解決方案只能執(zhí)行此操作一次。

wKgZomSIMdKASOf3AABcysiuIug055.png

圖2.重疊內(nèi)存復(fù)制解決方案 #1。

wKgaomSIKeuAc2bgAAApC56uu3E450.gif

圖3.重疊內(nèi)存復(fù)制解決方案 #2。

達(dá)拉斯硬件簡(jiǎn)化解決方案 #2

許多達(dá)拉斯微控制器產(chǎn)品(附錄 A 中提供的列表)為每個(gè)可用數(shù)據(jù)指針實(shí)現(xiàn)一個(gè)遞增/遞減 (IDx) 位,以指定“INC DPTR”指令是遞增還是遞減活動(dòng)數(shù)據(jù)指針。使用數(shù)據(jù)指針遞減功能,解決方案 #2 特別容易在 Dallas 產(chǎn)品上實(shí)現(xiàn),允許線性傳輸并最大限度地減少執(zhí)行時(shí)間。

為了利用數(shù)據(jù)指針遞減功能,應(yīng)用程序代碼首先必須確定源和目標(biāo)范圍是否以及如何重疊,即使數(shù)據(jù)指針遞減功能不可用,也會(huì)執(zhí)行該任務(wù)。當(dāng)檢測(cè)到有潛在問(wèn)題的源/目標(biāo)緩沖區(qū)重疊時(shí),數(shù)據(jù)指針將放置在相應(yīng)源/目標(biāo)副本范圍的末尾,并將 IDx 位配置為啟用數(shù)據(jù)指針遞減模式。下面提供了解決方案 #2 的示例代碼。請(qǐng)注意,DPTR 切換(“INC DPS”)和遞增/遞減(“INC DPTR”)功能包含在代碼中,僅用于理解,如果設(shè)置了相應(yīng)的自動(dòng)切換和/或自動(dòng)遞增/遞減位,則可以將其刪除。

審核編輯:郭婷

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(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)投訴
  • 微控制器
    +關(guān)注

    關(guān)注

    48

    文章

    7564

    瀏覽量

    151515
  • 存儲(chǔ)器
    +關(guān)注

    關(guān)注

    38

    文章

    7495

    瀏覽量

    163921
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    8

    文章

    3029

    瀏覽量

    74103
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    緩沖區(qū)的解釋

    (FIFO,F(xiàn)irst In First Out)的,NI的數(shù)據(jù)采集卡應(yīng)該是都有板載的緩沖區(qū),區(qū)別在于緩沖區(qū)的大小而已。然后當(dāng)板載緩沖區(qū)中的數(shù)據(jù)
    發(fā)表于 04-07 15:56

    STM32進(jìn)階之串口環(huán)形緩沖區(qū)實(shí)現(xiàn)

    兩個(gè)指針,一個(gè)指向列隊(duì)頭,一個(gè)指向列隊(duì)尾。指向列隊(duì)頭的指針(Head)是緩沖區(qū)可讀的數(shù)據(jù),指向列隊(duì)尾的指針(Tail)是
    發(fā)表于 06-08 14:03

    STM32串口環(huán)形緩沖區(qū)的實(shí)現(xiàn)

    一個(gè)數(shù)組,只不過(guò)有兩個(gè)指針,一個(gè)指向列隊(duì)頭,一個(gè)指向列隊(duì)尾。指向列隊(duì)頭的指針(Head)是緩沖區(qū)可讀的數(shù)據(jù),指向列隊(duì)尾的指針(Tail)是
    發(fā)表于 10-16 11:40

    什么是緩沖區(qū)功能

    嗨,大家好:我是FPGA設(shè)計(jì)的新手。什么是緩沖區(qū)功能。如果我沒(méi)有在應(yīng)該使用它們的地方使用緩沖區(qū),我可能面臨什么樣的問(wèn)題。以上來(lái)自于谷歌翻譯以下為原文hi guys: I'm a new
    發(fā)表于 01-24 09:44

    基于ARM和FPGA的環(huán)形緩沖區(qū)接口設(shè)計(jì)方案

    來(lái)設(shè)計(jì)的。在本方案中,F(xiàn)PGA存儲(chǔ)器空間包括兩個(gè)部分:寄存器空間和數(shù)據(jù)緩沖區(qū)空間。寄存器空間用于設(shè)置各種讀寫(xiě)的參數(shù),包括緩沖區(qū)讀寫(xiě)指針、緩沖區(qū)
    發(fā)表于 05-30 05:00

    CPU與GPU維護(hù)數(shù)據(jù)結(jié)構(gòu)來(lái)保證環(huán)形緩沖區(qū)的正確工作

    CPU 和 GPU 將各自維護(hù)一些數(shù)據(jù)結(jié)構(gòu)來(lái)保證環(huán)形緩沖區(qū)的正確工作。這些 數(shù)據(jù)結(jié)構(gòu)有緩沖區(qū)的基地址,緩沖區(qū)大小,寫(xiě)
    的頭像 發(fā)表于 03-30 15:01 ?6471次閱讀
    CPU與GPU維護(hù)<b class='flag-5'>數(shù)據(jù)</b>結(jié)構(gòu)來(lái)保證環(huán)形<b class='flag-5'>緩沖區(qū)</b>的正確工作

    環(huán)形緩沖區(qū)的實(shí)現(xiàn)原理

    在通信程序中,經(jīng)常使用環(huán)形緩沖區(qū)作為數(shù)據(jù)結(jié)構(gòu)來(lái)存放通信中發(fā)送和接收的數(shù)據(jù)。環(huán)形緩沖區(qū)是一個(gè)先進(jìn)先出的循環(huán)緩沖區(qū),可以向通信程序提供對(duì)
    的頭像 發(fā)表于 03-22 10:03 ?7552次閱讀
    環(huán)形<b class='flag-5'>緩沖區(qū)</b>的實(shí)現(xiàn)原理

    緩沖區(qū)是啥意思 STM32串口數(shù)據(jù)接收之環(huán)形緩沖區(qū)

    完成。 缺點(diǎn): ①緩沖數(shù)據(jù)組數(shù)一定,且有多變量,代碼結(jié)構(gòu)不太清晰。 ②接收數(shù)據(jù)長(zhǎng)度可能大于數(shù)組大小,也可能小于數(shù)組大小。不靈活,需要接收數(shù)據(jù)很長(zhǎng)時(shí)容易出錯(cuò),且
    的頭像 發(fā)表于 07-22 15:33 ?1.1w次閱讀

    STM32串口數(shù)據(jù)接收 --環(huán)形緩沖區(qū)

    STM32串口數(shù)據(jù)接收 --環(huán)形緩沖區(qū)環(huán)形緩沖區(qū)簡(jiǎn)介??在單片機(jī)中串口通信是我們使用最頻繁的,使用串口通信就會(huì)用到串口的數(shù)據(jù)接收與發(fā)送,環(huán)形緩沖區(qū)
    發(fā)表于 12-28 19:24 ?31次下載
    STM32串口<b class='flag-5'>數(shù)據(jù)</b>接收 --環(huán)形<b class='flag-5'>緩沖區(qū)</b>

    消除IoT上的緩沖區(qū)溢出漏洞

    黑客可以使用堆棧緩沖區(qū)溢出將可執(zhí)行文件替換為惡意代碼,從而允許他們利用堆內(nèi)存或調(diào)用堆棧本身等系統(tǒng)資源。例如,控制流劫持利用堆棧緩沖區(qū)溢出將代碼執(zhí)行重定向到正常操作中使用的位置以外的位置
    的頭像 發(fā)表于 10-12 15:25 ?937次閱讀
    消除IoT上的<b class='flag-5'>緩沖區(qū)</b>溢出漏洞

    消除物聯(lián)網(wǎng)上的緩沖區(qū)溢出漏洞

      黑客可以使用堆棧緩沖區(qū)溢出將可執(zhí)行文件替換為惡意代碼,從而使他們能夠利用堆內(nèi)存或調(diào)用堆棧本身等系統(tǒng)資源。例如,控制流劫持利用堆棧緩沖區(qū)溢出將代碼執(zhí)行重定向到正常操作中使用的位置以外
    的頭像 發(fā)表于 12-02 11:57 ?1024次閱讀

    數(shù)據(jù)指針遞減功能簡(jiǎn)化了重疊內(nèi)存緩沖區(qū)復(fù)制操作

    利用Maxim高速微控制器系列中的數(shù)據(jù)指針遞減功能,可以簡(jiǎn)化存儲(chǔ)器管理。本應(yīng)用筆記探討了該系列微控制器在DS80C400、DS5250、DS
    的頭像 發(fā)表于 02-20 09:27 ?493次閱讀
    <b class='flag-5'>數(shù)據(jù)</b><b class='flag-5'>指針</b><b class='flag-5'>遞減</b><b class='flag-5'>功能</b><b class='flag-5'>簡(jiǎn)化了</b><b class='flag-5'>重疊</b><b class='flag-5'>內(nèi)存</b><b class='flag-5'>緩沖區(qū)</b>的<b class='flag-5'>復(fù)制</b><b class='flag-5'>操作</b>

    C++環(huán)形緩沖區(qū)設(shè)計(jì)與實(shí)現(xiàn)

    Buffer) 環(huán)形緩沖區(qū)(Circular Buffer),也被稱為循環(huán)緩沖區(qū)(Cyclic Buffer)或者環(huán)形隊(duì)列(Ring Buffer),是一種數(shù)據(jù)結(jié)構(gòu)類型,它在內(nèi)存中形
    的頭像 發(fā)表于 11-09 11:21 ?2111次閱讀
    C++環(huán)形<b class='flag-5'>緩沖區(qū)</b>設(shè)計(jì)與實(shí)現(xiàn)

    操作系統(tǒng)不同的緩沖區(qū)概念

    就來(lái)區(qū)分一下不同的緩沖區(qū)概念(主要針對(duì)類unix平臺(tái))。 用戶進(jìn)程和操作系統(tǒng)的關(guān)系,首先我用一張圖來(lái)解釋“用戶進(jìn)程和操作系統(tǒng)的關(guān)系: 這是一個(gè)計(jì)算機(jī)系統(tǒng)運(yùn)行時(shí)的簡(jiǎn)化模型,我們把所有運(yùn)行
    的頭像 發(fā)表于 11-10 10:38 ?1321次閱讀
    <b class='flag-5'>操作</b>系統(tǒng)不同的<b class='flag-5'>緩沖區(qū)</b>概念

    內(nèi)存緩沖區(qū)內(nèi)存的關(guān)系

    內(nèi)存緩沖區(qū)內(nèi)存之間的關(guān)系是計(jì)算機(jī)體系結(jié)構(gòu)中一個(gè)至關(guān)重要的方面,它們共同協(xié)作以提高數(shù)據(jù)處理的效率和系統(tǒng)的整體性能。
    的頭像 發(fā)表于 09-10 14:38 ?614次閱讀