版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Features18-bitMicrocontroller with 8K Bytes In-System Programmable FlashAT89S52Rev. 1919A-07/01 Compatible with MCS-51 Products 8K Bytes of In-System Programmable (ISP) Flash Memory Endurance: 1000 Write/Erase Cycles 4.0V to 5.5V Operating Range Fully Static Operation: 0 Hz to 33 MHz Three-level Pro
2、gram Memory Lock 256 x 8-bit Internal RAM 32 Programmable I/O Lines Three 16-bit Timer/Counters Eight Interrupt SourcesFull Duplex UART Serial Channel Low-power Idle and Power-down Modes Interrupt Recovery from Power-down Mode Watchdog Timer Dual Data Pointer Power-off FlagDescriptionThe AT89S52 is
3、a low-power, high-performance CMOS 8-bit microcontroller with 8K bytes of in-system programmable Flash memory. The device is manufactured using Atmels high-density nonvolatile memory technology and is compatible with the indus- try-standard 80C51 instruction set and pinout. The on-chip Flash allows
4、the program memory to be reprogrammed in-system or by a conventional nonvolatile memory pro- grammer. By combining a versatile 8-bit CPU with in-system programmable Flash on a monolithic chip, the Atmel AT89S52 is a powerful microcontroller which provides a highly-flexible and cost-effective solutio
5、n to many embedded control applications.The AT89S52 provides the following standard features: 8K bytes of Flash, 256 bytes of RAM, 32 I/O lines, Watchdog timer, two data pointers, three 16-bit timer/counters, a six-vector two-level interrupt architecture, a full duplex serial port, on-chip oscillato
6、r, and clock circuitry. In addition, the AT89S52 is designed with static logic for operation down to zero frequency and supports two software selectable power saving modes. The Idle Mode stops the CPU while allowing the RAM, timer/counters, serial port, and interrupt system to continue functioning.
7、The Power-down mode saves the RAM con- tents but freezes the oscillator, disabling all other chip functions until the next interrupt or hardware reset.Pin ConfigurationsP1.4 P1.3 P1.2P1.1 (T2 EX) P1.0 (T2) NCVCCP0.0 (AD0)P0.1 (AD1)P0.2 (AD2)P0.3 (AD3)PDIPPLCCVCCP0.0 (AD0)P0.1 (AD1)P0.2 (AD2)P0.3 (AD
8、3)P0.4 (AD4)P0.5 (AD5)P0.6 (AD6)P0.7 (AD7) EA/VPP ALE/PROG PSENP2.7 (A15)P2.6 (A14)P2.5 (A13)P2.4 (A12)P2.3 (A11)P2.2 (A10)P2.1 (A9)P2.0 (A8)40393837363534333231302928272625242322211234567891011121314151617181920(T2) P1.0 (T2 EX) P1.1P1.2 P1.3 P1.4(MOSI) P1.5 (MISO) P1.6 (SCK) P1.7RST (RXD) P3.0(TXD
9、) P3.1 (INT0) P3.2 (INT1) P3.3 (T0) P3.4(T1) P3.5(WR) P3.6(RD) P3.7 XTAL2 XTAL1 GND(MOSI) P1.5 (MISO) P1.6 (SCK) P1.7789101112131415161739P0.4 (AD4)38P0.5 (AD5)37P0.6 (AD6)36P0.7 (AD7)35 EA/VPP34 NC33 ALE/PROG32 PSEN313029P2.7 (A15)P2.6 (A14)P2.5 (A13)6543214443424140RST (RXD) P3.0NC (TXD) P3.1 (INT
10、0) P3.2 (INT1) P3.3 (T0) P3.4(WR) P3.6(RD) P3.7 XTAL2 XTAL1 GND NC(A8) P2.0(A9) P2.1(A10) P2.2(A11) P2.3(A12) P2.41819202122232425262728(T1) P3.5P1.4 P1.3 P1.2P1.1 (T2 EX) P1.0 (T2) NCVCCP0.0 (AD0)P0.1 (AD1)P0.2 (AD2)P0.3 (AD3)TQFP123456789101133P0.4 (AD4)32P0.5 (AD5)31P0.6 (AD6)30P0.7 (AD7)29 EA/VP
11、P28 NC27 ALE/PROG26 PSEN252423P2.7 (A15)P2.6 (A14)P2.5 (A13)4443424140393837363534(MOSI) P1.5 (MISO) P1.6 (SCK) P1.7RST (RXD) P3.0NC (TXD) P3.1 (INT0) P3.2 (INT1) P3.3 (T0) P3.4(WR) P3.6(RD) P3.7 XTAL2 XTAL1 GND GND (A8) P2.0(A9) P2.1(A10) P2.2(A11) P2.3(A12) P2.41213141516171819202122(T1) P3.5AT89S
12、52Block DiagramP0.0 - P0.7P2.0 - P2.7PORT 2 DRIVERSPORT 0 DRIVERSVCCGNDRAM ADDR. REGISTERFLASHRAMPORT 2 LATCHPORT 0 LATCHB REGISTERACCSTACK POINTERPROGRAM ADDRESS REGISTERTMP2TMP1BUFFERINTERRUPT, SERIAL PORT, AND TIMER BLOCKSPSWPROGRAM COUNTERPC INCREMENTERALU27PSEN ALE/PROGEA / VPPRSTTIMING AND CON
13、TROLDUAL DPTRINSTRUCTION REGISTERISP PORTPORT 1 LATCHPORT 3 LATCHPROGRAM LOGICWATCH DOGPORT 1 DRIVERSPORT 3 DRIVERSOSCP3.0 - P3.7P1.0 - P1.7Pin DescriptionVCCSupply voltage.GNDGround.Port 0Port 0 is an 8-bit open drain bidirectional I/O port. As an output port, each pin can sink eight TTL inputs. Wh
14、en 1s are written to port 0 pins, the pins can be used as high- impedance inputs.Port 0 can also be configured to be the multiplexed low- order address/data bus during accesses to external program and data memory. In this mode, P0 has internal pullups.Port 0 also receives the code bytes during Flash
15、 program- ming and outputs the code bytes during program verifica- tion. External pullups are required during program verification.Port 1Port 1 is an 8-bit bidirectional I/O port with internal pullups. The Port 1 output buffers can sink/source four TTL inputs. When 1s are written to Port 1 pins, the
16、y are pulled high by the internal pullups and can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current (IIL) because of the internal pullups.In addition, P1.0 and P1.1 can be configured to be the timer/counter 2 external count input (P1.0/T2) and the tim
17、er/counter 2 trigger input (P1.1/T2EX), respectively, as shown in the following table.Port 1 also receives the low-order address bytes during Flash programming and verification.Port PinAlternate FunctionsP1.0T2 (external count input to Timer/Counter 2), clock-outP1.1T2EX (Timer/Counter 2 capture/rel
18、oad trigger and direction control)P1.5MOSI (used for In-System Programming)P1.6MISO (used for In-System Programming)P1.7SCK (used for In-System Programming)Port 2Port 2 is an 8-bit bidirectional I/O port with internal pullups. The Port 2 output buffers can sink/source four TTL inputs. When 1s are wr
19、itten to Port 2 pins, they are pulled high by the internal pullups and can be used as inputs. As inputs, Port 2 pins that are externally being pulled low will source current (IIL) because of the internal pullups.Port 2 emits the high-order address byte during fetches from external program memory and
20、 during accesses toexternal data memory that use 16-bit addresses (MOVX DPTR). In this application, Port 2 uses strong internal pul- lups when emitting 1s. During accesses to external data memory that use 8-bit addresses (MOVX RI), Port 2 emits the contents of the P2 Special Function Register.Port 2
21、 also receives the high-order address bits and some control signals during Flash programming and verification.Port 3Port 3 is an 8-bit bidirectional I/O port with internal pullups. The Port 3 output buffers can sink/source four TTL inputs. When 1s are written to Port 3 pins, they are pulled high by
22、the internal pullups and can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current (IIL) because of the pullups.Port 3 also serves the functions of various special features of the AT89S52, as shown in the following table.Port 3 also receives some control
23、signals for Flash pro- gramming and verification.Port PinAlternate FunctionsP3.0RXD (serial input port)P3.1TXD (serial output port)P3.2INT0 (external interrupt 0)P3.3INT1 (external interrupt 1)P3.4T0 (timer 0 external input)P3.5T1 (timer 1 external input)P3.6WR (external data memory write strobe)P3.
24、7RD (external data memory read strobe)RSTReset input. A high on this pin for two machine cycles while the oscillator is running resets the device. This pin drives High for 96 oscillator periods after the Watchdog times out. The DISRTO bit in SFR AUXR (address 8EH) can be used to disable this feature
25、. In the default state of bit DISRTO, the RESET HIGH out feature is enabled.ALE/PROGAddress Latch Enable (ALE) is an output pulse for latching the low byte of the address during accesses to external memory. This pin is also the program pulse input (PROG) during Flash programming.In normal operation,
26、 ALE is emitted at a constant rate of 1/6 the oscillator frequency and may be used for external timing or clocking purposes. Note, however, that one ALE pulse is skipped during each access to external data memory.If desired, ALE operation can be disabled by setting bit 0 of SFR location 8EH. With th
27、e bit set, ALE is active only dur- ing a MOVX or MOVC instruction. Otherwise, the pin isweakly pulled high. Setting the ALE-disable bit has noeffect if the microcontroller is in external execution mode.PSEN Program Store Enable (PSEN) is the read strobe to exter- nal program memory.When the AT89S52
28、is executing code from external pro- gram memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external data memory.EA/VPP External Access Enable. EA must be strapped to GND in order to enable the device to fetch code from external pr
29、o- gram memory locations starting at 0000H up to FFFFH.B 00000000ACC 00000000PSW 00000000T2CON 00000000T2MOD XXXXXX00RCAP2L 00000000RCAP2H 00000000TL2 00000000TH2 00000000IP XX000000P3 11111111IE 0X000000P2 11111111AUXR1 XXXXXXX0WDTRST XXXXXXXXSCON 00000000SBUF XXXXXXXXP1 11111111TCON 00000000TMOD 0
30、0000000TL0 00000000TL1 00000000TH0 00000000TH1 00000000AUXR XXX00XX0P0 11111111SP 00000111DP0L 00000000DP0H 00000000DP1L 00000000DP1H 00000000PCON 0XXX0000Table 1. AT89S52 SFR Map and Reset Values0F8H0F0HNote, however, that if lock bit 1 is programmed, EA will beinternally latched on reset.EA should
31、 be strapped to VCC for internal program execu- tions.This pin also receives the 12-volt programming enable volt- age (VPP) during Flash programming.XTAL1Input to the inverting oscillator amplifier and input to the internal clock operating circuit.XTAL2Output from the inverting oscillator amplifier.
32、0FFH0F7H0E8H0E0H0D8H0D0H0C8H0C0H0B8H0B0H0A8H0A0H98H90H88H80H0EFH0E7H0DFH0D7H0CFH0C7H0BFH0B7H0AFH0A7H9FH97H8FH87HSpecial Function RegistersA map of the on-chip memory area called the Special Func- tion Register (SFR) space is shown in Table 1.Note that not all of the addresses are occupied, and unoc-
33、 cupied addresses may not be implemented on the chip. Read accesses to these addresses will in general return random data, and write accesses will have an indetermi- nate effect.User software should not write 1s to these unlisted loca- tions, since they may be used in future products to invokeTable
34、2. T2CON Timer/Counter 2 Control RegisterTF2EXF2RCLKTCLKEXEN2TR2C/T2CP/RL276543210T2CON Address = 0C8H Bit AddressableBitnew features. In that case, the reset or inactive values of the new bits will always be 0.Timer 2 Registers: Control and status bits are contained in registers T2CON (shown in Tab
35、le 2) and T2MOD (shown in Table 3) for Timer 2. The register pair (RCAP2H, RCAP2L) are the Capture/Reload registers for Timer 2 in 16-bit cap- ture mode or 16-bit auto-reload mode.Interrupt Registers: The individual interrupt enable bits are in the IE register. Two priorities can be set for each of
36、the six interrupt sources in the IP register.Reset Value = 0000 0000BSymbolFunctionTF2Timer 2 overflow flag set by a Timer 2 overflow and must be cleared by software. TF2 will not be set when either RCLK = 1 or TCLK = 1.EXF2Timer 2 external flag set when either a capture or reload is caused by a neg
37、ative transition on T2EX and EXEN2 = 1. When Timer 2 interrupt is enabled, EXF2 = 1 will cause the CPU to vector to the Timer 2 interrupt routine. EXF2 must be cleared by software. EXF2 does not cause an interrupt in up/down counter mode (DCEN = 1).RCLKReceive clock enable. When set, causes the seri
38、al port to use Timer 2 overflow pulses for its receive clock in serial port Modes 1 and 3. RCLK = 0 causes Timer 1 overflow to be used for the receive clock.TCLKTransmit clock enable. When set, causes the serial port to use Timer 2 overflow pulses for its transmit clock in serial port Modes 1 and 3.
39、 TCLK = 0 causes Timer 1 overflows to be used for the transmit clock.EXEN2Timer 2 external enable. When set, allows a capture or reload to occur as a result of a negative transition on T2EX if Timer 2 is not being used to clock the serial port. EXEN2 = 0 causes Timer 2 to ignore events at T2EX.TR2St
40、art/Stop control for Timer 2. TR2 = 1 starts the timer.C/T2Timer or counter select for Timer 2. C/T2 = 0 for timer function. C/T2 = 1 for external event counter (falling edge triggered).CP/RL2Capture/Reload select. CP/RL2 = 1 causes captures to occur on negative transitions at T2EX if EXEN2 = 1. CP/
41、RL2 = 0 causes automatic reloads to occur when Timer 2 overflows or negative transitions occur at T2EX when EXEN2 = 1. Wheneither RCLK or TCLK = 1, this bit is ignored and the timer is forced to auto-reload on Timer 2 overflow.AUXRAddress = 8EHNot Bit AddressableReset Value = XXX00XX0BBitDISALEReser
42、ved for future expansionDisable/Enable ALEDISALE 01Operating ModeALE is emitted at a constant rate of 1/6 the oscillator frequency ALE is active only during a MOVX or MOVC instructionDISRTODisable/Enable Reset outDISRTO01Reset pin is driven High after WDT times outReset pin is input onlyWDIDLEDisabl
43、e/Enable WDT in IDLE mode WDIDLE0 WDT continues to count in IDLE mode1 WDT halts counting in IDLE modeTable 3a. AUXR: Auxiliary RegisterWDIDLEDISRTODISALE76543210Dual Data Pointer Registers: To facilitate accessing both internal and external data memory, two banks of 16-bit Data Pointer Registers ar
44、e provided: DP0 at SFR address locations 82H-83H and DP1 at 84H-85H. Bit DPS = 0 in SFR AUXR1 selects DP0 and DPS = 1 selects DP1. The user should always initialize the DPS bit to theAUXR1Address = A2HNot Bit AddressableReset Value = XXXXXXX0BBitDPSReserved for future expansion Data Pointer Register
45、 SelectDPS0 Selects DPTR Registers DP0L, DP0H1 Selects DPTR Registers DP1L, DP1HTable 3b. AUXR1: Auxiliary Register 1appropriate value before accessing the respective Data Pointer Register.Power Off Flag: The Power Off Flag (POF) is located at bit 4 (PCON.4) in the PCON SFR. POF is set to “1” during
46、 power up. It can be set and rest under software control and is not affected by reset.DPS76543210Memory OrganizationMCS-51 devices have a separate address space for Pro- gram and Data Memory. Up to 64K bytes each of external Program and Data Memory can be addressed.Program MemoryIf the EA pin is con
47、nected to GND, all program fetches are directed to external memory.On the AT89S52, if EA is connected to VCC, program fetches to addresses 0000H through 1FFFH are directed to internal memory and fetches to addresses 2000H through FFFFH are to external memory.Data MemoryThe AT89S52 implements 256 byt
48、es of on-chip RAM. The upper 128 bytes occupy a parallel address space to the Special Function Registers. This means that the upper 128 bytes have the same addresses as the SFR space but are physically separate from SFR space.When an instruction accesses an internal location above address 7FH, the a
49、ddress mode used in the instruction specifies whether the CPU accesses the upper 128 bytes of RAM or the SFR space. Instructions which use direct addressing access of the SFR space.For example, the following direct addressing instruction accesses the SFR at location 0A0H (which is P2).MOV 0A0H, #dat
50、aInstructions that use indirect addressing access the upper 128 bytes of RAM. For example, the following indirect addressing instruction, where R0 contains 0A0H, accesses the data byte at address 0A0H, rather than P2 (whose address is 0A0H).MOV R0, #dataNote that stack operations are examples of ind
51、irect addressing, so the upper 128 bytes of data RAM are avail- able as stack space.Watchdog Timer(One-time Enabled with Reset-out)The WDT is intended as a recovery method in situations where the CPU may be subjected to software upsets. The WDT consists of a 13-bit counter and the Watchdog Timer Res
52、et (WDTRST) SFR. The WDT is defaulted to disable from exiting reset. To enable the WDT, a user must write 01EH and 0E1H in sequence to the WDTRST register (SFR location 0A6H). When the WDT is enabled, it will increment every machine cycle while the oscillator is run- ning. The WDT timeout period is
53、dependent on the external clock frequency. There is no way to disable the WDT except through reset (either hardware reset or WDT over- flow reset). When WDT overflows, it will drive an output RESET HIGH pulse at the RST pin.Using the WDTTo enable the WDT, a user must write 01EH and 0E1H in sequence
54、to the WDTRST register (SFR location 0A6H). When the WDT is enabled, the user needs to service it by writing 01EH and 0E1H to WDTRST to avoid a WDT over- flow. The 13-bit counter overflows when it reaches 8191 (1FFFH), and this will reset the device. When the WDT is enabled, it will increment every machine cycle while the oscillator is running. This means the user must reset the WDT at least every 8191 machine cycles. To reset the WDT the user must write
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- (新)短效期疫苗报告制度2篇
- 职高难的数列题目及答案
- AI在水利水电建筑工程中的应用
- 医疗机构执业许可证管理制度
- 表4企业养老保险遗属待遇申领表
- 2026年中国GEO生成式引擎优化服务商综合排名白皮书
- 001-3.建筑材料及制品燃烧性能分级检测报告(难燃B1级)
- 2025-2026学年译林版(三起)小学英语六年级下册期末综合测试卷及答案
- 北湾智能网联汽车产业基地快速通道及周边配套项目水土保持报告表
- 湖北能源集团南漳清河 30MW-60MWh 储能电站水土保持报告表
- 2026年cnas测试题及答案
- 2026年新能源动力电池系统检修题库含答案
- 2026年国企竞聘笔考试试题库目简答题与答案
- 2026年安全知识竞赛及答案
- 2026年事业单位考试职测考点笔记
- 2026年广东高考物理试卷及答案
- 2025贵州省贵阳市殡仪服务中心公开招聘(编外)工作人员25人考试参考试题及答案解析
- GB/T 18422-2013橡胶和塑料软管及软管组合件透气性的测定
- GA/T 497-2016道路车辆智能监测记录系统通用技术条件
- 湖南省长沙市长郡教育集团2021-2022学年中考三模数学试题含解析
- 脱挂式索道(检测)课件
评论
0/150
提交评论