1.簡(jiǎn)述
使用像ZYNQ這樣的SOC架構(gòu)的FPGA,開(kāi)發(fā)難度比較大的,能熟練開(kāi)發(fā)FPGA已經(jīng)很難了,ZYNQ需要硬件邏輯開(kāi)發(fā),然后還要開(kāi)發(fā)ARM。在學(xué)校使用ZYNQ一年多的時(shí)間里了,斷斷續(xù)續(xù)用ZYNQ做了很多項(xiàng)目,總的使用體驗(yàn)就是:很爽,同時(shí)也很酸爽。今天專門記一下c/c++ 的指針,這也不難,就是容易迷糊,一周不寫(xiě)c代碼,指針就不會(huì)用了,每次都要花點(diǎn)時(shí)間重新?lián)炱饋?lái),為了提高效率,還是總結(jié)一下,結(jié)合vivado 的sdk開(kāi)發(fā)工具記錄。
2.正文
1)準(zhǔn)備
vivado搭建一個(gè)簡(jiǎn)單PS 的工程(記得勾選uart),生成bit,導(dǎo)出硬件,啟動(dòng)sdk,新建helloworld的工程就行。然后跑一下,看串口是否能打印helloworld。如果可以,這就成功搭建工程了。
2)開(kāi)始
(1)進(jìn)入debug模式,頁(yè)面如下,黃框是現(xiàn)在代碼運(yùn)行的位置,我們要點(diǎn)擊紅框中的按鈕進(jìn)行單步調(diào)試(這個(gè)對(duì)熟悉單片機(jī)或者arm開(kāi)發(fā)的來(lái)說(shuō)很熟悉),我們簡(jiǎn)單在hello world源碼上簡(jiǎn)單添加藍(lán)框中的代碼??梢钥吹椒奂t框中有變量的信息,現(xiàn)在的值是不對(duì)的,因?yàn)閐ata那行代碼還沒(méi)運(yùn)行,點(diǎn)擊紅框,值就會(huì)變成我們代碼賦的值。
(2)點(diǎn)擊后,可以看到data值變了,這是十進(jìn)制的數(shù),可以用計(jì)算器轉(zhuǎn)成16進(jìn)制數(shù),是一樣的。把鼠標(biāo)放到data上面會(huì)顯示data信息,可以知道data地址,如紅框中的。在右下角,點(diǎn)擊進(jìn)入memory ,點(diǎn)擊加號(hào),填入data的地址,就可以知道現(xiàn)在data在memory中的值了。這些是sdk簡(jiǎn)單調(diào)試技巧。
(3)添加如下指針代碼,運(yùn)行,查看memory中0x01000000地址中的值,因?yàn)槭莄har型,是一個(gè)字節(jié),arm都是32位的,所以這個(gè)數(shù)據(jù)占低8位,數(shù)值正確。
(4)把鼠標(biāo)放到srcDPtr上,如下圖顯示信息。他的值是0x01000000,而他的地址是0x10c020,這兒還是挺疑惑的??梢赃@么理解,我們給srcDPtr賦0x01000000,這是srcDPtr是變量,那么也應(yīng)該有對(duì)應(yīng)的memory地址。這兒就可以完全理解指針了,指針變量的值是對(duì)應(yīng)地址的值,指針變量的值本身也需要memory存儲(chǔ),所以他也有地址。挺繞的,所以隔幾天不寫(xiě)c代碼,看著容易懵。
(5)添加如下代碼,按之前方法求證。
3.總結(jié)
學(xué)習(xí)過(guò)程很漫長(zhǎng),現(xiàn)在回首一看,原來(lái)自己走了這么遠(yuǎn)了,望向遠(yuǎn)方,繼續(xù)前進(jìn)?。?!
原文標(biāo)題:xilinx vivado sdk的使用 debug調(diào)試技巧 c/c++指針記錄
文章出處:【微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
-
FPGA
+關(guān)注
關(guān)注
1630文章
21769瀏覽量
604635 -
SDK開(kāi)發(fā)
+關(guān)注
關(guān)注
0文章
12瀏覽量
7784 -
Vivado
+關(guān)注
關(guān)注
19文章
815瀏覽量
66704
原文標(biāo)題:xilinx vivado sdk的使用 debug調(diào)試技巧 c/c++指針記錄
文章出處:【微信號(hào):zhuyandz,微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論