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

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

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

CPU具體主要顯示了哪些代碼?

lhl545545 ? 來源:玩轉(zhuǎn)單片機(jī) ? 作者:玩轉(zhuǎn)單片機(jī) ? 2020-06-18 15:56 ? 次閱讀

嵌入式軟件開發(fā)過程中,一般來說,花在測試和花在編碼的時間比為3:1(實際上可能更多)。這個比例隨著你的編程和測試水平的提高而不斷下降,但不論怎樣,軟件測試對一般人來講很重要。

很多年前,一位開發(fā)人員為了在對嵌入式有更深層次的理解,詢問了這樣的一個問題:我怎么才能知道并懂得我的系統(tǒng)到底在干些什么呢?

面對這個問題有些吃驚,因為在當(dāng)時沒有人這么問過,而同時代的嵌入式開發(fā)人員問的最多的大都圍繞“我怎么才能使程序跑得更快”、“什么編譯器最好”等膚淺的問題。

所以,面對這個不同尋常卻異乎成熟的問題,我感到欣喜并認(rèn)真回復(fù)了他:你的問題很有深度很成熟,因為只有不斷地去深入理解才有可能不斷地提高水平。為了鼓勵這位執(zhí)著的程序員,把10條關(guān)于嵌入式軟件開發(fā)測試的秘訣告訴了他。下面我們一起來看看。

這十條秘訣在業(yè)界廣為流傳,使很多人受益。本文圍繞這十條秘訣展開論述。

1、懂得使用工具

通常嵌入式系統(tǒng)對可靠性的要求比較高。嵌入式系統(tǒng)安全性的失效可能會導(dǎo)致災(zāi)難性的后果,即使是非安全性系統(tǒng),由于大批量生產(chǎn)也會導(dǎo)致嚴(yán)重的經(jīng)濟(jì)損失。這就要求對嵌入式系統(tǒng),包括嵌入式軟件進(jìn)行嚴(yán)格的測試、確認(rèn)和驗證。隨著越來越多的領(lǐng)域使用軟件和微處理器控制各種嵌入式設(shè)備,對日益復(fù)雜的嵌入式軟件進(jìn)行快速有效的測試愈加顯得重要。

就像修車需要工具一樣,好的程序員應(yīng)該能夠熟練運用各種軟件工具。不同的工具,有不同的使用范圍,有不同的功能。使用這些工具,你可以看到你的系統(tǒng)在干些什么,它又占用什么資源,它到底和哪些外界的東西打交道。讓你郁悶好幾天的問題可能通過某個工具就能輕松搞定,可惜你就是不知道。

那么為什么那么多的人總是在折騰個半死之后才想到要用測試工具呢?原因很多,主要有兩個:

一個是害怕;

另一個是惰性;

害怕是因為加入測試工具或測試模塊到代碼需要技巧同時有可能引入新的錯誤,所以他們總喜歡寄希望于通過不斷地修改重編譯代碼來消除bug,結(jié)果卻無濟(jì)于事。

懶惰是因為他們習(xí)慣了使用printf之類的簡單測試手段。

下面來介紹一些嵌入式常用的測試工具

(1)、源碼級調(diào)試器[Source-levelDebugger]

這種調(diào)試器一般提供單步或多步調(diào)試、斷點設(shè)置、內(nèi)存檢測、變量查看等功能,是嵌入式調(diào)試最根本有效的調(diào)試方法。比如VxWorksTornadoII提供的gdb就屬于這一種。

(2)、簡單實用的打印顯示工具 [printf]

printf或其它類似的打印顯示工具估計是最靈活最簡單的調(diào)試工具。打印代碼執(zhí)行過程中的各種變量可以讓你知道代碼執(zhí)行的情況。但是,printf對正常的代碼執(zhí)行干擾比較大(一般printf占用CPU比較長的時間),需要慎重使用,最好設(shè)置打印開關(guān)來控制打印。

(3)、ICE或JTAG調(diào)試器[In- circuitEmulator

ICE是用來仿真CPU核心的設(shè)備,它可以在不干擾運算器的正常運行情況下,實時的檢測CPU的內(nèi)部工作情況。像桌面調(diào)試軟件所提供的:復(fù)雜的條件斷點、先進(jìn)的實時跟蹤、性能分析和端口分析這些功能,它也都能提供。ICE一般都有一個比較特殊的CPU,稱為外合(bond-out)CPU.這是一種被打開了封裝的CPU,并且通過特殊的連接,可以訪問到CPU的內(nèi)部信號,而這些信號,在CPU被封裝時,是沒法 “看到”的。當(dāng)和工作站上強(qiáng)大的調(diào)試軟件聯(lián)合使用時,ICE就能提供你所能找到的最全面的調(diào)試功能。但I(xiàn)CE同樣有一些缺點:昂貴;不能全速工作;同樣,并不是所有的CPU都可以作為外合CPU的,從另一個角度說,這些外合CPU也不大可能及時的被新出的CPU所更換。JTAG(JointTestActionGroup)雖然它最初開發(fā)出來是為了監(jiān)測IC和電路連接,但是這種串行接口擴(kuò)展了用途,包括對調(diào)試的支持。

(4)、ROM監(jiān)視器 [ROMMonitor]

ROM監(jiān)控器是一小程序,駐留在嵌入系統(tǒng)ROM中,通過串行的或網(wǎng)絡(luò)的連接和運行在工作站上的調(diào)試軟件通信。這是一種便宜的方式,當(dāng)然也是最低端的技術(shù)。它除了要求一個通信端口和少量的內(nèi)存空間外,不需要其它任何專門的硬件。

提供了如下功能:下載代碼、運行控制、斷點、單步步進(jìn)、以及觀察、修改寄存器和內(nèi)存。因為ROM監(jiān)控器是操作軟件的一部分,只有當(dāng)你的應(yīng)用程序運行時,它才會工作。如果你想檢查CPU和應(yīng)用程序的狀態(tài),你就必須停下應(yīng)用程序,再次進(jìn)入ROM監(jiān)控器。

(5)、Data監(jiān)視器 [DataMonitor]

這種監(jiān)視器在不停止CPU運行的情況下不僅可以顯示指定變量內(nèi)容,還可以收集并以圖形形式顯示各個變量的變化過程。

(6)、OS監(jiān)視器 [OperatingSystemMonitor]

操作系統(tǒng)監(jiān)視器可以顯示諸如任務(wù)切換、信號量收發(fā)、中斷等事件。一方面,這些監(jiān)視器能夠為你呈現(xiàn)事件之間的關(guān)系和時間聯(lián)系;另一方面,還可以提供對信號量優(yōu)先級反轉(zhuǎn)、死鎖和中斷延時等問題的診斷。

(7)、性能分析工具 [Profiler]

可以用來測試CPU到底耗在哪里。profiler工具可以讓你知道系統(tǒng)的瓶頸在哪里、CPU的使用率以及需要優(yōu)化的地方。

(8)、內(nèi)存測試工具 [MemoryTeseter]

可以找到內(nèi)存使用的問題所在,比如內(nèi)存泄露、內(nèi)存碎片、內(nèi)存崩潰等問題。如果發(fā)現(xiàn)系統(tǒng)出現(xiàn)一些不可預(yù)知的或間歇性的問題,就應(yīng)該使用內(nèi)存測試工具測測看。

(8)、運行跟蹤器 [ExecutionTracer]

可以顯示CPU執(zhí)行了哪些函數(shù)、誰在調(diào)用、參數(shù)是什么、何時調(diào)用等情況。這種工具主要用于測試代碼邏輯,可以在大量的事件中發(fā)現(xiàn)異常。

(9)、覆蓋工具[CoverageTester]

主要顯示CPU具體執(zhí)行了哪些代碼,并讓你知道那些代碼分支沒有被執(zhí)行到哪里。這樣有助于提高代碼質(zhì)量并消除無用代碼。

(10)、GUI測試工具 [GUITester]

很多嵌入式應(yīng)用帶有某種形式的圖形用戶界面進(jìn)行交互,有些系統(tǒng)性能測試是根據(jù)用戶輸入響應(yīng)時間進(jìn)行的。GUI測試工具可以作為腳本工具有開發(fā)環(huán)境中運行測試用例,其功能包括對操作的記錄和回放、抓取屏幕顯示供以后分析和比較、設(shè)置和管理測試過程(Rational 公司的robot和Mercury的Loadrunner工具是杰出的代表)。

很多嵌入式設(shè)備沒有GUI,但常??梢詫η度胧皆O(shè)備進(jìn)行插裝來運行GUI測試腳本,雖然這種方式可能要求對被測代碼進(jìn)行更改,但是節(jié)省了功能測試和回歸測試的時間。

(11)、自制工具 [Home-madetester]

在嵌入式應(yīng)用中,有時候為了特定的目的,需要自行編寫一些工具來達(dá)到某種測試目的。本人曾經(jīng)編寫的視頻流錄顯工具在測試視頻會議數(shù)據(jù)流向和變化上幫了大忙,幫公司找到了幾個隱藏很深的bug。

2、盡早發(fā)現(xiàn)內(nèi)存問題

內(nèi)存問題危害很大,不容易排查,主要有三種類型:內(nèi)存泄露、內(nèi)存碎片和內(nèi)存崩潰。對于內(nèi)存問題態(tài)度必須要明確,那就是早發(fā)現(xiàn)早“治療”。在軟件設(shè)計中,內(nèi)存泄露的“名氣”最大,主要由于不斷分配的內(nèi)存無法及時地被釋放,久而久之,系統(tǒng)的內(nèi)存耗盡。

即使細(xì)心的編程老手有時后也會遭遇內(nèi)存泄露問題。有測試過內(nèi)存泄露的朋友估計都有深刻地體驗,那就是內(nèi)存泄露問題一般隱藏很深,很難通過代碼閱讀來發(fā)現(xiàn)。有些內(nèi)存泄露甚至可能出現(xiàn)在庫當(dāng)中。有可能這本身是庫中的bug,也有可能是因為程序員沒有正確理解它們的接口說明文檔造成錯用。

在很多時候,大多數(shù)的內(nèi)存泄露問題無法探測,但可能表現(xiàn)為隨機(jī)的故障。程序員們往往會把這種現(xiàn)象怪罪于硬件問題。如果用戶對系統(tǒng)穩(wěn)定性不是很高,那么重啟系統(tǒng)問題也不大;但,如果用戶對系統(tǒng)穩(wěn)定很高,那么這種故障就有可能使用戶對產(chǎn)品失去信心,同時也意味著你的項目是個失敗的項目。

由于內(nèi)存泄露危害巨大,現(xiàn)在已經(jīng)有許多工具來解決這個問題。這些工具通過查找沒有引用或重復(fù)使用的代碼塊、垃圾內(nèi)存收集、庫跟蹤等技術(shù)來發(fā)現(xiàn)內(nèi)存泄露的問題。每個工具都有利有弊,不過總的來說,用要比不用好。總之,負(fù)責(zé)的開發(fā)人員應(yīng)該去測試內(nèi)存泄露的問題,做到防患于未然。

內(nèi)存碎片比內(nèi)存泄露隱藏還要深。隨著內(nèi)存的不斷分配并釋放,大塊內(nèi)存不斷分解為小塊內(nèi)存,從而形成碎片,久而久之,當(dāng)需要申請大塊內(nèi)存是,有可能就會失敗。如果系統(tǒng)內(nèi)存夠大,那么堅持的時間會長一些,但最終還是逃不出分配失敗的厄運。在使用動態(tài)分配的系統(tǒng)中,內(nèi)存碎片經(jīng)常發(fā)生。

目前,解決這個問題最效的方法就是使用工具通過顯示系統(tǒng)中內(nèi)存的使用情況來發(fā)現(xiàn)誰是導(dǎo)致內(nèi)存碎片的罪魁禍?zhǔn)?,然后改進(jìn)相應(yīng)的部分。由于動態(tài)內(nèi)存管理的種種問題,在嵌入式應(yīng)用中,很多公司干脆就禁用malloc/free的以絕后患。

內(nèi)存崩潰是內(nèi)存使用最嚴(yán)重的結(jié)果,主要原因有數(shù)組訪問越界、寫已經(jīng)釋放的內(nèi)存、指針計算錯誤、訪問堆棧地址越界等等。這種內(nèi)存崩潰造成系統(tǒng)故障是隨機(jī)的,而且很難查找,目前提供用于排查的工具也很少。

總之,如果要使用內(nèi)存管理單元的話,必須要小心,并嚴(yán)格遵守它們的使用規(guī)則,比如誰分配誰釋放。

3、深入理解代碼優(yōu)化

講到系統(tǒng)穩(wěn)定性,人們更多地會想到實時性和速度,因為代碼效率對嵌入式系統(tǒng)來說太重要了。知道怎么優(yōu)化代碼是每個嵌入式軟件開發(fā)人員必須具備的技能。就像女孩子減肥一樣,起碼知道她哪個地方最需要減,才能去購買減肥藥或器材來減掉它。

可見,代碼優(yōu)化的前提是找到真正需要優(yōu)化的地方,然后對癥下藥,優(yōu)化相應(yīng)部分的代碼。前面提到的profile(性能分析工具,一些功能齊全I(xiàn)DE都提供這種內(nèi)置的工具)能夠記錄各種情況比如各個任務(wù)的CPU占用率、各個任務(wù)的優(yōu)先級是否分配妥當(dāng)、某個數(shù)據(jù)被拷貝了多少次、訪問磁盤多少次、是否調(diào)用了網(wǎng)絡(luò)收發(fā)的程序、測試代碼是否已經(jīng)關(guān)閉等等。

但是,profile工具在分析實時系統(tǒng)性能方面還是有不夠的地方。一方面,人們使用profile工具往往是在系統(tǒng)出現(xiàn)問題即CPU耗盡之后,而 profile工具本身對CPU占用較大,所以profile對這種情況很可能不起作用。根據(jù)Heisenberg效應(yīng),任何測試手段或多或少都會改變系統(tǒng)運行,這個對profiler同樣適用!

總之,提高運行效率的前提是你必須要知道CPU到底干了些什么干的怎么樣。

4、不要讓自己大海撈針

大海撈針只是對調(diào)試的一種生動比喻。經(jīng)常聽到組里有人對自己正在調(diào)試的代碼說shit!可以理解,因為代碼不是他寫的,他有足夠的理由去 shitbug百出的代碼,只要他自己不要寫出這種代碼,否則有一天同組的其它人可能同樣會shit他寫的代碼。為何會有大海撈針呢?肯定是有人把針掉到海里咯;那針為何會掉在海里呢?肯定是有人不小心或草率唄。

所以當(dāng)你在抱怨針那么難找的時候,你是否想過是你自己草率地丟掉的。同樣,當(dāng)你調(diào)試個半死的時候,你是否想過你要好好反省一下當(dāng)初為了尋求捷徑可能沒有嚴(yán)格地遵守好的編碼設(shè)計規(guī)范、沒有檢測一些假設(shè)條件或算法的正確性、沒有將一些可能存在問題的代碼打上記號呢?

關(guān)于如何寫高質(zhì)量請參考林銳的《高質(zhì)量c++/c編程指南》或《關(guān)于C的0x8本“經(jīng)書》。

如果你確實已經(jīng)把針掉在海里是,為了防止在找到之前刺到自己,你必須要做一些防范工作,比如戴上安全手套。同樣,為了盡能地暴露和捕捉問題根源,我們可以設(shè)計比較全面的錯誤跟蹤代碼。

怎么來做呢?

盡可能對每個函數(shù)調(diào)用失敗作出處理,盡可能檢測每個參數(shù)輸入輸出的有效性,包括指針以及檢測是否過多或過少地調(diào)用某個過程。錯誤跟蹤能夠讓你知道你大概把針掉在哪個位置。

5、重現(xiàn)并隔離問題

如果你不是把針掉在大海了,而是掉在草堆里,那要好辦些。因為至少我們可以把草堆分成很多塊,一塊一塊的找。對于模塊獨立的大型項目,使用隔離方法往往是對付那些隱藏極深bug的最后方法。

如果問題的出現(xiàn)是間歇性的,我們有必要設(shè)法去重現(xiàn)它并記錄使其重現(xiàn)的整個過程以備在下一次可以利用這些條件去重現(xiàn)問題。如果你確信可以使用記錄的那些條件去重現(xiàn)問題,那么我們就可以著手去隔離問題。

怎么隔離呢?

我們可以用#ifdef把一些可能和問題無關(guān)的代碼關(guān)閉,把系統(tǒng)最小化到仍能夠重現(xiàn)問題的地步。如果還是無法定位問題所在,那么有必要打開“工具箱”了??梢栽囍肐CE或數(shù)據(jù)監(jiān)視器去查看某個可疑變量的變化;可以使用跟蹤工具獲得函數(shù)調(diào)用的情況包括參數(shù)的傳遞;檢查內(nèi)存是否崩潰以及堆棧溢出的問題。

6、以退為進(jìn)

獵人為了不使自己在森林里迷路,他常常會在樹木上流下一些標(biāo)記,以備自己將來有一天迷路時可以根據(jù)這些標(biāo)記找到出路。對過去代碼的修改進(jìn)行跟蹤記錄對將來出現(xiàn)問題之后的調(diào)試很有幫助。

假如有一天,你最近一次修改的程序跑了很久之后忽然死掉了,那么你這時的第一反映就是我到底改動了些什么呢,因為上次修改之前是好的。那么如何檢測這次相對于上次的修改呢?沒錯,代碼控制系統(tǒng)SCS或稱版本控制系統(tǒng) VCS可以很好地解決這個問題。

將上個版本checkin下來后和當(dāng)前測試版本比較。比較的工 具可以是SCS/VCS/CVS自帶的diff工具或其它功能更強(qiáng)的比較工具,比如BeyondCompare和 ExamDiff。通過比較,記錄所有改動的代碼,分析所有可能導(dǎo)致問題的可疑代碼。

7、確定測試的完整性

你怎么知道你的測試有多全面呢?覆蓋測試(coveragetesting)可以回答這個問題。覆蓋測試工具可以告訴你CPU到底執(zhí)行了哪些代碼。好的覆蓋工具通??梢愿嬖V你大概20%到40% 代碼沒有問題,而其余的可能存在bug.覆蓋工具有不同的測試級別,用戶可以根據(jù)自己的需要選擇某個級別。

即使你很確信你的單元測試已經(jīng)很全面并且沒有 deadcode,覆蓋工具還是可以為你指出一些潛在的問題。

看下面的代碼:

if(i》=0&& (almostAlwaysZero==0||(last=i)))

如果almostAlwaysZero為非0,那么last=i賦值語句就被跳過,這可能不是你所期望的。

這種問題通過覆蓋工具的條件測試功能可以輕松得被發(fā)現(xiàn)??傊采w測試對于提高代碼質(zhì)量很有幫助。

8、提高代碼質(zhì)量意味著節(jié)省時間

有研究表明軟件開發(fā)的時間超過80%被用在下面幾個方面:調(diào)試自己的代碼(單元測試)。調(diào)試自己和其他相關(guān)的代碼(模塊間測試)。調(diào)試整個系統(tǒng)(系統(tǒng)測試),更糟糕的是你可能需要花費10-200倍的時間來找一個 bug,而這個bug在開始的時候可能很容易就能找到。

一個小bug可能讓你付出巨大的代價,即使這個bug對整個系統(tǒng)的性能沒有太大的影響,但很可能會影響讓那些你可以看得到的部分。所以我們必須要養(yǎng)成良好的編碼和測試手段以求更高的代碼質(zhì)量,以便縮短調(diào)試的代碼。

9、發(fā)現(xiàn)它,分析它,解決它

這世界沒有萬能的膏藥。profile再強(qiáng)大也有力不從心的時候;內(nèi)存監(jiān)視器再好,也有無法發(fā)現(xiàn)的時候;覆蓋工具再好用,也有不能覆蓋的地方。

一些隱藏很深的問題即使用盡所有工具也有可能無法查到其根源,這時我們能做的就是通過這些問題所表現(xiàn)出來的外在現(xiàn)象或一些數(shù)據(jù)輸出來發(fā)現(xiàn)其中的規(guī)律或異常。一旦發(fā)現(xiàn)任何異常,一定要深入地理解并回溯其根源,直到解決為止。

10、請利用初學(xué)者思維

有人這樣說過:“有些事情在初學(xué)者的腦子里可能有各種各樣的情況,可在專家的頭腦里可能就很單一”。有時候,有些簡單的問題會被想得很復(fù)雜,有些簡單的系統(tǒng)被設(shè)計得很復(fù)雜,就是由于你的“專家思維”。當(dāng)你被問題難住時,關(guān)掉電腦,出去走走,把你的問題和你的朋友甚至你的小狗說說,或許他們可以給你意想不到的啟發(fā)。

總結(jié)

嵌入式調(diào)試也是一門藝術(shù)。就想其它的藝術(shù)一樣,如果你想取得成功,你必須具備智慧、經(jīng)驗并懂得使用工具。只要我們能夠很好地領(lǐng)悟Oracle這十條秘訣,我相信我們在嵌入式測試方面就能夠取得成功。
責(zé)任編輯:pj

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

    關(guān)注

    68

    文章

    10699

    瀏覽量

    209353
  • 監(jiān)視器
    +關(guān)注

    關(guān)注

    1

    文章

    775

    瀏覽量

    32992
  • 調(diào)試器
    +關(guān)注

    關(guān)注

    1

    文章

    297

    瀏覽量

    23568
收藏 人收藏

    評論

    相關(guān)推薦

    萬界星空科技AI低代碼MES的具體功能及工廠應(yīng)用效果

    萬界星空科技AI低代碼MES的具體功能及工廠應(yīng)用效果,萬界星空科技AI低代碼MES的具體功能及工廠應(yīng)用效果
    的頭像 發(fā)表于 09-18 14:56 ?81次閱讀
    萬界星空科技AI低<b class='flag-5'>代碼</b>MES的<b class='flag-5'>具體</b>功能及工廠應(yīng)用效果

    CPU主要參數(shù)有哪些

    CPU(Central Processing Unit,中央處理器)是計算機(jī)系統(tǒng)的核心部件,負(fù)責(zé)執(zhí)行程序指令、處理數(shù)據(jù)和進(jìn)行邏輯運算。CPU的參數(shù)繁多,但其中一些關(guān)鍵參數(shù)對于理解和選擇CPU至關(guān)重要。
    的頭像 發(fā)表于 09-10 11:51 ?264次閱讀

    CPU故障現(xiàn)象有哪些

    CPU作為計算機(jī)系統(tǒng)的核心部件,其穩(wěn)定性和性能直接影響到整個計算機(jī)系統(tǒng)的運行。當(dāng)CPU出現(xiàn)故障時,會表現(xiàn)出多種不同的現(xiàn)象。以下是對CPU故障現(xiàn)象的詳細(xì)解析,包括常見的故障類型、具體表現(xiàn)
    的頭像 發(fā)表于 09-10 11:46 ?299次閱讀

    CPU主要性能指標(biāo)有哪些

    CPU(中央處理器)的性能指標(biāo)是衡量其處理能力和效率的關(guān)鍵參數(shù)。這些指標(biāo)不僅決定CPU在處理各種任務(wù)時的速度和效率,還影響了整個計算機(jī)系統(tǒng)的性能。
    的頭像 發(fā)表于 09-02 11:01 ?615次閱讀

    __disable_irq()和__enable_irq()函數(shù)的具體定義

    前段時間一工程師向我咨詢一個問題,問我為什么他的MCU KEIL工程代碼里沒有找到__disable_irq() 和 __enable_irq()的具體定義,是不是有問題。
    的頭像 發(fā)表于 08-29 10:06 ?534次閱讀
    __disable_irq()和__enable_irq()函數(shù)的<b class='flag-5'>具體</b>定義

    cpu控制器的主要作用是什么

    CPU控制器,即中央處理器控制器,是計算機(jī)系統(tǒng)中的核心部件之一。它負(fù)責(zé)執(zhí)行程序指令,控制數(shù)據(jù)的輸入輸出,以及協(xié)調(diào)計算機(jī)系統(tǒng)中各個部件的工作。本文將詳細(xì)介紹CPU控制器的主要作用,以及其在計算機(jī)系統(tǒng)中
    的頭像 發(fā)表于 06-30 10:52 ?1211次閱讀

    用Kiel打開代碼時,電腦顯示只讀是怎么回事?

    我是初學(xué)者,在購買開發(fā)板后搜索一些模塊的例程代碼,但當(dāng)用Kiel打開代碼時,電腦顯示只讀,且無法打開具體
    發(fā)表于 05-22 07:45

    關(guān)于STM32 DMAMUX模塊具體的應(yīng)用示例代碼

    有人通過公眾號微信留言,詢問是否有關(guān)于STM32 DMAMUX模塊具體的應(yīng)用示例代碼。同時,個人也發(fā)現(xiàn),雖然STM32片內(nèi)的DMAMUX不是什么新模塊,似乎還是很多人并不太熟悉。這里借機(jī)聊聊這方面的內(nèi)容,重點演示相關(guān)功能的實現(xiàn),以供參考。
    的頭像 發(fā)表于 03-25 09:15 ?2011次閱讀
    關(guān)于STM32 DMAMUX模塊<b class='flag-5'>具體</b>的應(yīng)用示例<b class='flag-5'>代碼</b>

    什么是cpu的主頻和外頻,它們之間關(guān)系如何

    CPU的主頻和外頻是計算機(jī)中兩個重要的頻率指標(biāo),它們分別代表CPU內(nèi)部和與外部組件之間的數(shù)據(jù)傳輸速率。這兩個頻率指標(biāo)之間有著密切的關(guān)系,對計算機(jī)的性能和穩(wěn)定性有著重要的影響。 首先,我們來
    的頭像 發(fā)表于 02-03 16:50 ?2617次閱讀

    CPU的6個主要寄存器

    CPU寄存器是中央處理器內(nèi)的組成部分,是有限存貯容量的高速存貯部件。寄存器是CPU內(nèi)部的元件,包括通用寄存器、專用寄存器和控制寄存器。
    的頭像 發(fā)表于 02-03 15:15 ?2940次閱讀

    處理器和cpu是一個東西嗎 cpu和主板的區(qū)別

    執(zhí)行指令來進(jìn)行數(shù)據(jù)處理、運算和控制操作的核心。它主要包括算術(shù)邏輯單元(ALU)、控制單元(CU)和寄存器等多個功能部件的集合。CPU通過時鐘信號的驅(qū)動,從內(nèi)存中讀取指令和數(shù)據(jù),經(jīng)過解碼和執(zhí)行等操作,最終將結(jié)果返回給內(nèi)存或輸出設(shè)備。 而處理器是
    的頭像 發(fā)表于 01-19 09:52 ?1.5w次閱讀

    CPU和GPU之間的主要區(qū)別

    以下是以表格形式提供的CPU和GPU之間的一些區(qū)別:中央處理器圖形處理器CPU代表中央處理器。GPU代表圖形處理單元。CPU是通用處理器。GPU是專用處理器。CPU更靈活,指令集更大,
    的頭像 發(fā)表于 12-14 08:28 ?628次閱讀
    <b class='flag-5'>CPU</b>和GPU之間的<b class='flag-5'>主要</b>區(qū)別

    U-Boot啟動過程概述 U-Boot啟動代碼具體分析

    第一階段:主要是SOC內(nèi)部的初始化,板級的初始化比較少,所以移植的修改量比較小。此階段由匯編語言編寫,代碼主體分布在/uboot/cpu/s5pc11x/start.S和/uboot/board/samsung/x210/low
    的頭像 發(fā)表于 11-27 10:24 ?2417次閱讀
    U-Boot啟動過程概述 U-Boot啟動<b class='flag-5'>代碼</b><b class='flag-5'>具體</b>分析

    CPU怎么訪問代碼和數(shù)據(jù)

    程序經(jīng)過編譯后,變成了可執(zhí)行的文件,可執(zhí)行文件主要包括代碼和數(shù)據(jù)兩部分,代碼是只讀的,數(shù)據(jù)則是可讀可寫的。 可執(zhí)行文件由操作系統(tǒng)加載到內(nèi)存中,交由CPU去執(zhí)行,現(xiàn)在問題來了,
    的頭像 發(fā)表于 11-08 17:04 ?687次閱讀
    <b class='flag-5'>CPU</b>怎么訪問<b class='flag-5'>代碼</b>和數(shù)據(jù)

    CPU與GPPU架構(gòu)比較分析 在GPU上執(zhí)行Kernel的具體步驟

    大多數(shù)工程師對CPU和順序編程都十分熟悉,這是因為自從他們開始編寫CPU代碼以來,就與之密切接觸。然而,對于GPU的內(nèi)部工作原理及其獨特之處,他們的了解則相對較少。過去十年,由于GPU在深度學(xué)習(xí)中
    的頭像 發(fā)表于 11-05 11:33 ?1313次閱讀
    <b class='flag-5'>CPU</b>與GPPU架構(gòu)比較分析 在GPU上執(zhí)行Kernel的<b class='flag-5'>具體</b>步驟