《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > ATmega103單片機在跳頻系統數字信號處理中的應用
ATmega103單片機在跳頻系統數字信號處理中的應用
摘要: 文中介紹了ATMEL公司的高性能AVR單片機ATmega103的主要性能特點,給出了ATmega103在FH跳頻系統數字信號處理模塊中的應用方法,詳細介紹了片內同步串口SPI的使用技巧,同時給出了SPI的通信應用程序。
Abstract:
Key words :


ATmega103單片機是ATMEL公司推出的精簡指令集(RISC)AVR(ADVANCE RISC)系列單片機產品,這是一種增強型RISC結構,采用了CMOS技術的8位微控制器?該結構能有效支持高級語言以及密集度極大的匯編器代碼程序。

跳頻系統(FH)是指載波頻率按某種跳頻圖案(跳頻序列)在很寬的頻帶范圍內跳變的通信系統,由于該系統具有抗干擾、抗多徑和抗衰落性等能力,故在軍用和民用領域都得到了廣泛的應用。本系統方案中,信號處理模塊主要完成跳頻模式(FH)掠泄厥?中藕諾拇?恚??ɑ耙舯嘟飴搿⒒耙糇櫓?壩臚?接泄氐牟僮韉齲?廡┘際蹌殼笆翹?迪低車墓丶?際踔?弧?/P>

本文介紹ATmega103單片機的特點及其在FH系統數字信號處理模塊中的使用方法,同時詳細介紹SPI(Serial Peripheral Interface)的特點和應用。

1 ATmega103單片機概述

ATmega103是基于AVR RISC結構的8-bit低功耗CMOS微處理器,它吸取了PIC系列及8051系列單片機的優點,并作了重大改進,其特點如下:

●供電電壓為2.7~6V,主頻最高可達12MHz;

●具有120條指令,大多數指令執行時間為單個時鐘周期;

●帶有128k字節片內可下載的Flash存儲器(SPI串行下載1000次壽命)和4k字節的片內RAM以及4k字節的片內EEPROM;

●有32條可編程I/O線、8條輸入線和8條輸出線;

●具有32個8位通用寄存器;

●內含2個8位定時器和1個16位定時器;

●帶有可編程串行UART+SPI接口;

●具有內部中斷源和8個外部中斷源;

●帶有8通道10位A/D轉換器、片內模擬比較器以及看門狗等電路;

●可在線編程。

    ATmega103因其上述特點使其成為一種適合于多功能、快速,且具有高度靈活性和高性價比的微控制器。

2 跳頻信號處理對單片機的要求

跳頻信號處理模塊是FH電臺的關鍵部分之一,主要用于完成電臺的同步及有關數據處理組織等任務。單片機是該模塊的核心,模塊的許多功能都是在單片機的直接或間接參與下完成的。綜合考慮,單片機在該模塊中的作用大致如下:

(1)完成大量數據交換,因為電臺在工作時需要接收或傳送大量其它單片機以及模塊內部的有關參數數據;

(2)完成快速實時處理功能,因為模塊對許多信息要求立即處理,例如TOD(Time of Day)信息、話音數據、實時工作頻率計算等。

(3)用于數據交換,包括單片機接口、TOD、同步信息、控制狀態參數數據接口等。

(4)完成大量運算。一般電臺在FH工作方式時,每跳都需要計算TOD、工作頻率、接收或發送數據的重新組織。

(5)通過足夠的I/O口來提供多種控制狀態線,以供電臺及模塊內部使用。

(6)通過片內大量數據來存儲區存取運算過程中產生的大量中間數據。

3 設計思路

根據電臺FH信號處理模塊對單片機的要求,如果選用89C5X系列單片機,不但在實現功能上比較困難(如運算速度、I/O口數量等),而且所需的外圍擴展電路也必須增加(如RAM,通信口等)。而選用ATmega103單片機則能較好地滿足設計要求,因此,本設計選用ATmega103單片機來實現信號處理模塊的功能。圖1所示是其硬件原理圖。

此外,在實際使用中,還需注意軟件設計。為了便于調試、維護及功能擴展,該系統采用模塊化程序設計方案;而且考慮到軟件的可靠性,還增加了容錯和冗余設計;同時,針對數據接口多的特點,程序中還設計了簡明、通用性的接口通信協議。

4 Atmega103的SPI在FH中的應用

由上述描述可知,SPI在設計中占有重要的地位,模塊內部的主要控制和數據交換都由其完成,下面詳細介紹SPI在模塊中的設計方法。

4.1 SPI的工作原理

ATmega103和外設之間可通過SPI進行高速同步數據傳輸。主從CPU的SPI連接見圖2所示。其中,SCK為主機的時鐘輸出和從機的時鐘輸入。把數據寫入主機SPI數據寄存器的操作將啟動SPI時鐘產生器,此時,數據將從主機的MOSI移出,并從從機的MOSI移入,移完一個字節后,SPI時鐘停止,并設置發送結束標志。此時如果SPCR的SPIE(SPI中斷使能)置位,則引發中斷。選擇某器件為從機時,可將從機選擇輸入端SS拉低。主從機的移位寄存器可以看成是一個分布式的16 位循環移位寄存器。當數據從主機移向從機的同時,數據也將從從機移向主機,從而在移位過程中實現主從機的數據交換。

SPI的主要寄存器包括控制寄存器SPCR、狀態寄存器SPSR、數據寄存器SPDR。其中SPCR用于設置SPI的中斷使能、數據傳輸順序、主從機選擇、時鐘相位和時鐘速率等;SPSR為SPI中斷標志,用于標志寫沖突。SPDR寄存器用于在寄存器文件和SPI移位寄存器之間傳遞數據。寫該寄存器時,將先對數據傳送進行初始化,讀該寄存器時,讀到的將是移位寄存器接收緩沖區的值。

4.2 SPI的程序設計

在該FH信號處理模塊中,單片機通過SPI與FPGA交換數據。FPGA選用Xinlix公司的XCV100。下面具體介紹幾個主要的子程序:

(1)SPI的初始化

程序在復位時,通常都要對SPI口進行初始化。單片機設置若為主機。SPI的數據順序為LSB?低位?在前。SCK時鐘空閑時為低電平,在SCK的下降沿采樣數據;時鐘為系統時鐘的1/128。那么,具體的初始化程序如下:

reset:ldi rx,$0

out spsr,rx ?;清SPI中斷標志,寫沖突標志

ldi rx,$0f7;

out spcr, rx ?;設置SPI的傳輸參數

(2) SPI的發送程序

單片機每次需要把10byte的相關碼送給FPGA,因此應將SRAM區的$09c2-$09df段設定為SPI的數據緩沖區,然后由SPI從該緩沖區中取數據直到發送完畢。SPI的發送函數如下:

spi_send:ldi xh,$9

ldi xl,$0c2;

sts spififoo,xl ;將SPI緩沖區的輸出地址設為$c2

ldi ry, 10 ?;將10byte相關碼存入$9c2開始的地址

s67_2: ld rx, y+ ?;y為相關碼存放的地址

st x+, rx

s67_3: dec ry

brne s67_2

sts spififoi,xl ;將SPI緩沖區的輸入地址存入spififoi

ldi rx,$0aa ?;將發相關碼的標志$aa通過SPI

out spdr,rx ?;送給FPGA

sei ?;開中斷

ret

(3) SPI的中斷程序

每次SPI發送完一字節,都要產生一個中斷,以使程序跳轉到SPI的中斷程序。由于SPI主從機的移位寄存器可以看成是一個分布式的16 位循環移位寄存器,而且在當數據從主機移向從機的同時,數據也從從機移向主機,故在中斷程序中,應首先判斷SPDR中的數據是否是需要接收的數據(相關值),然后判斷SPI緩沖區中的數據(相關碼)是否發完,如沒有,則繼續發送,直到發完為止。具體程序如下:

spi_int:push xl ?;保存寄存器的值

push xh

in xl,sreg

push xl

lds xl, rcormark ?;判斷是否為有效數據,“0”為有效

brne spi_2 ?不等于0,跳

in xl, spdr

sts incorbuf, xl ?;將相關值存入incorbuf

spi_2: lds xl, spififoo ;比較緩沖區的輸入,輸出指針

lds sprx, spififoi

cp xl. sprx ?;

breq spiend ?;相等,則數據發完,跳

ldi xh,$9 ?;不等,則取下一個字節送入spdr

ld sprx, x+

out spdr, sprx

cpi xl, $0e0 ?;調整spififoo指針

brlo spi_0 ?;未超過緩沖區范圍,跳

ldi xl, $0c2 ?;超過,將緩沖區開始地

址給spififoo

spi_0: sts spififoo,xl;

spiend:pop xl

out sreg,xl

pop xh

pop xl

reti

5 結束語

本設計方案已通過軟硬件調試,結果表明:AT-mega103單片機較89C5X系列單片機在資源和功能上都有很大的提高,不但控制更加簡單、靈活,而且能夠節省不少外圍電路,因此具有成本和體積上的優勢,可完全滿足跳頻信號處理模塊的功能要求。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品美女久久久| 亚洲国产第一| 欧美v国产在线一区二区三区| 午夜精品久久久久久久蜜桃app | 香蕉av777xxx色综合一区| 一区二区三区日韩精品| 亚洲乱码久久| 日韩午夜av| 亚洲免费观看高清完整版在线观看| 亚洲国产精品尤物yw在线观看| 在线观看欧美精品| 亚洲高清色综合| 亚洲国产成人av| 亚洲韩国日本中文字幕| 亚洲激情综合| 日韩午夜三级在线| 亚洲深夜影院| 亚洲综合精品自拍| 欧美一区二区三区免费看| 欧美在线精品一区| 亚洲国产精品久久精品怡红院| 亚洲成人资源网| 亚洲精品日本| 99在线|亚洲一区二区| 亚洲图色在线| 欧美一级视频| 久久亚洲不卡| 欧美国产日韩一区二区三区| 欧美日韩国产成人在线观看| 欧美视频二区| 国产精品专区第二| 黄色日韩精品| 亚洲精品女人| 亚洲午夜免费福利视频| 欧美一级成年大片在线观看| 亚洲第一视频网站| 99精品热视频只有精品10| 亚洲性感激情| 久久精品国产成人| 欧美大片国产精品| 国产精品v欧美精品v日韩精品| 国产精品资源| 亚洲国产成人精品视频| 99国内精品久久| 亚洲欧洲av一区二区| 亚洲国产美女| 亚洲一区二区伦理| 久久精品在线免费观看| 欧美高清视频免费观看| 国产精品yjizz| 国产一区二区三区在线观看视频| 亚洲二区三区四区| 99视频精品| 欧美一级欧美一级在线播放| 亚洲精品久久久久久久久久久久久 | 欧美日韩不卡在线| 国产毛片精品国产一区二区三区| 狠狠色丁香久久婷婷综合丁香| 亚洲激情在线观看视频免费| 亚洲一本大道在线| 亚洲国产欧美精品| 亚洲综合电影| 欧美成人激情视频| 国产欧美一区二区三区在线老狼| 亚洲国产精品第一区二区| 亚洲自拍偷拍视频| 亚洲理论在线| 久久精品视频免费播放| 欧美三级第一页| 曰韩精品一区二区| 亚洲一区久久| 日韩一级黄色大片| 久久免费午夜影院| 国产精品久久久久久久久久久久久久| 一色屋精品亚洲香蕉网站| 这里只有精品视频| 亚洲精品在线免费| 久久精品人人做人人爽| 欧美午夜精品理论片a级按摩| 在线日韩欧美视频| 欧美亚洲系列| 亚洲一级一区| 欧美精品国产| 伊人成综合网伊人222| 亚洲在线播放| 亚洲一二三区在线观看| 欧美激情1区2区3区| 国产主播精品| 亚洲男人的天堂在线aⅴ视频| 一本久道综合久久精品| 蜜桃久久精品一区二区| 国产欧美日韩不卡| 亚洲深夜福利网站| 在线亚洲一区| 欧美精品一区二区三区在线播放| 黄色一区二区在线| 欧美与黑人午夜性猛交久久久| 亚洲欧美亚洲| 国产精品h在线观看| 亚洲免费av观看| 亚洲免费观看高清完整版在线观看| 久久五月激情| 国产亚洲成年网址在线观看| 亚洲专区一区| 午夜欧美精品| 国产精品久久久久aaaa樱花| 亚洲精品综合| 一区二区三区 在线观看视| 欧美激情综合| 亚洲日产国产精品| 亚洲免费观看视频| 欧美国产一区二区三区激情无套| 一色屋精品视频在线看| 久久精品人人做人人爽电影蜜月| 久久九九精品99国产精品| 国产精品一区免费观看| 亚洲校园激情| 亚洲在线一区二区| 国产精品国产三级国产普通话蜜臀| 亚洲乱码国产乱码精品精天堂| 99精品国产在热久久婷婷| 欧美日韩国产不卡在线看| 亚洲每日在线| 亚洲影院色无极综合| 国产精品久久久久久久久久久久| 在线一区二区三区四区| 亚洲伊人网站| 国产精品中文在线| 欧美一级专区免费大片| 久久久久**毛片大全| 国产中文一区| 亚洲日本成人| 欧美日韩视频一区二区| 一区二区三区免费在线观看| 午夜精品一区二区三区在线| 国产嫩草影院久久久久| 午夜精品久久久久久久久久久久久 | 欧美激情亚洲| 一区二区三区久久久| 亚洲欧美日韩视频一区| 国产视频一区欧美| 亚洲国产精品一区二区第一页| 国产日产精品一区二区三区四区的观看方式 | 久久岛国电影| 韩国久久久久| 亚洲国产精品久久人人爱蜜臀 | 欧美日韩国产成人高清视频| 99精品视频免费在线观看| 亚洲一级免费视频| 国产乱人伦精品一区二区| 香蕉久久精品日日躁夜夜躁| 久久―日本道色综合久久| 亚洲国产欧美精品| 亚洲一区二区三区四区在线观看| 国产精品一区二区在线| 亚洲国产高清自拍| 欧美日韩免费观看一区三区| 亚洲免费在线观看视频| 久久在线视频在线| 亚洲卡通欧美制服中文| 午夜欧美大片免费观看| 在线观看日韩av| 亚洲免费一在线| 狠狠爱综合网| 一区二区三区久久久| 国产亚洲精品久久久久婷婷瑜伽| 亚洲人成人99网站| 欧美色视频在线| 久久精品二区三区| 欧美日韩国语| 欧美资源在线| 欧美日韩一区二区在线视频| 欧美专区中文字幕| 欧美日韩国产在线观看| 午夜视频一区在线观看| 欧美精品久久一区二区| 午夜精品美女久久久久av福利| 欧美精品v国产精品v日韩精品| 亚洲一级特黄| 欧美fxxxxxx另类| 亚洲午夜三级在线| 免播放器亚洲一区| 亚洲一区二区在线免费观看| 久久中文字幕一区| 亚洲一区综合| 欧美激情精品久久久久久变态| 性欧美办公室18xxxxhd| 欧美黑人在线观看| 欧美一区二区视频在线观看| 欧美日韩综合久久| 亚洲黄色天堂| 国产欧美日韩三级| 一区二区三区毛片| 在线观看亚洲专区| 久久国产精品久久精品国产| 亚洲美女中文字幕| 欧美不卡一区| 欧美在线精品一区| 国产精品成人播放| 亚洲精品少妇30p|