關(guān) 閉

新聞中心

EEPW首頁 > 工控自動(dòng)化 > 設(shè)計(jì)應(yīng)用 > ATMEGA48與DS1302組成的定時(shí)控制系統(tǒng)

ATMEGA48與DS1302組成的定時(shí)控制系統(tǒng)

——
作者:北京源通電子有限公司 裴之秀 時(shí)間:2006-07-31 來源:電子設(shè)計(jì)應(yīng)用 收藏
  Atmel公司的ATMEGA48是一款高性能、低功耗的8 位AVR微處理器,使用先進(jìn)的RISC 結(jié)構(gòu),大多數(shù)指令的執(zhí)行時(shí)間為單個(gè)時(shí)鐘周期,所以運(yùn)算速度更快。兩個(gè)具有獨(dú)立預(yù)分頻器和比較器功能的8 位定時(shí)器/ 計(jì)數(shù)器;一個(gè)具有預(yù)分頻器、比較功能和捕捉功能的16 位定時(shí)器/ 計(jì)數(shù)器;具有獨(dú)立振蕩器的實(shí)時(shí)計(jì)數(shù)器RTC;六通道PWM;8路10 位ADC(TQFP 與MLF 封裝)[ 6路10 位ADC( PDIP 封裝)];可編程的串行USART 接口;可工作于主機(jī)/ 從機(jī)模式的SPI 串行接口;面向字節(jié)的兩線串行接口;具有獨(dú)立片內(nèi)振蕩器的可編程看門狗定時(shí)器;片內(nèi)模擬比較器;引腳電平變化可引發(fā)中斷及喚醒MCU等。

    其具有的下面特點(diǎn)無論從編程、自編程和加密等方面都給用戶提供了很大的方便。4K字節(jié)的系統(tǒng)內(nèi)可擦寫10,000 次的可編程Flash;具有獨(dú)立鎖定位的可選Boot 代碼區(qū),通過片上Boot程序?qū)崿F(xiàn)系統(tǒng)內(nèi)編程;256字節(jié)的擦寫100,000 次的EEPROM;512字節(jié)的片內(nèi)SRAM,可以對(duì)鎖定位進(jìn)行編程以實(shí)現(xiàn)用戶程序的加密。

    Maxim公司的8腳串行實(shí)時(shí)時(shí)鐘日歷芯片DS1302,體積小、與單片機(jī)接口簡(jiǎn)單、工作電壓范圍寬(2.5~5.5V)、功耗低、接口容易、占用CPU I/O口線少、可對(duì)時(shí)鐘芯片備份電池進(jìn)行涓流充電等特點(diǎn)。所以應(yīng)用方便,被很多設(shè)計(jì)者所青睞。


圖1  ATMEGA48與DS1302的電路連接


    筆者利用這兩種芯片,設(shè)計(jì)了實(shí)時(shí)時(shí)鐘,實(shí)時(shí)數(shù)據(jù)采集和定時(shí)控制系統(tǒng)。現(xiàn)就DS1302與ATMEGA48的應(yīng)用介紹給大家。

    由于ATMEGA48有可選的內(nèi)部振蕩器,所以只需接通電源即可;DS1302需要一個(gè)32768Hz的晶振,和一個(gè)備用電池??梢钥闯鼋Y(jié)構(gòu)很簡(jiǎn)單(由于本文只介紹ATMEGA48和DS1302的應(yīng)用,所以其余的顯示電路和數(shù)據(jù)采集電路均省略。)。

ATMEGA48與DS1302的通訊程序(ASM)


圖2  DS1302的時(shí)序

圖3  DS1302充電原理圖



DS1302的時(shí)序如圖2。
根據(jù)時(shí)序圖,給出下面的讀/寫程序:
讀出數(shù)據(jù)子程序如下:
  ;sbi portd,7 ;假設(shè)調(diào)用子程序以前已經(jīng)保持rst為高
RDS:  clr r17   ;將取到的數(shù)據(jù)保存到R17中
  ldi r24,8
  sbi portd,6  ;sclk
RDS1: cbi portd,6  ;sclk 下降沿讀取數(shù)據(jù)
  nop
  IN R16,pind      ;從CPU I/O讀取數(shù)據(jù)
  nop
  sbi portd,6  ;sclk
  BST R16,5  ;復(fù)制PIND.5到T
  LSR R17
  BLD R17,7  ;復(fù)制T到R17.7
  dec r24
  CPI R24,0
  BRNE  RDS1
  RET

    注:ATMEGA48 I/O口有三個(gè)寄存器分別是:數(shù)據(jù)寄存器- PORTx、數(shù)據(jù)方向寄存器- DDRx 和端口輸入引腳- PINx。I/O作為數(shù)據(jù)輸入使用時(shí),讀取數(shù)據(jù)命令應(yīng)為 IN Rd,PINx,如果使用IN Rd,PORTx則讀取到的是I/O口的狀態(tài),盡管將DDRx設(shè)置成數(shù)據(jù)輸入。特別注意的是,讀取軟件賦予引腳電平和執(zhí)行讀取指令in 之間至少有一個(gè)時(shí)鐘周期的間隔,文中用nop間隔。

寫入數(shù)據(jù)(命令/地址)子程序如下:
  ;ldi R17,data ;假設(shè)要寫入的數(shù)據(jù)已經(jīng)存放到R17中
  ;sbi portd,7 ;假設(shè)調(diào)用子程序以前已經(jīng)保持rst為高
WDS:  ldi r24,8
WDS1: cbi portd,6  ;sclk
  in r16,portd  ;讀入D口狀態(tài)
  BST R17,0  ;將R17.0復(fù)制到T
  BLD R16,5  ;將T復(fù)制到R16.5
  nop
  out portd,r16 ;寫數(shù)據(jù)到portd(R16.5->portd.5)
  sbi portd,6  ;sclk
  lsr r17
   dec r24
  CPI R24,0
  BRNE WDS1  
  RET

    關(guān)于命令字節(jié)的說明。DS1302命令字節(jié)由8位組成,BIT 0 為1時(shí),讀取數(shù)據(jù),為0時(shí)寫入數(shù)據(jù)。BIT 1-5 為地址。BIT 6 為1時(shí)指向31個(gè)RAM,為0 時(shí)指向時(shí)鐘寄存器。BIT 7 必須為1,為0時(shí)將使DS1302停止。
DS1302的控制寄存器的第七位是寫保護(hù)位,所以在寫入數(shù)據(jù)前應(yīng)該將其關(guān)閉,并在寫數(shù)據(jù)完畢后將其使能。下面是一段完整的設(shè)置分的程序。
......
ldi r19,0x43  ;假設(shè)當(dāng)前時(shí)間為43分,DS1302時(shí)間寄存器保存的數(shù)據(jù)為10進(jìn)制數(shù)十六進(jìn)制存儲(chǔ)。
ldi r18,0x82  ;寫分 命令
ldi r27,0x00  ;x H
ldi r26,19  ;x L    在這里使用間接尋址,所以只需改變R19的數(shù)據(jù)即可。
......
WRITE_DS1302:
  cbi portd,7
  cbi portd,6
  sbi portd,7 
  ldi r17,0x8e        ;控制寄存器en_WRITE
  rCALL  WDS   
  ldi r17,0    ;寫操作前WP=0
  rCALL  WDS 
  mov r17,r18          ;寫秒 分 時(shí) 日 月 星期 年 地址
        rCALL  WDS
  ld r17,x      ;寫秒 分 時(shí) 日 月 星期 年(R19中的數(shù)據(jù))
        rCALL  WDS 
  cbi portd,7
  cbi portd,6
  sbi portd,7
  ldi r17,0x8e        ;控制寄存器un_en_WRITE
  rCALL  WDS
  ldi r17,0x80   ;寫操作前WP=1
  rCALL  WDS 
  cbi portd,7    
  RET

    同樣,下面給出了一個(gè)完整的讀取分的程序
ldi r18,0x83  ;讀分 命令
ldi r27,0x00  ;x H
ldi r26,19  ;x L    將取到的數(shù)據(jù)存儲(chǔ)到R19中。
READ_DS1302:
  cbi portd,7
  cbi portd,6
  sbi portd,7
  mov r17,r18         ;寫秒 分 時(shí) 日 月 星期 年 地址
     rCALL  WDS 
     rCALL  RDS
  st x,r17  ; 保存數(shù)據(jù)到R19
  cbi portd,7
  RET

    整合寫和讀分的程序,改變R18的內(nèi)容就可以實(shí)現(xiàn)“秒、分、時(shí)、日、月、星期、年”的讀寫,寫操作時(shí)只需改變R19的內(nèi)容就可以將新的數(shù)據(jù)寫入,讀操作時(shí)直接讀取R19的內(nèi)容即可。也可以通過此程序直接來對(duì)31個(gè)RAM進(jìn)行數(shù)據(jù)讀取。

DS1302的充電功能

    DS1302的涓流充電功能也是非常方便的,同時(shí)又是其非常重要的一個(gè)功能,所以簡(jiǎn)單介紹一下其使用。其原理框圖如圖3。

    DS1302有一個(gè)單獨(dú)的寄存器控制涓流充電。BIT7:BIT4是涓流充電功能的選擇器,只有當(dāng)它們被設(shè)置成1010才能夠?qū)⑵涫鼓?。使用DS(BIT3和BIT2)可以在一個(gè)和兩個(gè)二極管之間選擇;使用RS(BIT1和BIT0)可以選擇兩個(gè)電源(Vcc1和Vcc2)之間的電阻,這兩個(gè)選擇器共同使用來幫助您得到所需要的電流。

結(jié)語

    通過這一實(shí)踐,表明應(yīng)用DS1302在測(cè)控系統(tǒng)中的數(shù)據(jù)記錄,其軟硬件設(shè)計(jì)簡(jiǎn)單,時(shí)間記錄準(zhǔn)確。同時(shí)由于ATMEGA48的高速度,大數(shù)據(jù)吞吐,給實(shí)際應(yīng)用帶來了很大方便。由于筆者水平有限,僅將應(yīng)用筆記供大家參考。

參考文獻(xiàn)
1.  8-bit AVR Microcontroller with 4K Bytes In-System Programmable Flash (data sheet)
2.  DS1302 - Trickle Charge Timekeeping Chip (data sheet)


分頻器相關(guān)文章:分頻器原理


評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉