久久久精品2019中文字幕神马_欧美亚洲一区三区_欧美大人香蕉在线_精品88久久久久88久久久_中文字幕一区二区三区在线播放 _精品国产一区二区三区久久影院_欧洲av在线精品_粉嫩av一区二区三区_亚洲欧美一区二区三区极速播放_国产亚洲精品久久

首頁 > 汽車

基于DWC_ether_qos的以太網(wǎng)驅(qū)動開發(fā)-LWIP的堆(內(nèi)存池)未對齊導(dǎo)致問題的案例分享

來源:面包芯語 時(shí)間:2023-09-09 13:12:32

一.前言

內(nèi)存未對齊訪問問題這個(gè)已經(jīng)是老生常談的問題了, 由于LWIP的堆管理中也用到了地址(指針)強(qiáng)制轉(zhuǎn)換所以也會遇到這個(gè)問題。對于老手比較容易發(fā)現(xiàn),對于新手可能會比較疑惑。所以也單獨(dú)分享一個(gè)案例吧,權(quán)當(dāng)一個(gè)小的check list的case。

二.問題

Lwipopts.h中MEM_ALIGNMENT可以配置堆對齊大小,有問題時(shí)是配置為1


(資料圖片僅供參考)

#define MEM_ALIGNMENT 1U

異常時(shí)打印寄存器如下,當(dāng)然不同平臺異常時(shí)如何獲取上下文信息方式不一樣,不在本文討論范圍內(nèi),我這里是RISC-V環(huán)境。

看到打印的mepc是0x20006C88,異常原因是地址未對齊。

所以是在運(yùn)行0x20006C88時(shí)進(jìn)入了異常,當(dāng)然這個(gè)地方不一定是原始問題所在點(diǎn),異常可能是跑了很久才出現(xiàn)的。

所以先在這里打個(gè)斷點(diǎn)試試

可以看到是pbuf.c的代碼中,所以可以懷疑是內(nèi)存池或者堆的問題。

我們運(yùn)行發(fā)現(xiàn)斷點(diǎn)并不能觸發(fā),之前就已經(jīng)異常了,所以只能跟代碼逐漸縮小范圍確認(rèn)問題的。一般采用的方式是,逐步斷點(diǎn)或者打印或者刪除代碼,逐步縮小范圍的方法。

可以借鑒一些二分的思想,加快定位。

這里還是從pbuf開始,先找到相關(guān)代碼上層函數(shù)處,斷點(diǎn)

b pbuf_init_alloced_pbuf

看到異常前是可以停下來的

看到此時(shí)p的值是0x28201406

查看如下匯編代碼可知

sw zero,0(a0)即對應(yīng)代碼p->next = NULL;

sw是word操作指令,但是地址a0不是word對齊,所以會產(chǎn)生異常

再si單步確實(shí)進(jìn)入異常

所以問題確認(rèn)了。

因?yàn)槎咽欠峙涞囊粔K區(qū)域,每一塊區(qū)域的開始地址對齊值就是上面設(shè)置的對齊大小,分配區(qū)塊后作為其他模塊使用,比如pbuf使用,前面部分作為管理結(jié)構(gòu)體

struct pbuf 操作,所以實(shí)際是將一個(gè)區(qū)塊地址強(qiáng)制轉(zhuǎn)為了結(jié)構(gòu)體指針。

此時(shí)訪問結(jié)構(gòu)體成員,編譯器是自動按照自然對齊生成匯編指令的,因?yàn)榫幾g器并不知道你的對齊要求,所以如果系統(tǒng)不支持對應(yīng)的指令非對其訪問就有問題,但是有些系統(tǒng)對應(yīng)的匯編指令的行為支持不對齊訪問那么就沒有問題。

當(dāng)然出于可靠性設(shè)計(jì),建議不要進(jìn)行強(qiáng)制類型轉(zhuǎn)換,比如MISRA標(biāo)準(zhǔn)里的規(guī)范就是如此。

如果代碼要做到兼容性可靠性非常好就要注意這個(gè)問題,此時(shí)不能使用強(qiáng)制類型轉(zhuǎn)換,而是使用字節(jié)序手動拼接得到成員的值。

但是出于靈活性考慮,很多協(xié)議棧的設(shè)計(jì)都是直接使用強(qiáng)制類型轉(zhuǎn)換的,所以這時(shí)用戶就需要注意,比如這里我們可以配置#define MEM_ALIGNMENT 4U

來保證上述分配出來的地址p是4字節(jié)對齊的,所以按照偏移,其成員也是4字節(jié)對齊的,sw指令操作的就是4字節(jié)對齊的成員,就不會有問題。

三.總結(jié)

以上分享一個(gè)簡單的案例,目的是提醒下要注意類似問題,尤其有指針強(qiáng)制類型轉(zhuǎn)換的要注意對齊問題。問題不難,也不復(fù)雜,但是可以作為check list的case可以作為檢查項(xiàng)目。

相關(guān)稿件

基于DWC_ether_qos的以太網(wǎng)驅(qū)動開發(fā)-LWIP的堆(內(nèi)存池)未對齊導(dǎo)致問題的案例分享

宗茂林(宗茂)

云杰:黃金1920多接1929空驗(yàn)證,后市將看跌1904

您好?我被偷拍私密視頻后被人傳播了?我有他偷拍的聊天記錄?但

2023美網(wǎng):中國新銳正當(dāng)時(shí)

廣東廣州:幼蛇頻頻出沒 小貓“大戰(zhàn)”眼鏡蛇

從“跳水大爺” 到安全志愿者

安徽豆粉云信息科技有限公司_關(guān)于安徽豆粉云信息科技有限公司介紹

高盛策略師:美國經(jīng)濟(jì)衰退可能性正在上升

華為智慧屏V5 Pro即將上市:98英寸巨幕影院

賠835.4萬 巴奴火鍋為子品牌超島涉事羊肉買單

《幽靈行者2》初代超過250萬份 發(fā)行商宣布

周杰倫天津演唱會發(fā)生意外?經(jīng)紀(jì)公司凌晨回應(yīng)

周末天氣多變,防雨水突襲?

通報(bào):山西一人搶救無效死亡!

公告精選:商品代雞苗售價(jià)大漲 民和股份8月銷售收入環(huán)比增加41%

滴滴出行虧損1.4億元 單量持續(xù)增加

中國8月狂賣192萬輛汽車創(chuàng)同期史高 自主品牌破100萬

張寶成是誰 張寶成

長春到沈陽高鐵幾小時(shí)

長春到沈陽高鐵啥時(shí)候開通的

馬蒂諾:如果梅西能出戰(zhàn)玻利維亞,我認(rèn)為他不會提前回到俱樂部

外媒:日本二季度GDP下修為年率增4.8%

信科移動:9月7日公司高管李秉成增持公司股份合計(jì)5800股

智力英文單詞怎么寫(智力英文)

一次開藥1800片?江西通報(bào)三起超量開藥類違規(guī)案例

華商記者幫|長安天然氣公司要求商戶整改安裝電磁閥 商戶們覺得其下屬子公司的“一口價(jià)”報(bào)價(jià)有些貴

茶坊鎮(zhèn)東紅村扶貧互助資金協(xié)會(關(guān)于茶坊鎮(zhèn)東紅村扶貧互助資金協(xié)會簡述)

一高校食堂檔口因不漲價(jià)被罰?校方:中止外包

若你成風(fēng)(關(guān)于若你成風(fēng)簡述)


久久久精品2019中文字幕神马_欧美亚洲一区三区_欧美大人香蕉在线_精品88久久久久88久久久_中文字幕一区二区三区在线播放 _精品国产一区二区三区久久影院_欧洲av在线精品_粉嫩av一区二区三区_亚洲欧美一区二区三区极速播放_国产亚洲精品久久
欧美日韩国产影片| 无码av免费一区二区三区试看| 国产欧美日产一区| 夜夜爽夜夜爽精品视频| 久久精品国内一区二区三区 | 国产精品欧美极品| 国产精品人成在线观看免费| 丝袜亚洲另类欧美综合| 亚洲成人你懂的| 免费高清视频精品| 国产乱码字幕精品高清av| 免费人成网站在线观看欧美高清| 欧美亚洲国产一区二区三区va| 亚洲国产激情av| 亚洲免费观看高清| 久久蜜桃一区二区| 欧美视频三区在线播放| 91一区二区三区在线观看| 成人午夜视频免费看| 亚洲精品一区二区三区精华液| 91热门视频在线观看| 欧美日韩激情在线| 日韩主播视频在线| 亚洲猫色日本管| 中文字幕精品在线不卡| 成人永久aaa| 亚洲免费视频成人| 91精品国产麻豆国产自产在线 | 国产999精品久久久久久绿帽| 亚洲午夜一区二区三区| 亚洲老司机在线| 不卡视频一二三四| 精品国产亚洲在线| 国产精品久久久久久久蜜臀| 91精品婷婷国产综合久久性色| 久久色视频免费观看| 亚洲人xxxx| 国产aⅴ综合色| 精品av久久707| 国产乱码精品一品二品| 日韩一区在线看| 国产精品久久午夜夜伦鲁鲁| 狠狠色狠狠色综合日日91app| 在线播放中文字幕一区| 中文字幕不卡的av| 91蜜桃免费观看视频| 亚洲午夜一区二区| 日本高清不卡aⅴ免费网站| 在线看不卡av| 精品视频999| 丁香啪啪综合成人亚洲小说| 国产欧美日韩在线视频| 欧美一区二区在线免费播放 | 国产精品黄色在线观看| 国产一区二区影院| 日韩三级免费观看| 在线亚洲欧美专区二区| 激情图片小说一区| 秋霞电影网一区二区| 国产精品免费久久| 亚洲成av人片在线观看| 日韩欧美亚洲国产另类| 8v天堂国产在线一区二区| 亚洲一区二区在线免费看| 欧美性生活大片视频| 男女激情视频一区| 国产日产欧产精品推荐色| 国产成人免费网站| 国产精品国模大尺度视频| 不卡的av中国片| 午夜影院久久久| 9i在线看片成人免费| 日韩一卡二卡三卡国产欧美| 国产精品人成在线观看免费| 从欧美一区二区三区| 一区二区三区在线观看网站| 在线欧美日韩国产| 欧美在线观看一区| 亚洲综合在线第一页| 91精品欧美福利在线观看| 亚洲精品久久久蜜桃| 蜜臀a∨国产成人精品| 丁香啪啪综合成人亚洲小说| 成人午夜视频免费看| 亚洲国产高清在线| 欧洲av在线精品| 久久精品一区二区三区不卡| 99re成人精品视频| 99热这里都是精品| 国产精品人妖ts系列视频 | 欧美日韩精品一区二区三区蜜桃| 国产精品福利av| 精品视频免费看| 欧美疯狂做受xxxx富婆| 91高清视频免费看| 日韩欧美三级在线| 国产调教视频一区| 欧美高清视频不卡网| 国产传媒日韩欧美成人| 视频一区二区中文字幕| 亚洲男人都懂的| 欧洲国内综合视频| 国产精品嫩草影院av蜜臀| 激情都市一区二区| 成人免费一区二区三区视频| 日韩亚洲电影在线| 欧美日韩成人高清| 99re亚洲国产精品| 日韩三级电影网址| 91精品国产丝袜白色高跟鞋| 国产乱理伦片在线观看夜一区| 色偷偷成人一区二区三区91| 欧美高清视频不卡网| 亚洲欧洲成人精品av97| 丝袜脚交一区二区| 欧美色男人天堂| 午夜欧美2019年伦理| 5566中文字幕一区二区电影 | 欧美在线观看视频一区二区三区| 亚洲成人在线网站| 色婷婷久久一区二区三区麻豆| 日韩一区二区在线看| 日本成人中文字幕在线视频| 欧美专区亚洲专区| 日韩欧美中文字幕公布| 精品午夜一区二区三区在线观看| 亚洲国产精品精华液2区45| 顶级嫩模精品视频在线看| 国产精品18久久久久| 久久精品日韩一区二区三区| 国产精品一区二区x88av| 久久国产乱子精品免费女| 91精品中文字幕一区二区三区| 亚洲人成亚洲人成在线观看图片 | 亚洲三级久久久| 亚洲一区二区三区四区的| 欧美视频一区二区在线观看| 久久精品国产在热久久| 欧美亚洲国产一区在线观看网站| 国产精品乱码妇女bbbb| 亚洲女与黑人做爰| 亚洲精品一区二区三区99| 成人精品在线视频观看| 成人精品一区二区三区四区| 久久99久久99精品免视看婷婷| 日韩一级片网址| 国产丶欧美丶日本不卡视频| 日韩区在线观看| 欧美精品一卡两卡| 欧美色综合久久| 亚洲精品久久久蜜桃| 欧美性大战久久久久久久蜜臀| 一区二区免费在线| 欧美日韩高清一区| 精品亚洲aⅴ乱码一区二区三区| 日本一不卡视频| 亚洲电影激情视频网站| 欧洲精品中文字幕| 一区二区三区影院| 欧美亚洲一区三区| 日韩三级免费观看| 不卡影院免费观看| 香蕉久久夜色精品国产使用方法| 9久草视频在线视频精品| 91麻豆自制传媒国产之光| 久久99国产乱子伦精品免费| 青椒成人免费视频| 国产在线精品一区二区夜色| 青青草97国产精品免费观看无弹窗版| 激情六月婷婷久久| 亚洲精品成人天堂一二三| 国产一区二区影院| 国产亚洲短视频| 欧美高清dvd| 亚洲成人激情自拍| 丁香婷婷深情五月亚洲| 国产精品天天摸av网| heyzo一本久久综合| 国产99久久久国产精品免费看| 久久综合综合久久综合| 日本一区二区成人| 欧美日韩电影在线播放| 91麻豆国产自产在线观看| 在线观看日韩高清av| 亚洲影院在线观看| 久久99久久精品| 9人人澡人人爽人人精品| 老司机精品视频在线| 亚洲成人自拍一区| 亚洲欧美在线视频观看| 国产毛片精品国产一区二区三区| 久久精品国产99国产| 国产+成+人+亚洲欧洲自线| 欧美tickling网站挠脚心| 色综合久久久久综合99| 日韩国产欧美一区二区三区| 欧美性videosxxxxx| 亚洲精品一二三四区| 不卡一区在线观看| 国产精品蜜臀av|