李瑞金 , 金 林 , 徐 軍 ,劉會釗
(安徽理工大學(xué) 電氣與信息工程學(xué)院,安徽 淮南232001)
C8051F040系列器件是完全集成的混合信號片上系統(tǒng)型MCU,具有64個數(shù)字I/O引腳,片內(nèi)集成了1個CAN2.0B控制器。其主要特性有:(1)高速流水線結(jié)構(gòu)的8051兼容的 CIP-51內(nèi)核(可達(dá) 25 MIPS);(2)全速非侵入式的在系統(tǒng)調(diào)試接口(片內(nèi))64 KB(C8051F040/1/2/3/4/5)可在系統(tǒng)編程的Flash存儲器,(4K+256)B的片內(nèi)RAM,尋址空間為64 KB的外部數(shù)據(jù)存儲器接口和硬件實(shí)現(xiàn)的 SPI、SMBus/I2C和兩個 UART串行通信接口,片內(nèi)集成看門狗定時器和VDD監(jiān)視器和溫度傳感器,具有時鐘振蕩器的C8051F04x系列器件,是真正能獨(dú)立工作的片上系統(tǒng)。所有模擬和數(shù)字外設(shè)均可由用戶固件使能/禁止和配置。Flash存儲器還具有在系統(tǒng)重新編程能力,可用于非易失性數(shù)據(jù)存儲,并允許現(xiàn)場更新8051固件。每個 MCU都可在工業(yè)溫度范圍 (-45℃~+85℃)工作,工作電壓為 2.7 V~3.6 V。端口I/O、RST和 JTAG 引腳都允許5 V的輸入信號電壓。
當(dāng)向LED器件施加正向電壓時,流過的電流使其發(fā)光。因此,LED的驅(qū)動問題就轉(zhuǎn)化為如何使PN結(jié)處于正向偏置的問題。為了控制它的發(fā)光強(qiáng)度,還要解決其正向電流的調(diào)節(jié)問題。驅(qū)動方法分為直流驅(qū)動、恒流驅(qū)動和脈沖驅(qū)動。
2.1.1 直流驅(qū)動
直流驅(qū)動是最簡單的驅(qū)動方法。LED的工作點(diǎn)由電源電壓、串聯(lián)電阻和LED器件的伏安特性共同決定。這種驅(qū)動方式適合LED器件較少、發(fā)光強(qiáng)度恒定的情況。
2.1.2 恒流驅(qū)動
LED器件的正向特性較陡,加上器件的分散性,使得在同樣電源電壓和同樣限流電阻的情況下,各器件的正向電流并不相同,從而引起發(fā)光強(qiáng)度的差異。若對LED器件進(jìn)行恒流驅(qū)動,只要恒流值相同,發(fā)光強(qiáng)度就比較接近。晶體管的輸出特性具有恒流特性,因此可用晶體管驅(qū)動LED。
2.1.3 脈沖驅(qū)動
利用人眼的視覺惰性,采用LED器件重復(fù)通斷電的方式使之點(diǎn)亮,就是脈沖驅(qū)動方式。脈沖驅(qū)動主要應(yīng)用于掃描驅(qū)動和占空比驅(qū)動兩個方面。掃描驅(qū)動主要目的是節(jié)約驅(qū)動,簡化電路。占空比控制的目的是調(diào)節(jié)器件的發(fā)光強(qiáng)度,用于圖像顯示中的灰度控制。在實(shí)際應(yīng)用中往往是兩方面組合在一起使用。
2.1.4 常用LED顯示屏驅(qū)動
目前普遍采用的是串行控制驅(qū)動方式,就是將顯示的數(shù)據(jù)通過串行方式送入點(diǎn)驅(qū)動電路,多采用4953+74HC595作為驅(qū)動。
256 B雙色 LED屏主要由 32塊 8×8 LED模塊、32片 74HC595、8片 4953、2片 74HC245和 2片 74HC138組成。LED屏按其電路分為接口電路、驅(qū)動電路、譯碼電路和列數(shù)據(jù)電路。現(xiàn)對接口電路數(shù)據(jù)線作介紹。
A、B、C、D:行掃描信號線,決定 16行中的哪一行點(diǎn)亮;
R1、R2:紅色 LED列數(shù)據(jù);
G1、G2:綠色 LED列數(shù)據(jù);
CK:74HC595串行數(shù)據(jù)移位信號,上升沿將數(shù)據(jù)存入驅(qū)動模塊中的串行寄存器;
ST:74HC595數(shù)據(jù)鎖存信號,上升沿將串行數(shù)據(jù)存入并行數(shù)據(jù)寄存器,同時屏體顯示更新;
EN:74HC138片選信號,有效時屏體點(diǎn)亮。
2.3.1 LED列數(shù)據(jù)電路分析
LED屏主要由顯示點(diǎn)陣以及行列驅(qū)動電路組成,顯示點(diǎn)陣多采用64×32板組成。由于LED發(fā)光器件數(shù)目較多,通常采用掃描驅(qū)動方式。掃描驅(qū)動電路通常采用多行的同名列共用一套列驅(qū)動器。行驅(qū)動器的行連到電源的一端,列驅(qū)動器的列連到電源的另外一端,當(dāng)行驅(qū)動選擇第i行,列驅(qū)動器選擇第 j列時,相應(yīng)的LED就點(diǎn)亮。控制電路主要負(fù)責(zé)有序地選通各行,在選通每一行之前還要把該行各列的數(shù)據(jù)準(zhǔn)備好。采用掃描方式進(jìn)行顯示時,每行有一個行驅(qū)動器,各行的同名列共用一個列驅(qū)動器。行譯碼器給出行有效信號,從第一行開始,按順序依次對各行進(jìn)行掃描。根據(jù)列鎖存器的數(shù)據(jù)確定該列是否接通,接通的列就在該行點(diǎn)亮。當(dāng)一行的持續(xù)掃描時間結(jié)束后,下一行又以同樣的方法進(jìn)行顯示。每行都掃描一遍后,又從第一行開始下一個周期的掃描。只要掃描周期的時間比人眼閃爍臨界時間短,就感覺不出數(shù)據(jù)的更替,這是編寫軟件的重要思想步驟。
LED顯示屏采用74HC595作為列驅(qū)動電路,該芯片具備以下功能:具有8 bit的串入并出的移位寄存器和一個8 bit輸出鎖存器,移位寄存器和輸出鎖存器的控制各自獨(dú)立,因此當(dāng)?shù)谝恍袛?shù)據(jù)鎖存到行線上時,其內(nèi)部同時通過移位寄存器組織第二行數(shù)據(jù),這使得行數(shù)據(jù)準(zhǔn)備與顯示可以同時進(jìn)行。對于列準(zhǔn)備數(shù)據(jù),它具有串入并出的移位功能,對于列顯示數(shù)據(jù)具有并行鎖存的功能。
2.3.2 LED行掃描電路分析
行掃描電路選用74HC138譯碼器,但由于該芯片驅(qū)動能力有限,因此在它的輸出端再接上8片4953(每片可以驅(qū)動兩行)以增強(qiáng)行驅(qū)動能力。138譯碼器ABC 3條信號線可產(chǎn)生8 bit輸出信號,每次選通一片4953即可對應(yīng)其中一行,如果此時對應(yīng)列鎖存輸出數(shù)據(jù)到線上,則該行二極管導(dǎo)通,顯示數(shù)據(jù)。
本文LED雙色板采用16線掃描方式,用ABCD 4條掃描線結(jié)合2片74HC138產(chǎn)生16線掃描信號。
對于一個可正常顯示且不閃爍的LED顯示屏,其正常刷新頻率理論上至少不能少于50場/s。但實(shí)測表明只有大于55場/s(一場掃描時間大約18 ms)時,人眼才不會感覺到閃爍。對于64×32 LED來說,處理1 B的時間為 70.3 μs,平均指令條數(shù)為 Tb/1.5=70.3/1.5=47條。C8051F040晶振頻率為22.118 4 MHz,時鐘周期為 0.045 μs,C8051F040 70%的指令執(zhí)行周期為 1~2個時鐘周期, 故平均指令執(zhí)行時間 為 2×0.045 μs=0.9 μs, 滿 足LED顯示控制要求。
C8051F040與LED連接圖如圖1所示。
本電路采用C8051F040的P2口和P3口的高3位控制LED顯示,其中P2口的高4位連接138譯碼器的4根地址信號線(ABCD),分別是 P2.7接 A、P2.6接 B、P2.5接 C、P2.4 接 D、P2.3 接 G1、P2.2 接 G2、P2.1 接 CK、P2.0接 ST、P3.7接 EN、P3.6接 R1、P3.5接 R2。時鐘顯示電路選用PCF8563P芯片,采用I2C總線控制方式,SDA和SCL分別接P1.3、P1.2。溫度電路采用 18B20芯片,采用單總線控制方式,SDA接P0.3。
(1)功能介紹
這顯主要介紹C8051F040控制LED分屏顯示日期、時間和溫度。按照圖1所示的硬件連接,行掃描軟件地址可 分 配 為 0x00、0x80、0x40、0xc0、0x20、0xa0、0x60、0xe0、0x10、0x20、0x90、0x50、0xd0、0x30、0xb0、0x70、0xf0,編寫程序時將根據(jù)以上地址進(jìn)行行掃描。
(2)軟件流程圖
C8051F040控制LED的主程序流程圖如圖2所示,顯示程序流程圖如圖3所示。
圖2 主程序流程圖
圖3 顯示程序流程圖
(3)C8051F040源程序
C8051F040的源程序如下。
(1)系統(tǒng)時鐘配置
(2)系統(tǒng)端口配置
(4)PCF8563與C8051F040的連接
PCF8563與C8051F040之間的硬件連接圖如圖4所示。
圖4 PCF8563與C8051F040之間的硬件連接圖
(5)PCF8563初始化流程
PCF8563初始化流程圖如圖5所示。
(6)DS18B20與C8051F040的連接
DS18B20與C8051F040之間的硬件連接圖如圖6所示。
(7)DS18B20測溫系統(tǒng)
DS18B20測溫系統(tǒng)流程圖7所示。
圖5 PCF8563初始化流程圖
圖6 D818B20與C8051F040之間的硬件連接圖
本文主要介紹了LED顯示的工作原理、硬件電路組成以及對單片機(jī)控制系統(tǒng)的要求等,利用C8051F040的特有優(yōu)勢實(shí)現(xiàn)對LED的有效控制,可以直接驅(qū)動LED,不需要在控制板上再加一級總線驅(qū)動器,節(jié)約系統(tǒng)資源。本文還給出了具體部分軟件流程圖和源程序代碼,可根據(jù)硬件連接圖連接后正常顯示運(yùn)行。本文在LED顯示屏的應(yīng)用中具有一定的參考和應(yīng)用價值。
圖7 PCF8563初始化流程圖
[1]靳桅,鄔芝權(quán),李騏,等.基于51系列單片機(jī)的LED顯示屏開發(fā)技術(shù)[M].北京:北京航空航天大學(xué)出版社,2009.
[2]潘琢金.C8051F040混合信號ISP FLASH微控制器數(shù)據(jù)手冊[Z].新華龍電子有限公司,2004.
[3]譚浩強(qiáng).C程序設(shè)計(jì) [M].北京:清華大學(xué)出版社,2005.