新聞中心

        bf561的loader問(wèn)題介紹

        作者: 時(shí)間:2012-10-14 來(lái)源:網(wǎng)絡(luò) 收藏

        近來(lái)開(kāi)始用BF 561設(shè)計(jì)圖像匹配系統(tǒng)。所以把這一過(guò)程的所得記錄在此,以便與大家共享。

        本文引用地址:http://www.104case.com/article/170786.htm

        在程序下載這個(gè)環(huán)節(jié)上遇到如下一些

        visual dsp++5.0下針對(duì)BF561開(kāi)發(fā)板的燒寫(xiě)flash的程序,不能正常下載,重新編譯一下才可以。

        在開(kāi)發(fā)時(shí),尤其是當(dāng)使用sdram空間時(shí)尤其小心flash內(nèi)的內(nèi)容,因?yàn)楫?dāng)開(kāi)發(fā)的代碼需要使用sdram空間時(shí),sdram必須已經(jīng)被初始化過(guò),不然會(huì)導(dǎo)致出現(xiàn)異常中斷。所以在調(diào)試程序前先給flash內(nèi)燒一個(gè)帶有初始化sdram的代碼,就沒(méi)有這個(gè)了,不然在開(kāi)發(fā)程序的時(shí)候,還的經(jīng)常注意這個(gè)

        BF561開(kāi)發(fā)板上的一個(gè)可能的bug:當(dāng)boot模式選擇為:從flash啟動(dòng)時(shí),若flash內(nèi)的程序有問(wèn)題,則仿真器連不上,需要更改boot方式才可以。這可能是個(gè)bug,技術(shù)支持也這樣認(rèn)為。

        Init code 一般包括初始化sdram,設(shè)置pll等工作,前者是為了程序正常使用sdram,后者是為了過(guò)程比較快的完成。

        Init code文件的注意事項(xiàng):

        要有rts指令。因?yàn)?a class="contentlabel" href="http://www.104case.com/news/listbylabel/label/loader">loader在辨認(rèn)出是initcode時(shí),采用call指令來(lái)調(diào)用init代碼,所以為了保證程序能夠正常執(zhí)行下去,initcode中必須有rts指令

        推薦把a(bǔ)stat,rets,Rx,Px全都?jí)簵!?/p>

        下邊是一個(gè)init code的簡(jiǎn)單例子,在該實(shí)例中只是初始化了sdram

        #include

        .section program;

        /********************************************************************/

        [--SP] = ASTAT; // Save registers onto Stack

        [--SP] = RETS;

        [--SP] = (R7:0);

        [--SP] = (P5:0);

        /********************************************************************/

        /*******Init Code Section********************************************/

        /*******SDRAM Setup************/

        Setup_SDRAM:

        P0.L = lo(EBIU_SDRRC);

        P0.H = hi(EBIU_SDRRC); // SDRAM Refresh Rate Control Register

        R0 = 0x03A9(Z);

        W[P0] = R0;

        SSYNC;

        P0.L = lo(EBIU_SDBCTL);

        P0.H = hi(EBIU_SDBCTL); // SDRAM Memory Bank Control Register

        R0 = 0x0015(Z);

        W[P0] = R0;

        SSYNC;

        P0.L = lo(EBIU_SDGCTL);

        P0.H = hi(EBIU_SDGCTL); // SDRAM Memory Global Control Register

        R0.H = 0x0091;

        R0.L = 0x998F;

        [P0] = R0;

        SSYNC;

        /********************************************************************/

        (P5:0) = [SP++]; // Restore registers from Stack

        (R7:0) = [SP++];

        RETS = [SP++];

        ASTAT = [SP++];

        /********************************************************************/

        RTS;



        關(guān)鍵詞: 介紹 問(wèn)題 loader bf561

        評(píng)論


        相關(guān)推薦

        技術(shù)專(zhuān)區(qū)

        關(guān)閉
        主站蜘蛛池模板: 大悟县| 兴和县| 漳平市| 新巴尔虎左旗| 富蕴县| 库伦旗| 普安县| 崇州市| 嘉峪关市| 翁源县| 双柏县| 永宁县| 裕民县| 敦煌市| 唐山市| 土默特右旗| 始兴县| 灵山县| 贵州省| 永川市| 沙坪坝区| 新丰县| 锡林浩特市| 连城县| 西城区| 府谷县| 桂阳县| 湘潭县| 安平县| 奎屯市| 涡阳县| 曲周县| 沂水县| 靖州| 淮北市| 夹江县| 蒲城县| 富裕县| 汕头市| 纳雍县| 石河子市|