新聞中心

        EEPW首頁 > 手機與無線通信 > 設計應用 > 基于NIOS II的多串口數據通信的實現

        基于NIOS II的多串口數據通信的實現

        作者: 時間:2011-03-17 來源:網絡 收藏


        圖4中SET_EN用于設置個的輸入模式(是否乒乓輸入及乒乓輸入時緩存的大小)和使能等操作,輸入控制寄存器的默認值在系統初始化時由DSP寫入。
        當數據輸入時, CPU檢測到來自的中斷請求,進入對應的中斷響應程序。首先對數據傳輸模式進行判斷,P_flag默認值為0,表示非數據塊輸入模式。該模式下輸入的數據有特定的結尾標志符組合,一旦檢測到結束標志則發送已緩存的數據并完成狀態清零以便下次接收;P_flag為1則為連續數據塊輸入,當Half_BAM0或Half_RAM1其中一塊寫滿時即向DSP發出中斷信號,DSP即進入中斷服務程序讀取數據。程序流程圖如圖5所示。



        3 結束語
        采用Altera FPGA芯片上的 CPU控制串口的優點是充分使用硬件資源,可以減輕DSP芯片的計算量。測試表明, CPU工作頻率為20.46 MHz,串口波特率設置為115 200,數據位為8 bit,各串口可以同時正常輸入輸出。多串口可以同時輸入輸出數據,由指令可以靈活配置傳輸模式,以適應不同數據傳輸類型的需求。
        本文解決了單串口傳輸不能滿足GPS高精度接收機對多種數據同時輸入輸出的要求,了GPS定位結果、RTK差分數據與外界的實時交換以及用戶控制命令的輸入。本方案的優點是通過增加各串口的輸入/輸出控制寄存器,使DSP芯片可以僅以兩個GPIO資源原本需要3個串口輸入/輸出功能相對應的6個中斷操作;采用NIOS II CPU進行多串口控制可以減少硬件調試時間,節約FPGA片內資源。不足之處是未串口波特率、數據位等實時配置。


        上一頁 1 2 3 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 萍乡市| 比如县| 河池市| 牙克石市| 南平市| 永顺县| 呈贡县| 泗水县| 礼泉县| 保定市| 托克托县| 乐平市| 丽江市| 平罗县| 阿瓦提县| 龙门县| 青州市| 沭阳县| 涞水县| 朝阳区| 永登县| 洱源县| 萍乡市| 东明县| 海门市| 澄城县| 临湘市| 梨树县| 诸城市| 塔城市| 名山县| 广宗县| 昌邑市| 沿河| 浦江县| 攀枝花市| 同仁县| 镶黄旗| 东乡县| 定远县| 嘉兴市|