www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > 單片機
[導(dǎo)讀] 一、前言之前花了一點時間閱讀了編譯器sdcc的man文檔,算是對這款交叉編譯器有了基本的了解。但要寫重新寫單片機程序,還要對相應(yīng)的知識做進一步的復(fù)習(xí)。下面我將閱讀芯片的datasheet和application gui

一、前言

之前花了一點時間閱讀了編譯器sdcc的man文檔,算是對這款交叉編譯器有了基本的了解。但要寫重新寫單片機程序,還要對相應(yīng)的知識做進一步的復(fù)習(xí)。下面我將閱讀芯片的datasheet和application guide,結(jié)合一些實際的應(yīng)用,對單片機的知識進行復(fù)習(xí)。我開發(fā)板上的芯片是stc90c51,不同型號的51芯片可能會略有差異。

二、外圍電路

要使單片機正常工作,需要在VCC腳上給予5v/3.3v的電壓,將GND腳接地。為了濾波 ,VCC和GND之間接兩個電容。XTAL上接一個外部振蕩器,RST腳上接外部復(fù)位電路。

雖然這些都已經(jīng)標準化,無關(guān)編程。但在某些特殊情況下(比如晶振、穩(wěn)壓芯片壞了,虛焊等等),需要配合示波器等作出硬件故障的排除,就需要檢查外圍電路的工作狀態(tài)。

三、片內(nèi)資源3.1 特殊功能寄存器&相關(guān)模塊

這里貼一下sdcc下c51通用的頭文件。可以清晰得看到控制GPIO,定時器,中斷,串口的相關(guān)寄存器。

#ifndef REG8051_H

#define REG8051_H


/* BYTE Register */

__sfr __at (0x80) P0 ;

__sfr __at (0x81) SP ;

__sfr __at (0x82) DPL ;

__sfr __at (0x83) DPH ;

__sfr __at (0x87) PCON ;

__sfr __at (0x88) TCON ;

__sfr __at (0x89) TMOD ;

__sfr __at (0x8A) TL0 ;

__sfr __at (0x8B) TL1 ;

__sfr __at (0x8C) TH0 ;

__sfr __at (0x8D) TH1 ;

__sfr __at (0x90) P1 ;

__sfr __at (0x98) SCON ;

__sfr __at (0x99) SBUF ;

__sfr __at (0xA0) P2 ;

__sfr __at (0xA8) IE ;

__sfr __at (0xB0) P3 ;

__sfr __at (0xB8) IP ;

__sfr __at (0xD0) PSW ;

__sfr __at (0xE0) ACC ;

__sfr __at (0xF0) B ;



/* BIT Register */

/* P0 */

__sbit __at (0x80) P0_0 ;

__sbit __at (0x81) P0_1 ;

__sbit __at (0x82) P0_2 ;

__sbit __at (0x83) P0_3 ;

__sbit __at (0x84) P0_4 ;

__sbit __at (0x85) P0_5 ;

__sbit __at (0x86) P0_6 ;

__sbit __at (0x87) P0_7 ;


/* TCON */

__sbit __at (0x88) IT0 ;

__sbit __at (0x89) IE0 ;

__sbit __at (0x8A) IT1 ;

__sbit __at (0x8B) IE1 ;

__sbit __at (0x8C) TR0 ;

__sbit __at (0x8D) TF0 ;

__sbit __at (0x8E) TR1 ;

__sbit __at (0x8F) TF1 ;


/* P1 */

__sbit __at (0x90) P1_0 ;

__sbit __at (0x91) P1_1 ;

__sbit __at (0x92) P1_2 ;

__sbit __at (0x93) P1_3 ;

__sbit __at (0x94) P1_4 ;

__sbit __at (0x95) P1_5 ;

__sbit __at (0x96) P1_6 ;

__sbit __at (0x97) P1_7 ;


/* SCON */

__sbit __at (0x98) RI ;

__sbit __at (0x99) TI ;

__sbit __at (0x9A) RB8 ;

__sbit __at (0x9B) TB8 ;

__sbit __at (0x9C) REN ;

__sbit __at (0x9D) SM2 ;

__sbit __at (0x9E) SM1 ;

__sbit __at (0x9F) SM0 ;


/* P2 */

__sbit __at (0xA0) P2_0 ;

__sbit __at (0xA1) P2_1 ;

__sbit __at (0xA2) P2_2 ;

__sbit __at (0xA3) P2_3 ;

__sbit __at (0xA4) P2_4 ;

__sbit __at (0xA5) P2_5 ;

__sbit __at (0xA6) P2_6 ;

__sbit __at (0xA7) P2_7 ;


/* IE */

__sbit __at (0xA8) EX0 ;

__sbit __at (0xA9) ET0 ;

__sbit __at (0xAA) EX1 ;

__sbit __at (0xAB) ET1 ;

__sbit __at (0xAC) ES ;

__sbit __at (0xAF) EA ;


/* P3 */

__sbit __at (0xB0) P3_0 ;

__sbit __at (0xB1) P3_1 ;

__sbit __at (0xB2) P3_2 ;

__sbit __at (0xB3) P3_3 ;

__sbit __at (0xB4) P3_4 ;

__sbit __at (0xB5) P3_5 ;

__sbit __at (0xB6) P3_6 ;

__sbit __at (0xB7) P3_7 ;


__sbit __at (0xB0) RXD ;

__sbit __at (0xB1) TXD ;

__sbit __at (0xB2) INT0 ;

__sbit __at (0xB3) INT1 ;

__sbit __at (0xB4) T0 ;

__sbit __at (0xB5) T1 ;

__sbit __at (0xB6) WR ;

__sbit __at (0xB7) RD ;


/* IP */

__sbit __at (0xB8) PX0 ;

__sbit __at (0xB9) PT0 ;

__sbit __at (0xBA) PX1 ;

__sbit __at (0xBB) PT1 ;

__sbit __at (0xBC) PS ;


/* PSW */

__sbit __at (0xD0) P ;

__sbit __at (0xD1) F1 ;

__sbit __at (0xD2) OV ;

__sbit __at (0xD3) RS0 ;

__sbit __at (0xD4) RS1 ;

__sbit __at (0xD5) F0 ;

__sbit __at (0xD6) AC ;

__sbit __at (0xD7) CY ;


/* BIT definitions for bits that are not directly accessible */

/* PCON bits */

#define IDL 0x01

#define PD 0x02

#define GF0 0x04

#define GF1 0x08

#define SMOD 0x80


/* TMOD bits */

#define T0_M0 0x01

#define T0_M1 0x02

#define T0_CT 0x04

#define T0_GATE 0x08

#define T1_M0 0x10

#define T1_M1 0x20

#define T1_CT 0x40

#define T1_GATE 0x80


#define T0_MASK 0x0F

#define T1_MASK 0xF0


/* Interrupt numbers: address = (number * 8) + 3 */

#define IE0_VECTOR 0 /* 0x03 external interrupt 0 */

#define TF0_VECTOR 1 /* 0x0b timer 0 */

#define IE1_VECTOR 2 /* 0x13 external interrupt 1 */

#define TF1_VECTOR 3 /* 0x1b timer 1 */

#define SI0_VECTOR 4 /* 0x23 serial port 0 */


#endif


3.2 內(nèi)部Ram&Rom

最初的51單片機有128byte的片內(nèi)Ram和4K的片內(nèi)的Rom,現(xiàn)在的51單片機可以有1K的片內(nèi)Ram和64K片內(nèi)的Rom。至于如何選擇芯片型號要根據(jù)項目的實際需要和成本,參考選型指南、供應(yīng)市場的具體情況作出。


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉