51手記之MEGAWIN
1.基本特性
工作頻率:24MHZ(最大,外部晶體)
有兩種節能模式和8位的系統時(shí)鐘分頻器。 時(shí)鐘源:外部晶體/時(shí)鐘,內部高頻/低頻RC振蕩器;上電后,內部高頻RC振蕩器(12MHZ)為默認的系統時(shí)鐘源。軟件能使能其它振蕩器電路和通過(guò)編程AUXRA寄存器對它們進(jìn)行切換。切換時(shí)鐘源為外部晶體時(shí),必須使能外部晶體振蕩器電路并等它穩定后再切換。選好時(shí)鐘后,可軟件禁止未用的振蕩器電路以減少能耗。
切換系統時(shí)鐘為外部時(shí)鐘:
1).使能外部時(shí)鐘
IFMT=0X07;//AUXRA讀操作
SCMD=0X46;
SCMD=0XB9;//此時(shí)IFD的值=AUXRA的值
IFD |= 0X08;//設置使能外部晶體,將AUXRA的預設值寫(xiě)入IFD
IFMT=0X06;//AUXRA寫(xiě)操作
SCMD=0X46;
SCMD=0XB9;
2).切換到外部時(shí)鐘
IFMT=0X07;
SCMD=0X46;
SCMD=0XB9;
IFD |= 0X03;//設置外部晶體為系統時(shí)鐘
IFMT=0X06;
SCMD=0X46;
SCMD=0XB9;
3).關(guān)閉內部時(shí)鐘
IFMT=0X07;
SCMD=0X46;
SCMD=0XB9;
IFD &= 0XFB;//設置將內置晶體停止
IFMT=0X06;
SCMD=0X46;
SCMD=0XB9;
有六個(gè)復位源: 上電復位、WDT復位、軟件復位、外部(RST)復位、掉電檢測器(brown-out)復位及非法地址復位。
2.存儲器
1)程序存儲器
支持ISP(在系統可編程)/IAP(在應用可編程);IAP空間可用作數據閃存。
IAP區域由IAPLB和ISP起始地址共同決定:IAP低邊界 = IAPLB * 256;IAP高邊界 = ISP起始地址 – 1;IAP低邊界地址必須不要高于ISP起始地址或非設備定義的空間。否則,可能會(huì )導致Flash存儲器中數據內容遭到破壞。
2)數據存儲器
片上256字節隨機存取儲存器和1024字節片上擴展存儲器(XRAM)
3.通用I/O口
有41個(gè)普通I/O口(GPIO),P0, P1, P2, P3, P4(P40-P46)能被配置為準雙向口、上拉輸出、集電極開(kāi)漏輸出以及高阻輸入,P6.0 和 P6.1 僅可作準雙向口模式及復用為 XTAL2和 XTAL1。每個(gè)端口有兩個(gè)模式寄存器來(lái)選擇各端口引腳的輸出類(lèi)型:

4.中斷系統
有四級中斷優(yōu)先級的14個(gè)中斷源。與這四級中斷有關(guān)聯(lián)的特殊功能寄存器有IE、 IP0L、 IP0H、EIE1、EIP1L、EIP1H及XICON。
nINT0/nINT1 觸發(fā)類(lèi)型:低電平或下降沿;
nINT2/nINT3觸發(fā)類(lèi)型:低電平、下降沿、高電平或上升沿
5.定時(shí)器
三個(gè)16位定時(shí)/計數器:定時(shí)器 0、定時(shí)器1及定時(shí)器2;每一個(gè)包含兩個(gè)8位寄存器THx和TLx(這里,x=0、1或2)。它們可配置為定時(shí)器或事件計數器。三個(gè)定時(shí)器輸出口(T0CKO 對應P34、T1CKO對應P35、T2CKO對應P10);T0/T1/T2時(shí)鐘可以選擇X12 模式。
定時(shí)器功能,TLx寄存器每12個(gè)系統時(shí)鐘周期(標準C51的機器周期)或每1個(gè)系統時(shí)鐘周期(是標準C51的12倍)加1,通過(guò)軟件設置AUXR2.T0X12、 AUXR2.T1X12和 T2MOD.T2X12位來(lái)選擇 。每12個(gè)系統時(shí)鐘周期加一,計數速率是1/12的晶振頻率。
計數器功能,根據對應的外部輸入引腳的下降沿T0、T1或T2寄存器加1。在這功能中,每個(gè)定時(shí)器時(shí)鐘周期對外部輸入信號(T0、T1和T2引腳)進(jìn)行采樣,當采樣信號出現一個(gè)高電平接著(zhù)一個(gè)低電平,計數加1。當檢測到跳變時(shí)新計數值出現在寄存器中。
定時(shí)器2有四種工作模式:捕獲、自動(dòng)加載(向上或向下計數)、波特率發(fā)生器和可編程時(shí)鐘輸出,通過(guò)專(zhuān)用寄存器T2CON和T2MOD來(lái)選擇。
1)捕獲模式

2)自動(dòng)加載模式

在復位之后,DCEN=0意思是默認為定時(shí)器2向上計數。如果DCEN置位,定時(shí)器2向上或向下計數由T2EX引腳的值來(lái)決定。
3)波特率發(fā)生器模式

T2CON寄存器的RCLK和/或RCLK位允許串行口發(fā)送和接收波特率既可源自定時(shí)器1或定時(shí)器2。當TCLK=0時(shí),定時(shí)器1作為串行口傳送波特率發(fā)生器。當TCLK=1,定時(shí)器2作為串行口傳送波特率發(fā)生器。RCLK對串行口接收波特率有相同的功能
4)可編程時(shí)鐘輸出模式
CP/RL2=0且T2OE=1;定時(shí)器2作為一個(gè)輸出占空比為50%的可編程時(shí)鐘發(fā)生器,所產(chǎn)生的時(shí)鐘從P1.0 引腳輸出來(lái)。
輸出頻率=Fosc/4(65536-(RCAP2H,RCAP2L))
定時(shí)器2 的可編程時(shí)鐘輸出模式編程步驟如下:
a.置位T2MOD寄存器的T2OE位。 b.清除T2CON寄存器的C/T2位。
c.從公式計算出16位加載值并輸入到RCAP2H和RCAP2L寄存器。
d.在TH2和TL2輸入一個(gè)16位初始值??梢院椭剌d值相等。
e.設置T2CON的TR2控制位開(kāi)啟動(dòng)定時(shí)器。
在時(shí)鐘輸出模式,定時(shí)器2翻轉不會(huì )產(chǎn)生中斷
6.串行口
2個(gè)全雙工串行口,功能同標準51;
串行口可以工作在四種模式:模式 0 提供同步通訊同時(shí)模式 1、2 和模式 3 提供異步通訊。異步通訊作為一個(gè)全雙工的通用異步收發(fā)器(UART),可以同時(shí)發(fā)送和接收并使用不同的波特率。
模式0:8位數據(低位先出)通過(guò)RXD0(P3.0)傳送和接收,波特率可通過(guò)SCFG寄存器的URM0X6位選擇為系統時(shí)鐘頻率的1/12或1/2。
模式1:10位數據通過(guò)TXD0傳送或通過(guò)RXD0接收,波特率是可變的。
模式2:11位數據通過(guò)TXD0傳送或通過(guò)RXD0接收,波特率可以配置為1/32或1/64 的系統時(shí)鐘頻率
模式3:11位數據通過(guò)TXD0傳送或通過(guò)RXD0接收,波特率是可變的。
除了標準操作外,UART0還能具有偵察丟失停止位的幀錯誤和自動(dòng)地址識別的功能。
串口1使用獨立波特率發(fā)生器,串口0可選擇使用定時(shí)器1或定時(shí)器2(T2CON的RCLK和TCLK決定),也可共用串口1的波特率(RCLK=0,TCLK=0及URTS=1)
7.可編程計數器陣列(PCA)
該功能與標準定時(shí)/計數器相比以更少的CPU占用提供了更多的定時(shí)能力。它的優(yōu)點(diǎn)包括減少了軟件復雜度并提高了精度。
PCA由一個(gè)專(zhuān)用定時(shí)/計數器作為一個(gè)6組比較/捕獲模塊的時(shí)間基礎,6組比較/捕獲模塊中的每一組都可以編程為如下任意模式:
- 上升和/或下降沿捕獲
- 軟件定時(shí)器
- 高速輸出
- 脈寬調制(PWM)輸出
1)PCA 定時(shí)器/計數器
它的時(shí)鐘輸入可以從以下來(lái)源選擇(CPS1 和 CPS0選擇):
- 1/12 系統時(shí)鐘頻率
- 1/2 系統時(shí)鐘頻率
- 定時(shí)器0溢出,可以讓低頻時(shí)鐘源輸入到PCA定時(shí)器
- 外部時(shí)鐘輸入,ECI(P1.1)引腳的1-0反轉
2)比較/捕獲模塊
6組比較/捕獲模塊中的每一組都有一個(gè)模式寄存器,叫做CCAPMn(n代表0,1,2,3,4,5),來(lái)選擇其工作模式。ECCFn位控制當中斷標志置位時(shí)每個(gè)模塊的中斷開(kāi)啟/關(guān)閉。
3)PCA運行模式

具體工作模式與STC同。
提供4種精度的PWM輸出:8位(可自動(dòng)重載)、10位、12位、16位(后3種需手動(dòng)重載溢出值)
8.串行外設接口(SPI)
提供了一個(gè)高速串行通訊接口(SPI)。SPI接口是一種全雙工、高速同步通訊總線(xiàn),有兩種操作模式:主機模式和從機模式。無(wú)論哪種模式,12MHz系統時(shí)鐘時(shí)支持高達3Mbps的通訊速度。SPI狀態(tài)寄存器(SPSTAT)有一個(gè)傳送完成標志(SPIF)和寫(xiě)沖突標志(WCOL)。
SPI接口有4個(gè)引腳:MISO (P1.6), MOSI (P1.5), SPICLK (P1.7) 和nSS (P1.4)。
1)典型SPI配置模式:
a.單主機單從機

b.互為主機/從機

c.單主機多從機

2)注意事項
SPI通訊中,傳輸總是由主機發(fā)起 。若 SPI使能(SPEN=1)并作為主機運行,寫(xiě)入SPI數據寄存器(SPDAT) 數據即可啟動(dòng)SPI時(shí)鐘生成器和數據傳輸器,大約半個(gè)到1個(gè)SPI位時(shí)間后寫(xiě)入SPDAT的數據開(kāi)始出現在MOSI線(xiàn)上。
在開(kāi)始傳輸之前,主機通過(guò)拉低相應nSS引腳選擇一個(gè)從機作為當前從機。寫(xiě)入SPDAT寄存器德數據從主機MOSI引腳移出,同時(shí)從從機MISO移入主機MISO的數據也寫(xiě)入到主機的SPDAT寄存器中。移出1字節后,SPI時(shí)鐘發(fā)生器停止,置傳輸完成標志SPIF,若SPI中斷使能則生成一個(gè)中斷。主機CPU和從機CPU中的兩個(gè)移位寄存器可以看成一個(gè)分開(kāi)的16位環(huán)形移位寄存器,數據從主機移到從機同時(shí)數據也從從機移到主機。這意味著(zhù),在一次傳輸過(guò)程中,主從機數據進(jìn)行了交換。
SPI在發(fā)送方向是單緩沖的,而在接收方向是雙緩沖的。發(fā)送數據直到上一次數據發(fā)送完成后才能寫(xiě)入移位寄存器,數據發(fā)送過(guò)程中寫(xiě)入數據寄存器就會(huì )使WCOL(SPSTAT.6) 置位來(lái)表明數據沖突。這種情況下,正在發(fā)送的數據繼續發(fā)送,而剛寫(xiě)入數據寄存器造成沖突的數據就會(huì )丟失。WCOL使用軟件向其位寫(xiě)入’1’來(lái)清零。
SPI時(shí)鐘頻率選擇(主機模式)使用SPCTL寄存器的SPR1 和SPR0 位來(lái)設置。
9.鍵盤(pán)中斷
鍵盤(pán)中斷功能主要用于當P2口等于或不等于某個(gè)值時(shí)產(chǎn)生一個(gè)中斷,這個(gè)功能可以用作總線(xiàn)地址識別或鍵盤(pán)鍵碼識別。
鍵盤(pán)中斷掩碼寄存器(KBMASK) 用來(lái)定義P2口哪些引腳可以產(chǎn)生中斷;鍵盤(pán)模式寄存器(KBPATN)用來(lái)定義與P2口值進(jìn)行比較的值,比較匹配時(shí)硬件置鍵盤(pán)中斷控制寄存器(KBCON)中的鍵盤(pán)中斷標志(KBIF)。
10.10位模數轉換器ADC
ADC子系統由一個(gè)模擬多路器(AMUX)、一個(gè)200ksps、10逐次逼近型模數轉換器組成。ADC轉換時(shí)鐘由ADCON寄存器的SPEED1、SPEED0兩位決定的系統時(shí)鐘分頻而來(lái)。(備注:目前建議ADC操作時(shí),系統時(shí)鐘不要超過(guò)20MHz) ADC轉換結果=Vin*1024/Vdd;
在使用ACD功能之前,用戶(hù)應:
a.設置ADCEN 位啟動(dòng)ADC硬件;
b.設置SPEED1 和 SPEED0位設定轉換速度;
c.設置CHS2、CHS1 和CHS0選擇輸入通道;
d.設置P1M0和P1M1寄存器將所選引腳設定成只輸入模式;
e.設置ADRJ 位配置ADC轉換結果輸出形式。
一旦轉換結束,硬件自動(dòng)清除ADCS位,設置中斷標志ADCI,并將轉換結果按照ADRJ的設置存入ADCH和ADCL。為了獲得最佳轉換效果,用作ADC的引腳應當禁止其數字輸出和輸入,可以將引腳設為只輸入模式。
11.看門(mén)狗定時(shí)器WDT
看門(mén)狗定時(shí)器 (WDT) 用來(lái)使程序從跑飛或死機狀態(tài)(諸如電源噪音/波動(dòng)、靜電干擾等使CPU運行出現混亂或死機)恢復的一個(gè)手段。軟件跑飛時(shí),WDT使系統復位來(lái)防止系統執行錯誤的代碼。WDT由一個(gè)15位獨立定時(shí)器、一個(gè)8分頻器和一個(gè)控制寄存器(WDTCR)組成。

看門(mén)狗溢出時(shí)間=12*分頻值*32768/SYSCLK (系統時(shí)鐘為12Mhz時(shí),最長(cháng)延時(shí)8s,時(shí)鐘越高,延時(shí)越短)
評論