STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
STC90C58AD系列单片机器件手册
---����������������
广受欢迎的STC89系列升级版本
---�����������
超����������
强抗静电,�����
超����
强抗干扰
---�������������������
抗干扰能力比89系列更强,复位效果更好
---����������������
直接取代89系列,软硬件无需改动
---低功耗,超低价,高速,高可靠
STC90C51AD,
STC90C52AD,
STC90C54AD,
STC90C58AD,
STC90C510AD,
STC90C512AD,
STC90C514AD,
STC90C516AD,
C
T
S
.
d
e
t
i
m
STC90LE51AD
STC90LE52AD
STC90LE54AD
STC90LE58AD
STC90LE510AD
STC90LE512AD
STC90LE514AD
STC90LE516AD
U
C
M
Li
全部中国本土独立自主知识产权,请全体中国人民支持,您的
支持是中国本土����������
力量前进的�����
有力保证.
STC-ISP:最方便的在线升级软件
技术支持网站�: www.STCMCU.com
Update date: 2011/10/30
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
目录
第1章 STC90系列单片机总体介绍............................ 6
1.1 STC90C58AD系列单片机简介..................................6
1.2 STC90C58AD系列单片机的内部结构............................7
1.3 STC90C58AD系列单片机管脚图................................8
1.4 STC90C58AD系列单片机选型一览表............................9
1.5 STC90C58AD系列单片机最小应用系统.........................10
1.6 STC90C58AD系列在系统可编程(ISP)典型应用线路图.............11
1.7 STC90C58AD系列管脚说明...................................12
1.8 STC90C58AD系列单片机封装尺寸图...........................14
1.9 STC90C58AD系列单片机命名规则.............................18
1.10 降低单片机时钟对外界的电磁辐射(EMI)——三大措施...........19
1.11 超低功耗——STC90C58AD 系列单片机........................20
第2章 省电模式及复位.................................... 21
2.1 STC90C58AD系列单片机的省电模式.......................... 21
2.1.1 空闲模式(建议不要使用)...............................................................................22
2.1.2 掉电模式/停机模式........................................................................................22
2.2 复位...................................................... 28
2.2.1
2.2.2
2.2.3
2.2.4
2.2.5
外部RST引脚复位..........................................................................................28
软件复位........................................................................................................28
上电复位/掉电复位........................................................................................29
看门狗(WDT)复位..........................................................................................29
冷启动复位和热启动复位...............................................................................33
第3章 片内存储器和特殊功能寄存器(SFRs)..................................... 34
3.1 程序存储器................................................ 34
3.2 数据存储器(SRAM)................................................................................... 35
3.2.1 内部RAM.......................................................................................................35
3.2.2 内部扩展RAM(物理上是内部,逻辑上是外部,用MOVX访问)...................37
3.2.3 可外部扩展64K Bytes(字节)数据存储器........................................................46
3.3 特殊功能寄存器(SFRs).............................................................................. 47
第4章 STC90C58AD系列单片机的I/O口结构................. 53
4.1 I/O口各种不同的工作模式及配置介绍.......................... 53
4.2
4.3
4.4
4.5
4.6
4.1.1 准双向口输出配置...................................................................................................53
4.1.2 开漏输出配置(P0口上电复位后处于开漏模式)..............................................54
头文件/新增特殊功能寄存器的声明,P4口的使用................
STC90C58AD系列单片机ALE/P4.5管脚的设置..................
一种典型三极管控制电路....................................
混合电压供电系统3V/5V器件I/O口互连........................
I/O口直接驱动LED数码管应用线路图..........................
55
57
58
58
59
第5章 指令系统.......................................... 60
5.1 寻址方式.................................................. 60
5.1.1
5.1.2
5.1.3
5.1.4
5.1.5
5.1.6
5.1.7
立即寻址........................................................................................................60
直接寻址........................................................................................................60
间接寻址........................................................................................................60
寄存器寻址. ...................................................................................................61
相对寻址........................................................................................................61
变址寻址........................................................................................................61
位寻址............................................................................................................61
5.2 指令系统分类总结.......................................... 62
5.3 传统8051单片机指令定义详解(中文&English)................... 66
5.3.1 传统8051单片机指令定义详解...............................................................................66
5.3.2 Instruction Definitions of Traditional 8051 MCU...................................................106
第6章 中断系统......................................... 143
6.1
6.2
6.3
6.4
6.5
6.6
中断结构.................................................
中断寄存器...............................................
中断优先级...............................................
中断处理.................................................
外部中断.................................................
中断测试程序.............................................
6.6.1
6.6.2
6.6.3
6.6.3
145
147
153
154
155
156
外部中断0(INT0)的测试程序(C程序及汇编程序)........................................156
外部中断1(INT1)的测试程序(C程序及汇编程序)........................................160
外部中断2(INT2)的测试程序(C程序及汇编程序)........................................164
外部中断3(INT3)的测试程序(C程序及汇编程序)........................................169
第7章 定时器/计数器.................................... 174
7.1 定时器/计数器0/1......................................... 174
7.1.1 定时器/计数器0和1的相关寄存器...............................................................174
7.1.2 定时器/计数器0工作模式(与传统8051单片机兼容)....................................177
7.1.2.1
7.1.2.2
7.1.2.3
7.1.2.4
模式0(13位定时器/计数器).......................................... 177
模式1(16位定时器/计数器)及其测试程序(C程序及汇编程序)............. 178
模式2(8位自动重装模式)及其测试程序(C程序及汇编程序)............... 182
模式3(两个8位计数器)..............................................................................................185
7.1.3 定时器/计数器1工作模式(与传统8051单片机兼容)....................................186
7.1.3.1 模式0(13位定时器/计数器)......................................................................................186
7.1.3.2 模式1(16位定时器/计数器)及其测试程序(C程序及汇编程序)............. 187
7.1.3.3 模式2(8位自动重装模式)及其测试程序(C程序及汇编程序)............... 191
7.1.4 古老Intel 8051单片机定时器0/1的应用举例..................................................194
7.2 定时器/计数器T2.................................................................................... 201
7.2.1
7.2.2
7.2.3
7.2.4
7.2.5
定时器2的捕获模式...............................................................................................203
定时器2的自动重装模式(递增/递减计数器).....................................................204
定时器2作串行口波特率发生器及其测试程序(C程序及汇编程序).................206
定时器2的可编程时钟输出及其测试程序(C程序及汇编程序).........................214
定时器/计数器2作定时器的测试程序(C程序及汇编程序)...............................217
第8章 串行口通信....................................... 221
8.1 串行口相关寄存器......................................... 221
8.2 串行口工作模式........................................... 226
8.2.1
8.2.2
8.2.3
8.2.4
8.3
8.4
8.5
8.6
串行口工作模式0:同步移位寄存器............................................................226
串行口工作模式1:8位UART,波特率可变...................................................228
串行口工作模式2:9位UART,波特率固定...................................................230
串行口工作模式3:9位UART,波特率可变...................................................232
串行通信中波特率的设置...................................
串行口的测试程序(C程序及汇编程序)........................
双机通信.............................................
多机通信.............................................
234
237
243
254
第9章 STC90C58AD系列单片机的A/D转换器................ 260
9.1
9.2
9.3
9.4
A/D转换器的结构..........................................
与A/D转换相关的寄存器....................................
A/D转换典型应用线路......................................
A/D做按键扫描应用线路图..................................
260
262
264
265
9.5 A/D转换模块的参考电压源.................................. 266
9.6 A/D转换测试程序(C程序和汇编程序)........................ 267
第10章 STC90C58AD系列EEPROM的应用................. 275
10.1
10.2
10.3
10.4
IAP及EEPROM新增特殊功能寄存器介绍.....................
STC90C58AD系列单片机EEPROM空间大小及地址............
IAP及EEPROM汇编简介...................................
EEPROM测试程序(C程序及汇编程序).......................
275
278
281
285
第11章 STC90C58AD系列单片机开发/编程工具............. 293
11.1 在系统可编程(ISP)原理,官方演示工具使用说明.............. 293
11.1.1
11.1.2
11.1.3
11.1.4
11.1.5
在系统可编程(ISP)原理使用说明................................................................293
STC90C58AD系列在系统可编程(ISP)典型应用线路图...............................295
电脑端的ISP控制软件界面使用说明...........................................................297
STC-ISP(最方便的在线升级软件)下载编程工具硬件使用说明..................299
若无RS-232转换器,如何用STC的ISP下载板做RS-232通信转换. ..............300
11.2 编译器/汇编器,编程器,仿真器........................... 301
附录A:汇编语言编程.................................... 303
附录B:C语言编程....................................... 325
附录C:STC90C58AD系列单片机电气特性.................. 335
附录D:内部常规256字节RAM间接寻址测试程序............ 337
附录E:用串口扩展I/O接口............................... 339
附录F:利用STC单片机普通I/O驱动LCD显示............... 342
附录G:如何利用Keil C软件减少代码长度.................. 349
附录H:如何实现运行中自定义下载........................ 350
——无仿真器时方便调试.................................. 350
——自定义下载演示程序(实现不停电下载).................. 350
附录I:每日更新内容的备忘录............................. 355
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
第1章 STC90系列单片机总体介绍
1.1 STC90C58AD系列单片机简介
STC90C58AD系列单片机是STC��������������������������
推出的�����������������������
新一代超强抗干扰/高速/低功耗的�������
单片机,指令代
码完全兼容传统�������������������������������������
8051单片机,12���������������������������
时钟/机器周期和6时钟/机器周期可以任意选择。内部集成
MAX810专用复位电路,当时钟频率在6MHz时,该复位电路时可靠的;当时钟频率在12MHz时,
勉强可用����������������������������������������
。���������������������������������������
在要求不高的情况下,可在复位脚外接电阻电容复位。8路10位高速A/D转换器(可
达25万次/秒)。
1. 增强型8051�������������������������������������
单片机,���������������������������������
6时钟/机器周期�������������������������
和������������������������
12时钟/机器周期���������������
可任意选择����������
,指令代码完全兼容传
统8051
.
d
e
t
i
m
2. 工作电压:5.5V - 3.3V (5V单片机) ��/ 3.6V - 2.0V (3V单片机)
3. 工作频率范围:0~40MHz,相当于普通8051的 0~80MHz,实际工作频率可达48MHz.
Li
4. 用户应用程序空间�
:4K / 8K/ 16K / 32K /40K/ 48K/ 56K/ 61K字节
5. 片上集成256+4096字节RAM
U
C
M
6. 通用I/O口(35/39个),复位后为:P1/P2/P3/P4是准双向口/弱上拉(普通8051传统I/O口)�
;P0
口是开漏输出,作为总线扩展用时,不用加上拉电阻,作为I/O口用时,需加上拉电阻。
C
T
S
7. ISP(在系统可编程)/ IAP(在应用可编程),无需专用编程器,无需专用仿真器
可通过串口(RxD/P3.0, TxD/P3.1)直接下载用户程序,数秒即可完成一片
8. 有EEPROM功能
9. 看门狗
10.内部集成MAX810专用复位电路,�����������������������������
当时钟频率在6MHz时该内部简单的MAX810专用复位电路
时可靠的;当时钟频率在12MHz时勉强可用��������������������
。�������������������
在要求不高的情况下,可在复位脚外接电阻
电容复位。
11.共3个16位定时器/计数器,其中定时器0还可以当成2个8位定时器使用�
。
12.外部中断4路,下降沿中断或低电平触发中断�
,Power Down模式可由外部中断低电平触发中
断方式唤醒�
。
13. 8路10位A/D转换。
14. 通用异步串行口(UART),还可用定时器软件实现多个UART
15. 工作温度范围:-40 ~ +85℃(工业级) / 0 ~ 75℃(商业级)
16. 封装:LQFP-44, PDIP-40, PLCC-44, PQFP-44. 如选择STC89系列,请优先选择LQFP-44封
装���������������������
。不过������������������
推荐优先选择采用最新第六代加密技术的STC11/10xx系列单片机
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
1.2 STC90C58AD系列单片机的内部结构
STC90C58AD系列单片机的内部结构框图如下图所示。STC90C58AD单片机中包含中央
处理器(CPU)、程序存储器(Flash)、数据存储器(SRAM)、定时/计数器、UART串口、I/O接
口、EEPROM、看门狗,A/D转换器等模块。STC90C58AD系列单片机几乎包含了数据采集和
控制中所需的所有单元模块,可称得上一个片上系统。
RAM 地址
寄存器
AUX-RAM
4096字节
RAM
256字节
.
d
e
t
i
m
程序存储器(Flash)
B寄存器
ACC
双数据指针
TMP2
C
T
S
TMP1
ALU
EEPROM
Control
Unit
RESET
U
C
M
堆栈指针
Li
定时器 0/1
定时器 2
地址生成器
串口
程序计数器(���
PC)
WDT
PSW
ISP/IAP
Port 0,2,3,4
锁存器
Port1 锁存器
ADC
XTAL1
XTAL2
Port 1 驱动器
8
P1.0 ~ P1.7
P1.0 ~ P1.7
Port 0,2,3,4
驱动器
P0,P2,P3,P4
STC90C58AD系列内部结构框图
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
LQFP-44
PQFP-44
增加了P4口
并可位寻址
P2.4
P2.3
P2.2
P2.1
P2.0
P4.0
Gnd
XTAL1
XTAL2
P3.7/RD
P3.6/WR
22
21
20
19
18
17
16
15
14
13
12
ADC5/P1.5
ADC6/RxD/P1.6
ADC7/TxD/P1.7
RST
RxD/P3.0
INT2/P4.3
TxD/P3.1
INT0/P3.2
INT1/P3.3
T0/P3.4
T1/P3.5
1
2
3
4
5
6
7
8
9
10
11
34
35
36
37
38
39
40
41
42
43
44
P1.4/ADC4
P1.3/ADC3
P1.2/ADC2
P1.1/T2EX/ADC1
P1.0/T2/ADC0
P4.2/INT3
Vcc
P0.0
P0.1
P0.2
P0.3
6
5
4
3
2
1
44
43
42
41
40
C
T
S
PLCC-44
增加了P4口
并可位寻址
39
38
37
36
35
34
33
32
31
30
29
P0.4
P0.5
P0.6
P0.7
EA/P4.6
P4.1
ALE/P4.5
PSEN/P4.4
P2.7
P2.6
P2.5
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
39
38
37
36
35
34
33
32
31
30
29
28
27
26
25
24
23
22
21
Li
Vcc
P0.0
P0.1
P0.2
P0.3
P0.4
P0.5
P0.6
P0.7
EA/P4.6
ALE/P4.5
PSEN/P4.4
P2.7
P2.6
P2.5
P2.4
P2.3
P2.2
P2.1
P2.0
关于编译器/ 汇编器:
1.任何老的编译器/汇编器均可使用Keil C51
中��������������������������
:�������������������������
Device选择标准的Intel8052头文件包含
标准的
2.新增特殊功能寄存器如要用到,则用“sfr”
及“sbit”声明地址即可
3 . 汇编中用“data”,或“EQU”声明地址
U
C
M
18
19
20
21
22
23
24
25
26
27
28
7
8
9
10
11
12
13
14
15
16
17
1
40
.
d
e
t
i
m
P4口地址在C0H,
P4.3-P4.0
关于仿真及仿真器:
1.任何老的仿真器均可使用
2.老的仿真器仿真他可仿真的基本功能
3.新增特殊功能用ISP直接下载程序看结果即可
5.其实现在大部分STC用户不用仿真器,用ISP就可
调通64K程序
WR/P3.6
RD/P3.7
XTAL2
XTAL1
Gnd
P4.0
P2.0
P2.1
P2.2
P2.3
P2.4
ADC5/P1.5
ADC6/RxD/P1.6
ADC7/TxD/P1.7
RST
RxD/P3.0
INT2P4.3
TxD/P3.1
INT0/P3.2
INT1/P3.3
T0/P3.4
T1/P3.5
ADC0/T2/P1.0
ADC1/T2EX/P1.1
ADC2/P1.2
ADC3/P1.3
ADC4/P1.4
ADC5/P1.5
ADC6/RxD/P1.6
ADC7/TxD/P1.7
RST
RxD/P3.0
TxD/P3.1
INT0/P3.2
INT1/P3.3
T0/P3.4
T1/P3.5
WR/P3.6
RD/P3.7
XTAL2
XTAL1
Gnd
PDIP-40, 增加了P4口
P0.3
P0.2
P0.1
P0.0
Vcc
INT3/P4.2
ADC0/T2/P1.0
ADC1/T2EX/P1.1
ADC2/P1.2
ADC3/P1.3
ADC4/P1.4
33
32
31
30
29
28
27
26
25
24
23
P0.4
P0.5
P0.6
P0.7
EA/P4.6
P4.1
ALE/P4.5
PSEN/P4.4
P2.7
P2.6
P2.5
1.3 STC90C58AD系列������
单片机���
管脚图
由AUXR寄存器设置串行口/UART是在P3口还是在P1口
AUXR : Auxiliary Register
Mnemonic
AUXR
Add
bit
B7
8EH name UART_P1
B6
B5
B4
B3
B2
B1
B0
Reset Value
-
-
-
-
-
EXTRAM
ALEOFF
0xxx,xx00
UART_P1: 0, 复位后AUXR.7/UART_P1=0,串行口/UART在P3口[RxD/P3.0,TxD/P3.1]
���
1, 通过设置AUXR.7/UART_P1=1,将串行口/UART从P3口切换到P1口[RxD/P1.6,TxD/P1.7]
EXTRAM: ����������
内部/外部RAM存取
0������������������������������������������������������
,�����������������������������������������������������
允许访问内部扩展0000H-0FFFH单元(4096字节RAM),超过0FFFH的地址空间总是访问外部数
据存储器
1, 禁止访问内部扩展0000H-0FFFH 单元(4096字节RAM),直接访问外部数据存储器数据
ALEOFF����������
:ALE信号输出控制
0, ALE信号正常输出。
1, 禁止ALE 信号输出。但在访问外部数据空间及外部程序空间时有信号输出。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
1.4 STC90C58AD系列单片机选型一览表
型号
最高时钟频率
Flash
D
Hz
EEP 看
工作
定
中
UART P
程序 SRAM
ROM 门 A/D 断
电压
时
存储器 字节
串口 T
(V)
器
(字节) 狗
源
5V
3V
R
(字节)
中
支持
断
掉电
内置 封装
优 I/O 唤醒
封装44-Pin
复位 40-Pin
先
外部
级
中断
STC90C58AD系列单片机选型一览
STC90C51AD
5.5 - 3.3 0-80M
STC90C52AD
STC90C54AD
5K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
2
5K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
2
45K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
1个
2
29K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
3
1个
2
21K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
4352
3
1个
2
13K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
4352
3
1个
2
5K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
4352
3
1个
2
-
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
4K
4352
3
1个
2
5.5 - 3.3 0-80M
8K
4352
3
1个
5.5 - 3.3 0-80M
16K
4352
3
1个
STC90C58AD
5.5 - 3.3 0-80M
32K
4352
3
STC90C510AD
5.5 - 3.3 0-80M
40K
4352
STC90C512AD
5.5 - 3.3 0-80M
48K
STC90C514AD
5.5 - 3.3 0-80M
56K
STC90C516AD
5.5 - 3.3 0-80M
61K
.
d
te
i
m
Li
STC90LE58AD系列单片机选型一览
STC90LE51AD
3.6 - 2.0
0-80M
4K
4352
3
1个
2
5K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
STC90LE52AD
3.6 - 2.0
0-80M
8K
4352
3
1个
2
5K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
STC90LE54AD
3.6 - 2.0
0-80M
16K
4352
3
1个
2
45K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
STC90LE58AD
3.6 - 2.0
0-80M
32K
STC90LE510AD 3.6 - 2.0
STC90LE512AD 3.6 - 2.0
STC90LE514AD 3.6 - 2.0
STC90LE516AD 3.6 - 2.0
U
C
M
4352
3
1个
2
29K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
0-80M
40K
4352
3
1个
2
21K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
0-80M
48K
4352
3
1个
2
13K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
0-80M
56K
4352
3
1个
2
5K
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
0-80M
61K
4352
3
1个
2
-
有 10位 8
4 35/39 4个
有
PDIP LQFP/PLCC
C
T
S
STC90C58AD系列单片机44-pin的封装除LQFP44和PLCC44外,还有PFQP44,但是不推荐使用
PLCC44和PFQP44封装,建议选用LQFP44的封装。
选用STC单片机的理由:降低成本,提升性能,原有程序直接使用,硬件无需改动。STC公司鼓
励您放心大胆选用LQFP44小型封装单片机,使您的产品更小,更轻,功耗更低。
用STC提供的STC-ISP.exe 工具将您的2进制代码或16进制代码下载进STC相关的单片机即可。
STC90C58AD系列为真正的看门狗,缺省为关闭(冷启动),启动后无法关闭,可放心省去外部看
门狗�
.
内部Flash擦写次数为10�����
万����
次以上。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
1.5 STC90C58AD系列���������
单片机最小应用系统
10μF +
10K
C1
R1
C2 9] V [(AC) = 1]]
THEN(A3-0) ��
←���
��
(A3-0) + 6
AND
IF [[(A7-4) > 9] V [(C) = 1]]
THEN (A7-4) ��
←���
��
(A7-4) + 6
DEC byte
.
d
e
t
i
m
功能: 把BYTE所代表的操作数减1
说明:
BYTE所代表的变量被减去l。如果原来的值为00H,那么减去1后,变成0FFH。
没有标志位会受到影响。该指令支持4种操作数寻址方式:累加器寻址、寄存器寻
址、直接寻址和寄存器间接寻址。
Li
注意:当DEC指令用于修改输出端口的状态时,BYTE所代表的数据是从端口输
出数据锁存器中获取的,而不是从引脚上读取的输入状态。
U
C
M
举例: 假设寄存器0的内容为7FH(01111111B),内部RAM的7EH和7FH单元的内容分别为
00H和40H。则指令
C
T
S
DEC
@R0
DEC
R0
DEC
@R0
执行后,寄存器0的内容变成7EH,内部RAM的7EH和7FH单元的内容分别变为0FFH
和3FH。
DEC A
指令长度(字节): 1
执行周期: 1
二进制编码:
0 0
0
1
0 1 0 0
操作: DEC
(A)�����
←����
(A) -1
DEC
Rn
指令长度(字节): 1
执行周期: 1
二进制编码:
0 0 0 1
1 r r r
操作: DEC
(Rn)������
←�����
(Rn) ��- �1
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
77
STC90C58AD系列单片机指南
DEC
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
direct
指令长度(字节): 2
执行周期: 1
二进制编码:
0 0 0 1
0 1 0 1
direct address
操作: DEC
(direct)����������
←���������
(direct) -1
DEC
@Ri
指令长度(字节): 1
执行周期: 1
二进制编码:
0 0 0 1
0 1 1 i
.
d
e
t
i
m
操作: DEC
((Ri))��������
←�������
((Ri)) ��- �1
DIV AB
U
C
M
功能: 除法
说明:
Li
DIV指令把累加器A中的8位无符号整数除以寄存器B中的8位无符号整数,并将
商置于累加器A中,余数置于寄存器B中。进位标志C和溢出标志OV被清零。
C
T
S
例�������
外������
:如果寄存器B的初始值为00H(即除数为0),那么执行DIV指令后,累加
器A和寄存器B中的值是不确定的,且溢出标志OV将被置位。但在任何情况下,进位
标志C都会被清零。
举例: 假设累加器的值为251 (0FBH或11111011B),寄存器B的值为18 (12H或
00010010B)。则指令
DIV
AB
执行后,累加器的值变成13 (0DH或00001101B),寄存器B的值变成17 (11H或
0001000B),正好符合251=13×18+17。进位和溢出标志都被清零。
指令长度(字节): 1
执行周期: 4
二进制编码:
1 0
0
0
0 1 0 0
操作: DIV
(A)15-8
(A)/(B)
(B)7-0 ←��������
78
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
DJNZ ,
功能: 减1,若非0则跳转
说明:
DJNZ指令首先将第1个操作数所代表的变量减1,如果结果不为0,则转移到
第2个操作数所指定的地址处去执行。如果第1个操作数的值为00H,则减1后变为
0FFH。该指令不影响标志位。跳转目标地址的计算:首先将PC值加2(即指向下一
条指令的首字节),然后将第2操作数表示的有符号的相对偏移量加到PC上去即可。
byte所代表的操作数可采用寄存器寻址或直接寻址。
注意:如果该指令被用来修改输出引脚上的状态,那么byte所代表的数据是从端
口输出数据锁存器中获取的,而不是直接读取引脚。
举例:
假设内部RAM的40H、50H和60H单元分别存放着01H、70H和15H,则指令
DJNZ
40H, LABEL_1
DJNZ
50H, LABEL_2
DJNZ
60H, LABEL_3
.
d
e
t
i
m
Li
执行之后,程序将跳转到标号LABEL2处执行,且相应的3个RAM单元的内容变成
00H、6FH和15H。之所以第1个跳转没被执行,是因为减1后其结果为0,不满足跳转
条件。
U
C
M
使用DJNZ指令可以方便地在程序中实现指定次数的循环,此外用一条指令就可
以在程序中实现中等长度的时间延迟(2~512个机器周期)。指令序列
C
T
S
MOV
TOOOLE:
R2,#8
CPL
P1.7
DJNZ
R2, TOOGLE
将使得P1.7的电平翻转8次,从而在P1.7产生4个脉冲,每个脉冲将持续3个机器周
期,其中2个为DJNZ指令的执行时间,1个为CPL指令的执行时间。
DJNZ
Rn,rel
指令长度(字节): 2
执行周期: 2
二进制编码:
1 1 0 1
1 r r r
rel. address
操作: DJNZ
(PC) ��
← �������
�������
(PC) + �2
(Rn) ��
← �����
�����
(Rn) ��– �1
IF (Rn) > 0 or (Rn) < 0
THEN
(PC) ��
←�������
������
(PC)+ ���
rel
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
79
STC90C58AD系列单片机指南
DJNZ
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
direct, rel
指令长度(字节): 3
执行周期: 2
二进制编码:
操作: DJNZ
(PC) ��
←��������
�������
(PC) + �2
(direct) ←����������
�� ���������
(direct) ��– �1
IF (direct) > 0 or (direct) < 0
THEN
(PC) ��
← �������
�������
(PC) + ���
rel
INC
.
d
e
t
i
m
功能: 加1
说明:
INC指令将所代表的数据加1。如果原来的值为FFH,则加1后变为00H,
该指令步影响标志位。支持3种寻址模式:寄存器寻址、直接寻址、寄存器间接寻
址。
U
C
M
Li
注意:如果该指令被用来修改输出引脚上的状态,那么byte所代表的数据是从端
口输出数据锁存器中获取的,而不是直接读的引脚。
举例: 假设寄存器0的内容为7EH(0111110B),内部RAM的7E单元和7F单元分别存放着0FFH
和40H,则指令序列
C
T
S
INC
@R0
INC
R0
INC
@R0
执行完毕后,寄存器0的内容变为7FH,而内部RAM的7EH和7FH单元的内容分别变
成00H和41H。
INC
A
指令长度(字节): 1
执行周期: 1
二进制编码:
0 0
0
0
0 1 0 0
操作: INC
(A) ��
← (A)+1
�����
INC Rn
指令长度(字节): 1
执行周期: 1
二进制编码:
0 0
0
0
1 r r r
操作: INC
(Rn) ← (Rn)+1
�� ������
80
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
INC
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
direct
指令长度(字节): 2
执行周期: 1
二进制编码:
0 0 0 0
0 1 0 1
direct address
操作: INC
(direct)����������
←���������
(direct) + 1
INC
@Ri
指令长度(字节): 1
执行周期: 1
二进制编码:
0 0 0 0
0 1 1 i
.
d
e
t
i
m
操作: INC
((Ri))�����������
←����������
((Ri)) + 1
INC
DPTR
U
C
M
功能: 数据指针加1
说明:
Li
该指令实现将DPTR加1功能。需要注意的是,这是16位的递增指令,低位字节
DPL从FFH增加1之后变为00H,同时进位到高位字节DPH。该操作不影响标志位。
C
T
S
该指令是唯一1条16位寄存器递增指令。
举例: 假设寄存器DPH和DPL的内容分别为12H和0FEH,则指令序列
INC
DPTR
INC
DPTR
INC
DPTR
执行完毕后,DPH和DPL变成13H和01H
指令长度(字节): 1
执行周期: 2
二进制编码:
1 0
1
0
0 0 1 1
操作: INC
(DPTR) ��
← (DPTR)+1
��������
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
81
STC90C58AD系列单片机指南
JB
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
bit, rel
功能: 若位数据为1则跳转
说明: 如果bit代表的位数据为1,则跳转到rel所指定的地址处去执行;否则,继续执行下
一条指令。跳转的目标地址按照如下方式计算:先增加PC的值,使其指向下一条指
令的首字节地址,然后把rel所代表的有符号的相对偏移量(指令的第3个字节)加到
PC上去,新的PC值即为目标地址。该指令只是测试相应的位数据,但不会改变其数
值,而且该操作不会影响标志位。
举例: 假设端口1的输入数据为11001010B,累加器的值为56H(01010110B)。则指令
JB
P1.2, LABEL1
JB
ACC.2, LABEL2
将导致程序转到标号LABEL2处去执行
指令长度(字节): 3
执行周期: 2
二进制编码:
0 0 1 0
0 0 0 0
bit address
操作: JB
(PC) ��
← �������
�������
(PC)+ 3
IF (bit) = 1
THEN
(PC) ��
←��������
�������
(PC) + ���
rel
JBC
bit, rel
C
T
S
U
C
M
.
d
e
t
i
m
Li
rel. address
功能: 若位数据为1则跳转并将其清零
说明:
如果bit代表的位数据为1,则将其清零并跳转到rel所指定的地址处去执行。如果
bit代表的位数据为0,则继续执行下一条指令。跳转的目标地址按照如下方式计算:
先增加PC的值,使其指向下一条指令的首字节地址,然后把rel所代表的有符号的相
对偏移量(指令的第3个字节)加到PC上去,新的PC值即为目标地址,而且该操作不
会影响标志位。
注意:如果该指令被用来修改输出引脚上的状态,那么byte所代表的数据是从端
口输出数据锁存器中获取的,而不是直接读取引脚。
举例: 假设累加器的内容为56H(01010110B),则指令序列
JBC ACC.3, LABEL1
JBC
ACC.2, LABEL2
将导致程序转到标号LABEL2处去执行,且累加器的内容变为52H(01010010B)。
指令长度(字节): 3
执行周期: 2
二进制编码:
0 0 0 1
0 0 0 0
bit address
rel. address
操作: JBC
(PC) ��
← �������
�������
(PC)+ 3
IF (bit) = 1
THEN
(bit) ← 0
�� �
(PC) ��
←��������
�������
(PC) + ���
rel
82
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
JC
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
rel
功能: 若进位标志为1,则跳转
说明: 如果进位标志为1,则程序跳转到rel所代表的地址处去执行;否则,继续执行下面的
指令。跳转的目标地址按照如下方式计算:先增加PC的值,使其指向紧接JC指令的
下一条指令的首地址,然后把rel所代表的有符号的相对偏移量(指令的第2个字节)
加到PC上去,新的PC值即为目标地址。该操作不会影响标志位。
举例: 假设进位标志此时为0,则指令序列
JC
LABEL1
CPL C
JC
LABEL2
执行完毕后,进位标志变成1,并导致程序跳转到标号LABEL2处去执行。
指令长度(字节): 2
执行周期: 2
二进制编码:
0 1 0 0
0 0 0 0
操作: JC
(PC) ��
← ������
������
(PC)+ �2
IF (C) = 1
THEN
(PC) ��
←��������
�������
(PC) + ���
rel
JMP @A+DPTR
U
C
M
C
T
S
功能: 间接跳转。
.
d
e
t
i
m
rel. address
Li
说明: 把累加器A中的8位无符号数据和16位的数据指针的值相加,其和作为下一条将要执
行的指令的地址,传送给程序计数器PC。执行16位的加法时,低字节DPL的进位会
传到高字节DPH。累加器A和数据指针DPTR 的内容都不会发生变化。不影响任何标
志位。
举例: 假设累加器A中的值是偶数(从0到6)。下面的指令序列将使得程序跳转到位于跳转
表JMP_TBL 的4条AJMP指令中的某一条去执行:
MOV
DPTR, #JMP_TBL
JMP
@A+DPTR
JMP-TBL:
AJMP
LABEL0
AJMP
LABEL1
AJMP
LABEL2
AJMP
LABEL3
如果开始执行上述指令序列时,累加器A中的值为04H,那么程序最终会跳转到标号
LABEL2处去执行。
注意:AJMP是一个2字节指令,因而在跳转表中,各个跳转指令的入口地址依次相
差2个字节。
指令长度(字节): 1
执行周期: 2
二进制编码:
0 1 1 1
0 0 1 1
操作: JMP
(PC) ��
← ������������
������������
(A) + (DPTR)
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
83
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
JNB bit, rel
功能: 如果bit所代表的位不为1则跳转。
说明: 如果bit所表示的位为0,则转移到rel所代表的地址去执行;否则,继续执行下一条
指令。跳转的目标地址如此计算:先增加PC的值,使其指向下一条指令的首字节地
址,然后把rel所代表的有符号的相对偏移量(指令的第3个字节)加到PC上去,新的
PC值即为目标地址。该指令只是测试相应的位数据,但不会改变其数值,而且该操
作不会影响标志位。
举例: 假设端口1的输入数据为110010108,累加器的值为56H(01010110B)。则指令序列
JNB
P1.3, LABEL1
JNB
ACC.3, LABEL2
执行后将导致程序转到标号LABEL2处去执行。
指令长度(字节): 3
执行周期: 2
二进制编码:
0 0 1 1
0 0 0 0
bit address
操作: JNB
(PC) ��
← �������
�������
(PC)+ 3
IF (bit) = 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
JNC
C
T
S
rel
U
C
M
Li
.
d
e
t
i
m
rel. address
功能: 若进位标志非1则跳转
说明: 如果进位标志为0,则程序跳转到rel所代表的地址处去执行;否则,继续执行下面的
指令。跳转的目标地址按照如下方式计算:先增加PC的值加2,使其指向紧接JNC指
令的下一条指令的地址,然后把rel所代表的有符号的相对偏移量(指令的第2个字
节)加到PC上去,新的PC值即为目标地址。该操作不会影响标志位。
举例: 假设进位标志此时为1,则指令序列
JNC LABEL1
CPL C
JNC LABEL2
执行完毕后,进位标志变成0,并导致程序跳转到标号LABEL2处去执行。
指令长度(字节): 2
执行周期: 2
二进制编码:
0 1 0 1
0 0 0 0
rel. address
操作: JNC
(PC) ��
← ������
������
(PC)+ �2
IF (C) = 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
84
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
JNZ
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
rel
功能: 如果累加器的内容非0则跳转
说明: 如果累加器A的任何一位为1,那么程序跳转到rel所代表的地址处去执行,如果各个
位都为0,继续执行下一条指令。跳转的目标地址按照如下方式计算:先把PC的值增
加2,然后把rel所代表的有符号的相对偏移量(指令的第2个字节)加到PC上去,新
的PC值即为目标地址。操作过程中累加器的值不会发生变化,不会影响标志位。
举例: 设累加器的初始值为00H,则指令序列
JNZ
INC
JNZ
LABEL1
A
LAEEL2
执行完毕后,累加器的内容变成01H,且程序将跳转到标号LABEL2处去执行。
指令长度(字节): 2
执行周期: 2
二进制编码:
0 1 1 1
0 0 0 0
rel. address
操作: JNZ
(PC) ��
← ������
������
(PC)+ �2
IF (A) ≠ 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
JZ
C
T
S
rel
U
C
M
.
d
e
t
i
m
Li
功能: 若累加器的内容为0则跳转
说明: 如果累加器A的任何一位为0,那么程序跳转到rel所代表的地址处去执行,如果各个
位都为0,继续执行下一条指令。跳转的目标地址按照如下方式计算:先把PC的值增
加2,然后把rel所代表的有符号的相对偏移量(指令的第2个字节)加到PC上去,新
的PC值即为目标地址。操作过程中累加器的值不会发生变化,不会影响标志位。
举例: 设累加器的初始值为01H,则指令序列
JZ
DEC
JZ
LABEL1
A
LAEEL2
执行完毕后,累加器的内容变成00H,且程序将跳转到标号LABEL2处去执行。
指令长度(字节): 2
执行周期: 2
二进制编码:
0 1 1 0
0 0 0 0
rel. address
操作: JZ
(PC) ��
← ������
������
(PC)+ �2
IF (A) = 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
85
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
LCALL addr16
功能: 长调用
说明: LCALL用于调用addr16所指地址处的子例程。首先将PC的值增加3,使得PC指向紧随
LCALL的下一条指令的地址,然后把16位PC的低8位和高8位依次压入栈(低位字节
在先),同时把栈指针加2。然后再把LCALL指令的第2字节和第3字节的数据分别装
入PC的高位字节DPH和低位字节DPL,程序从新的PC所对应的地址处开始执行。因
而子例程可以位于64KB程序存储空间的任何地址处。该操作不影响标志位。
举例: 栈指针的初始值为07H,标号SUBRTN被分配的程序存储器地址为1234H。则执行如
下位于地址0123H的指令后,
LCALL SUBRTN
栈指针变成09H,内部RAM的08H和09H单元的内容分别为26H和01H,且PC的当前
值为1234H。
指令长度(字节): 3
执行周期: 2
二进制编码:
0 0 0 1
0 0 1 0
C
T
S
LJMP addr16
addr15-addr8
U
C
M
操作: LCALL
(PC) ��
←���������
��������
(PC) + 3
(SP) ��
←���������
��������
(SP) + 1
((SP)) ��
←����
���
(PC7-0)
(SP) ��
←���������
��������
(SP) + 1
((SP)) ��
←����
���
(PC15-8)
(PC) ��
←� ����
addr15-0
Li
.
d
e
t
i
m
addr7-addr0
功能: 长跳转
说明: LJMP使得CPU无条件跳转到addr16所指的地址处执行程序。把该指令的第2字节和第
3字节分别装入程序计数器PC的高位字节DPH和低位字节DPL。程序从新PC值对应的
地址处开始执行。该16位目标地址可位于64KB程序存储空间的任何地址处。该操作
不影响标志位。
举例: 假设标号JMPADR被分配的程序存储器地址为1234H。则位于地址1234H的指令
LJMP JMPADR
执行完毕后,PC的当前值变为1234H。
指令长度(字节): 3
执行周期: 2
二进制编码:
0 0 0 0
0 0 1 0
addr15-addr8
addr7-addr0
操作: LJMP
(PC) ��
←� ����
addr15-0
86
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOV ,
功能: 传送字节变量
说明:
将第2操作数代表字节变量的内容复制到第1操作数所代表的存储单元中去。该
指令不会改变源操作数,也不会影响其他寄存器和标志位。
MOV指令是迄今为止使用最灵活的指令,源操作数和目的操作数组合起来,寻
址方式可达15种。
举例: 假设内部RAM的30H单元的内容为40H,而40H单元的内容为10H。端口1 的数据为
11001010B(0CAH)。则指令序列
MOV
MOV
MOV
MOV
MOV
MOV
R0, #30H
A, @R0
R1, A
B, @Rl
@Rl, Pl
P2, P1
;R0< = 30H
;A < = 40H
;R1 < = 40H
;B < = 10H
;RAM (40H) < = 0CAH
;P2 #0CAH
.
d
e
t
i
m
Li
执行完毕后,寄存器0的内容为30H,累加器和寄存器1的内容都为40H,寄存器B的
内容为10H,RAM中40H单元和P2口的内容均为0CAH。
MOV A,Rn
指令长度(字节): 1
执行周期: 1
二进制编码:
U
C
M
C
T
S
0
1 r r r
1 1 1 0
0 1 0 1
1 1
1
操作: MOV
(A) ��
←�����
����
(Rn)
*MOV A,direct
指令长度(字节): 2
执行周期: 1
二进制编码:
direct address
操作: MOV
(A)��
←���������
��������
(direct)
注意:MOV A, ACC是无效指令。
MOV A,@Ri
指令长度(字节): 1
执行周期: 1
二进制编码:
1 1
1
0
0 1 1 i
操作: MOV
(A) ��
←�������
������
((Ri))
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
87
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOV A,#data
指令长度(字节): 2
执行周期: 1
二进制编码:
0 1 1 1
0 1 0 0
immediate data
操作: MOV
(A)��
←� �����
#data
MOV Rn, A
指令长度(字节): 1
执行周期: 1
二进制编码:
1 1 1 1
1 r r r
操作: MOV
(Rn)����
←���
(A)
MOV Rn,direct
指令长度(字节): 2
执行周期: 2
二进制编码:
1 0 1 0
操作: MOV
(Rn)���������
←��������
(direct)
MOV Rn,#data
指令长度(字节): 2
执行周期: 1
二进制编码:
C
T
S
0 1 1 1
U
C
M
.
d
e
t
i
m
Li
1 r r r
direct addr.
1 r r r
immediate data
0 1 0 1
direct address
1 r r r
direct address
操作: MOV
(Rn) ←�
�� �����
#data
MOV direct, A
指令长度(字节): 2
执行周期: 1
二进制编码:
1 1 1 1
操作: MOV
(direct) ←����
�� ���
(A)
MOV direct, Rn
指令长度(字节): 2
执行周期: 2
二进制编码:
1 0 0 0
操作: MOV
(direct) ←�����
�� ����
(Rn)
88
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOV direct, direct
指令长度(字节): 3
执行周期: 2
二进制编码:
1 0 0 0
0 1 0 1
dir.addr. (src)
操作: MOV
(direct)��
←���������
��������
(direct)
MOV direct, @Ri
指令长度(字节): 2
执行周期: 2
二进制编码:
1 0 0 0
0 1 1 i
direct addr.
.
d
e
t
i
m
操作: MOV
(direct)�������
←������
((Ri))
MOV direct,#data
指令长度(字节): 3
执行周期: 2
二进制编码:
0 1 1 1
操作: MOV
(direct) ← �����
�� �����
#data
MOV @Ri, A
指令长度(字节): 1
执行周期: 1
二进制编码:
U
C
M
0 1 0 1
C
T
S
1 1 1 1
direct address
Li
0 1 1 i
操作: MOV
((Ri)) ←����
�� (A)
���
MOV @Ri, direct
指令长度(字节): 2
执行周期: 2
二进制编码:
1 0 1 0
0 1 1 i
direct addr.
0 1 1 i
immediate data
操作: MOV
((Ri)) ←���������
�� (direct)
��������
MOV @Ri, #data
指令长度(字节): 2
执行周期: 1
二进制编码:
0 1 1 1
操作: MOV
((Ri)) ←�
�� �����
#data
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
89
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOV ,
功能: 传送位变量
说明:
将代表的布尔变量复制到所指定的数据单元中去,两个操作数
必须有一个是进位标志,而另外一个是可直接寻址的位。本指令不影响其他寄存器和
标志位。
举例: 假设进位标志C的初值为1,端口P2中的数据是11000101B,端口1的数据被设置为
35H(00110101B)。则指令序列
MOV
MOV
MOV
P1.3, C
C, P3.3
P1.2, C
执行后,进位标志被清零,端口1的数据变为39H(00111001B)。
MOV C,bit
.
d
e
t
i
m
指令长度(字节): 2
执行周期: 1
二进制编码:
1
0
1
0
0
0
1
操作: MOV
(C) ��
←������
�����
(bit)
指令长度(字节): 2
二进制编码:
C
T
S
1
0
0
1
0
bit address
U
C
M
MOV bit,C
执行周期: 2
1
0
1
0
Li
bit address
操作: MOV
(bit)��
←����
(C)
���
MOV DPTR , #data 16
功能: 将16位的常数存放到数据指针
说明:
该指令将16位常数传递给数据指针DPTR。16位的常数包含在指令的第2字节和
第3字节中。其中DPH中存放的是#data16的高字节,而DPL中存放的是#data16的低字
节。不影响标志位。
该指令是唯一一条能一次性移动���������
16�������
位数据的指令。
举例: 指令:
MOV
DPTR, #1234H
将立即数1234H装入数据指针寄存器中。DPH的值为12H,DPL的值为34H。
指令长度(字节): 3
执行周期: 2
二进制编码: 1 0 0
1
0
0
0
0
immediate data 15-8
操作: MOV
(DPTR) ��
←� �����
#data15-0
DPH DPL ← #data
�� �����15-8 #data7-0
90
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOVC A , @A+
功能: 把程序存储器中的代码字节数据(常数数据)转送至累加器A
说明: MOVC指令将程序存储器中的代码字节或常数字节传送到累加器A。被传送的数据字
节的地址是由累加器中的无符号8位数据和16位基址寄存器(DPTR或PC)的数值相
加产生的。如果以PC为基址寄存器,则在累加器内容加到PC之前,PC需要先增加到
指向紧邻MOVC之后的语句的地址;如果是以DPTR为基址寄存器,则没有此问题。
在执行16位的加法时,低8位产生的进位会传递给高8位。本指令不影响标志位。
举例:
假设累加器A的值处于0~4之间,如下子例程将累加器A中的值转换为用DB伪指
令(定义字节)定义的4个值之一。
REL-PC:
INC
A
MOVC A, @A+PC
RET
DB
66H
DB
77H
DB
88H
DB
99H
U
C
M
.
d
e
t
i
m
Li
如果在调用该子例程之前累加器的值为01H,执行完该子例程后,累加器的值
变为77H。MOVC指令之前的INC A指令是为了在查表时越过RET而设置的。如果
MOVC和表格之间被多个代码字节所隔开,那么为了正确地读取表格,必须将相应
的字节数预先加到累加器A上。
C
T
S
MOVC A,@A+DPTR
指令长度(字节): 1
执行周期: 2
二进制编码:
1 0
0
1
0 0 1 1
操作: MOVC
(A) ��
←�������������
������������
((A)+(DPTR))
MOVC A,@A+PC
指令长度(字节): 1
执行周期: 2
二进制编码:
1 0 0 0
0 0 1 1
操作: MOVC
(PC) ��
← (PC)+1
������
(A) ��
←�����������
����������
((A)+(PC))
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
91
STC90C58AD系列单片机指南
MOVX
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
,
功能: 外部传送
说明:
MOVX指令用于在累加器和外部数据存储器之间传递数据。因此在传送指令
MOV后附加了X。MOVX又分为两种类型,它们之间的区别在于访问外部数据RAM
的间接地址是8位的还是16位的。
对于第1种类型,当前工作寄存器组的R0和R1提供8位地址到复用端口P0。对于
外部I/O扩展译码或者较小的RAM阵列,8位的地址已经够用。若要访问较大的RAM
阵列,可在端口引脚上输出高位的地址信号。此时可在MOVX指令之前添加输出指
令,对这些端口引脚施加控制。
对于第2种类型,通过数据指针DPTR产生16位的地址。当P2端口的输出缓冲器
发送DPH的内容时,P2的特殊功能寄存器保持原来的数据。在访问规模较大的数据
阵列时,这种方式更为有效和快捷,因为不需要额外指令来配置输出端口。
.
d
e
t
i
m
在某些情况下,可以混合使用两种类型的MOVX指令。在访问大容量的RAM
空间时,既可以用数据指针DP在P2端口上输出地址的高位字节,也可以先用某条
指令,把地址的高位字节从P2端口上输出,再使用通过R0或Rl间址寻址的MOVX指
令。
举例:
U
C
M
Li
假设有一个分时复用地址/数据线的外部RAM存储器,容量为256B(如�
:Inte1的
8155 RAM / I/O / TIMER),该存储器被连接到8051的端口P0上,端口P3被用于提供
外部RAM所需的控制信号。端口Pl和P2用作通用输入/输出端口。R0和Rl中的数据分
别为12H和34H,外部RAM的34H单元存储的数据为56H,则下面的指令序列:
C
T
S
MOVX
MOVX
A, @R1
@R0, A
将数据56H复制到累加器A以及外部RAM的12H单元中。
MOVX A,@Ri
指令长度(字节): 1
执行周期: 2
二进制编码:
1 1
1
0
0 0 1 i
操作: MOVX
(A) ��
←�������
������
((Ri))
MOVX A,@DPTR
指令长度(字节): 1
执行周期: 2
二进制编码:
1 1 1 0
0 0 0 0
操作: MOVX
(A) ��
←���������
��������
((DPTR))
92
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
MOVX
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
@Ri, A
指令长度(字节): 1
执行周期: 2
二进制编码:
1 1 1 1
0 0 1 i
操作: MOVX
((Ri))��
←����
(A)
���
MOVX
@DPTR, A
指令长度(字节): 1
执行周期: 2
二进制编码:
1 1 1 1
.
d
e
t
i
m
0 0 0 0
操作: MOVX
(DPTR)����
←���
(A)
U
C
M
MUL AB
功能: 乘法
Li
说明: 该指令可用于实现累加器和寄存器B中的无符号8位整数的乘法。所产生的16位乘积
的低8位存放在累加器中,而高8位存放在寄存器B中。若乘积大于255(0FFH),则置
位溢出标志;否则清零标志位。在执行该指令时,进位标志总是被清零。
C
T
S
举例: 假设累加器A的初始值为80(50H),寄存器B的初始值为160 (0A0H),则指令�
:
MUL AB
求得乘积12 800 (3200H),所以寄存器B的值变成32H (00110010B),累加器被清零,
溢出标志被置位,进位标志被清零。
指令长度(字节): 1
执行周期: 4
二进制编码:
1
0
1
0
0
1
0
0
操作: MUL
(A)7-0 ←��������
(A)×(B)
(B)15-8
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
93
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
NOP
功能: 空操作
说明: 执行本指令后,将继续执行随后的指令。除了PC外,其他寄存器和标志位都不会有
变化。
举例: 假设期望在端口P2的第7号引脚上输出一个长时间的低电平脉冲,该脉冲持续5个机
器周期(精确)。若是仅使用SETB和CLR指令序列,生成的脉冲只能持续1个机器周
期。因而需要设法增加4个额外的机器周期。可以按照如下方式来实现所要求的功能
(假设中断没有被启用):
CLR
NOP
NOP
NOP
NOP
SETB
P2.7
P2.7
指令长度(字节): 1
执行周期: 1
二进制编码:
0
0
0
0
操作: NOP
(PC) ←�������
(PC)+1
C
T
S
ORL ,
0
0
U
C
M
0
0
.
d
e
t
i
m
Li
功能: 两个字节变量的逻辑或运算
说明:
ORL指令将由和所指定的两个字节变量进行逐位逻辑或运
算,结果存放在所代表的数据单元中。该操作不影响标志位。
两个操作数组合起来,支持6种寻址方式。当目的操作数是累加器A时,源操作
数可以采用寄存器寻址、直接寻址、寄存器间接寻址或者立即寻址。当目的操作数
采用直接寻址方式时,源操作数可以是累加器或立即数。
注意:如果该指令被用来修改输出引脚上的状态,那么所代表的数
据是从端口输出数据锁存器中获取的数据,而不是从引脚上读取的数据。
举例:
假设累加器A中数据为0C3H (11000011B),寄存器R0中的数据为55H(01010101) ,
则指令�
:
ORL
A, R0
执行后,累加器的内容变成0D7H(11010111B)。当目的操作数是直接寻址数据字节
时,ORL指令可用来把任何RAM单元或者硬件寄存器中的各个位设置为1。究竟哪
些位会被置1由屏蔽字节决定,屏蔽字节既可以是包含在指令中的常数,也可以是
累加器A在运行过程中实时计算出的数值。执行指令�
:
ORL
P1, #00110010B
之后,把1口的第5、4、1位置1。
94
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ORL A,Rn
指令长度(字节): 1
执行周期: 1
二进制编码:
0
1
0
0
1
r
r
r
1
0
1
操作: ORL
(A) ��
←����
���
(A)∨(Rn)
ORL A,direct
指令长度(字节): 2
执行周期: 1
二进制编码:
0
1
0
0
0
direct address
操作: ORL
(A)��
←����
���
(A)∨(direct)
ORL A,@Ri
指令长度(字节): 1
执行周期: 1
二进制编码:
0
1
0
0
0
U
C
M
1
1
i
1
0
0
操作: ORL
(A)��
←����
���
(A)∨((Ri))
ORL A,#data
指令长度(字节): 2
执行周期: 1
二进制编码:
C
T
S
0
1
0
0
0
.
d
e
t
i
m
Li
immediate data
操作: ORL
(A)��
←����
���
(A)∨ #data
ORL direct, A
指令长度(字节): 2
执行周期: 1
二进制编码:
0
1
0
0
0
0
1
0
direct address
1
direct address
操作: ORL
(direct)��
←���������
��������
(direct)∨(A)
ORL direct, #data
指令长度(字节): 3
执行周期: 2
二进制编码:
0
1
0
0
0
0
1
immediate data
操作: ORL
(direct) ←���������
�� ��������
(direct)∨#data
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
95
STC90C58AD系列单片机指南
ORL
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
C,
功能: 位变量的逻辑或运算
说明: 如果所表示的位变量为1,则置位进位标志;否则,保持进位标志的当前状
态不变。在汇编语言中,位于源操作数之前的“/”表示将源操作数取反后使用,但
源操作数本身不发生变化。在执行本指令时,不影响其他标志位。
举例: 当执行如下指令序列时,当且仅当P1.0=1或ACC.7=1或OV=0时,置位进位标志C:
MOV
ORL
ORL
C, P1.0
C, ACC.7
C, /OV
;LOAD CARRY WITH INPUT PIN P10
;OR CARRY WITH THE ACC.BIT 7
;OR CARRY WITH THE INVERSE OF OV
ORL C, bit
指令长度(字节): 2
执行周期: 2
二进制编码:
0
1
1
1
0
0
1
0
ORL C, /bit
指令长度(字节): 2
执行周期: 2
二进制编码:
1
0
1
0
C
T
S
0
0
操作: ORL
(C) ��
←����
���
(C)∨(bit)
POP direct
U
C
M
0
0
.
d
e
t
i
m
bit address
操作: ORL
(C) ��
←����
���
(C)∨(bit)
Li
bit address
功能: 出栈
说明: 读取栈指针所指定的内部RAM单元的内容,栈指针减1。然后,将读到的内容传送到
由direct所指示的存储单元(直接寻址方式)中去。该操作不影响标志位。
举例:
设栈指针的初值为32H,内部RAM的30H~32H单元的数据分别为20H、23H和
01H。则执行指令�
:
POP DPH
POP DPL
之后,栈指针的值变成30H,数据指针变为0123H。此时指令
POP SP
将把栈指针变为20H 。
注意:在这种特殊情况下,在写入出栈数据(20H)之前,栈指针先减小到
2FH,然后再随着20H的写入,变成20H。
指令长度(字节): 2
执行周期: 2
二进制编码: 1 1 0 1
0
0
0
0
direct address
操作: POP
(diect) ←�������
((SP))
(SP) ��
←������
�����
(SP) ��- �1
96
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
PUSH direct
功能: 压栈
说明: 栈指针首先加1,然后将direct所表示的变量内容复制到由栈指针指定的内部RAM存
储单元中去。该操作不影响标志位。
举例: 设在进入中断服务程序时栈指针的值为09H,数据指针DPTR的值为0123H。则执行如
下指令序列
PUSH
PUSH
DPL
DPH
之后,栈指针变为0BH,并把数据23H和01H分别存入内部RAM的0AH和0BH存储单
元之中。
指令长度(字节): 2
执行周期: 2
二进制编码: 1 1 0 0
0
0
0
操作: PUSH
(SP) ��
←���������
��������
(SP) + 1
((SP)) ��
←���������
��������
(direct)
direct address
U
C
M
C
T
S
RET
0
功能: 从子例程返回
.
d
e
t
i
m
Li
说明: 执行RET指令时,首先将PC值的高位字节和低位字节从栈中弹出,栈指针减2。然
后,程序从形成的PC值所对应的地址处开始执行,一般情况下,该指令和ACALL或
LCALL配合使用。改指令的执行不影响标志位。
举例: 设栈指针的初值为0BH,内部RAM的0AH和0BH存储单元中的数据分别为23H和
01H。则指令:
RET
执行后,栈指针变为09H。程序将从0123H地址处继续执行。
指令长度(字节): 1
执行周期: 2
二进制编码: 0 0 1 0
0
0
1
0
操作: RET
(PC15-8) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
(PC7-0) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
97
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RETI
功能: 中断返回
说明: 执行该指令时,首先从栈中弹出PC值的高位和低位字节,然后恢复中断启用,准备
接受同优先级的其他中断,栈指针减2。其他寄存器不受影响。但程序状态字PSW
不会自动恢复到中断前的状态。程序将继续从新产生的PC值所对应的地址处开始执
行,一般情况下是此次中断入口的下一条指令。在执行RETI指令时,如果有一个优
先级较低的或同优先级的其他中断在等待处理,那么在处理这些等待中的中断之前需
要执行1条指令。
举例: 设栈指针的初值为0BH,结束在地址0123H处的指令执行结束期间产生中断,内部
RAM的0AH和0BH单元的内容分别为23H和01H。则指令�
:
.
d
e
t
i
m
RETI
执行完毕后,栈指针变成09H,中断返回后程序继续从0123H地址开始执行。
指令长度(字节): 1
执行周期: 2
二进制编码: 0 0 1 1
0
0
操作: RETI
(PC15-8) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
(PC7-0) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
RL A
C
T
S
U
C
M
1
0
Li
功能: 将累加器A中的数据位循环左移
说明: 将累加器中的8位数据均左移1位,其中位7移动到位0。该指令的执行不影响标志位。
举例: 设累加器的内容为0C5H(11000101B),则指令
RL
A
执行后,累加器的内容变成8BH(10001011B),且标志位不受影响。
指令长度(字节): 1
执行周期: 1
二进制编码: 0 0 1 0
0
0
1
1
操作: RL
(An+1) ��
←�����������
����������
(An) n ��
= ���
0-6
(A0) ��
←�����
����
(A7)
98
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RLC A
功能: 带进位循环左移
说明: 累加器的8位数据和进位标志一起循环左移1位。其中位7移入进位标志,进位标志的
初始状态值移到位0。该指令不影响其他标志位。
举例: 假设累加器A的值为0C5H(11000101B),则指令
RLC
A
执行后,将把累加器A的数据变为8BH(10001011B),进位标志被置位。
指令长度(字节): 1
执行周期: 1
二进制编码:
0
0
1 1
操作: RLC
(An+1) ��
←���
��
(An)
(A0) ←����
�� (C)
���
(C) ←���
�� (A
��7)
RR A
0
0
1
n = 0-6
U
C
M
C
T
S
.
d
e
t
i
m
1
Li
功能: 将累加器的数据位循环右移
说明: 将累加器的8个数据位均右移1位,位0将被移到位7,即循环右移,该指
令不影响标志位。
举例: 设累加器的内容为0C5H(11000101B),则指令
RR
A
执行后累加器的内容变成0E2H(11100010B),标志位不受影响。
指令长度(字节): 1
执行周期: 1
二进制编码: 0 0 0 0
操作: RR
(An) ←���
�� (A
��n+1)
(A7) ←���
�� (A
��0)
南通国芯微电子有限公司
0
0
1
1
n=0-6
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
99
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RRC A
功能: 带进位循环右移
说明: 累加器的8位数据和进位标志一起循环右移1位。其中位0移入进位标志,进位标志的
初始状态值移到位7。该指令不影响其他标志位。
举例: 假设累加器的值为0C5H(11000101B),进位标志为0,则指令
RRC
A
执行后,将把累加器的数据变为62H(01100010B),进位标志被置位。
指令长度(字节): 1
执行周期: 1
二进制编码:
0
0
0 1
0
操作: RRC
(An+1) ←���
�� ��
(An)
(A7) ��
←����
���
(C)
(C) ��
←���
��
(A0)
SETB
0
1
1
n = 0-6
U
C
M
功能: 置位
.
d
e
t
i
m
Li
说明: SETB指令可将相应的位置1,其操作对象可以是进位标志或其他可直接寻址的位。
该指令不影响其他标志位。
C
T
S
举例: 设进位标志被清零,端口1的输出状态为34H(00110100B),则指令
SETB
C
SETB
P1.0
执行后,进位标志变为1,端口1的输出状态变成35H(00110101B)。
SETB
C
指令长度(字节): 1
执行周期: 1
二进制编码:
1
1
0 1
0
0
1
1
0
0
0
1
0
操作: SETB
(C) ��
←��
�1
SETB
bit
指令长度(字节): 2
执行周期: 1
二进制编码:
1
1
1
bit address
操作: SETB
(bit) ←��
�� 1�
100
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
SJMP rel
功能: 短跳转
说明: 程序无条件跳转到rel所示的地址去执行。目标地址按如下方法计算:首先PC值加2,
然后将指令第2字节(即rel)所表示的有符号偏移量加到PC上,得到的新PC值即短
跳转的目标地址。所以,跳转的范围是当前指令(即SJMP)地址的前128字节和后
127字节。
举例: 设标号RELADR对应的指令地址位于程序存储器的0123H地址,则指令:
SJMP
RELADR
汇编后位于0100H。当执行完该指令后,PC值变成0123H。
注意:在上例中,紧接SJMP的下一条指令的地址是0102H,因此,跳转的偏移
量为0123H-0102H=21H。另外,如果SJMP的偏移量是0FEH,那么构成只有1条指
令的无限循环。
指令长度(字节): 2
执行周期: 2
二进制编码:
1
0
0 0
0
操作: SJMP
(PC) ��
←�������
������
(PC)+2
(PC) ��
←���������
��������
(PC)+rel
SUBB A,
C
T
S
功能: 带借位的减法
说明:
0
0
0
rel. address
U
C
M
.
d
e
t
i
m
Li
SUBB指令从累加器中减去所代表的字节变量的数值及进位标志,减
法运算的结果置于累加器中。如果执行减法时第7位需要借位,SUBB将会置位进位
标志(表示借位);否则,清零进位标志。(如果在执行SUBB指令前,进位标志
C已经被置位,这意味着在前面进行多精度的减法运算时,产生了借位。因而在执
行本条指令时,必须把进位连同源操作数一起从累加器中减去。)如果在进行减法
运算的时候,第3位处向上有借位,那么辅助进位标志AC会被置位;如果第6位有借
位;而第7位没有,或是第7位有借位,而第6位没有, 则溢出标志OV被置位。
当进行有符号整数减法运算时,若OV置位,则表示在正数减负数的过程中产生
了负数;或者,在负数减正数的过程中产生了正数。
源操作数支持的寻址方式:寄存器寻址、直接寻址、寄存器间接寻址和立即数
寻址。
举例:
设累加器中的数据为0C9H(11001001B)。寄存器R2的值为54H(01010100B),进
位标志C被置位。则如下指令:
SUBB
A, R2
执行后,累加器的数据变为74H(01110100B),进位标志C和辅助进位标志AC被清
零,溢出标志C被置位。
注意:0C9H减去54H应该是75H,但在上面的计算中,由于在SUBB指令执行
前,进位标志C已经被置位,因而最终结果还需要减去进位标志,得到74H。因此,
如果在进行单精度或者多精度减法运算前,进位标志C的状态未知,那么应改采用
CLR C 指令把进位标志C清零。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
101
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
SUBB A, Rn
指令长度(字节): 1
执行周期: 1
二进制编码: 1 0 0 1
1 r r r
操作: SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- ����
(Rn)
SUBB A, direct
指令长度(字节): 2
执行周期: 1
二进制编码: 1 0 0
1
0
1
0
1
direct address
操作: SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- ��������
(direct)
.
d
e
t
i
m
SUBB A, @Ri
指令长度(字节): 1
执行周期: 1
二进制编码: 1 0 0
1
0
1
1
i
U
C
M
操作: SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- ������
((Ri))
SUBB A, #data
C
T
S
指令长度(字节): 2
执行周期: 1
二进制编码: 1 0 0
1
0
1
0
0
Li
immediate data
操作: SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- �����
#data
SWAP A
功能: 交换累加器的高低半字节
说明: SWAP指令把累加器的低4位(位3~位0)和高4位(位7~位4)数据进行交换。实际上
SWAP指令也可视为4位的循环指令。该指令不影响标志位。
举例: 设累加器的内容为0C5H(11000101B),则指令
SWAP
A
执行后,累加器的内容变成5CH(01011100B)。
指令长度(字节): 1
执行周期: 1
二进制编码:
1
1
0 0
操作: SWAP
(A3-0)
102
南通国芯微电子有限公司
0
1
0
0
(A7-4)
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
XCH A,
功能: 交换累加器和字节变量的内容
说明: XCH指令将所指定的字节变量的内容装载到累加器,同时将累加器的旧内容
写入所指定的字节变量。指令中的源操作数和目的操作数允许的寻址方式:寄
存器寻址、直接寻址和寄存器间接寻址。
举例: 设R0的内容为地址20H,累加器的值为3FH (00111111B)。内部RAM的20H单元的内
容为75H (01110101B)。则指令
XCH
A, @R0
执行后,内部RAM的20H单元的数据变为3FH (00111111B),累加器的内容变为
75H(01110101B)。
.
d
e
t
i
m
XCH A, Rn
指令长度(字节): 1
执行周期: 1
二进制编码: 1 1 0 0
操作: XCH
(A)
1 r r r
(Rn)
XCH A, direct
指令长度(字节): 2
执行周期: 1
二进制编码: 1 1 0 0
C
T
S
操作: XCH
(A)
U
C
M
0 1 0 1
Li
direct address
(direct)
XCH A, @Ri
指令长度(字节): 1
执行周期: 1
二进制编码: 1 1 0 0
操作: XCH
(A)
南通国芯微电子有限公司
0 1 1
i
((Ri))
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
103
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
XCHD A, @Ri
功能: 交换累加器和@Ri对应单元中的数据的低4位
说明: XCHD指令将累加器内容的低半字节(位0~3,一般是十六进制数或BCD码)和间接
寻址的内部RAM单元的数据进行交换,各自的高半字(位7~4)节不受影响。另外,
该指令不影响标志位。
举例: 设R0保存了地址20H,累加器的内容为36H (00110110B)。内部RAM的20H单元存储
的数据为75H (011110101B)。则指令:
XCHD
A, @R0
执行后,内部RAM 20H单元的内容变成76H (01110110B),累加器的内容变为
35H(00110101B)。
指令长度(字节): 1
执行周期: 1
二进制编码: 1 1 0 1
操作: XCHD
(A3-0)
0 1 1 i
(Ri3-0)
XRL ,
C
T
S
功能: 字节变量的逻辑异或
说明:
U
C
M
.
d
e
t
i
m
Li
XRL指令将和所代表的字节变量逐位进行逻辑异或运算,
结果保存在所代表的字节变量里。该指令不影响标志位。
两个操作数组合起来共支持6种寻址方式:当目的操作数为累加器时,源操作数
可以采用寄存器寻址、直接寻址、寄存器间接寻址和立即数寻址;当目的操作数是
可直接寻址的数据时,源操作数可以是累加器或者立即数。
注意:如果该指令被用来修改输出引脚上的状态,那么dest-byte所代表的数据就
是从端口输出数据锁存器中获取的数据,而不是从引脚上读取的数据。
举例:
如果累加器和寄存器0的内容分别为0C3H (11000011B)和0AAH(10101010B),则
指令�
:
XRL
A, R0
执行后,累加器的内容变成69H (01101001B)。
当目的操作数是可直接寻址字节数据时,该指令可把任何RAM单元或者寄存器
中的各个位取反。具体哪些位会被取反,在运行过程当中确定。指令�
:
XRL
P1, #00110001B
执行后,P1口的位5、4、0被取反。
104
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
XRL A, Rn
操作: XRL
(A) ��
← (A)�
����
≮
指令长度(字节): 1
执行周期: 1
二进制编码: 0 1 1 0
1 r r r
(Rn)
XRL A, direct
指令长度(字节): 2
执行周期: 1
0 1 1 0
操作: XRL
(A) ��
← (A)�
����
0 1 0 1
≮
二进制编码:
direct address
XRL A, @Ri
指令长度(字节): 1
执行周期: 1
1
操作: XRL
(A) ��
← (A)�
����
XRL A, #data
指令长度(字节): 2
执行周期: 1
二进制编码:
0
≮
0 1
0 1
1
操作: XRL
(A) ��
← (A)�
����
0
U
C
M
0 1 1 i
((Ri))
C
T
S
≮
二进制编码:
.
d
e
t
i
m
(direct)
0 1 0 0
Li
immediate data
#data
XRL direct, A
指令长度(字节): 2
执行周期: 1
0 1
1
0
0 0 1 0
操作: XRL
(direct) ← (direct)�
�� ���������
≮
二进制编码:
direct address
(A)
XRL direct, #dataw
指令长度(字节): 3
执行周期: 2
0 1
1
0
0 0 1 1
操作: XRL
(direct) ← (direct)�
�� ���������
南通国芯微电子有限公司
≮
二进制编码:
direct address
immediate data
# data
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
105
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
5.3.2 Instruction Definitions of Traditional 8051 MCU
ACALL addr 11
Function:
Description:
Absolute Call
ACALL unconditionally calls a subroutine located at the indicated address.The instruction
increments the PC twice to obtain the address of the following instruction, then pushes the
16-bit result onto the stack (low-order byte first) and increments the Stack Pointer twice.
The destination address is obtained by suceesively concatenating the five high-order bits of
the incremented PC opcode bits 7-5,and the second byte of the instruction. The subroutine
called must therefore start within the same 2K block of the program memory as the first
byte of the instruction following ACALL. No flags are affected.
Example:
Initially SP equals 07H. The label “SUBRTN” is at program memory location 0345H. After
executingthe instruction,
.
d
e
t
i
m
ACALL SUBRTN
at location 0123H, SP will contain 09H, internal RAM locations 08H and 09H will contain
25H and 01H, respectively, and the PC will contain 0345H.
Bytes:
2
Cycles:
2
Encoding:
Operation:
a10 a9 a8 1
U
C
M
0 0 1 0
a7 a6 a5 a4
Li
a3 a2 a1 a0
ACALL
(PC)��
←�������
������
(PC)+ �2
(SP)���������
←��������
(SP) + 1
((SP)) ��
←����
���
(PC7-0)
(SP)���������
←��������
(SP) + 1
((SP))����
←���
(PC15-8)
(PC10-0)��
←� page
����� �������
address
C
T
S
ADD A,
Function:
Description:
Add
ADD adds the byte variable indicated to the Accumulator, leaving the result in the
Accumulator. The carry and auxiliary-carry flags are set, respectively, if there is a carryout from bit 7 or bit 3, and cleared otherwise. When adding unsigned integers, the carry flag
indicates an overflow occured.
OV is set if there is a carry-out of bit 6 but not out of bit 7, or a carry-out of bit 7 but not bit
6; otherwise OV is cleared. When adding signed integers, OV indicates a negative number
produced as the sum of two positive operands, or a positive sum from two negative operands.
Example:
Four source operand addressing modes are allowed: register,direct register-indirect, or
immediate.
The Accumulator holds 0C3H(11000011B) and register 0 holds 0AAH (10101010B). The
instruction,
ADD A,R0
will leave 6DH (01101101B) in the Accumulator with the AC flag cleared and both the carry
flag and OV set to 1.
106
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ADD A,Rn
Bytes:
1
Cycles:
1
Encoding:
Operation:
0 0
1
0
1 r r r
ADD
(A)�����������
←����������
(A) + (Rn)
ADD A,direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 0 1 0
0 1 0 1
direct address
ADD
(A)���������������
←��������������
(A) + (direct)
.
d
e
t
i
m
ADD A,@Ri
Bytes:
1
Cycles:
1
Encoding:
Operation:
0 0
Operation:
0
2
1
C
T
S
0 0 1 0
U
C
M
0 1 1 i
ADD
(A)�������������
←������������
(A) + ((Ri))
ADD A,#data
Bytes:
Cycles:
Encoding:
1
0 1 0 0
Li
immediate data
ADD
(A)�������
←������
(A) + �����
#data
ADDC A,
Function:
Description:
Example:
Add with Carry
ADDC simultaneously adds the byte variable indicated, the Carry flag and the Accumulator,
leaving the result in the Accumulator. The carry and auxiliary-carry flags are set, respectively,
if there is a carry-out from bit 7 or bit 3, and cleared otherwise. When adding unsigned
integers, the carry flag indicates an overflow occured.
OV is set if there is a carry-out of bit 6 but not out of bit 7, or a carry-out of bit 7 but not
out of bit 6; otherwise OV is cleared. When adding signed integers, OV indicates a negative
number produced as the sum of two positive operands or a positive sum from two negative
operands.
Four source operand addressing modes are allowed: register, direct, register-indirect, or
immediate.
The Accumulator holds 0C3H(11000011B) and register 0 holds 0AAH (10101010B) with the
Carry. The instruction,
ADDC A,R0
will leave 6EH (01101101B) in the Accumulator with the AC flag cleared and both the carry
flag and OV set to 1.
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
107
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ADDC A,Rn
Bytes:
1
Cycles:
1
Encoding:
Operation:
0 0
1
1
1 r r r
ADDC
(A)�����������������
←����������������
(A) + (C) + (Rn)
ADDC A,direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 0 1 1
0 1 0 1
direct address
ADDC
(A)���������������������
←��������������������
(A) + (C) + (direct)
ADDC A,@Ri
Bytes:
1
Cycles:
1
Encoding:
Operation:
0 0
1
U
C
M
0 1 1 i
ADDC
(A)�������������������
←������������������
(A) + (C) + ((Ri))
ADDC A,#data
Bytes:
2
Cycles:
1
Encoding:
Operation:
1
C
T
S
0 0 1 1
0 1 0 0
.
d
e
t
i
m
Li
immediate data
ADDC
(A)�������������
←������������
(A) + (C) + �����
#data
AJMP addr 11
Function:
Description:
Example:
Bytes:
Cycles:
Encoding:
Operation:
108
Absolute Jump
AJMP transfers program execution to the indicated address, which is formed at run-time by
concatenating the high-order five bits of the PC (after incrementing the PC twice), opcode
bits 7-5, and the second byte of the instruction. The destination must therefore be within the
same 2K block of program memory as the first byte of the instruction following AJMP.
The label “JMPADR” is at program memory location 0123H. The instruction,
AJMP JMPADR
is at location 0345H and will load the PC with 0123H.
2
2
a10 a9 a8 0
0 0 0 1
a7 a6 a5 a4
a3 a2 a1 a0
AJMP
(PC)��
←�������
������
(PC)+ �2
(PC10-0)��
←� �����
page �������
address
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ANL ,
Function:
Description:
Logical-AND for byte variables
ANL performs the bitwise logical-AND operation between the variables indicated and stores
the results in the destination variable. No flags are affected.
The two operands allow six addressing mode combinations. When the destination is the
Accumulator, the source can use register, direct, register-indirect, or immediate addressing;
when the destination is a direct address, the source can be the Accumulator or immediate
data.
Note: When this instruction is used to modify an output port, the value used as the original
port data will be read from the output data latch not the input pins.
Example:
If the Accumulator holds 0C3H(11000011B) and register 0 holds 55H (01010101B) then the
instruction,
.
d
e
t
i
m
ANL A,R0
will leave 41H (01000001B) in the Accumulator.
Li
When the destination is a directly addressed byte, this instruction will clear combinations of
bits in any RAM location or hardware register. The mask byte determining the pattern of bits
to be cleared would either be a constant contained in the instruction or a value computed in
the Accumulator at run-time. The instruction,
ANL Pl, #01110011B
U
C
M
will clear bits 7, 3, and 2 of output port 1.
ANL A,Rn
Bytes:
1
Cycles:
1
Encoding:
Operation:
C
T
S
0 1
0
1
1 r r r
ANL
(A)�����
←����
(A) ∧ (Rn)
ANL A,direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 1 0 1
0 1 0 1
direct address
ANL
(A)�����
←����
(A) ∧ (direct)
ANL A,@Ri
Bytes:
1
Cycles:
1
Encoding:
Operation:
0 1
0
1
0 1 1 i
ANL
(A)�����
←����
(A) ∧ ((Ri))
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
109
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ANL A,#data
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 1 0 1
0 1 0 0
immediate data
ANL
(A)�����
←����
(A) ∧ #data
ANL direct,A
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 1 0 1
0 0 1 0
direct address
ANL direct,#data
Bytes:
3
Cycles:
2
Encoding:
Operation:
0 1 0 1
U
C
M
0 0 1 1
Li
direct address
immediate data
ANL
(direct)����������
←���������
(direct) ∧ #data
C
T
S
ANL C ,
Function:
Description:
.
d
e
t
i
m
ANL
(direct)����������
←���������
(direct) ∧ (A)
Logical-AND for bit variables
If the Boolean value of the source bit is a logical 0 then clear the carry flag; otherwise
leave the carry flag in its current state. A slash (“ / ”) preceding the operand in the assembly
language indicates that the logical complement of the addressed bit is used as the source
value, but the source bit itself is not affceted. No other flsgs are affected.
Only direct addressing is allowed for the source operand.
Example:
Set the carry flag if, and only if, P1.0 = 1, ACC. 7 = 1, and OV = 0:
MOV C, P1.0
;LOAD CARRY WITH INPUT PIN STATE
ANL C, ACC.7
;AND CARRY WITH ACCUM. BIT.7
ANL C, /OV
;AND WITH INVERSE OF OVERFLOW FLAG
ANL C,bit
Bytes:
2
Cycles:
2
Encoding:
Operation:
110
1 0 0 0
0 0 1 0
bit address
ANL
(C) ��
← ����
����
(C) ∧ (bit)
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ANL C, /bit
Bytes:
2
Cycles:
2
Encoding:
1 0 1 1
Operation:
ANL
(C)�����
←����
(C) ∧ (bit)
0 0 0 0
bit address
CJNE , , rel
Function:
Description:
Compare and Jump if Not Equal
CJNE compares the magnitudes of the first two operands, and branches if their values are not
equal. The branch destination is computed by adding the signed relative-displacement in the
last instruction byte to the PC, after incrementing the PC to the start of the next instruction.
The carry flag is set if the unsigned integer value of is less than the unsigned
integer value of ; otherwise, the carry is cleared. Neither operand is affected.
.
d
e
t
i
m
The first two operands allow four addressing mode combinations: the Accumulator may
be compared with any directly addressed byte or immediate data, and any indirect RAM
location or working register can be compared with an immediate constant.
Example:
U
C
M
Li
The Accumulator contains 34H. Register 7 contains 56H. The first instruction in the sequence
CJNE
...
JC
...
;
NOT_EQ:
;
C
T
S
R7,#60H, NOT-EQ
......
REQ_LOW
.....
; R7 = 60H.
; IF R7 < 60H.
; R7 > 60H.
sets the carry flag and branches to the instruction at label NOT-EQ. By testing the carry flag,
this instruction determines whether R7 is greater or less than 60H.
If the data being presented to Port 1 is also 34H, then the instruction,
WAIT: CJNE A,P1,WAIT
clears the carry flag and continues with the next instruction in sequence, since the
Accumulator does equal the data read from P1. (If some other value was being input on Pl,
the program will loop at this point until the P1 data changes to 34H.)
CJNE A,direct,rel
Bytes:
3
Cycles:
2
Encoding:
Operation:
1 0 1 1
0 1 0 1
direct address
rel. address
(PC) ��
←���������
��������
(PC) + 3
IF (A) < > (direct)
THEN
(PC) ��
←��������
�������
(PC) + relative offset
IF (A) < (direct)
THEN
(C) ��
←��
�1
ELSE
(C) ��
←��
�0
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
111
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
CJNE A,#data,rel
Bytes:
3
Cycles:
2
Encoding:
Operation:
1 0 1 1
0 1 0 1
immediata data
(PC) ��
←���������
��������
(PC) + 3
IF (A) < > (data)
THEN
(PC) ��
←��������
�������
(PC) + relative offset
IF (A) < (data)
THEN
(C) ��
←��
�1
ELSE
(C) ��
←��
�0
rel. address
.
d
e
t
i
m
CJNE Rn,#data,rel
Bytes:
3
Cycles:
2
Encoding:
Operation:
1 0 1 1
U
C
M
1 r r r
(PC) ��
←���������
��������
(PC) + 3
IF (Rn) < > (data)
THEN
(PC) ��
←��������
�������
(PC) + relative offset
IF (Rn) < (data)
THEN
(C) ��
←��
�1
ELSE
(C) ��
←��
�0
C
T
S
Li
immediata data
rel. address
CJNE @Ri,#data,rel
Bytes:
3
Cycles:
2
Encoding:
Operation:
112
1 0 1 1
0 1 1 i
immediate data
rel. address
(PC) ��
←���������
��������
(PC) + 3
IF ((Ri)) < > (data)
THEN
(PC) ��
←��������
�������
(PC) + relative offset
IF ((Ri)) < (data)
THEN
(C) ��
←��
�1
ELSE
(C) ��
←��
�0
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
CLR A
Function:
Description:
Example:
Clear Accumulator
The Aecunmlator is cleared (all bits set on zero). No flags are affected.
The Accumulator contains 5CH (01011100B). The instruction,
CLR A
will leave the Accumulator set to 00H (00000000B).
Bytes:
1
Cycles:
1
Encoding:
Operation:
1 1 1 0
0 1 0 0
CLR
(A)��
←��
�0
.
d
e
t
i
m
CLR bit
Function:
Description:
Example:
Clear bit
The indicated bit is cleared (reset to zero). No other flags are affected. CLR can operate on
the carry flag or any directly addressable bit.
Li
Port 1 has previously been written with 5DH (01011101B). The instruction,
CLR
P1.2
U
C
M
will leave the port set to 59H (01011001B).
CLR C
Bytes:
1
Cycles:
1
C
T
S
Encoding:
1 1
Operation:
CLR
(C) ��
←��
�0
0
0
0 0 1 1
CLR bit
Bytes:
2
Cycles:
1
Encoding:
Operation:
1 1 0 0
0 0 1 0
bit address
CLR
(bit) ← �
�� 0�
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
113
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
CPL A
Function:
Description:
Example:
Complement Accumulator
Each bit of the Accumulator is logically complemented (one’s complement). Bits which
previously contained a one are changed to a zero and vice-versa. No flags are affected.
The Accumulator contains 5CH(01011100B). The instruction,
CPL
A
will leave the Accumulator set to 0A3H (101000011B).
Bytes:
1
Cycles:
1
Encoding:
Operation:
1 1 1 1
0 1 0 0
CPL bit
Function:
Description:
Example:
.
d
e
t
i
m
CPL
(A)��
←� (A)
Li
Complement bit
The bit variable specified is complemented. A bit which had been a one is changed to zero
and vice-versa. No other flags are affected. CLR can operate on the carry or any directly
addressable bit.
U
C
M
Note:When this instruction is used to modify an output pin, the value used as the original
data will be read from the output data latch, not the input pin.
Port 1 has previously been written with 5DH (01011101B). The instruction,
C
T
S
CLR
P1.1
CLR
P1.2
will leave the port set to 59H (01011001B).
CPL C
Bytes:
1
Cycles:
1
Encoding:
Operation:
CPL bit
1 0
Bytes:
2
1
Operation:
1
0 0 1 1
CPL
(C) ��
←� (C)
Cycles:
Encoding:
1
1 0 1 1
0 0 1 0
bit address
CPL
(bit) ←
�� (bit)
114
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
DA
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
A
Function:
Description:
Decimal-adjust Accumulator for Addition
DA A adjusts the eight-bit value in the Accumulator resulting from the earlier addition of
two variables (each in packed-BCD format), producing two four-bit digits.Any ADD or
ADDC instruction may have been used to perform the addition.
If Accumulator bits 3-0 are greater than nine (xxxx1010-xxxx1111), or if the AC flag is one,
six is added to the Accumulator producing the proper BCD digit in the low-order nibble.
This internal addition would set the carry flag if a carry-out of the low-order four-bit field
propagated through all high-order bits, but it would not clear the carry flag otherwise.
If the carry flag is now set or if the four high-order bits now exceed nine(1010xxxx111xxxx), these high-order bits are incremented by six, producing the proper BCD digit
in the high-order nibble. Again, this would set the carry flag if there was a carry-out of the
high-order bits, but wouldn’t clear the carry. The carry flag thus indicates if the sum of
the original two BCD variables is greater than 100, allowing multiple precision decimal
addition. OV is not affected.
.
d
e
t
i
m
Li
All of this occurs during the one instruction cycle. Essentially, this instruction performs the
decimal conversion by adding 00H, 06H, 60H, or 66H to the Accumulator, depending on
initial Accumulator and PSW conditions.
U
C
M
Note: DA A cannot simply convert a hexadecimal number in the Accumulator to BCD
notation, nor does DA A apply to decimal subtraction.
Example:
C
T
S
The Accumulator holds the value 56H(01010110B) representing the packed BCD digits of
the decimal number 56. Register 3 contains the value 67H (01100111B) representing the
packed BCD digits of the decimal number 67.The carry flag is set. The instruction sequence.
ADDC A,R3
DA
A
will first perform a standard twos-complement binary addition, resulting in the value 0BEH
(10111110) in the Accumulator. The carry and auxiliary carry flags will be cleared.
The Decimal Adjust instruction will then alter the Accumulator to the value 24H
(00100100B), indicating the packed BCD digits of the decimal number 24, the low-order
two digits of the decimal sum of 56,67, and the carry-in. The carry flag will be set by the
Decimal Adjust instruction, indicating that a decimal overflow occurred. The true sum 56,
67, and 1 is 124.
BCD variables can be incremented or decremented by adding 01H or 99H. If the Accumulator initially holds 30H (representing the digits of 30 decimal), then the instruction sequence,
ADD
DA
A,#99H
A
will leave the carry set and 29H in the Accumulator, since 30+99=129. The low-order byte
of the sum can be interpreted to mean 30 – 1 = 29.
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
115
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
Bytes: 1
Cycles: 1
Encoding:
1 1
0 1
0 1 0
0
Operation: DA
-contents of Accumulator are BCD
IF [[(A3-0) > 9] V [(AC) = 1]]
THEN(A3-0) ��
←���
��
(A3-0) + 6
AND
IF [[(A7-4) > 9] V [(C) = 1]]
THEN (A7-4) ��
←���
��
(A7-4) + 6
DEC byte
Function:
Description:
Example:
Decrement
The variable indicated is decremented by 1. An original value of 00H will underflow to
0FFH.
No flags are affected. Four operand addressing modes are allowed: accumulator, register,
direct, or register-indirect.
Note: When this instruction is used to modify an output port, the value used as the original
port data will be read from the output data latch, not the input pins.
U
C
M
.
d
e
t
i
m
Li
Register 0 contains 7FH (01111111B). Internal RAM locations 7EH and 7FH contain 00H
and 40H, respectively. The instruction sequence,
C
T
S
DEC
@R0
DEC
R0
DEC
@R0
will leave register 0 set to 7EH and internal RAM locations 7EH and 7FH set to 0FFH and
3FH.
DEC A
Bytes:
1
Cycles:
1
Encoding:
Operation:
DEC
116
0 0
0
1
0 1 0 0
DEC
(A)�����
←����
(A) -1
Rn
Bytes:
1
Cycles:
1
Encoding:
0 0 0 1
Operation:
DEC
(Rn)������
←�����
(Rn) ��- �1
南通国芯微电子有限公司
1 r r r
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
DEC
临时技术支持:13922829991
研发顾问:13922809991
direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
DEC
技术支持网站:www.STCMCU.com
0 0 0 1
0 1 0 1
direct address
DEC
(direct)����������
←���������
(direct) -1
@Ri
Bytes:
1
Cycles:
1
Encoding:
0 0 0 1
Operation:
DEC
((Ri))��������
←�������
((Ri)) ��- �1
0 1 1 i
DIV AB
Function:
Description:
.
d
e
t
i
m
Li
Divide
DIV AB divides the unsigned eight-bit integer in the Accumulator by the unsigned eight-bit
integer in register B. The Accumulator receives the integer part of the quotient; register B
receives the integer remainder. The carry and OV flags will be cleared.
U
C
M
Exception: if B had originally contained 00H, the values returned in the Accumulator and
B-register will be undefined and the overflow flag will be set. The carry flag is cleared in any
case.
Example:
DIV
Bytes:
Cycles:
Encoding:
Operation:
C
T
S
The Accumulator contains 251(OFBH or 11111011B) and B contains 18(12H or 00010010B).
The instruction,
AB
will leave 13 in the Accumulator (0DH or 00001101B) and the value 17 (11H or 00010010B)
in B, since 251 = (13×18) + 17. Carry and OV will both be cleared.
1
4
1 0
0
0
0 1 0 0
DIV
(A)15-8
(A)/(B)
(B)7-0 ←��������
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
117
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
DJNZ ,
Function:
Description:
Decrement and Jump if Not Zero
DJNZ decrements the location indicated by 1, and branches to the address indicated by the
second operand if the resulting value is not zero. An original value of 00H will underflow to
0FFH. No flags are afected. The branch destination would be computed by adding the signed
relative-displacement value in the last instruction byte to the PC, after incrementing the PC
to the first byte of the following instruction.
The location decremented may be a register or directly addressed byte.
Note: When this instruction is used to modify an output port, the value used as the original
port data will be read from the output data latch, not the input pins.
Example:
Internal RAM locations 40H, 50H, and 60H contain the values 01H, 70H, and 15H,
respectively. The instruction sequence,
DJNZ 40H, LABEL_1
DJNZ 50H, LABEL_2
DJNZ 60H, LABEL_3
.
d
e
t
i
m
Li
will cause a jump to the instruction at label LABEL_2 with the values 00H, 6FH, and 15H in
the three RAM locations. The first jump was not taken because the result was zero.
This instruction provides a simple way of executing a program loop a given number of times,
or for adding a moderate time delay (from 2 to 512 machine cycles) with a single instruction
The instruction sequence,
MOV
CPL
DJNZ
C
T
S
TOOOLE:
U
C
M
R2,#8
P1.7
R2, TOOGLE
will toggle P1.7 eight times, causing four output pulses to appear at bit 7 of output Port 1.
Each pulse will last three machine cycles; two for DJNZ and one to alter the pin.
DJNZ
Rn,rel
Bytes:
2
Cycles:
2
Encoding:
Operation:
DJNZ
1 r r r
rel. address
DJNZ
(PC) ��
← �������
�������
(PC) + �2
(Rn) ��
← �����
�����
(Rn) ��– �1
IF (Rn) > 0 or (Rn) < 0
THEN
(PC) ��
←�������
������
(PC)+ ���
rel
direct, rel
Bytes:
3
Cycles:
2
Encoding:
118
1 1 0 1
1 1 0 1
南通国芯微电子有限公司
0 1 0 1
direct address
总机:0513-5501 2928 / 2929 / 2966
rel. address
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
Operation:
INC
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
DJNZ
(PC) ��
←��������
�������
(PC) + �2
(direct) ←����������
�� ���������
(direct) ��– �1
IF (direct) > 0 or (direct) < 0
THEN
(PC) ��
← �������
�������
(PC) + ���
rel
Function:
Description:
Increment
INC increments the indicated variable by 1. An original value of 0FFH will overflow to
00H.No flags are affected. Three addressing modes are allowed: register, direct, or registerindirect.
Note: When this instruction is used to modify an output port, the value used as the original
port data will be read from the output data latch, not the input pins.
Example:
INC
INC
INC
INC
A
Bytes:
1
Cycles:
1
Operation:
C
T
S
0 0
U
C
M
Li
0
0
0 1 0 0
INC
(A) ��
← (A)+1
�����
Rn
Bytes:
1
Cycles:
1
Encoding:
Operation:
INC
@R0
R0
@R0
will leave register 0 set to 7FH and internal RAM locations 7EH and 7FH holding
(respectively) 00H and 41H.
Encoding:
INC
.
d
e
t
i
m
Register 0 contains 7EH (011111110B). Internal RAM locations 7EH and 7FH contain 0FFH
and 40H, respectively. The instruction sequence,
0 0
0
0
1 r r r
INC
(Rn) ��
← (Rn)+1
������
direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 0 0 0
0 1 0 1
direct address
INC
(direct)����������
←���������
(direct) + 1
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
119
STC90C58AD系列单片机指南
INC
Bytes:
1
Cycles:
1
Operation:
Example:
0 0 0 0
0 1 1 i
INC
((Ri))�����������
←����������
((Ri)) + 1
Increment Data Pointer
Increment the 16-bit data pointer by 1. A 16-bit increment (modulo 216) is performed; an
overflow of the low-order byte of the data pointer (DPL) from 0FFH to 00H will increment
the high-order-byte (DPH). No flags are affected.
This is the only 16-bit register which can be incremented.
Bytes:
1
Cycles:
2
Operation:
C
T
S
1 0
Example:
U
C
M
0 0 1 1
The data present at input port 1 is 11001010B. The Accumulator holds 56 (01010110B). The
instruction sequence,
JB
P1.2, LABEL1
JB ACC.2, LABEL2
will cause program execution to branch to the instruction at label LABEL2.
Bytes:
3
2
Operation:
0
Li
Jump if Bit set
If the indicated bit is a one, jump to the address indicated; otherwise proceed with the next
instruction. The branch destination is computed by adding the signed relative-displacement
in the third instruction byte to the PC, after incrementing the PC to the first byte of the next
instruction. The bit tested is not modified. No flags are affected.
Cycles:
Encoding:
1
INC
(DPTR) ��
← (DPTR)+1
��������
bit, rel
Function:
Description:
.
d
e
t
i
m
Register DPH and DPL contains 12H and 0FEH,respectively. The instruction sequence,
INC DPTR
INC DPTR
INC DPTR
will change DPH and DPL to 13H and 01H.
Encoding:
120
研发顾问:13922809991
DPTR
Function:
Description:
JB
临时技术支持:13922829991
@Ri
Encoding:
INC
技术支持网站:www.STCMCU.com
0 0 1 0
0 0 0 0
bit address
rel. address
JB
(PC) ��
← �������
�������
(PC)+ 3
IF (bit) = 1
THEN
(PC) ��
←��������
�������
(PC) + ���
rel
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
JBC
临时技术支持:13922829991
研发顾问:13922809991
bit, rel
Function:
Description:
Example:
Jump if Bit is set and Clear bit
If the indicated bit is one,branch to the address indicated;otherwise proceed with the next
instruction.The bit wili not be cleared if it is already a zero. The branch destination is
computed by adding the signed relative-displacement in the third instruction byte to the PC,
after incrementing the PC to the first byte of the next instruction. No flags are affected.
Note: When this instruction is used to test an output pin, the value used as the original data
will be read from the output data latch, not the input pin.
The Accumulator holds 56H (01010110B). The instruction sequence,
JBC
JBC
Bytes:
Cycles:
Operation:
2
0 0 0 1
Example:
Bytes:
C
T
S
U
C
M
.
d
e
t
i
m
Li
rel. address
The carry flag is cleared. The instruction sequence,
LABEL1
C
LABEL2s
will set the carry and cause program execution to continue at the instruction identified by the
label LABEL2.
2
2
Encoding:
Operation:
bit address
Jump if Carry is set
If the carry flag is set, branch to the address indicated; otherwise proceed with the next
instruction. The branch destination is computed by adding the signed relative-displacement in
the second instruction byte to the PC, after incrementing the PC twice.No flags are affected.
JC
CPL
JC
Cycles:
0 0 0 0
JBC
(PC) ��
← �������
�������
(PC)+ 3
IF (bit) = 1
THEN
(bit) ← 0
�� �
(PC) ��
←��������
�������
(PC) + ���
rel
rel
Function:
Description:
ACC.3, LABEL1
ACC.2, LABEL2
will cause program execution to continue at the instruction identified by the label LABEL2,
with the Accumulator modified to 52H (01010010B).
3
Encoding:
JC
技术支持网站:www.STCMCU.com
0 1 0 0
0 0 0 0
rel. address
JC
(PC) ��
← ������
������
(PC)+ �2
IF (C) = 1
THEN
(PC) ��
←��������
�������
(PC) + ���
rel
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
121
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
JMP @A+DPTR
Function:
Description:
Example:
Jump indirect
Add the eight-bit unsigned contents of the Accumulator with the sixteen-bit data pointer,
and load the resulting sum to the program counter. This will be the address for subsequent
instruction fetches. Sixteen-bit addition is performed (modulo 216): a carry-out from the loworder eight bits propagates through the higher-order bits. Neither the Accumulator nor the
Data Pointer is altered. No flags are affected.
An even number from 0 to 6 is in the Accumulator. The following sequence of instructions
will branch to one of four AJMP instructions in a jump table starting at JMP_TBL:
JMP-TBL:
MOV
JMP
AJMP
AJMP
AJMP
AJMP
DPTR, #JMP_TBL
@A+DPTR
LABEL0
LABEL1
LABEL2
LABEL3
.
d
e
t
i
m
If the Accumulator equals 04H when starting this sequence, execution will jump to label
LABEL2. Remember that AJMP is a two-byte instruction, so the jump instructions start at
every other address.
Bytes:
1
Cycles:
2
Encoding:
Operation:
0 1 1 1
JMP
(PC) ��
← ������������
������������
(A) + (DPTR)
C
T
S
JNB bit, rel
Function:
Description:
Example:
U
C
M
0 0 1 1
Li
Jump if Bit is not set
If the indicated bit is a zero, branch to the indicated address; otherwise proceed with the next
instruction. The branch destination is computed by adding the signed relative-displacement
in the third instruction byte to the PC, after incrementing the PC to the first byte of the next
instruction. The bit tested is not modified. No flags are affected.
The data present at input port 1 is 11001010B. The Accumulator holds 56H (01010110B).
The instruction sequence,
JNB
JNB
P1.3, LABEL1
ACC.3, LABEL2
will cause program execution to continue at the instruction at label LABEL2
Bytes:
3
Cycles:
2
Encoding:
Operation:
122
0 0 1 1
0 0 0 0
bit address
rel. address
JNB
(PC) ��
← �������
�������
(PC)+ 3
IF (bit) = 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
JNC
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
rel
Function:
Description:
Example:
Jump if Carry not set
If the carry flag is a zero, branch to the address indicated; otherwise proceed with the next
instruction. The branch destination is computed by adding the signed relative-displacement
in the second instruction byte to the PC, after incrementing the PC twice to point to the next
instruction. The carry flag is not modified
The carry flag is set. The instruction sequence,
JNC LABEL1
CPL C
JNC LABEL2
will clear the carry and cause program execution to continue at the instruction identified by
the label LABEL2.
Bytes:
2
Cycles:
2
Encoding:
Operation:
JNZ
0 1 0 1
Description:
Example:
rel. address
JNC
(PC) ��
← ������
������
(PC)+ �2
IF (C) = 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
C
T
S
rel
Function:
0 0 0 0
U
C
M
.
d
e
t
i
m
Li
Jump if Accumulator Not Zero
If any bit of the Accumulator is a one, branch to the indicated address; otherwise proceed
with the next instruction. The branch destination is computed by adding the signed relativedisplacement in the second instruction byte to the PC, after incrementing the PC twice. The
Accumulator is not modified. No flags are affected.
The Accumulator originally holds 00H. The instruction sequence,
JNZ
INC
JNZ
LABEL1
A
LAEEL2
will set the Accumulator to 01H and continue at label LABEL2.
Bytes:
2
Cycles:
2
Encoding:
Operation:
0 1 1 1
0 0 0 0
rel. address
JNZ
(PC) ��
← ������
������
(PC)+ �2
IF (A) ≠ 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
123
STC90C58AD系列单片机指南
JZ
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
rel
Function:
Description:
Example:
Bytes:
Cycles:
Jump if Accumulator Zero
If all bits of the Accumulator are zero, branch to the address indicated; otherwise proceed
with the next instruction. The branch destination is computed by adding the signed relativedisplacement in the second instruction byte to the PC, after incrementing the PC twice. The
Accumulator is not modified. No flags are affected.
The Accumulator originally contains 01H. The instruction sequence,
JZ LABEL1
DEC A
JZ LAEEL2
will change the Accumulator to 00H and cause program execution to continue at the
instruction identified by the label LABEL2.
2
Encoding:
Operation:
.
d
e
t
i
m
2
0 1 1 0
0 0 0 0
rel. address
JZ
(PC) ��
← ������
������
(PC)+ �2
IF (A) = 0
THEN (PC) ��
←��������
�������
(PC) + ���
rel
U
C
M
LCALL addr16
Li
Function:
Description:
Long call
LCALL calls a subroutine loated at the indicated address. The instruction adds three to the
program counter to generate the address of the next instruction and then pushes the 16-bit
result onto the stack (low byte first), incrementing the Stack Pointer by two. The high-order
and low-order bytes of the PC are then loaded, respectively, with the second and third bytes
of the LCALL instruction. Program execution continues with the instruction at this address.
The subroutine may therefore begin anywhere in the full 64K-byte program memory address
space. No flags are affected.
Example:
Initially the Stack Pointer equals 07H. The label “SUBRTN” is assigned to program memory
location 1234H. After executing the instruction,
C
T
S
LCALL SUBRTN
Bytes:
Cycles:
Encoding:
Operation:
124
at location 0123H, the Stack Pointer will contain 09H, internal RAM locations 08H and 09H
will contain 26H and 01H, and the PC will contain 1234H.
3
2
0 0 0 1
0 0 1 0
addr15-addr8
addr7-addr0
LCALL
(PC) ��
←���������
��������
(PC) + 3
(SP) ��
←���������
��������
(SP) + 1
((SP)) ��
←����
���
(PC7-0)
(SP) ��
←���������
��������
(SP) + 1
((SP)) ��
←����
���
(PC15-8)
(PC) ��
←� ����
addr15-0
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
LJMP addr16
Function:
Description:
Example:
Long Jump
LJMP causes an unconditional branch to the indicated address, by loading the high-order
and low-order bytes of the PC (respectively) with the second and third instruction bytes. The
destination may therefore be anywhere in the full 64K program memory address space. No
flags are affected.
The label “JMPADR” is assigned to the instruction at program memory location 1234H. The
instruction,
LJMP JMPADR
at location 0123H will load the program counter with 1234H.
Bytes:
3
Cycles:
2
Encoding:
0 0 0 0
Operation:
LJMP
(PC) ��
←� ����
addr15-0
0 0 1 0
MOV ,
Function:
Description:
addr15-addr8
U
C
M
.
d
e
t
i
m
Li
addr7-addr0
Move byte variable
The byte variable indicated by the second operand is copied into the location specified by the
first operand. The source byte is not affected. No other register or flag is affected.
C
T
S
This is by far the most flexible operation. Fifteen combinations of source and destination
addressing modes are allowed.
Example:
Internal RAM location 30H holds 40H. The value of RAM location 40H is 10H. The data
present at input port 1 is 11001010B (0CAH).
MOV
R0, #30H ;R0< = 30H
MOV
A, @R0
;A < = 40H
MOV
R1, A
;R1 < = 40H
MOV
B, @Rl
;B < = 10H
MOV
@Rl, Pl
;RAM (40H) < = 0CAH
MOV
P2, P1
;P2 #0CAH
leaves the value 30H in register 0,40H in both the Accumulator and register 1,10H in register
B, and 0CAH(11001010B) both in RAM location 40H and output on port 2.
MOV A,Rn
Bytes:
1
Cycles:
1
Encoding:
Operation:
1 1
1
0
1 r r r
MOV
(A) ��
←�����
����
(Rn)
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
125
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
*MOV A,direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
1 1 1 0
0 1 0 1
direct address
MOV
(A)��
←���������
��������
(direct)
*MOV A, ACC is not a valid instruction
MOV A,@Ri
Bytes:
1
Cycles:
1
Encoding:
Operation:
1 1
1
0
0 1 1 i
MOV A,#data
Bytes:
2
Cycles:
1
Encoding:
0 1 1 1
Operation:
MOV
(A)��
←� �����
#data
MOV Rn, A
Bytes:
1
Cycles:
1
Encoding:
Operation:
.
d
e
t
i
m
MOV
(A) ��
←�������
������
((Ri))
C
T
S
1 1 1 1
U
C
M
0 1 0 0
immediate data
Li
1 r r r
MOV
(Rn)����
←���
(A)
MOV Rn,direct
Bytes:
2
Cycles:
2
Encoding:
Operation:
1 0 1 0
1 r r r
direct addr.
1 r r r
immediate data
MOV
(Rn)���������
←��������
(direct)
MOV Rn,#data
Bytes:
2
Cycles:
1
Encoding:
Operation:
126
0 1 1 1
MOV
(Rn) ��
←� �����
#data
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOV direct, A
Bytes:
2
Cycles:
1
Encoding:
1 1 1 1
Operation:
MOV
(direct) ←����
�� ���
(A)
MOV direct, Rn
Bytes:
2
Cycles:
2
Encoding:
1 0 0 0
Operation:
MOV
(direct) ←�����
�� ����
(Rn)
0 1 0 1
direct address
1 r r r
direct address
MOV direct, direct
Bytes:
3
Cycles:
2
Encoding:
Operation:
1 0 0 0
MOV
(direct)��
←���������
��������
(direct)
C
T
S
MOV direct, @Ri
Bytes:
2
Cycles:
2
Encoding:
1 0 0 0
Operation:
MOV
(direct)�������
←������
((Ri))
U
C
M
0 1 0 1
0 1 1 i
dir.addr. (src)
.
d
e
t
i
m
Li
direct addr.
MOV direct,#data
Bytes:
3
Cycles:
2
Encoding:
Operation:
0 1 1 1
0 1 0 1
direct address
MOV
(direct) ← �����
�� �����
#data
MOV @Ri, A
Bytes:
1
Cycles:
1
Encoding:
1 1 1 1
Operation:
MOV
((Ri)) ←����
�� (A)
���
南通国芯微电子有限公司
0 1 1 i
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
127
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOV @Ri, direct
Bytes:
2
Cycles:
2
Encoding:
1 0 1 0
0 1 1 i
direct addr.
0 1 1 i
immediate data
Operation:
MOV
((Ri)) ←���������
�� (direct)
��������
MOV @Ri, #data
Bytes:
2
Cycles:
1
Encoding:
0 1 1 1
Operation:
MOV
((Ri)) ←�
�� �����
#data
MOV ,
Function:
Description:
Example:
.
d
e
t
i
m
Li
Move bit data
The Boolean variable indicated by the second operand is copied into the location specified by
the first operand. One of the operands must be the carry flag; the other may be any directly
addressable bit. No other register or flag is affected.
U
C
M
The carry flag is originally set. The data present at input Port 3 is 11000101B. The data
previously written to output Port 1 is 35H (00110101B).
C
T
S
MOV
MOV
MOV
P1.3, C
C, P3.3
P1.2, C
will leave the carry cleared and change Port 1 to 39H (00111001B).
MOV C,bit
Bytes:
2
Cycles:
1
Encoding:
Operation:
1
0
1
0
0
0
1
1
bit address
1
0
0
1
0
bit address
MOV
(C) ��
←������
�����
(bit)
MOV bit,C
Bytes:
2
Cycles:
2
Encoding:
Operation:
128
1
0
0
MOV
(bit)��
←����
(C)
���
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOV DPTR , #data 16
Function:
Description:
Example:
Bytes:
Cycles:
Encoding:
Operation:
Load Data Pointer with a 16-bit constant
The Data Pointer is loaded with the 16-bit constant indicated.The 16-bit constant is loaded
into the second and third bytes of the instruction. The second byte (DPH) is the high-order
byte, while the third byte (DPL) holds the low-order byte. No flags are affected.
This is the only instruction which moves 16 bits of data at once.
The instruction,
MOV DPTR, #1234H
will load the value 1234H into the Data Pointer: DPH will hold 12H and DPL will hold 34H.
3
2
1
0
0
1
0
0
0
0
immediate data 15-8
MOV
(DPTR) ��
←� �����
#data15-0
DPH DPL ← #data
�� �����15-8 #data7-0
MOVC A , @A+
Function:
Description:
Example:
.
d
e
t
i
m
Li
Move Code byte
The MOVC instructions load the Accumulator with a code byte, or constant from program
memory. The address of the byte fetched is the sum of the original unsigned eight-bit.
Accumulator contents and the contents of a sixteen-bit base register, which may be either
the Data Pointer or the PC. In the latter case, the PC is incremented to the address of the
following instruction before being added with the Accumulator; otherwise the base register
is not altered. Sixteen-bit addition is performed so a carry-out from the low-order eight bits
may propagate through higher-order bits. No flags are affected.
C
T
S
U
C
M
A value between 0 and 3 is in the Accumulator. The following instructions will translate the
value in the Accumulator to one of four values defimed by the DB (define byte) directive.
REL-PC: INC
A
MOVC A, @A+PC
RET
DB
66H
DB
77H
DB
88H
DB
99H
If the subroutine is called with the Accumulator equal to 01H, it will return with 77H in the
Accumulator. The INC A before the MOVC instruction is needed to “get around” the RET
instruction above the table. If several bytes of code separated the MOVC from the table, the
corresponding number would be added to the Accumulator instead.
MOVC A,@A+DPTR
Bytes:
1
Cycles:
2
Encoding:
Operation:
1 0
0
1
0 0 1 1
MOVC
(A) ��
←�������������
������������
((A)+(DPTR))
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
129
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOVC A,@A+PC
Bytes:
1
Cycles:
2
Encoding:
Operation:
MOVX
1 0 0 0
0 0 1 1
MOVC
(PC) ��
← (PC)+1
������
(A) ��
←�����������
����������
((A)+(PC))
,
Function:
Description:
Move External
The MOVX instructions transfer data between the Accumulator and a byte of external data
memory, hence the “X” appended to MOV. There are two types of instructions, differing in
whether they provide an eight-bit or sixteen-bit indirect address to the external data RAM.
.
d
e
t
i
m
In the first type, the contents of R0 or R1 in the current register bank provide an eight-bit
address multiplexed with data on P0. Eight bits are sufficient for external I/O expansion
decoding or for a relatively small RAM array. For somewhat larger arrays, any output port
pins can be used to output higher-order address bits. These pins would be controlled by an
output instruction preceding the MOVX.
U
C
M
Li
In the second type of MOVX instruction, the Data Pointer generates a sixteen-bit address.
P2 outputs the high-order eight address bits (the contents of DPH) while P0 multiplexes the
low-order eight bits (DPL) with data. The P2 Special Function Register retains its previous
contents while the P2 output buffers are emitting the contents of DPH. This form is faster and
more efficient when accessing very large data arrays (up to 64K bytes), since no additional
instructions are needed to set up the output ports.
C
T
S
It is possible in some situations to mix the two MOVX types. A large RAM array with its
high-order address lines driven by P2 can be addressed via the Data Pointer, or with code to
output high-order address bits to P2 followed by a MOVX instruction using R0 or R1.
Example:
An external 256 byte RAM using multiplexed address/data lines (e.g., an Intel 8155 RAM/
I/O/Timer) is connected to the 8051 Port 0. Port 3 provides control lines for the external
RAM. Ports 1 and 2 are used for normal I/O. Registers 0 and 1 contain 12H and 34H.
Location 34H of the external RAM holds the value 56H. The instruction sequence,
MOVX
MOVX
A, @R1
@R0, A
copies the value 56H into both the Accumulator and external RAM location 12H.
MOVX A,@Ri
Bytes:
1
Cycles:
2
Encoding:
Operation:
130
1 1
1
0
0 0 1 i
MOVX
(A) ��
←�������
������
((Ri))
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
MOVX A,@DPTR
Bytes:
1
Cycles:
2
Encoding:
1 1 1 0
Operation:
MOVX
(A) ��
←���������
��������
((DPTR))
MOVX
0 0 0 0
@Ri, A
Bytes:
1
Cycles:
2
Encoding:
1 1 1 1
Operation:
MOVX
((Ri))��
←����
(A)
���
MOVX
0 0 1 i
@DPTR, A
Bytes:
1
Cycles:
2
Encoding:
Operation:
1 1 1 1
MOVX
(DPTR)����
←���
(A)
C
T
S
MUL AB
Function:
Description:
Example:
U
C
M
0 0 0 0
.
d
e
t
i
m
Li
Multiply
MUL AB multiplies the unsigned eight-bit integers in the Accumulator and register B. The
low-order byte of the sixteen-bit product is left in the Accumulator, and the high-order byte
in B. If the product is greater than 255 (0FFH) the overflow flag is set; otherwise it is cleared.
The carry flag is always cleared
Originally the Accumulator holds the value 80 (50H). Register B holds the value 160
(0A0H). The instruction,
MUL AB
will give the product 12,800 (3200H), so B is changed to 32H (00110010B) and the
Accumulator is cleared. The overflow flag is set, carry is cleared.
Bytes:
1
Cycles:
4
Encoding:
Operation:
1
0
1
0
0
1
0
0
MUL
(A)7-0 ←��������
(A)×(B)
(B)15-8
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
131
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
NOP
Function:
Description:
Example:
No Operation
Execution continues at the following instruction. Other than the PC, no registers or flags are
affected.
It is desired to produce a low-going output pulse on bit 7 of Port 2 lasting exactly 5 cycles. A
simple SETB/CLR sequence would generate a one-cycle pulse, so four additional cycles
must be inserted. This may be done (assuming no interrupts are enabled) with the instruction
sequence.
CLR
NOP
NOP
NOP
NOP
SETB
Bytes:
1
Cycles:
1
Encoding:
Operation:
0
0
P2.7
0
0
NOP
(PC) ←�������
(PC)+1
ORL ,
Function:
Description:
.
d
e
t
i
m
P2.7
C
T
S
0
0
0
0
U
C
M
Li
Logical-OR for byte variables
ORL performs the bitwise logical-OR operation between the indicated variables, storing the
results in the destination byte. No flags are affected.
The two operands allow six addressing mode combinations. When the destination is the
Accumulator, the source can use register, direct, register-indirect, or immediate addressing;
when the destination is a direct address, the source can be the Accumulator or immediate
data.
Note: When this instruction is used to modify an output port, the value used as the original
port data will be read from the output data latch, not the input pins.
Example:
If the Accumulator holds 0C3H (11000011B) and R0 holds 55H (01010101B) then the
instruction,
ORL
A, R0
will leave the Accumulator holding the value 0D7H (11010111B).
When the destination is a directly addressed byte, the instruction can set combinations of bits
in any RAM location or hardware register. The pattern of bits to be set is determined by a
mask byte, which may be either a constant data value in the instruction or a variable
computed in the Accumulator at run-time.The instruction,
ORL
P1, #00110010B
will set bits 5,4, and 1of output Port 1.
132
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ORL A,Rn
Bytes:
1
Cycles:
1
Encoding:
Operation:
0
1
0
0
1
r
r
r
1
0
1
ORL
(A) ��
←����
���
(A)∨(Rn)
ORL A,direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
0
1
0
0
0
direct address
ORL
(A)��
←����
���
(A)∨(direct)
ORL A,@Ri
Bytes:
Cycles:
1
1
Encoding:
Operation:
0
0
0
0
1
1
1
0
ORL
(A)��
←����
���
(A)∨((Ri))
ORL A,#data
Bytes:
2
Cycles:
1
Encoding:
Operation:
1
0
C
T
S
1
0
0
0
U
C
M
i
0
.
d
e
t
i
m
Li
immediate data
ORL
(A)��
←����
���
(A)∨ #data
ORL direct, A
Bytes:
2
Cycles:
1
Encoding:
Operation:
0
1
0
0
0
0
1
0
direct address
1
direct address
ORL
(direct)��
←���������
��������
(direct)∨(A)
ORL direct, #data
Bytes:
3
Cycles:
2
Encoding:
Operation:
0
1
0
0
0
0
1
immediate data
ORL
(direct) ←���������
�� ��������
(direct)∨#data
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
133
STC90C58AD系列单片机指南
ORL
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
C,
Function:
Description:
Example:
Logical-OR for bit variables
Set the carry flag if the Boolean value is a logical 1; leave the carry in its current state
otherwise. A slash (“ / ”) preceding the operand in the assembly language indicates that the
logical complement of the addressed bit is used as the source value, but the source bit itself is
not affected. No other flags are affected.
Set the carry flag if and only if P1.0 = 1, ACC. 7 = 1, or OV = 0:
MOV
C, P1.0
;LOAD CARRY WITH INPUT PIN P10
ORL
C, ACC.7
;OR CARRY WITH THE ACC.BIT 7
ORL
C, /OV
;OR CARRY WITH THE INVERSE OF OV
ORL C, bit
Bytes:
2
Cycles:
2
Encoding:
Operation:
0
2
Cycles:
2
Encoding:
1
Function:
Example:
Bytes:
Cycles:
Encoding:
Operation:
134
1
0
0
0
1
0
C
T
S
0
1
0
0
ORL
(C) ��
←����
���
(C)∨(bit)
POP direct
Description:
1
1
0
U
C
M
0
0
.
d
e
t
i
m
bit address
ORL
(C) ��
←����
���
(C)∨(bit)
ORL C, /bit
Bytes:
Operation:
1
Li
bit address
Pop from stack
The contents of the internal RAM location addressed by the Stack Pointer is read, and the
Stack Pointer is decremented by one. The value read is then transferred to the directly
addressed byte indicated. No flags are affected.
The Stack Pointer originally contains the value 32H, and internal RAM locations 30H
through 32H contain the values 20H, 23H, and 01H, respectively. The instruction sequence,
POP DPH
POP DPL
will leave the Stack Pointer equal to the value 30H and the Data Pointer set to 0123H. At this
point the instruction,
POP SP
will leave the Stack Pointer set to 20H. Note that in this special case the Stack Pointer was
decremented to 2FH before being loaded with the value popped (20H).
2
2
1
0 1
0
0
0
direct address
POP
(diect) ←�������
((SP))
(SP) ��
←������
�����
(SP) ��- �1
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
PUSH direct
Function:
Description:
Example:
Push onto stack
The Stack Pointer is incremented by one. The contents of the indicated variableis then copied
into the internal RAM location addressed by the Stack Pointer. Otherwise no flags are
affected.
On entering interrupt routine the Stack Pointer contains 09H. The Data Pointer holds the
value 0123H. The instruction sequence,
PUSH
PUSH
DPL
DPH
will leave the Stack Pointer set to 0BH and store 23H and 01H in internal RAM locations
0AH and 0BH, respectively.
Bytes:
2
Cycles:
Encoding:
2
Operation:
1
1
0 0
0
0
0
PUSH
(SP) ��
←���������
��������
(SP) + 1
((SP)) ��
←���������
��������
(direct)
RET
Function:
Return from subroutine
C
T
S
0
direct address
U
C
M
.
d
e
t
i
m
Li
Description:
RET pops the high-and low-order bytes of the PC successively from the stack, decrementing
the Stack Pointer by two. Program execution continues at the resulting address, generally the
instruction immediately following an ACALL or LCALL. No flags are affected.
Example:
The Stack Pointer originally contains the value 0BH. Internal RAM locations 0AH and 0BH
contain the values 23H and 01H, respectively. The instruction,
RET
will leave the Stack Pointer equal to the value 09H. Program execution will continue at
location 0123H.
Bytes:
1
Cycles:
Encoding:
2
Operation:
0
0
1 0
0
0
1
0
RET
(PC15-8) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
(PC7-0) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
135
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RETI
Function:
Description:
Example:
Return from interrupt
RETI pops the high- and low-order bytes of the PC successively from the stack, and restores
the interrupt logic to accept additional interrupts at the same priority level as the one just
processed. The Stack Pointer is left decremented by two. No other registers are affected; the
PSW is not automatically restored to its pre-interrupt status. Program execution continues at
the resulting address, which is generally the instruction immediately after the point at which
the interrupt request was detected. If a lower- or same-level interrupt had been pending when
the RETI instruction is executed, that one instruction will be executed before the pending
interrupt is processed.
The Stack Pointer originally contains the value 0BH. An interrupt was detected during the
instruction ending at location 0122H. Internal RAM locations 0AH and 0BH contain the
values 23H and 01H, respectively. The instruction,
.
d
e
t
i
m
RETI
will leave the Stack Pointer equal to 09H and return program execution to location 0123H.
Bytes:
1
Cycles:
Encoding:
2
Operation:
0
Function:
Example:
1 1
0
U
C
M
0
1
RETI
(PC15-8) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
(PC7-0) ��
←�������
������
((SP))
(SP) ��
←��������
�������
(SP) -1
C
T
S
RL A
Description:
0
0
Li
Rotate Accumulator Left
The eight bits in the Accumulator are rotated one bit to the left. Bit 7 is rotated into the bit 0
position. No flags are affected.
The Accumulator holds the value 0C5H (11000101B). The instruction,
RL
A
leaves the Accumulator holding the value 8BH (10001011B) with the carry unaffected.
Bytes:
1
Cycles:
Encoding:
1
Operation:
136
0
0
1 0
RL
(An+1) ��
←���
��
(An)
(A0) ←���
�� (A
��7)
南通国芯微电子有限公司
0
0
1
1
n = 0-6
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RLC A
Function:
Description:
Example:
Bytes:
Cycles:
Rotate Accumulator Left through the Carry flag
The eight bits in the Accumulator and the carry flag are together rotated one bit to the left. Bit
7 moves into the carry flag; the original state of the carry flag moves into the bit 0 position.
No other flags are affected.
The Accumulator holds the value 0C5H (11000101B), and the carry is zero. The instruction,
RLC A
leaves the Accumulator holding the value 8BH (10001011B) with the carry set.
1
1
Encoding:
Operation:
0
0
1 1
0
RLC
(An+1) ��
←���
��
(An)
(A0) ��
←����
���
(C)
(C) ��
←���
��
(A7)
0
1
1
RR A
Function:
Description:
Example:
Bytes:
Cycles:
Encoding:
Operation:
RRC A
Function:
Description:
Example:
Bytes:
Cycles:
Rotate Accumulator Right
Li
The eight bits in the Accumulator are rotated one bit to the right. Bit 0 is rotated into the bit 7
position. No flags are affected.
The Accumulator holds the value 0C5H (11000101B). The instruction,
RR A
leaves the Accumulator holding the value 0E2H (11100010B) with the carry unaffected.
1
1
0
U
C
M
C
T
S
0
0 0
RR
(An) ��
←���
��
(An+1)
(A7) ��
←���
��
(A0)
0
0
1
1
n=0-6
Rotate Accumulator Right through the Carry flag
The eight bits in the Accumulator and the carry flag are together rotated one bit to the right.
Bit 0 moves into the carry flag; the original value of the carry flag moves into the bit 7
position.No other flags are affected.
The Accumulator holds the value 0C5H (11000101B), and the carry is zero. The instruction,
RRC A
leaves the Accumulator holding the value 62H (01100010B) with the carry set.
1
1
Encoding:
Operation:
.
d
e
t
i
m
n = 0-6
0
0
0 1
RRC
(An+1) ��
←���
��
(An)
(A7) ��
←����
���
(C)
(C) ��
←���
��
(A0)
南通国芯微电子有限公司
0
0
1
1
n = 0-6
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
137
STC90C58AD系列单片机指南
SETB
Function:
Example:
SETB sets the indicated bit to one. SETB can operate on the carry flag or any directly
addressable bit. No other flags are affected
The carry flag is cleared. Output Port 1 has been written with the value 34H (00110100B).
The instructions,
SETB
C
SETB
P1.0
will leave the carry flag set to 1 and change the data output on Port 1 to 35H (00110101B).
1
Cycles:
1
Encoding:
1
2
Cycles:
1
Encoding:
0 1
0
0
1
1
0
1
0
0
SETB
(bit) ←��
�� 1�
C
T
S
SJMP rel
Function:
1
1
U
C
M
1
.
d
e
t
i
m
1
SETB
(C) ��
←��
�1
bit
Bytes:
Operation:
0
bit address
Li
Short Jump
Description:
Program control branches unconditionally to the address indicated. The branch destination is
computed by adding the signed displacement in the second instruction byte to the PC, after
incrementing the PC twice. Therefore, the range of destinations allowed is from 128bytes
preceding this instruction to 127 bytes following it.
Example:
The label “RELADR” is assigned to an instruction at program memory location 0123H. The
instruction,
SJMP RELADR
will assemble into location 0100H. After the instruction is executed, the PC will contain the
value 0123H.
(Note: Under the above conditions the instruction following SJMP will be at 102H.Therefore,
the displacement byte of the instruction will be the relative offset (0123H - 0102H) = 21H.
Put another way, an SJMP with a displacement of 0FEH would be an one-instruction infinite
loop).
Bytes:
2
Cycles:
2
Encoding:
Operation:
138
研发顾问:13922809991
Set bit
C
Bytes:
Operation:
SETB
临时技术支持:13922829991
Description:
SETB
技术支持网站:www.STCMCU.com
1
0
0 0
0
0
0
0
rel. address
SJMP
(PC) ��
←�������
������
(PC)+2
(PC) ��
←���������
��������
(PC)+rel
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
SUBB A,
Function:
Description:
Subtract with borrow
SUBB subtracts the indicated variable and the carry flag together from the Accumulator,
leaving the result in the Accumulator. SUBB sets the carry (borrow)flag if a borrow is needed
for bit 7, and clears C otherwise.(If C was set before executing a SUBB instruction, this
indicates that a borrow was needed for the previous step in a multiple precision subtraction,
so the carry is subtracted from the Accumulator along with the source operand).AC is set if a
borrow is needed for bit 3, and cleared otherwise. OV is set if a borrow is needed into bit 6,
but not into bit 7, or into bit 7, but not bit 6.
When subtracting signed integers OV indicates a negative number produced when a negative
value is subtracted from a positive value, or a positive result when a positive number is
subtracted from a negative number.
The source operand allows four addressing modes: register, direct, register-indirect, or
immediate.
Example:
.
d
e
t
i
m
The Accumulator holds 0C9H (11001001B), register 2 holds 54H (01010100B), and the
carry flag is set. The instruction,
SUBB
A, R2
U
C
M
Li
will leave the value 74H (01110100B) in the accumulator, with the carry flag and AC cleared
but OV set.
Notice that 0C9H minus 54H is 75H. The difference between this and the above result is due
to the carry (borrow) flag being set before the operation. If the state of the carry is not known
before starting a single or multiple-precision subtraction, it should be explicitly cleared by a
CLR C instruction.
C
T
S
SUBB A, Rn
Bytes:
Cycles:
Encoding:
Operation:
1
1
1 0
0
1
1 r r r
SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- ����
(Rn)
SUBB A, direct
Bytes: 2
Cycles: 1
Encoding:
1 0 0 1 0 1 0 1
Operation: SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- ��������
(direct)
direct address
SUBB A, @Ri
Bytes:
Cycles:
Encoding:
Operation:
1
1
1
0
0
1
0
1
1
i
SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- ������
((Ri))
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
139
STC90C58AD系列单片机指南
SUBB A, #data
Bytes:
Cycles:
Encoding:
Operation:
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2
1
1
0
0
1
0
1
0
0
immediate data
SUBB
(A) ��
←�����
����
(A) ��- ����
(C) ��- �����
#data
SWAP A
Function:
Description:
Example:
Swap nibbles within the Accumulator
SWAP A interchanges the low- and high-order nibbles (four-bit fields) of the Accumulator
(bits 3-0 and bits 7-4). The operation can also be thought of as a four-bit rotate instruction.
No flags are affected.
The Accumulator holds the value 0C5H (11000101B). The instruction,
SWAP
Bytes:
Cycles:
1
Encoding:
1
Operation:
SWAP
(A3-0)
XCH A,
1
0 0
0
(A7-4)
C
T
S
1
0
0
U
C
M
Li
Function:
Description:
Exchange Accumulator with byte variable
XCH loads the Accumulator with the contents of the indicated variable, at the same time
writing the original Accumulator contents to the indicated variable. The source/destination
operand can use register, direct, or register-indirect addressing.
Example:
R0 contains the address 20H. The Accumulator holds the value 3FH (00111111B). Internal
RAM location 20H holds the value 75H (01110101B). The instruction,
XCH
XCH A, Rn
Bytes:
Cycles:
Encoding:
Operation:
XCH A, direct
Bytes:
Cycles:
Encoding:
Operation:
140
.
d
e
t
i
m
A
leaves the Accumulator holding the value 5CH (01011100B).
1
A, @R0
will leave RAM location 20H holding the values 3FH (00111111B) and 75H (01110101B) in
the accumulator.
1
1
1 1
XCH
(A)
0
0
1 r r r
(Rn)
2
1
1 1 0 0
XCH
(A)
0 1 0 1
direct address
(direct)
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
XCH A, @Ri
Bytes:
Cycles:
Encoding:
Operation:
1
1
1 1 0 0
XCH
(A)
0 1 1
i
((Ri))
XCHD A, @Ri
Function:
Description:
Example:
Exchange Digit
XCHD exchanges the low-order nibble of the Accumulator (bits 3-0), generally representing
a hexadecimal or BCD digit, with that of the internal RAM location indirectly addressed by
the specified register. The high-order nibbles (bits 7-4) of each register are not affected. No
flags are affected.
.
d
e
t
i
m
R0 contains the address 20H. The Accumulator holds the value 36H (00110110B). Internal
RAM location 20H holds the value 75H (01110101B). The instruction,
XCHD
A, @R0
Li
will leave RAM location 20H holding the value 76H (01110110B) and 35H (00110101B) in
the accumulator.
Bytes:
Cycles:
Encoding:
Operation:
1
1
1 1 0 1
0 1 1 i
C
T
S
XCHD
(A3-0)
(Ri3-0)
U
C
M
XRL ,
Function:
Description:
Logical Exclusive-OR for byte variables
XRL performs the bitwise logical Exclusive-OR operation between the indicated variables,
storing the results in the destination. No flags are affected.
The two operands allow six addressing mode combinations.When the destination is the
Accumulator, the source can use register, direct, register-indirect, or immediate addressing;
when the destination is a direct address,the source can be the Accumulator or immediate data.
(Note: When this instruction is used to modify an output port, the value used as the original
port data will be read from the output data latch, not the input pins.)
Example:
If the Accumulator holds 0C3H (11000011B) and register 0 holds 0AAH (10101010B) then
the instruction,
XRL
A, R0
will leave the Accumulator holding the vatue 69H (01101001B).
When the destination is a directly addressed byte, this instruction can complement combinnation of bits in any RAM location or hardware register. The pattern of bits to be complemented
is then determined by a mask byte, either a constant contained in the instruction or a variable
computed in the Accumulator at run-time. The instruction,
XRL
P1, #00110001B
will complement bits 5,4 and 0 of outpue Port 1.
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
141
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
XRL A, Rn
Bytes:
Cycles:
Encoding:
Operation:
1
1
0 1
1
0
XRL
(A) ��
← (A)�
����
1 r r r
(Rn)
XRL A, direct
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 1 1 0
0 1 0 1
XRL
(A) ��
← (A)�
����
direct address
.
d
e
t
i
m
(direct)
XRL A, @Ri
Bytes:
1
Cycles:
1
Encoding:
Operation:
0 1
0
XRL
(A) ��
← (A)�
����
XRL A, #data
Bytes:
2
Cycles:
1
Encoding:
Operation:
1
0 1 1 i
((Ri))
C
T
S
0 1
1
0
XRL
(A) ��
← (A)�
����
U
C
M
0 1 0 0
Li
immediate data
#data
XRL direct, A
Bytes:
2
Cycles:
1
Encoding:
Operation:
0 1
1
0
0 0 1 0
XRL
(direct) ← (direct)�
�� ���������
direct address
(A)
XRL direct, #data
Bytes:
3
Cycles:
2
Encoding:
Operation:
142
0 1
1
0
0 0 1 1
XRL
(direct) ← (direct)�
�� ���������
南通国芯微电子有限公司
direct address
immediate data
# data
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
第6章 中断系统
中断系统是为使CPU具有对外界����������������
紧急��������������
事件的�����������
实时���������
处理能力而设置的。
当中央处理机CPU正在处理某件事的时候外界发生了紧急事件请求,要求CPU暂停当前
的工作,转而去处理这个紧急事件�������������������������
,������������������������
处理完以后,再回到原来被中断的地方,继续原来的工
作,这样的过程称为中断。实现这种功能的部件称为中断系统,请示CPU中断的请求源称为中
断源。微型机的中断系统一般允许多个中断源,当几个中断源同时向CPU请求中断,要求为它
服务的时候,这就存在CPU优先响应哪一个中断源请求的问题。通常根据中断源的轻重缓急排
队,优先处理最紧急事件的中断请求源,即规定每一个中断源有一个优先级别。CPU总是先响
应������������
优先����������
级别最高的中断请求。
.
d
e
t
i
m
当CPU正在处理一个中断源请求的时候(执行相应的���������������
中断�������������
服务程序),发生了另外一个
优先级比它还高的中断源请求。如果CPU能够暂停对原来中断源的������������
服务����������
程序,转而去处理优先
级更高的中断请求源,处理完以后,再回到原低级中断�����������������
服务���������������
程序,这样的过程称为中断嵌套。
这样的中断系统称为多级中断系统,没有中断嵌套功能的中断系统称为单级中断系统。
Li
STC90C58AD系列单片机提供了8个中断请求源,它们分别是:外部中断0(INT0)、定时器
0中断、外部中断1(INT1)、定时器1中断、定时器2中断、串口(UART)中断、外部中断2(INT2
)、外部中断3(INT3)。所有的中断都具有4个中断优先级。用户可以用关总中断允许位(EA/
IE.7)或相应中断的允许位来屏蔽所有的中断请求,也可以用打开相应的中断允许位来使CPU
响应相应的中断申请;每一个中断源可以用软件独立地控制为开中断或关中断状态;每一个中
断的优先级别均可用软件设置。高优先级的中断请求可以打断低优先级的中断,反之,低优先
级的中断请求不可以打断高优先级及同优先级的中断。当两个相同优先级的中断同时产生时,
将由查询次序来决定系统先响应哪个中断。STC90C58AD系列单片机的各个中断查询次序如下
C
T
S
U
C
M
表6-1所示:
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
143
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
表6-1 中断查询次序
中断源
中断
中断优先级
相同优先级内
优先级0 优先 优先 优先级3
向量
设置
中断请求标志位
的查询次序
(最低) 级1 级2 (最高)
(IPH,IP)
地址
INT0
0003H
(外部中断 0)
Timer 0
0 (highest) PX0H, PX0
中断允许控制位
0, 0
0, 1
1, 0
1, 1
IE0
EX0/EA
000BH
1
PT0H, PT0
0, 0
0, 1
1, 0
1, 1
TF0
ET0/EA
INT1
0013H
(外部中断1)
2
PX1H, PX1
0, 0
0, 1
1, 0
1, 1
IE1
EX1/EA
ET1/EA
Timer1
001BH
3
PT1H, PT1
0, 0
0, 1
1, 0
1, 1
TF1
UART
0023H
4
PSH, PS
0, 0
0, 1
1, 0
1, 1
RI+TI
Timer2
002BH
5
PT2H, PT2
0, 0
0, 1
1, 0
1, 1
TF2 + EXF2
(ET2)/EA
INT2
0033H
(外部中断2)
6
PX2H, PX2
0, 0
0, 1
1, 0
1, 1
IE2
EX2/EA
7 (lowest) PX3H, PX3
0, 0
0, 1
1, 0
IE3
EX3/EA
INT3
003BH
(外部中断3)
U
C
M
.
d
e
t
i
m
Li
1, 1
通过设置新增加的特殊功能寄存器IPH中的相应位,可将中断优先级设为四级,如果只设
置IP或XICON,那么中断优先级就只有两级,与传统8051单片机两级中断优先级完全兼容。
C
T
S
如果使用C语言编程,中断查询次序号就是中断号,例如:
144
void
void
void
void
void
void
void
void
Int0_Routine(void)
Timer0_Rountine(void)
Int1_Routine(void)
Timer1_Rountine(void)
UART_Routine(void)
Timer2_Routine(void)
Int2_Routine(void)
Int3_Routine(void)
南通国芯微电子有限公司
interrupt 0;
interrupt 1;
interrupt 2;
interrupt 3;
interrupt 4;
interrupt 5;
interrupt 6;
interrupt 7;
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.1 中断结构
STC90C58AD系列单片机的中断系统结构示意图如图6-1所示
中断优先级
控制寄存器
中断允许控
制寄存器
最低优先级中断
IP, XICON, IPH
IE, XICON寄存器 寄存器
TCON.0/IT0=0
INT0
IE0
EX0
EA
TCON.0/IT0=1
PX0H, PX0
ET0
Timer0 / TF0
TCON.2/IT1=0
INT1
PT0H, PT0
IE1
PX1H, PX1
EX1
TCON.2/IT1=1
Timer1 / TF1
UART RI
TI
Timer2 TF2
EXF2
ES
C
T
S
XICON.0/IT2=0
INT2
PT1H, PT1
ET1
IE2
ET2
CU
M
PSH, PS
PT2H, PT2
PX2H, PX2
EX2
0,0
0,0
0,0
0,0
0,0
0,0
0,0
最高优先级中断
0,1
1,0
Li
0,1
0,1
0,1
0,1
high
.
d
e
t
i
m
0,1
0,1
1,1
1,0
1,0
1,0
1,0
1,0
1,0
1,1
1,1
1,1
1,1
中断
查询
次序
1,1
1,1
XICON.0/IT2=1
XICON.4/IT3=0
INT3
IE3
PX3H, PX3
EX3
0,0
0,1
1,0
1,1
XICON.4/IT3=1
low
EA
Global Enable
EA
图6-1 STC90C58AD系列中断系统结构图
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
145
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
外部中断0(INT0)、外部中断1(INT1)、外部中断2(INT2)和外部中断3( INT3 )既可低电平
触发,也下降沿触发。请求四个外部中断的标志位是位于寄存器TCON中的IE0/TCON.1、
IE1/TCON.3、IE2/XICON.2和IE3/XICON.5。当外部中断服务程序被响应后,中断请求标志位
IE0、IE1、IE2和IE3会自动被清0。TCON寄存器中的IT0/TCON.0、IT1/TCON.2、IT2/XICON.0
和IT3/XICON.4决定了外部中断0、1、2和3是低电平触发方式还是下降沿触发方式。如果ITx =
0(x = 0,1,2,3),那么系统在INTx(x = 0,1,2,3)脚探测到低电平后可产生外部中断。如果ITx = 1(x
= 0,1,2,3),那么系统在INTx( x= 0,1,2,3)脚探测下降沿后可产生外部中断。外部中断0(INT0)、
外部中断1(INT1)、外部中断2(INT2)和外部中断3(INT3)还可以用于将单片机从掉电模式唤醒。
定时器0和1的中断请求标志位是TF0和TF1。当定时器寄存器THx/TLx(x = 0,1)溢出时,溢
出标志位TFx(x = 0,1)会被置位,定时器中断发生。当单片机转去执行该定时器中断时,定时器
的溢出标志位TFx(x = 0,1)会被硬件清除。
.
d
e
t
i
m
当串行口接收中断请求标志位RI和串行口1发送中断请求标志位TI中的任何一个被置为1
后,串行口中断都会产生。。
定时器2的中断请求标志位是TF2和EXF2。当定时器寄存器TH2/TL2溢出时,溢出标志位
TF2会被置位,定时器中断发生。当单片机转去执行该定时器中断时,定时器的溢出标志位
TF2会被硬件清除。当EXEN2=1且T2EX的负跳变产生捕获或重装时,EXF2置位。定时器2中断使
能时,EXF2=也将使CPU从中断向量处执行定时器2中断子程序。
U
C
M
Li
各个中断触发行为总结如下表6-2所示:
中断源
INT0
(外部中断0)
Timer 0
INT1
(外部中断1)
146
C
T
S
表6-2 中断触发
触发行为
(IT0/TCON.0 = 1): 下降沿
(IT0/TCON.0 = 0): 低电平
定时器0溢出
(IT1/TCON.2 = 1): 下降沿
Timer1
定时器1溢出
UART
发送或接受完成
Timer2
定时器2溢出
(IT1/TCON.2 = 0): 低电平
INT2
(外部中断2)
(IT2/XICON.0 = 1): 下降沿
(IT2/XICON.0 = 0): 低电平
INT3
(外部中断3)
(IT3/XICON.4 = 1): 下降沿
(IT3/XICON.4 = 0): 低电平
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.2 中断寄存器
位地址及符号
符号
描述
地址
IE
Interrupt Enable
Interrupt Priority
Low
Interrupt Priority
High
Timer/Counter 0 and
1 Control
A8H
EA
B8H
-
-
PT2
B7H
PX3H
PX2H
PT2H
88H
TF1
TR1
TF0
TR0
IE1
IT1
Serial Control
98H
SM0/FE
SM1
SM2
REN
TB8
RB8
IP
IPH
TCON
SCON
T2CON
XICON
Timer/Counter 2
Control
Auxiliary Interupt
Control
MSB
C8H
LSB
-
ET2
ES
PS
ET1
EX1
ET0
EX0
0x00 0000B
PT1
PX1
PT0
PX0
xx00 0000B
PX0H
0000,0000B
IE0
IT0
0000 0000B
TI
RI
0000 0000B
PSH PT1H PX1H PT0H
.
d
e
t
i
m
TF2 EXF2 RCLK TCLK EXEN2
E8H
PX3
EX3
IE3
IT3
复位值
PX2
TR2
C/T2
EX2
IE2
CP/RL2
0000 0000B
IT2
0000 0000B
Li
上表中列出了与STC90C58AD系列单片机中断相关的所有寄存器,下面逐一地对上述寄存
器进行介绍。
U
C
M
1. 中断允许寄存器IE和XICON
STC90C58AD系列单片机CPU对中断源的开放或屏蔽,每一个中断源是否被允许中断,是
由内部的中断允许寄存器IE(地址为A8H)和XICON(地址为E8H)控制的。寄存器IE的格式
如下:
C
T
S
IE : 中断允许寄存器 (可位寻址)
SFR name
IE
Address
A8H
bit
name
B7
EA
B6
-
B5
ET2
B4
ES
B3
ET1
B2
EX1
B1
ET0
B0
EX0
EA : CPU的总中断允许控制位,EA=1,CPU开放中断,EA=0,CPU屏蔽所有的中断申请。
EA的作用是使中断允许形成两级控制。即各中断源首先受EA控制;其次还受各中断源自
己的中断允许控制位控制。
ET2: 定时/计数器T2的溢出中断允许位。ET2=1,允许T2中断;ET2=0,禁止T2中断。
ES : 串行口1中断允许位。ES=1,允许串行口1中断;ES=0,禁止串行口1中断。
ET1 : 定时/计数器T1的溢出中断允许位。ET1=1,允许T1中断;ET1=0,禁止T1中断。
EX1 : 外部中断1中断允许位。EX1=1,允许外部中断1中断;EX1=0,禁止外部中断1中断。
ET0 : T0的溢出中断允许位。ET0=1,允许T0中断;ET0=0禁止T0中断。
EX0 : 外部中断0中断允许位。EX0=1,允许中断;EX0=0禁止中断。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
147
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
寄存器XICON的格式如下:
XICON : 辅助中断控制寄存器 (可位寻址)
SFR name
XICON
Address
E8H
bit
name
B7
PX3
B6
EX3
B5
IE3
B4
IT3
B3
PX2
B2
EX2
B1
IE2
B0
IT2
PX3: 置位表明外部中断3的优先级为高,优先级最终由[PXH3,PX3]=[0,0];[0,1];[1,0];
[1,1]来决定。
EX3 : 如被设置成1,允许外部中断3中断;如被清成0,禁止外部中断3中断。
IE3 : 外部中断3中断请求标志位,中断条件成立后,IE3=1,可由硬件自动清零。
IT3 : 当此位由软件置位时,外部中断3为下降沿触发中断;当此位由软件清零时,为低电平触发
中断。
.
d
e
t
i
m
PX2: 置位表明外部中断2的优先级为高,优先级最终由[PXH2,PX2]=[0,0];[0,1];[1,0];
[1,1]来决定。
Li
EX2 : 如被设置成1,允许外部中断2中断;如被清成0,禁止外部中断2中断。
U
C
M
IE2 : 外部中断2中断请求标志位,中断条件成立后,IE2=1,可由硬件自动清零。
IT2 : 当此位由软件置位时,外部中断2为下降沿触发中断;当此位由软件清零时,为低电平触发
中断。
C
T
S
STC90C58AD系列单片机复位以后,IE和XICON被清0,由用户程序置“1”或清“0”IE和
XICON相应的位,实现允许或禁止各中断源的中断申请,若使某一个中断源允许中断必须同
时使CPU开放中断。更新IE和XICON的内容可由位操作指令来实现(SETB BIT;CLR BIT),
也可用字节操作指令实现(即MOV IE,#DATA,ANL IE,#DATA;ORL IE,#DATA;MOV
IE,A等)。
148
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 中断优先级控制寄存器IP/XICON和IPH
传统8051单片机具有两个中断优先级,即高优先级和低优先级,可以实现两级中断嵌套。
STC90C58AD系列单片机通过设置新增加的特殊功能寄存器(IPH)中的相应位,可将中断优先
级设置为4个中断优先级;如果只设置IP,那么中断优先级只有两级,与传统8051单片机两级
中断优先级完全兼容。
一个正在执行的低优先级中断能被高优先级中断所中断,但不能被另一个低优先级中断所
中断,一直执行到结束,遇到返回指令RETI,返回主程序后再执行一条指令才能响应新的中
断申请。以上所述可归纳为下面两条基本规则:
⒈ 低优先级中断可被高优先级中断所中断,反之不能。
⒉ 任何一种中断(不管是高级还是低级),一旦得到响应,不会再被它的同级中断所中断
.
d
e
t
i
m
STC90C58AD系列单片机的片内各优先级控制寄存器的格式如下:
IPH: 中断优先级控制寄存器高(不可位寻址)
SFR name Address
IPH
B7H
bit
B7
B6
B5
B4
name
-
-
PT2
PSH
U
C
M
Li
B3
Address
E8H
bit
name
C
T
S
B7
PX3
B6
EX3
B5
IE3
B1
B0
PT1H PX1H PT0H PX0H
XICON : 辅助中断控制寄存器 (可位寻址)
SFR name
XICON
B2
B4
IT3
B3
PX2
B2
EX2
B1
IE2
B0
IT2
IP : 中断优先级控制寄存器低 (可位寻址)
SFR name
Address
IP
B8H
bit
B7
B6
B5
B4
B3
B2
B1
B0
name
PX3
PX2
PT2
PS
PT1
PX1
PT0
PX0
PX3H, PX3: 外部中断3优先级控制位。
当PX3H=0且PX3=0时,外部中断3为最低优先级中断(优先级0)
当PX3H=0且PX3=1时,外部中断3为较低优先级中断(优先级1)
当PX3H=1且PX3=0时,外部中断3为较高优先级中断(优先级2)
当PX3H=1且PX3=1时,外部中断3为最高优先级中断(优先级3)
PX2H, PX2: 外部中断2优先级控制位。
当PX2H=0且PX2=0时,外部中断2为最低优先级中断(优先级0)
当PX2H=0且PX2=1时,外部中断2为较低优先级中断(优先级1)
当PX2H=1且PX2=0时,外部中断2为较高优先级中断(优先级2)
当PX2H=1且PX2=1时,外部中断2为最高优先级中断(优先级3)
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
149
STC90C58AD系列单片机指南
PT2H, PT2:
PSH, PS:
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
定时器2中断优先级控制位。
当PT2H=0且PT2=0时,定时器2中断为最低优先级中断(优先级0)
当PT2H=0且PT2=1时,定时器2中断为较低优先级中断(优先级1)
当PT2H=1且PT2=0时,定时器2中断为较高优先级中断(优先级2)
当PT2H=1且PT2=1时,定时器2中断为最高优先级中断(优先级3)
串口1中断优先级控制位。
当PSH=0且PS=0时,串口1中断为最低优先级中断(优先级0)
当PSH=0且PS=1时,串口1中断为较低优先级中断(优先级1)
当PSH=1且PS=0时,串口1中断为较高优先级中断(优先级2)
当PSH=1且PS=1时,串口1中断为最高优先级中断(优先级3)
PT1H, PT1:
.
d
e
t
i
m
定时器1中断优先级控制位。
当PT1H=0且PT1=0时,定时器1中断为最低优先级中断(优先级0)
当PT1H=0且PT1=1时,定时器1中断为较低优先级中断(优先级1)
当PT1H=1且PT1=0时,定时器1中断为较高优先级中断(优先级2)
当PT1H=1且PT1=1时,定时器1中断为最高优先级中断(优先级3)
U
C
M
Li
PX1H, PX1: 外部中断1优先级控制位。
当PX1H=0且PX1=0时,外部中断1为最低优先级中断(优先级0)
当PX1H=0且PX1=1时,外部中断1为较低优先级中断(优先级1)
当PX1H=1且PX1=0时,外部中断1为较高优先级中断(优先级2)
当PX1H=1且PX1=1时,外部中断1为最高优先级中断(优先级3)
PT0H, PT0:
C
T
S
定时器0中断优先级控制位。
当PT0H=0且PT0=0时,定时器0中断为最低优先级中断(优先级0)
当PT0H=0且PT0=1时,定时器0中断为较低优先级中断(优先级1)
当PT0H=1且PT0=0时,定时器0中断为较高优先级中断(优先级2)
当PT0H=1且PT0=1时,定时器0中断为最高优先级中断(优先级3)
PX0H, PX0: 外部中断0优先级控制位。
当PX0H=0且PX0=0时,外部中断0为最低优先级中断(优先级0)
当PX0H=0且PX0=1时,外部中断0为较低优先级中断(优先级1)
当PX0H=1且PX0=0时,外部中断0为较高优先级中断(优先级2)
当PX0H=1且PX0=1时,外部中断0为最高优先级中断(优先级3)
中断优先级控制寄存器IP和IPH的各位都由可用户程序置“1”和清“0”。但IP寄存器可
位操作,所以可用位操作指令或字节操作指令更新IP的内容。而IPH寄存器的内容只能用字节
操作指令来更新。STC90C58AD系列单片机复位后IP和IPH均为00H,各个中断源均为低优先
级中断。
150
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
3. 定时器/计数器控制寄存器TCON
TCON为定时器/计数器T0、T1的控制寄存器,同时也锁存T0、T1溢出中断源和外部请求
中断源等,TCON格式如下:
TCON : 定时器/计数器中断控制寄存器 (可位寻址)
SFR name
TCON
Address
88H
bit
name
B7
TF1
B6
TR1
B5
TF0
B4
TR0
B3
IE1
B2
IT1
B1
IE0
B0
IT0
TF1: T1溢出中断标志。T1被允许计数以后,从初值开始加1计数。当产生溢出时由硬件置
“1”TF1,向CPU请求中断,一直保持到CPU响应中断时,才由硬件清“0”(也可由
查询软件清“0”)。
TR1: 定时器1的运行控制位。
TF0:T0溢出中断标志。T0被允许计数以后,从初值开始加1计数,当产生溢出时,由硬件置
“1”TF0,向CPU请求中断,一直保持CPU响应该中断时,才由硬件清0(也可由查询
软件清0)。
TR0: 定时器0的运行控制位。
.
d
e
t
i
m
Li
IE1:外部中断1请求源(INT1/P3.3)标志。IE1=1,外部中断向CPU请求中断,当CPU响应该
中断时由硬件清“0”IE1。
U
C
M
IT1:外部中断1中断源类型选择位。IT1=0,INT1/P3.3引脚上的低电平信号可触发外部中断
1。IT1=1,外部中断1为下降沿触发方式。
C
T
S
IE0:外部中断0请求源(INT0/P3.2)标志。IE0=1外部中断0向CPU请求中断,当CPU响应外
部中断时,由硬件清“0”IE0(边沿触发方式)。
IT0:外部中断0中断源类型选择位。IT0=0,INT0/P3.2引脚上的低电平可触发外部中断0。
IT0=1,外部中断0为下降沿触发方式。
4. 串行口控制寄存器SCON
SCON为串行口控制寄存器,SCON格式如下:
SCON : 串行口控制寄存器 (可位寻址)
SFR name
SCON
Address
98H
bit
name
B7
SM0/FE
B6
SM1
B5
SM2
B4
REN
B3
TB8
B2
RB8
B1
TI
B0
RI
RI: 串行口1接收中断标志。若串行口1允许接收且以方式0工作,则每当接收到第8位数据时
置1;若以方式1、2、3工作且SM2=0时,则每当接收到停止位的中间时置1;当串行口以
方式2或方式3工作且SM2=1时,则仅当接收到的第9位数据RB8为1后,同时还要接收到停
止位的中间时置1。RI为1表示串行口1正向CPU申请中断(接收中断),RI必须由用户的中
断服务程序清零。
TI: 串行口1发送中断标志。串行口1以方式0发送时,每当发送完8位数据,由硬件置1;若以
方式1、方式2或方式3发送时,在发送停止位的开始时置1。TI=1表示串行口1正在向CPU
申请中断(发送中断)。值得注意的是,CPU响应发送中断请求,转向执行中断服务程序
时并不将TI清零,TI必须由用户在中断服务程序中清零。
SCON寄存器的其他位与中断无关,在此不作介绍。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
151
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
3. 定时器/计数器2控制寄存器T2CON
TCON为定时器/计数器T0、T1的控制寄存器,同时也锁存T0、T1溢出中断源和外部请求
中断源等,TCON格式如下:
TCON : 定时器/计数器中断控制寄存器 (可位寻址)
SFR name
T2CON
Address
C8H
bit
name
B7
TF2
B6
EXF2
B5
B4
B3
B2
RCLK TCLK EXEN2 TR2
B1
B0
C/T2 CP/RL2
TF2:�����������������������������������������������
定时器2 溢出标志。定时器2溢出时置位,必须由软件清除。当RCLK或TCLK=1 时,TF2
将不会置位
EXF2������������������������������������������������
:�����������������������������������������������
定时器2外部标志。当EXEN2=1且T2EX的负跳变产生捕获或重装时,EXF2置位。定时器2
中断使能时,EXF2=1将使CPU从中断向量处执行定时器2 中断子程序。EXF2位必须用软
件清零。在递增/递减计数器模式(DCEN=1)中,EXF2不会引起中断
RCLK�����������������������������������������
:����������������������������������������
接收时钟标志。RCLK置位时,定时器2的溢出脉冲作为串行口模式1和模式3的接收时
钟。RCLK=0时,将定时器1的溢出脉冲作为接收时钟
TCLK�����������������������������������������
:����������������������������������������
发送时钟标志。TCLK置位时,定时器2的溢出脉冲作为串行口模式1和模式3的发送时
钟。TCLK=0时,将定时器1的溢出脉冲作为发送时钟
EXEN2�����������������������������������������
:����������������������������������������
定时器2外部使能标志。当其置位且定时器2未作为串行口时钟时,允许T2EX的负跳变
产生捕获或重装。EXEN2=0 时,T2EX的跳变对定时器2无效
TR2����������������������
:���������������������
定时器2启动/停止控制位。置1时启动定时器
C
T
S
U
C
M
.
d
e
t
i
m
Li
C/T2:�����������������
定时器/ 计数器选择。(定时器2)
0= 内部定时器(OSC/12 或OSC/6)
1 = 外部事件计数器(下降沿触发)
CP/RL2:�������������������������������������������������
捕获/ 重装标志。置位:E XEN2=1 时,T2EX 的负跳变产生捕获。 清零:EXEN2=0
时,定时器2溢出或T2EX 的负跳变都可使定时器自动重装。当RCLK=1 或TCLK=1时,
该位无效且定时器强制为溢出时自动重装
152
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.3 中断优先级
STC90C58AD系列单片机的所有的中断都具有4个中断优先级,对于这些中断请求源可编
程为高优先级中断或低优先级中断,可实现两级中断服务程序嵌套。�����������
一个正在执行的低优先级
中断能被高优先级中断所中断,但不能被另一个低优先级中断所中断,一直执行到结束,遇到
返回指令RETI,返回主程序后再执行一条指令才能响应新的中断申请。以上所述可归纳为下
面两条基本规则:
⒈ 低优先级中断可被高优先级中断所中断,反之不能。
⒉ 任何一种中断(不管是高级还是低级),一旦得到响应,不会再被它的同级中断所中断
当同时收到几个同一优先级的中断要求时,哪一个要求得到服务,取决于内部的查询次
序。这相当于在每个优先级内,还同时存在另一个辅助优先级结构,STC90C58AD系列单片机
各中断优先查询次序如下:
0.
1.
2.
3.
4.
5.
中断源
INT0
Timer 0
INT1
Timer 1
UART
Timer 1
查询次序
(highest)
C
T
S
6.
INT2
7.
INT3
U
C
M
.
d
e
t
i
m
Li
(lowest)
如果使用C 语言编程,中断查询次序号就是中断号,例如:
void
Int0_Routine(void)
interrupt 0;
void
Timer0_Rountine(void)
interrupt 1;
void
Int1_Routine(void)
interrupt 2;
void
Timer1_Rountine(void)
interrupt 3;
void
UART_Routine(void)
interrupt 4;
void
Timer2_Routine(void)
interrupt 5;
void
Int2_Routine(void)
interrupt 6;
void
Int3_Routine(void)
interrupt 7;
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
153
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.4 中断处理
当某中断产生而且被CPU响应,主程序被中断,接下来将执行如下操作:
1. 当前正被执行的指令全部执行完毕;
2. PC值被压入栈;
3. 现场保护;
4. 阻止同级别其他中断;
5. 将中断向量地址装载到程序计数器PC;
6. 执行相应的中断服务程序。
中断服务程序ISR完成和该中断相应的一些操作。ISR以RETI(中断返回)指令结束,将PC值
从栈中取回,并恢复原来的中断设置,之后从主程序的断点处继续执行。
.
d
e
t
i
m
当某中断被响应时,被装载到程序计数器PC中的数值称为中断向量,是同该中断源相对应
的中断服务程序的起始地址。各中断源服务程序的入口地址(即中断向量)为:
C
T
S
Li
中断源
中断向量
External Interrupt 0
Timer 0
External Interrupt 1
Timer 1
UART
Timer 2
External Interrupt 2
External Interrupt 3
0003H
000BH
0013H
001BH
0023H
002BH
0033H
003BH
U
C
M
当“转去执行中断”时,引起中断的标志位将被硬件自动清零。由于中断向量入口地址位于
程序存储器的开始部分,所以主程序的第1条指令通常为跳转指令,越过中断向量区(LJMP
MAIN)。
注意:不能用RET指令代替RETI指令
RET指令虽然也能控制PC返回到原来中断的地方,但RET指令没有清零中断优先级状态触
发器的功能,中断控制系统会认为中断仍在进行,其后果是与此同级或低级的中断请求将不被
响应。
若用户在中断服务程序中进行了入栈操作,则在RETI指令执行前应进行相应的出栈操
作,即在中断服务程序中PUSH指令与POP指令必须成对使用,否则不能正确返回断点。
154
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.5 外部中断
外部中断0(INT0)、外部中断1(INT1)、外部中断2(INT2)和外部中断3( INT3)有两种触发方
式,下降沿触发方式和低电平触发方式。
请求四个外部中断的标志位是位于寄存器TCON中的IE0/TCON.1、IE1/TCON.3、IE2/XICON.2和IE3/XICON.5。当外部中断服务程序被响应后,中断请求标志位IE0、IE1、IE2和IE3
会自动被清0。TCON寄存器中的IT0/TCON.0、IT1/TCON.2、IT2/XICON.0和IT3/XICON.4决定
了外部中断0、1、2和3是低电平触发方式还是下降沿触发方式。如果ITx = 0(x = 0,1,2,3),那么
系统在INTx(x = 0,1,2,3)脚探测到低电平后可产生外部中断。如果ITx = 1(x = 0,1,2,3),那么系统
在INTx( x= 0,1,2,3)脚探测下降沿后可产生外部中断。外部中断0(INT0)、外部中断1(INT1)、外
部中断2(INT2)和外部中断3(INT3)还可以用于将单片机从掉电模式唤醒。
.
d
e
t
i
m
由于系统每个时钟对外部中断引脚采样1次,所以为了确保被检测到,输入信号应该至少
维持2个系统时钟。如果外部中断是仅下降沿触发,要求必须在相应的引脚维持高电平至少1个
系统时钟,而且低电平也要持续至少一个系统时钟,才能确保该下降沿被CPU检测到。同样,
如果外部中断是低电平可触发,则要求必须在相应的引脚维持低电平至少2个系统时钟,这样
才能确保CPU能够检测到该低电平信号。
C
T
S
南通国芯微电子有限公司
U
C
M
总机:0513-5501 2928 / 2929 / 2966
Li
传真:0513-5501 2969 / 2956 / 2947
155
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.6 中断测试程序
6.6.1 外部中断0(INT0)的测试程序(C程序及汇编程序)
1. 程序1——演示外部中断0的下降沿中断
C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断0�(下降沿) ---------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
//External interrupt0 service routine
void exint0() interrupt 0
{
P0++;
}
void main()
{
IT0 = 1;
EX0 = 1;
EA = 1;
C
T
S
U
C
M
.
d
e
t
i
m
Li
//INT0, interrupt 0 (location at 0003H)
//set INT0 interrupt type (1:Falling 0:Low level)
//enable INT0 interrupt
//open global interrupt switch
while (1);
}
156
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
汇编程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断0�(下降沿) --------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -------------------------------------------- --*/
/* 如果要在程序中使用或在文章中引用该程序, ----------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 ----------*/
/*------------------------------------------------------------------------------------*/
;----------------------------------------;interrupt vector table
ORG 0000H
LJMP MAIN
ORG 0003H
LJMP EXINT0
;----------------------------------------
MAIN:
ORG
C
T
S
0100H
MOV SP,
SETB IT0
SETB EX0
SETB EA
SJMP $
#7FH
U
C
M
.
d
e
t
i
m
Li
;INT0, interrupt 0 (location at 0003H)
;initial SP
;set INT0 interrupt type (1:Falling 0:Low level)
;enable INT0 interrupt
;open global interrupt switch
;----------------------------------------;External interrupt0 service routine
EXINT0:
CPL
RETI
P0.0
;----------------------------------------
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
157
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 程序2——演示外部中断0的下降沿中断唤醒掉电模式
C程序:
/*-------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ----------------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断0�(下降沿)唤醒掉电模式 ----*/
/* --- Mobile: (86)13922805190 ------------------------------------------------------*/
/* --- Fax: 86-755-82905966 ----------------------------------------------------------*/
/* --- Tel: 86-755-82948412 -----------------------------------------------------------*/
/* --- Web: www.STCMCU.com ------------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, ------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -------------------*/
/*---------------------------------------------------------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
//External interrupt0 service routine
void exint0( )
interrupt 0
{
}
void main()
{
IT0 = 1;
EX0 = 1;
EA = 1;
while (1)
{
}
U
C
M
.
d
e
t
i
m
Li
//INT0, interrupt 0 (location at 0003H)
C
T
S
//set INT0 interrupt type (1:Falling 0:Low level)
//enable INT0 interrupt
//open global interrupt switch
INT0 = 1;
while (!INT0);
_nop_();
_nop_();
PCON = 0x02;
_nop_();
_nop_();
P1++;
//ready read INT0 port
//check INT0
//MCU power down
}
158
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
汇编程序:
/*-------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ----------------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断0�(下降沿)唤醒掉电模式 -----*/
/* --- Mobile: (86)13922805190 -------------------------------------------------------*/
/* --- Fax: 86-755-82905966 ------------------------------------------------------------*/
/* --- Tel: 86-755-82948412 -------------------------------------------------------------*/
/* --- Web: www.STCMCU.com --------------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, ---------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 ---------------------*/
/*-----------------------------------------------------------------------------------------------*/
;----------------------------------------;interrupt vector table
ORG 0000H
LJMP MAIN
ORG 0003H
LJMP EXINT0
;----------------------------------------
MAIN:
LOOP:
ORG
0100H
MOV
SETB
SETB
SETB
SP,
IT0
EX0
EA
C
T
S
#7FH
SETB INT0
JNB INT0, $
NOP
NOP
MOV PCON, #02H
NOP
NOP
CPL P1.0
SJMP LOOP
.
d
e
t
i
m
Li
;INT0, interrupt 0 (location at 0003H)
U
C
M
;initial SP
;set INT0 interrupt type (1:Falling 0:Low level)
;enable INT0 interrupt
;open global interrupt switch
;ready read INT0 port
;check INT0
;MCU power down
;----------------------------------------;External interrupt0 service routine
EXINT0:
RETI
;----------------------------------------
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
159
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.6.2 外部中断1(INT1)的测试程序(C程序及汇编程序)
1. 程序1——演示外部中断1的下降沿中断
C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断1�(下降沿) ----------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
//External interrupt1 service routine
void exint1() interrupt 2
{
P0++;
}
void main()
{
IT1 = 1;
EX1 = 1;
EA = 1;
C
T
S
U
C
M
.
d
e
t
i
m
Li
//INT1, interrupt 2 (location at 0013H)
//set INT1 interrupt type (1:Falling only 0:Low level)
//enable INT1 interrupt
//open global interrupt switch
while (1);
}
160
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
汇编程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断1�(下降沿) ---------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
.
d
e
t
i
m
;----------------------------------------;interrupt vector table
ORG 0000H
LJMP MAIN
ORG 0013H
LJMP EXINT1
C
T
S
;----------------------------------------
MAIN:
ORG
0100H
MOV SP,
SETB IT1
SETB EX1
SETB EA
SJMP $
#7FH
U
C
M
Li
;INT1, interrupt 2 (location at 0013H)
;initial SP
;set INT1 interrupt type (1:Falling 0:Low level)
;enable INT1 interrupt
;open global interrupt switch
;----------------------------------------;External interrupt1 service routine
EXINT1:
CPL
RETI
P0.0
;----------------------------------------
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
161
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 程序2——演示外部中断1的下降沿中断唤醒掉电模式
C程序:
/*-------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断1�(下降沿)唤醒掉电模式 -----*/
/* --- Mobile: (86)13922805190 -------------------------------------------------------*/
/* --- Fax: 86-755-82905966 -----------------------------------------------------------*/
/* --- Tel: 86-755-82948412 ------------------------------------------------------------*/
/* --- Web: www.STCMCU.com -------------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -------------------*/
/*---------------------------------------------------------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
//External interrupt0 service routine
void exint1( ) interrupt 2
{
}
void main()
{
IT1 = 1;
EX1 = 1;
EA = 1;
while (1)
{
}
U
C
M
.
d
e
t
i
m
Li
//INT1, interrupt 2 (location at 0013H)
C
T
S
//set INT1 interrupt type (1:Falling 0:Low level)
//enable INT1 interrupt
//open global interrupt switch
INT1 = 1;
while (!INT1);
_nop_();
_nop_();
PCON = 0x02;
_nop_();
_nop_();
P1++;
//ready read INT1 port
//check INT1
//MCU power down
}
162
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
汇编程序:
/*--------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断1�(下降沿)唤醒掉电模式 -----*/
/* --- Mobile: (86)13922805190 -------------------------------------------------------*/
/* --- Fax: 86-755-82905966 -----------------------------------------------------------*/
/* --- Tel: 86-755-82948412 ------------------------------------------------------------*/
/* --- Web: www.STCMCU.com -------------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -------------------*/
/*---------------------------------------------------------------------------------------------*/
;----------------------------------------;interrupt vector table
ORG 0000H
LJMP MAIN
ORG 0013H
LJMP EXINT1
ORG
0100H
MOV
SETB
SETB
SETB
SP,#7FH
IT1
EX1
EA
Li
;INT1, interrupt 2 (location at 0013H)
;----------------------------------------
MAIN:
LOOP:
.
d
e
t
i
m
C
T
S
U
C
M
;initial SP
;set INT1 interrupt type (1:Falling 0:Low level)
;enable INT1 interrupt
;open global interrupt switch
SETB INT1
JNB INT1,$
NOP
NOP
MOV PCON,#02H
NOP
NOP
CPL P1.0
SJMP LOOP
;ready read INT1 port
;check INT1
;MCU power down
;----------------------------------------;External interrupt1 service routine
EXINT1:
RETI
;----------------------------------------
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
163
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.6.3 外部中断2(INT2)的测试程序(C程序及汇编程序)
1. 程序1——演示外部中断2的下降沿中断
C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断2�(下降沿) ---------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
sfr P4 = 0xc0;
sbit INT2 = P4^3;
sbit INT3 = P4^2;
//for 89-90 series, location at 0E8H
sfr XICON = 0xe8;
sbit PX3 = XICON^7;
sbit EX3 = XICON^6;
sbit IE3 = XICON^5;
sbit IT3 = XICON^4;
sbit PX2 = XICON^3;
sbit EX2 = XICON^2;
sbit IE2 = XICON^1;
sbit IT2 = XICON^0;
U
C
M
.
d
e
t
i
m
Li
//for 89-90 series, location at 0C0H
C
T
S
//External interrupt2 service routine
void exint2() interrupt 6
//INT2, interrupt 6 (location at 0033H)
{
P0++;
}
void main()
{
IT2 = 1;
EX2 = 1;
EA = 1;
//set INT2 interrupt type (1:Falling only 0:Low level)
//enable INT2 interrupt
//open global interrupt switch
while (1);
}
164
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
汇编程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断2�(下降沿) -----------------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
P4
EQU 0C0H
;for 89-90 series, location at 0E8H
INT2 BIT P4.3
INT3 BIT P4.2
XICON EQU 0E8H
PX3 BIT XICON.7
EX3 BIT XICON.6
IE3 BIT XICON.5
IT3 BIT XICON.4
PX2 BIT XICON.3
EX2 BIT XICON.2
IE2 BIT XICON.1
IT2 BIT XICON.0
;----------------------------------------;interrupt vector table
C
T
S
.
d
e
t
i
m
;for 89-90 series, location at 0C0H
U
C
M
Li
ORG 0000H
LJMP MAIN
ORG 0033H
LJMP EXINT2
;----------------------------------------
ORG 0100H
MAIN:
MOV SP,#7FH
SETB IT2
SETB EX2
SETB EA
SJMP $
;----------------------------------------;External interrupt2 service routine
EXINT2:
CPL P0.0
RETI
;----------------------------------------
END
南通国芯微电子有限公司
;INT2, interrupt 6 (location at 0033H)
;initial SP
;set INT2 interrupt type (1:Falling 0:Low level)
;enable INT2 interrupt
;open global interrupt switch
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
165
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 程序2——演示外部中断2的下降沿中断唤醒掉电模式
C程序:
/*-------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断2�(下降沿)唤醒掉电模式 -----*/
/* --- Mobile: (86)13922805190 -------------------------------------------------------*/
/* --- Fax: 86-755-82905966 ------------------------------------------------------------*/
/* --- Tel: 86-755-82948412 -------------------------------------------------------------*/
/* --- Web: www.STCMCU.com --------------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, ---------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 ---------------------*/
/*-----------------------------------------------------------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
sfr P4 = 0xc0;
sbit INT2 = P4^3;
sbit INT3 = P4^2;
sfr XICON
sbit PX3
sbit EX3
sbit IE3
sbit IT3
sbit PX2
sbit EX2
sbit IE2
sbit IT2
C
T
S
//External interrupt2 service routine
void exint2() interrupt 6
{
}
166
南通国芯微电子有限公司
Li
//for 89-90 series, location at 0E8H
= 0xe8;
= XICON^7;
= XICON^6;
= XICON^5;
= XICON^4;
= XICON^3;
= XICON^2;
= XICON^1;
= XICON^0;
void main()
{
IT2 = 1;
EX2 = 1;
EA = 1;
.
d
e
t
i
m
U
C
M
//for 89-90 series, location at 0C0H
//INT2, interrupt 6 (location at 0033H)
//set INT2 interrupt type (1:Falling 0:Low level)
//enable INT2 interrupt
//open global interrupt switch
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
while (1)
{
}
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
INT2 = 1;
while (!INT2);
_nop_();
_nop_();
PCON = 0x02;
_nop_();
_nop_();
P1++;
//ready read INT2 port
//check INT2
//MCU power down
}
.
d
e
t
i
m
汇编程序:
/*-------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断2�(下降沿)唤醒掉电模式 -----*/
/* --- Mobile: (86)13922805190 -------------------------------------------------------*/
/* --- Fax: 86-755-82905966 ------------------------------------------------------------*/
/* --- Tel: 86-755-82948412 -------------------------------------------------------------*/
/* --- Web: www.STCMCU.com --------------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, ---------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 ---------------------*/
/*-----------------------------------------------------------------------------------------------*/
C
T
S
U
C
M
Li
P4
EQU 0C0H
INT2 BIT P4.3
INT3 BIT P4.2
;for 89-90 series, location at 0E8H
XICON
PX3
EX3
IE3
IT3
PX2
EX2
IE2
IT2
;for 89-90 series, location at 0C0H
EQU
BIT
BIT
BIT
BIT
BIT
BIT
BIT
BIT
0E8H
XICON.7
XICON.6
XICON.5
XICON.4
XICON.3
XICON.2
XICON.1
XICON.0
;----------------------------------------;interrupt vector table
ORG 0000H
LJMP MAIN
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
167
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
ORG 0033H
LJMP EXINT2
;----------------------------------------
MAIN:
LOOP:
ORG
0100H
MOV
SETB
SETB
SETB
SP,
IT2
EX2
EA
;initial SP
;set INT2 interrupt type (1:Falling 0:Low level)
;enable INT2 interrupt
;open global interrupt switch
SETB INT2
JNB INT2, $
NOP
NOP
MOV PCON, #02H
NOP
NOP
CPL P1.0
SJMP LOOP
EXINT2:
RETI
C
T
S
研发顾问:13922809991
;INT2, interrupt 6 (location at 0033H)
#7FH
;----------------------------------------;External interrupt2 service routine
临时技术支持:13922829991
;ready read INT2 port
;check INT2
;MCU power down
U
C
M
.
d
e
t
i
m
Li
;----------------------------------------
168
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
6.6.3 外部中断3(INT3)的测试程序(C程序及汇编程序)
1. 程序1——演示外部中断3的下降沿中断
C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断3�(下降沿) ---------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
sfr P4 = 0xc0;
sbit INT2 = P4^3;
sbit INT3 = P4^2;
sfr XICON = 0xe8;
sbit PX3 = XICON^7;
sbit EX3 = XICON^6;
sbit IE3 = XICON^5;
sbit IT3 = XICON^4;
sbit PX2 = XICON^3;
sbit EX2 = XICON^2;
sbit IE2 = XICON^1;
sbit IT2 = XICON^0;
Li
//for 89-90 series, location at 0E8H
C
T
S
U
C
M
.
d
e
t
i
m
//for 89-90 series, location at 0C0H
//External interrupt3 service routine
void exint3() interrupt 7
//INT3, interrupt 7 (location at 003BH)
{
P0++;
}
void main()
{
IT3 = 1;
EX3 = 1;
EA = 1;
//set INT3 interrupt type (1:Falling only 0:Low level)
//enable INT3 interrupt
//open global interrupt switch
while (1);
}
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
169
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
汇编程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断3�(下降沿) ---------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
P4
EQU 0C0H
;for 89-90 series, location at 0E8H
INT2 BIT P4.3
INT3 BIT P4.2
XICON EQU 0E8H
;for 89-90 series, location at 0C0H
PX3 BIT XICON.7
EX3 BIT XICON.6
IE3 BIT XICON.5
IT3 BIT XICON.4
PX2 BIT XICON.3
EX2 BIT XICON.2
IE2 BIT XICON.1
IT2 BIT XICON.0
;----------------------------------------;interrupt vector table
U
C
M
C
T
S
ORG 0000H
LJMP MAIN
ORG 003BH
LJMP EXINT3
.
d
e
t
i
m
Li
;INT3, interrupt 7 (location at 003BH)
;----------------------------------------
ORG 0100H
MAIN:
MOV SP,#7FH
SETB IT3
SETB EX3
SETB EA
SJMP $
;----------------------------------------;External interrupt3 service routine
;initial SP
;set INT3 interrupt type (1:Falling 0:Low level)
;enable INT3 interrupt
;open global interrupt switch
EXINT3:
CPL P0.0
RETI
;----------------------------------------
END
170
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 程序2——演示外部中断3的下降沿中断唤醒掉电模式
C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断3�(下降沿)唤醒掉电模式 -----*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
sfr P4 = 0xc0;
sbit INT2 = P4^3;
sbit INT3 = P4^2;
//for 89-90 series, location at 0E8H
sfr XICON = 0xe8;
sbit PX3 = XICON^7;
sbit EX3
= XICON^6;
sbit IE3
= XICON^5;
sbit IT3
= XICON^4;
sbit PX2 = XICON^3;
sbit EX2 = XICON^2;
sbit IE2
= XICON^1;
sbit IT2 = XICON^0;
U
C
M
.
d
e
t
i
m
Li
//for 89-90 series, location at 0C0H
C
T
S
//External interrupt3 service routine
void exint3() interrupt 7
{
}
//INT3, interrupt 7 (location at 003BH)
void main()
{
IT3 = 1;
EX3 = 1;
EA = 1;
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
//set INT3 interrupt type (1:Falling 0:Low level)
//enable INT3 interrupt
//open global interrupt switch
传真:0513-5501 2969 / 2956 / 2947
171
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
while (1)
{
INT3 = 1;
}
while (!INT3);
_nop_();
_nop_();
PCON = 0x02;
_nop_();
_nop_();
P1++;
临时技术支持:13922829991
研发顾问:13922809991
//ready read INT3 port
//check INT3
//MCU power down
}
汇编程序:
.
d
e
t
i
m
Li
/*--------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------------------*/
/* --- 演示STC90C58AD系列单片机外部中断3�(下降沿)唤醒掉电模式 -----*/
/* --- Mobile: (86)13922805190 -------------------------------------------------------*/
/* --- Fax: 86-755-82905966 -----------------------------------------------------------*/
/* --- Tel: 86-755-82948412 ------------------------------------------------------------*/
/* --- Web: www.STCMCU.com -------------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -------------------*/
/*---------------------------------------------------------------------------------------------*/
P4
EQU 0C0H
;for 89-90 series, location at 0E8H
INT2 BIT P4.3
INT3 BIT P4.2
C
T
S
XICON
PX3
EX3
IE3
IT3
PX2
EX2
IE2
IT2
EQU
BIT
BIT
BIT
BIT
BIT
BIT
BIT
BIT
0E8H
XICON.7
XICON.6
XICON.5
XICON.4
XICON.3
XICON.2
XICON.1
XICON.0
U
C
M
;for 89-90 series, location at 0C0H
;----------------------------------------;interrupt vector table
172
ORG 0000H
LJMP MAIN
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
ORG 003BH
LJMP EXINT3
临时技术支持:13922829991
研发顾问:13922809991
;INT3, interrupt 7 (location at 003BH)
;----------------------------------------
MAIN:
LOOP:
ORG
0100H
MOV
SETB
SETB
SETB
SP,
IT3
EX3
EA
#7FH
SETB INT3
JNB INT3, $
NOP
NOP
MOV PCON,#02H
NOP
NOP
CPL P1.0
SJMP LOOP
;initial SP
;set INT3 interrupt type (1:Falling 0:Low level)
;enable INT3 interrupt
;open global interrupt switch
;ready read INT3 port
;check INT3
;MCU power down
C
T
S
;----------------------------------------;External interrupt3 service routine
EXINT3:
RETI
U
C
M
.
d
e
t
i
m
Li
;----------------------------------------
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
173
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
第7章 定时器/计数器
7.1 定时器/计数器0/1
STC90C58AD系列����������������������������������
单片机的定时器0和定时器1,与传统8051的定时器完全兼容,当在定时
器1做波特率发生器时,定时器0可以当两个8位定时器用。
STC90C58AD系列����������������������������������
单片机内部设置的两个16位定时器/计数器T0和T1都具有计数方式和定
时方式两种工作方式。对每个定时器/计数器(T0和T1),在特殊功能寄存器TMOD中都有一控制
位— C/T来选择T0或T1为定时器还是计数器。定时器/计数器的核心部件是一个加法(也有减
法)的计数器,其本质是对脉冲进行计数。只是计数脉冲来源不同:如果计数脉冲来自系统时
钟,则为定时方式,此时定时器/计数器每12个时钟或者每6个时钟得到一个计数脉冲,计数值
加1;如果计数脉冲来自单片机外部引脚(T0为P3.4,T1为P3.5),则为计数方式,每来一个脉冲
加1。
.
d
e
t
i
m
Li
当定时器/计数器工作在定时模式时,可在烧录用户程序时在STC-ISP编程器中设置(如下
图所示)是系统时钟/12还是系统时钟/6后让T0和T1进行计数。当定时器/计数器工作在计数模
式时,对外部脉冲计数不分频。
U
C
M
C
T
S
定时器/计数器0有4种工作模式:模式0(13位定时器/计数器),模式1(16位定时器/计数器
模式),模式2(8位自动重装模式),模式3(两个8位定时器/计数器)。定时器/计数器1除模式3
外,其他工作模式与定时器/计数器0相同,T1在模式3时无效,停止计数。
7.1.1 定时器/计数器0和1的相关寄存器
符号
描述
地址
TCON
定时器控制寄存器 88H
TMOD
TL0
TL1
TH0
TH1
定时器模式寄存器
Timer Low 0
Timer Low 1
Timer High 0
Timer High 1
174
南通国芯微电子有限公司
89H
8AH
8BH
8CH
8DH
位地址及其符号
MSB
LSB
复位值
TF1
TR1
TF0
TR0
IE1
IT1
IE0
IT0
0000 0000B
GATE
C/T
M1
M0
GATE
C/T
M1
M0
0000 0000B
0000 0000B
0000 0000B
0000 0000B
0000 0000B
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
1. 定时器/计数器控制寄存器TCON
TCON为定时器/计数器T0、T1的控制寄存器,同时也锁存T0、T1溢出中断源和外部请求
中断源等,TCON格式如下:
TCON : 定时器/计数器中断控制寄存器 (可位寻址)
SFR name
TCON
Address
88H
bit
name
B7
TF1
B6
TR1
B5
TF0
B4
TR0
B3
IE1
B2
IT1
B1
IE0
B0
IT0
TF1: 定时器/计数器T1溢出标志。T1被允许计数以后,从初值开始加1计数。当最高位产生溢
出时由硬件置“1”TF1,向CPU请求中断,一直保持到CPU响应中断时,才由硬件清
“0”TF1(TF1也可由程序查询清“0”)。
TR1: 定时器T1的运行控制位。该位由软件置位和清零。当GATE(TMOD.7)=0,TR1=1时就
允许T1开始计数,TR1=0时禁止T1计数。当GATE(TMOD.7)=1,TR1=1且INT1 输入
高电平时,才允许T1计数。
.
d
e
t
i
m
TF0:定时器/计数器T0溢出中断标志。T0被允许计数以后,从初值开始加1计数,当最高位产
生溢出时,由硬件置“1”TF0,向CPU请求中断,一直保持CPU响应该中断时,才由硬
件清“0”TF0( TF0也可由程序查询清“0”)。
U
C
M
Li
TR0: 定时器T0的运行控制位。该位由软件置位和清零。当GATE(TMOD.3)=0,TR0=1时就
允许T0开始计数,TR0=0时禁止T0计数。当GATE(TMOD.3)=1,TR1=0且INT0 输入
高电平时,才允许T0计数。
C
T
S
IE1:外部中断1请求源(INT1 /P3.3)标志。IE1=1,外部中断向CPU请求中断,当CPU响应该
中断时由硬件清“0”IE1。
IT1:外部中断1触发方式控制位。IT1=0时,外部中断1为低电平触发方式,当INT1(P3.3)
输入低电平时,置位IE1 。采用低电平触发方式时,外部中断源(输入到INT1)必须保
持低电平有效,直到该中断被CPU 响应,同时在该中断服务程序执行完之前,外部中断
源必须被清除(P3.3要变高),否则将产生另一次中断。当IT1=1时,则外部中断1(INT1 )
端口由“1”→“0”下降沿跳变,激活中断请求标志位IE1 ,向主机请求中断处理。
IE0:外部中断0请求源(INT0/P3.2)标志。IE0=1外部中断0向CPU请求中断,当CPU响应外
部中断时,由硬件清“0”IE0(边沿触发方式)。
IT0:外部中断0触发方式控制位。IT0=0时,外部中断0为低电平触发方式,当INT0(P3.2)
输入低电平时,置位IE0。采用低电平触发方式时,外部中断源(输入到INT0)必须保
持低电平有效,直到该中断被CPU响应,同时在该中断服务程序执行完之前,外部中断源
必须被清除(P3.2要变高),否则将产生另一次中断。当IT0=1时,则外部中断0�(INT0)
端口由“1”→“0”下降沿跳变,激活中断请求标志位IE1 ,向主机请求中断处理。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
175
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 定时器�����������
/����������
计数器工作模式寄存器TMOD
定时和计数功能由特殊功能寄存器TMOD的控制位C/T进行选择,TMOD寄存器的各位信
息如下表所列。可以看出,2个定时/计数器有4种操作模式,通过TMOD的M1和M0选择。2个
定时/计数器的模式0、1和2都相同,模式3不同,各模式下的功能如下所述。
寄存器TMOD各位的功能描述
TMOD 地址:89H
不可位寻址
7
复位值:00H
6
GATE
5
C/T
M1
4
3
M0
GATE
TMOD.7/
TMOD.3/
GATE
TMOD.3控制定时器0,置1时只有在INT0脚为高及TR0控制位置1
时才可打开定时器/计数器0。
C
T
S
TMOD.2/
C/T
0
0
0
1
1
0
1
1
TMOD.1/TMOD.0 M1、M0
0
176
0
0
1
1
0
1
1
U
C
M
Li
TMOD.6控制定时器1用作定时器或计数器,清零则用作定时器
(从内部系统时钟输入),置1用作计数器(从T1/P3.5脚输入)
TMOD.2控制定时器0用作定时器或计数器,清零则用作定时器
(从内部系统时钟输入),置1用作计数器(从T0/P3.4脚输入)
TMOD.5/TMOD.4 M1、M0
.
d
e
t
i
m
功能
TMOD.7控制定时器1,置1时只有在INT1脚为高及TR1控制位置1
时才可打开定时器/计数器1。
C/T
M0
符号
GATE
TMOD.6/
M1
C/T
0
定时器0
定时器1
位
2 1
南通国芯微电子有限公司
定时器定时器/计数器1模式选择
13位定时器/计数器,兼容8048定时模式,TL1只用低5位参与
分频,TH1整个8位全用。
16位定时器/计数器,TL1、TH1全用
8位自动重装载定时器,当溢出时将TH1存放的值自动重装入TL1.
定时器/计数器1此时无效(停止计数)。
定时器/计数器0模式选择
13位定时器/计数器,兼容8048定时模式,TL0只用低5位参与
分频,TH0整个8位全用。
16位定时器/计数器,TL0、TH0全用
8位自动重装载定时器,当溢出时将TH0存放的值自动重装入TL0
定时器0此时作为双8位定时器/计数器。TL0作为一个8位定时
器/计数器,通过标准定时器0的控制位控制。TH0仅作为一个
8位定时器,由定时器1的控制位控制。
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.2 定时器/计数器0工作模式(与传统8051单片机兼容)
通过对寄存器TMOD中的M1(TMOD.1)、M0(TMOD.0)的设置,定时器/计数器0有4种不同的
工作模式
7.1.2.1 模式0(13位定时器/计数器)
将定时器设置成模式0时类似8048定时器,即8位计数器带32分频的预分频器。下图所示
为��������������������������������������������
定时器�����������������������������������������
/����������������������������������������
计数器的������������������������������������
模式0工作方式。此模式下,定时器0配置为13位的计数器,由TL0的低5位
和TH0的8位所构成。TL0低5位溢出向TH0进位,TH0计数溢出置位TCON中的溢出标志位TF0。
GATE(TMOD.3)=0 时,如TR0=1,则定时器计数。GATE=1 时,允许由外部输入INT1控制定时器
1,INT0控制定时器0,这样可实现脉宽测量。TR0为TCON寄存器内的控制位,TCON寄存器各位
的具体功能描述见TCON寄存器各位的具体功能描述表。
.
d
e
t
i
m
在模式0下定时器������������������������
/�����������������������
计数器��������������������
0�������������������
作为�����������������
13���������������
位定时器/计数器,如下图所示。
MCU in 12T mode
÷12
SYSclk
÷6
MCU in 6T mode
T0 Pin
C
T
S
GATE
INT0
U
C
M
C/T=0
C/T=1
TR0
Li
TL0
(5 bits)
TH0
(8 bits)
TF0
Interrupt
control
定时器/计数器0的模式 0: 13位定时器/计数器
当C/T=0时,多路开关连接到系统时钟的分频输出,T0对时钟周期计数,T0工作在定时方
式。当C/T=1时,多路开关连接到外部脉冲输入P3.4/T0,即T0工作在计数方式。
STC90C58AD�������������������������������������
系列单片机的定时器有两种计数速率:一种是�����������������
12T��������������
模式,每����������
12��������
个时钟加����
1���
,与传
统�����������������������������������������������
8051�������������������������������������������
单片机相同;另外一种是��������������������������������
6T������������������������������
模式,每6个时钟加���������������������
1��������������������
,速度是传统��������������
8051����������
单片机的������
2�����
倍。���
T0�
的
速率在烧录用户程序时在STC-ISP编程器中设置。
该���������������������������������������������
模式下的�����������������������������������������
13位寄存器包含TH0全部8个位及TL0的低5位。TL0的高3位不定,可将其忽略。
置位运行标志(TR0)不能清零此寄存器。模式0的操作对于定时器0及定时器1都是相同的。2
个不同的GATE位(TMOD.7和TMOD.3)分别分配给定时器1及定时器0。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
177
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.2.2 模式1(16位定时器/计数器)及其测试程序(C程序及汇编程序)
模式1除了使用了TH0及TL0全部16位外,其他与模式0完全相同。�
即此模式下定时器���
/��
计数
器��������������������
0�������������������
作为�����������������
16���������������
位定时器/计数器,如下图所示。
÷12
MCU in 12T mode
SYSclk
÷6
MCU in 6T mode
C/T=0
C/T=1
T0 Pin
TR0
TL0
TH0
(8 Bits) (8 bits)
TF0
Interrupt
control
GATE
.
d
e
t
i
m
INT0
定时器/计数器0的模式 1: 16位定时器/计数器
Li
此模式下,定时器配置为�����������������������������������
16���������������������������������
位定时器/计数器,由�����������������������
TL0��������������������
的�������������������
8������������������
位和����������������
TH0�������������
的������������
8�����������
位所构成。������
TL0���
的8位
溢出向������������������������������
TH0���������������������������
进位,������������������������
TH0���������������������
计数溢出置位���������������
TCON�����������
中的溢出标志位����
TF0�
。
U
C
M
当�������
GATE=0(TMOD.3)时,如TR0=1,则定时器计数。GATE=1时,允许由外部输入INT0控制定
时器0,这样可实现脉宽测量。TR0为TCON寄存器内的控制位,TCON寄存器各位的具体功能描述
见上节�����������
TCON寄存器����
的介绍�
。
C
T
S
当C/T=0时,多路开关连接到系统时钟的分频输出,T0对时钟周期计数,T0工作在定时方
式。当C/T=1时,多路开关连接到外部脉冲输入P3.4/T0,即T0工作在计数方式。
STC90C58AD系列单片机的定时器有两种计数速率:一种是����������������
12T�������������
模式,每���������
12�������
个时钟加���
1��
,与
传统����������������������������������������������
8051������������������������������������������
单片机相同;另外一种是�������������������������������
6T�����������������������������
模式,每6个时钟加��������������������
1�������������������
,速度是传统�������������
8051���������
单片机的�����
2����
倍。��
T0
的速率在烧录用户程序时在STC-ISP编程器中设置。
178
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
定时器0工作在16位定时器/计数器模式的测试程序
1. C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机定时器0的16位定时器/计数器模式 --*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
typedef unsigned char BYTE;
typedef unsigned int WORD;
//----------------------------------------------/* define constants */
#define FOSC 18432000L
U
C
M
.
d
e
t
i
m
Li
#define T1MS (65536-FOSC/12/1000)
//1ms timer calculation method in 12T mode
/* define SFR */
sbit TEST_LED = P1^0;
//work LED, flash once per second
/* define variables */
WORD count;
C
T
S
//1000 times counter
//----------------------------------------------/* Timer0 interrupt routine */
void tm0_isr() interrupt 1 using 1
{
TL0 = T1MS;
TH0 = T1MS >> 8;
if (count-- == 0)
{
count = 1000;
TEST_LED = ! TEST_LED;
}
}
//reload timer0 low byte
//reload timer0 high byte
//1ms * 1000 -> 1s
//reset counter
//work LED flash
//-----------------------------------------------
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
179
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
/* main program */
void main()
{
TMOD = 0x01;
TL0 = T1MS;
TH0 = T1MS >> 8;
TR0 = 1;
ET0 = 1;
EA = 1;
count = 0;
}
while (1);
临时技术支持:13922829991
//set timer0 as mode1 (16-bit)
//initial timer0 low byte
//initial timer0 high byte
//timer0 start running
//enable timer0 interrupt
//open global interrupt switch
//initial counter
//loop
2. 汇编程序:
研发顾问:13922809991
.
d
e
t
i
m
Li
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机定时器0的16位定时器/计数器模式 ---*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
;/* define constants */
T1MS
EQU 0FA00H
;1ms timer calculation method in 12T mode is (65536-18432000/12/1000)
C
T
S
;/* define SFR */
TEST_LED BIT P1.0
;/* define variables */
COUNT DATA 20H
U
C
M
;work LED, flash once per second
;1000 times counter (2 bytes)
;----------------------------------------------
ORG
LJMP
ORG
LJMP
0000H
MAIN
000BH
TM0_ISR
;-----------------------------------------------
180
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
;/* main program */
MAIN:
MOV TMOD,#01H
MOV TL0,#LOW T1MS
MOV TH0,#HIGH T1MS
SETB TR0
SETB ET0
SETB EA
CLR A
MOV COUNT,A
MOV COUNT+1,A
SJMP $
临时技术支持:13922829991
;set timer0 as mode1 (16-bit)
;initial timer0 low byte
;initial timer0 high byte
;timer0 start running
;enable timer0 interrupt
;open global interrupt switch
;initial counter
.
d
e
t
i
m
;----------------------------------------------;/* Timer0 interrupt routine */
TM0_ISR:
PUSH ACC
PUSH PSW
MOV TL0,
#LOW T1MS
MOV TH0,
#HIGH T1MS
MOV A,
COUNT
ORL A,
COUNT+1
JNZ SKIP
MOV COUNT, #LOW 1000
MOV COUNT+1,
#HIGH 1000
CPL TEST_LED
SKIP:
CLR C
MOV A,
COUNT
SUBB A,
#1
MOV COUNT, A
MOV A,
COUNT+1
SUBB A,
#0
MOV COUNT+1,A
POP PSW
POP ACC
RETI
C
T
S
研发顾问:13922809991
U
C
M
Li
;reload timer0 low byte
;reload timer0 high byte
;check whether count(2byte) is equal to 0
;1ms * 1000 -> 1s
;work LED flash
;count--
;----------------------------------------------
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
181
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.2.3 模式2(8位自动重装模式)及其测试程序(C程序及汇编程序)
此模式下定时器��������������������������
/�������������������������
计数器����������������������
0���������������������
作为可自动重装载的������������
8�����������
位计数器,如下图所示。
MCU in 12T mode
÷12
SYSclk
÷6
MCU in 6T mode
C/T=0
TL0
(8 Bits)
C/T=1
T0 Pin
TF0
Interrupt
control
TR0
GATE
TH0
(8 Bits)
INT0
.
d
e
t
i
m
定时器/计数器0的模式 2: 8位自动重装
Li
TL0���������������������������������������������
的溢出不仅置位��������������������������������������
TF0�����������������������������������
,而且将�������������������������������
TH0����������������������������
内容重新装入����������������������
TL0�������������������
,������������������
TH0���������������
内容由软件预置,重装时����
TH0�
内
容不变。
U
C
M
;定时器0中断的测试程序,定时器0工作在8位自动重装模式
1. C程序:
C
T
S
/*---------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ------------------------------------*/
/* --- STC89-90xx Series MCU T0(Falling edge) Demo ---------------*/
/* --- Mobile: (86)13922805190 -------------------------------------------*/
/* --- Fax: 86-755-82905966 -----------------------------------------------*/
/* --- Tel: 86-755-82948412 -----------------------------------------------*/
/* --- Web: www.STCMCU.com ------------------------------------------*/
/* If you want to use the program or the program referenced in the */
/* article, please specify in which data and procedures from STC */
/*------------------------------------------------------------------------------*/
#include "reg51.h"
sfr AUXR = 0x8e;
//Auxiliary register
//T0 interrupt service routine
void t0int() interrupt 1
//T0 interrupt (location at 000BH)
{
P0++;
}
182
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
void main()
{
AUXR = 0x80;
TMOD = 0x06;
TL0 = TH0 = 0xff;
TR0 = 1;
ET0 = 1;
EA = 1;
临时技术支持:13922829991
研发顾问:13922809991
//timer0 work in 1T mode
//set timer0 as counter mode2 (8-bit auto-reload)
//fill with 0xff to count one time
//timer0 start run
//enable T0 interrupt
//open global interrupt switch
while (1);
}
2. 汇编程序:
U
C
M
Li
;/*----------------------------------------------------------------------------------*/
;/* --- STC MCU International Limited -------------------------------------*/
;/* --- STC89-90xx Series MCU T0(Falling edge) Demo -----------------*/
;/* --- Mobile: (86)13922805190 ---------------------------------------------*/
;/* --- Fax: 86-755-82905966 -------------------------------------------------*/
;/* --- Tel: 86-755-82948412 --------------------------------------------------*/
;/* --- Web: www.STCMCU.com ---------------------------------------------*/
;/* If you want to use the program or the program referenced in the ---*/
;/* article, please specify in which data and procedures from STC ----*/
;/*----------------------------------------------------------------------------------*/
C
T
S
AUXR
DATA 08EH
.
d
e
t
i
m
;Auxiliary register
;----------------------------------------;interrupt vector table
ORG 0000H
LJMP MAIN
ORG 000BH
LJMP T0INT
;T0 interrupt (location at 000BH)
;----------------------------------------ORG
0100H
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
183
STC90C58AD系列单片机指南
MAIN:
MOV SP,
MOV AUXR,
MOV TMOD,
MOV A,
MOV TL0,
MOV TH0,
SETB TR0
SETB ET0
SETB EA
SJMP $
技术支持网站:www.STCMCU.com
#7FH
#80H
#06H
#0FFH
A
A
临时技术支持:13922829991
;initial SP
;timer0 work in 1T mode
;set timer0 as counter mode2 (8-bit auto-reload)
;fill with 0xff to count one time
;timer0 start run
;enable T0 interrupt
;open global interrupt switch
;----------------------------------------;T0 interrupt service routine
T0INT:
CPL P0.0
RETI
;----------------------------------------
184
END
C
T
S
南通国芯微电子有限公司
研发顾问:13922809991
U
C
M
.
d
e
t
i
m
Li
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.2.4 模式3(两个8位计数器)
对定时器1,在模式3时,定时器1停止计数,效果与将TR1设置为0相同。
对定时器0,此模式下定时器0的TL0及TH0作为2个独立的8位计数器。下图为模式3时的定
时器0逻辑图。TL0占用定时器0的控制位:C/T、GATE、TR0、INT0及TF0。TH0限定为定时器功
能(计数器周期),占用定时器1的TR1及TF1。此时,TH0控制定时器1中断。
模式���������������������������������������
3��������������������������������������
是为了增加一个附加的����������������������������
8���������������������������
位定时器�����������������������
/����������������������
计数器而提供的,使单片机具有三个定时器���
/��
计数
器。模式�������������������������������������������
3������������������������������������������
只适用于定时器�����������������������������������
/����������������������������������
计数器�������������������������������
0������������������������������
,定时器��������������������������
T1������������������������
处于模式��������������������
3�������������������
时相当于���������������
TR1=0����������
,停止计数,而���
T0�
可
作为两个定时器用。
÷12
MCU in 12T mode
.
d
e
t
i
m
SYSclk
÷6
MCU in 6T mode
TL0
(8 bit)
C/T=1
T0 Pin
TR0
GATE
INT0
÷12
SYSclk
C/T=0
U
C
M
Li
Interrupt
MCU in 12T mode
C
T
S
÷6
control
TF0
MCU in 6T mode
TR1
TH0
(8 Bits)
TF1
Interrupt
control
定时/计数器0 模式3: 两个8位计数器
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
185
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.3 定时器/计数器1工作模式(与传统8051单片机兼容)
通过对寄存器TMOD中的M1(TMOD.5)、M0(TMOD.4)的设置,定时器/计数器1有3种不同的
工作模式。
7.1.3.1 模式0(13位定时器/计数器)
此模式下定时器��������������������������������������
/�������������������������������������
计数器����������������������������������
1���������������������������������
作为�������������������������������
13�����������������������������
位定时器/计数器,有�������������������
TL1����������������
的低��������������
5�������������
位和�����������
TH1��������
的�������
8������
位所构成,如
下图所示。模式0的操作对于定时器1����������
和���������
定时器0是相同的。
MCU in 12T mode
÷12
SYSclk
÷6
MCU in 6T mode
C/T=0
TH1
(8 bits)
C/T=1
T1 Pin
TR1
control
GATE
INT1
U
C
M
TL1
(8 bits)
.
d
te
i
m
Li
TF1
Interrupt
定时器/计数器1的模式 0: 13位定时器/计数器
C
T
S
当�������
GATE=0(TMOD.7)时,如TR1=1,则定时器计数。GATE=1时,允许由外部输入INT1控制定
时器1,这样可实现脉宽测量。TR1为TCON寄存器内的控制位,TCON寄存器各位的具体功能描述
见上节�����������
TCON寄存器����
的介绍�
。
当C/T=0时,多路开关连接到系统时钟的分频输出,T1对时钟周期计数,T1工作在定时方
式。当C/T=1时,多路开关连接到外部脉冲输入P3.5/T1,即T1工作在计数方式。
STC90C58AD系列单片机的定时器有两种计数速率:一种是����������������
12T�������������
模式,每���������
12�������
个时钟加���
1��
,与
传统����������������������������������������������
8051������������������������������������������
单片机相同;另外一种是�������������������������������
6T�����������������������������
模式,每6个时钟加��������������������
1�������������������
,速度是传统�������������
8051���������
单片机的�����
2����
倍。��
T1
的速率在烧录用户程序时在STC-ISP编程器中设置。
186
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.3.2 模式1(16位定时器/计数器)及其测试程序(C程序及汇编程序)
此模式下定时器������������������������
/�����������������������
计数器��������������������
1�������������������
作为�����������������
16���������������
位定时器/计数器,如下图所示。
÷12
MCU in 12T mode
SYSclk
÷6
MCU in 6T mode
C/T=0
C/T=1
T1 Pin
TR1
TL1
TH1
(8 Bits) (8 bits)
TF1
Interrupt
control
GATE
INT1
.
d
e
t
i
m
定时器/计数器1的模式 1: 16位定时器/计数器
此模式下,定时器1配置为�����������������������������������
16���������������������������������
位定时器/计数器,由�����������������������
TL1��������������������
的�������������������
8������������������
位和����������������
TH1�������������
的������������
8�����������
位所构成。������
TL1���
的8位
溢出向������������������������������
TH1���������������������������
进位,������������������������
TH1���������������������
计数溢出置位���������������
TCON�����������
中的溢出标志位����
TF1�
。
U
C
M
Li
当�������
GATE=0(TMOD.7)时,如TR1=1,则定时器计数。GATE=1时,允许由外部输入INT1控制定
时器1,这样可实现脉宽测量。TR1为TCON寄存器内的控制位,TCON寄存器各位的具体功能描述
见上节�����������
TCON寄存器����
的介绍�
。
C
T
S
当C/T=0时,多路开关连接到系统时钟的分频输出,T1对时钟周期计数,T1工作在定时方
式。当C/T=1时,多路开关连接到外部脉冲输入P3.5/T1,即T1工作在计数方式。
STC90C58AD系列单片机的定时器有两种计数速率:一种是����������������
12T�������������
模式,每���������
12�������
个时钟加���
1��
,与
传统����������������������������������������������
8051������������������������������������������
单片机相同;另外一种是�������������������������������
6T�����������������������������
模式,每6个时钟加��������������������
1�������������������
,速度是传统�������������
8051���������
单片机的�����
2����
倍。��
T1
的速率在烧录用户程序时在STC-ISP编程器中设置。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
187
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
定时器1工作在16位定时器/计数器模式的测试程序
1. C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机定时器1的16位定时器/计数器模式 --*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
typedef unsigned char
typedef unsigned int
BYTE;
WORD;
//----------------------------------------------/* define constants */
#define FOSC 18432000L
C
T
S
U
C
M
.
d
e
t
i
m
Li
#define T1MS (65536-FOSC/12/1000)
//1ms timer calculation method in 12T mode
/* define SFR */
sbit
TEST_LED = P1^0;
//work LED, flash once per second
/* define variables */
WORD count;
//1000 times counter
//----------------------------------------------/* Timer0 interrupt routine */
void tm1_isr() interrupt 3 using 1
{
TL1 = T1MS;
TH1 = T1MS >> 8;
if (count-- == 0)
{
count = 1000;
TEST_LED = ! TEST_LED;
}
}
//-----------------------------------------------
188
南通国芯微电子有限公司
//reload timer1 low byte
//reload timer1 high byte
//1ms * 1000 -> 1s
//reset counter
//work LED flash
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
/* main program */
void main()
{
TMOD = 0x10;
TL1 = T1MS;
TH1 = T1MS >> 8;
TR1 = 1;
ET1 = 1;
EA = 1;
count = 0;
while (1);
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
//set timer1 as mode1 (16-bit)
//initial timer1 low byte
//initial timer1 high byte
//timer1 start running
//enable timer1 interrupt
//open global interrupt switch
//initial counter
//loop
}
2. 汇编程序:
.
d
e
t
i
m
Li
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机定时器1的16位定时器/计数器模式 --*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
;/* define constants */
T1MS
EQU 0FA00H
;1ms timer calculation method in 12T mode is (65536-18432000/12/1000)
C
T
S
;/* define SFR */
TEST_LED BIT P1.0
;/* define variables */
COUNT DATA 20H
U
C
M
;work LED, flash once per second
;1000 times counter (2 bytes)
;----------------------------------------------
ORG 0000H
LJMP MAIN
ORG 001BH
LJMP TM1_ISR
;----------------------------------------------南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
189
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
;/* main program */
MAIN:
MOV TMOD, #10H
MOV TL1,
#LOW T1MS
MOV TH1
,#HIGH T1MS
SETB TR1
SETB ET1
SETB EA
CLR A
MOV COUNT, A
MOV COUNT+1,
A
SJMP $
临时技术支持:13922829991
;set timer1 as mode1 (16-bit)
;initial timer1 low byte
;initial timer1 high byte
;timer1 start running
;enable timer1 interrupt
;open global interrupt switch
;initial counter
.
d
e
t
i
m
;----------------------------------------------;/* Timer1 interrupt routine */
TM1_ISR:
PUSH ACC
PUSH PSW
MOV TL1,
#LOW T1MS
MOV TH1,
#HIGH T1MS
MOV A,
COUNT
ORL A,
COUNT+1
JNZ SKIP
MOV COUNT, #LOW 1000
MOV COUNT+1,#HIGH 1000
CPL TEST_LED
SKIP:
CLR C
MOV A,
COUNT
SUBB A,
#1
MOV COUNT,A
MOV A,COUNT+1
SUBB A,#0
MOV COUNT+1,A
POP PSW
POP ACC
RETI
C
T
S
研发顾问:13922809991
U
C
M
Li
;reload timer1 low byte
;reload timer1 high byte
;check whether count(2byte) is equal to 0
;1ms * 1000 -> 1s
;work LED flash
;count--
;----------------------------------------------
190
END
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.3.3 模式2(8位自动重装模式)及其测试程序(C程序及汇编程序)
此模式下定时器��������������������������
/�������������������������
计数器����������������������
1���������������������
作为可自动重装载的������������
8�����������
位计数器,如下图所示。
MCU in 12T mode
÷12
SYSclk
÷6
MCU in 6T mode
T1 Pin
C/T=0
C/T=1
TL1
(8 Bits)
TF1
Interrupt
control
TR1
GATE
TH1
(8 Bits)
INT1
.
d
e
t
i
m
定时器/计数器1的模式 2: 8位自动重装
Li
TL1���������������������������������������������
的溢出不仅置位��������������������������������������
TF1�����������������������������������
,而且将�������������������������������
TH1����������������������������
内容重新装入����������������������
TL1�������������������
,������������������
TH1���������������
内容由软件预置,重装时����
TH1�
内
容不变。
U
C
M
;定时器1中断的测试程序,定时器1工作在8位自动重装模式
1. C程序:
C
T
S
/*-----------------------------------------------------------------------------------*/
/* --- STC MCU International Limited --------------------------------------*/
/* --- STC89-90xx Series MCU T1(Falling edge) Demo -----------------*/
/* --- Mobile: (86)13922805190 ---------------------------------------------*/
/* --- Fax: 86-755-82905966 -------------------------------------------------*/
/* --- Tel: 86-755-82948412 --------------------------------------------------*/
/* --- Web: www.STCMCU.com ---------------------------------------------*/
/* If you want to use the program or the program referenced in the */
/* article, please specify in which data and procedures from STC */
/*----------------------------------------------------------------------------------*/
#include "reg51.h"
sfr AUXR = 0x8e;
//Auxiliary register
//T1 interrupt service routine
void t1int() interrupt 3
//T1 interrupt (location at 001BH)
{
P0++;
}
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
191
STC90C58AD系列单片机指南
void main()
{
AUXR = 0x40;
TMOD = 0x60;
TL1 = TH1 = 0xff;
TR1 = 1;
ET1 = 1;
EA = 1;
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
//timer1 work in 1T mode
//set timer1 as counter mode2 (8-bit auto-reload)
//fill with 0xff to count one time
//timer1 start run
//enable T1 interrupt
//open global interrupt switch
while (1);
}
2. 汇编程序:
U
C
M
Li
;/*----------------------------------------------------------------------------------*/
;/* --- STC MCU International Limited -------------------------------------*/
;/* --- STC89-90xx Series MCU T1(Falling edge) Demo -----------------*/
;/* --- Mobile: (86)13922805190 ---------------------------------------------*/
;/* --- Fax: 86-755-82905966 -------------------------------------------------*/
;/* --- Tel: 86-755-82948412 --------------------------------------------------*/
;/* --- Web: www.STCMCU.com ---------------------------------------------*/
;/* If you want to use the program or the program referenced in the */
;/* article, please specify in which data and procedures from STC */
;/*---------------------------------------------------------------------------------*/
C
T
S
AUXR
DATA 08EH
;----------------------------------------;interrupt vector table
.
d
e
t
i
m
;Auxiliary register
ORG 0000H
LJMP MAIN
ORG 001BH
LJMP T1INT
;T1 interrupt (location at 001BH)
;-----------------------------------------
192
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
MAIN:
ORG
技术支持网站:www.STCMCU.com
研发顾问:13922809991
0100H
MOV SP,
MOV AUXR,
MOV TMOD,
MOV A,
MOV TL1,
MOV TH1,
SETB TR1
SETB ET1
SETB EA
SJMP
#7FH
#40H
#60H
#0FFH
A
A
;initial SP
;timer1 work in 1T mode
;set timer1 as counter mode2 (8-bit auto-reload)
;fill with 0xff to count one time
;timer1 start run
;enable T1 interrupt
;open global interrupt switch
;----------------------------------------;T1 interrupt service routine
T1INT:
CPL P0.0
RETI
;----------------------------------------
临时技术支持:13922829991
END
南通国芯微电子有限公司
C
T
S
U
C
M
总机:0513-5501 2928 / 2929 / 2966
.
d
e
t
i
m
Li
传真:0513-5501 2969 / 2956 / 2947
193
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.1.4 古老Intel 8051单片机定时器0/1的应用举例
【例1】 定时/计数器编程,定时/计数器的应用编程主要需考虑:根据应用要求,通过程序初
始化,正确设置控制字,正确计算和计算计数初值,编写中断服务程序,适时设置控制位等。
通常情况下,设置顺序大致如下:
1)工作方式控制字(TMOD、T2CON)的设置;
2)计数初值的计算并装入THx、TLx、RCAP2H、RCAP2L;
3)中断允许位ETx、EA的设置,使主机开放中断;
4) 启/停位TRx的设置等。
现以定时/计数器0或1为例作一简要介绍。
.
d
e
t
i
m
8051系列单片机的定时器/计数器0或1是以不断加1进行计数的,即属加1计数器,因此,就
不能直接将实际的计数值作为计数初值送入计数寄存器THx、TLx中去,而必须将实际计数值以
28、213、216为模求补,以其补码作为计数初值设置THx和TLx。
Li
设:实际计数值为X,计数器长度为n(n=8、13、16),则应装入计数器THx、TLx中的计
数初值为2n-x,式中2n为取模值。例如,工作方式0的计数长度为13位,则n=13,以213为模,
工作方式1的计数长度为16,则n=16,以216为模等等。所以,计数初值为(x)= 2n-x。
U
C
M
对于定时模式,是对机器周期计数,而机器周期与选定的主频密切相关。因此,需根据应
C
T
S
用系统所选定的主频计算出机器周期值。现以主频6MHz为例,则机器周期为:
一个机器周期=
12
主振频率
=
12
6×106
μs
= 2μs
实际定时时间Tc = x·Tp
式中Tp为机器周期,Tc为所需定时时间,x为所需计数次数。Tp和Tp一般为已知值,在求出
Tp后即可求得所需计数值x,再将x求补码,即求得定时计数初值。即
(x)补= 2n - x
例如,设定时时间Tc = 5ms,机器周期TP = 2μs,可求得定时计数次数
5ms
x =
= 2500次
2μs
设选用工作方式1,则n=16,则应设置的定时时间计数初值为:
(x)补= 216 - x=65536-2500=63036,还需将它分解成两个8位十六进制数,分别求得低8
位为3CH装入TLx,高8位为F6H装入THx中。
工作方式0、1、2的最大计数次数分别为8192、65536和256。
对外部事件计数模式,只需根据实际计数次数求补后变换成两个十六进制码即可。
194
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
【例2】 定时/计数器应用编程,设某应用系统,选择定时/计数器1定时模式,定时时间Tc
= 10ms,主频频率为12MHz,每10ms向主机请求处理。选定工作方式1。计算得计数初值:低8
位初值为F0H,高8位初值为D8H。
(1)初始化程序
…
所谓初始化,一般在主程序中根据应用要求对定时/计数器进行功能选择及参数设定等预置
程序,本例初始化程序如下:
START:
;����
主程序段
MOV
SP,#60H
;设置堆栈区域
MOV
TMOD,#10H
;选择T1、定时模式,工作方式1
MOV
TH1,#0D8H
;设置高字节计数初值
MOV
TL1,#0F0H
;设置低字节计数初值
SETB
EA
SETB
ET1
C
T
S
SETB
TR1
(2)中断服务程序
INTT1: PUSH
U
C
M
;
开中断
�
;其他初始化程序
;启动T1开始计时
;������
继续主程序
…
…
.
d
e
t
i
}
Lim
;
A
;
PUSH DPL
PUSH DPH
MOV
TL1,#0F0H
MOV
TH1,#0D8H
POP
DPH
POP
DPL
POP
A
}
RETI
;返回
}
;
现场保护
…
…
;
南通国芯微电子有限公司
;
}
;
重新置初值
;中断处理主体程序
;
总机:0513-5501 2928 / 2929 / 2966
;
现场恢复
;
传真:0513-5501 2969 / 2956 / 2947
195
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
这里展示了中断服务子程序的基本格式。STC90C58AD系列单片机的中断属于矢量中断,每
一个矢量中断源只留有8个字节单元,一般是不够用的,常需用转移指令转到真正的中断服务
子程序区去执行。
【例3】 对外部正脉冲测宽。选择定时/计数器2进行脉宽测试较方便,但也可选用定时/计
数器0或定时/计数器1进行测宽操作。本例选用定时/计数器0(T0)以定时模式,工作方式1对
INT0引脚上的正脉冲进行脉宽测试。
INT0 引脚
T0计数
启动
.
d
e
t
i
m
停止
设置GATE为1,机器周期TP为1μs。本例程序段编制如下:
INTT0:
MOV
TMOD,#09H
MOV
TL0,#00H
MOV
TH0,#00H
CLR
EX0
;关INT0中断
LOP1:
JB
P3.2,LOP1
;等待INT0引低电平
LOP2:
JNB
P3.2,LOP2
;等待INT0引脚高电平
SETB
TR0
;启动T0开始计数
LOP3:
JB
P3.2,LOP3
;等待INT0低电平
CLR
TR0
;停止T0计数
MOV
A,TL0
;低字节计数值送A
MOV
B,TH0
;高字节计数值送B
…
;计算脉宽和处理
196
C
T
S
南通国芯微电子有限公司
L}i
U
C
M
;设T0为定时方式1,GATE为1
;
;
总机:0513-5501 2928 / 2929 / 2966
TH0,TL0清0
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
【例4】 利用定时/计数器0或定时/计数器1的Tx端口改造成外部中断源输入端口的应用设计。
在某些应用系统中常会出现原有的两个外部中断源INT0和INT1不够用,而定时/计数器有
多余,则可将Tx用于增加的外部中断源。现选择定时/计数器1为对外部事件计数模式工作方式
2(自动再装入),设置计数初值为FFH,则T1端口输入一个负跳变脉冲,计数器即回0溢出,
置位对应的中断请求标志位TF1为1,向主机请求中断处理,从而达到了增加一个外部中断源的
目的。应用定时/计数器1(T1)的中断矢量转入中断服务程序处理。其程序示例如下:
(1)主程序段:
ORG
0000H
AJMP
MAIN
;转主程序
ORG
001BH
LJMP
INTER
;转T1中断服务程序
ORG
0100
…
…
MAIN: …
C
T
S
U
C
M
;主程序入口
.
d
e
t
i
m
Li
MOV
SP,#60H
MOV
TMOD,#60H
;设置定时/计数器1,计数方式2
MOV
TL1,#0FFH
;设置计数常数
MOV
TH1,#0FFH
SETB
EA
;开中断
SETB
ET1
;开定时/计数器1中断
SETB
TR1
;启动定时/计数器1计数
…
;设置堆栈区
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
197
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ORG
1000H
INTER:
PUSH
A
;
PUSH
DPL
;
PUSH
DPH
;
… … …
(2)中断服务程序(具体处理程序略)
;
中断处理主体程序
;�
��
POP
DPH
;
POP
DPL
POP
A
RETI
这是中断服务程序的基本格式。
U
C
M
}
现场入栈保护
}
}ited.
;
现场出栈复原
Lim
;
;返回
【例5】 某应用系统需通过P1.0和P1.1分别输出周期为200μ s和400μ s的方波。为此,系统
C
T
S
选用定时器/计数器0(T0),定时方式3,主频为6M H z,T P=2μ s,经计算得定时常数为9C H和
本例程序段编制如下:
(1)初始化程序段
PLT0: MOV
TMOD,#03H
;设置T0定时方式3
MOV
TL0,#9CH
;设置TL0初值
MOV
TH0,#38H
;设置TH0初值
SETB
EA
;
SETB
ET0
SETB
ET1
}
SETB
TR0
;启动
SETB
TR1
;启动
198
…
…
38H。
南通国芯微电子有限公司
;
开中断
;
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
(2)中断服务程序段
1)
INT0P:
MOV
CPL
RETI
2)
INT1P
MOV
TH0,#38H
CPL
P1.1
RETI
在实际应用中应注意的问题如下。
(1)定时/计数器的实时性
定时/计数器启动计数后,当计满回0溢出向主机请求中断处理,由内部硬件自动进
TL0,#9CH
P1.0
;重新设置初值
;对P1.0输出信号取反
;返回
…
… …
…
… …
C
T
S
U
C
M
.
d
e
t
i
m
Li
;重新设置初值
;对P1.1输出信号取反
;返回
行。但从回0溢出请求中断到主机响应中断并作出处理存在时间延迟,且这种延时随中断请求
时的现场环境的不同而不同,一般需延时3个机器周期以上,这就给实时处理带来误差。大多
数应用场合可忽略不计,但对某些要求实时性苛刻的场合,应采用补偿措施。
这种由中断响应引起的时间延时,对定时/计数器工作于方式0或1而言有两种含义:一
是由于中断响应延时而引起的实时处理的误差;二是如需多次且连续不间断地定时/计数,由
于中断响应延时,则在中断服务程序中再置计数初值时已延误了若干个计数值而引起误差,特
别是用于定时就更明显。
例如选用定时方式1设置系统时钟,由于上述原因就会产生实时误差。这种场合应采用
动态补偿办法以减少系统始终误差。所谓动态补偿,即在中断服务程序中对THx、TLx重新置计
数初值时,应将THx、TLx从回0溢出又重新从0开始继续计数的值读出,并补偿到原计数初值中
去进行重新设置。可考虑如下补偿方法:
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
199
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
CLR
EA
;禁止中断
MOV
A,TLx
;读TLx中已计数值
ADD
A,#LOW
;LOW为原低字节计数初值
MOV
TLx,A
;设置低字节计数初值
MOV
A,#HIGH
;原高字节计数初值送A
ADDC
A,THx
;高字节计数初值补偿
MOV
THx,A
;置高字节计数初值
SETB
EA
;开中断
…
研发顾问:13922809991
.
d
e
t
i
m
…
(2)动态读取运行中的计数值
U
C
M
Li
在动态读取运行中的定时/计数器的计数值时,如果不加注意,就可能出错。这是因为不
可能在同一时刻同时读取THx和TLx中的计数值。比如,先读TLx后读THx,因为定时/计数器处
于运行状态,在读TLx时尚未产生向THx进位,而在读THx前已产生进位,这时读得的THx就不对
C
T
S
了;同样,先读THx后读TLx也可能出错。
一种可避免读错的方法是:先读THx,后读TLx,将两次读得的THx进行比较;若两次读得
的值相等,则可确定读的值是正确的,否则重复上述过程,重复读得的值一般不会再错。此法
的软件编程如下:
RDTM: MOV A,THx
;读取THx存A中
MOV R0,TLx
;读取TLx存R0中
CJNE A,THx,RDTM
;比较两次THx值,若相等,则读得的
;值正确,程序往下执行,否则重读
MOV
R1,A
;将THx存于R1中
200
…
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.2 定时器/计数器T2
定时器2是一个16位定时/计数器。通过设置特殊功能寄存器T2CON中的C/T2位,可将其作为定
时器或计数器(特殊功能寄存器T2CON的描述如�����
下所示��
)。
定时器/计数器2的相关寄存器表:
位地址及其符号
符号
描述
T2CON
定时器2控制寄存器
C8H TF2 EXF2 RCLK TCLK EXEN2 TR2 C/T2 CP/RL2 0000 0000B
T2MOD
定时器2模式寄存器
C9H
地址
Timer / Counter 2
RCAP2L Reload/Capture Low Byte
Timer / Counter 2
RCAP2H Reload/Capture High Byte
TL2 Timer / Counter 2 Low Byte
Timer/Counter 2 High Byte
TH2
MSB
-
LSB
-
-
-
6
DECN
CCH
CDH
5
C
T
S
xxxx xx00B
0000 0000B
U
C
M
4
3
TF2 EXF2 RCLK TCLK EXEN2 TR2
位
T2OE
.
d
te
CBH
T2CON 地址:0C8H
7
-
CAH
寄存器T2CON(定时器2的控制寄存器)各位的功能描述
可位寻址
-
复位值
i
m
Li
2 1
C/T2
0000 0000B
0000 0000B
0000 0000B
复位值:00H
0
CP/RL2
符号
TF2
功能
定时器2溢出标志。定时器2溢出时置位,必须由软件清除。
当RCLK或TCLK=1 时,TF2将不会置位
T2CON.6/
EXF2
定时器2外部标志。当EXEN2=1且T2EX的负跳变产生捕获或重
装时,EXF2置位。定时器2中断使能时,EXF2=1将使CPU从中
断向量处执行定时器2中断子程序。EXF2位必须用软件清零。
在递增/递减计数器模式(DCEN=1)中,EXF2不会引起中断
T2CON.5/
RCLK
接收时钟标志。RCLK置位时,定时器2的溢出脉冲作为串行口
模式1和模式3的接收时钟。RCLK=0时,将定时器1的溢出脉冲
作为接收时钟
T2CON.7/
T2CON.4/
TCLK
T2CON.3/
EXEN2
南通国芯微电子有限公司
发送时钟标志。TCLK置位时,定时器2的溢出脉冲作为串行口
模式1和模式3的发送时钟。TCLK=0时,将定时器1的溢出脉冲
作为发送时钟
定时器2外部使能标志。当其置位且定时器2未作为串行口时
钟时,允许T2EX的负跳变产生捕获或重装。EXEN2=0时,T2EX
的跳变对定时器2无效
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
201
STC90C58AD系列单片机指南
位
技术支持网站:www.STCMCU.com
符号
T2CON.2/
TR2
T2CON.1/
C/T2
T2CON.0/
CP/RL2
临时技术支持:13922829991
研发顾问:13922809991
功能
定时器2 启动/停止控制位。置1 时启动定时器
定时器/ 计数器选择。(定时器2 )
0 = 内部定时器(SYSclk/12 或SYSclk/6)
1 = 外部事件计数器(下降沿触发)
捕获/重装标志。置位:�������
EXEN2=1时,T2EX的负跳变产生捕获.
清零:EXEN2=0时,定时器2溢出或T2EX的负跳变都可使定时
器自动重装。当RCLK=1 或TCLK=1 时,该位无效且定时器强
制为溢出时自动重装
定时器2有3种操作模式:捕获、自动重新装载(递增或递减计数)和波特率发生器�����
。����
这3种模
式由T2CON中的位进行选择(如������
下�����
表所列)。
RCLK+TCLK
0
0
1
x
C
T
S
.
d
e
t
i
m
定时器2的工作方式
TR2
模式
CP/RL2
0
1
16位自动重装
1
1
16位捕获
x
1
波特率发生器
x
0
(关闭)
U
C
M
Li
T2MOD : 定时器/计数器2模式控制寄存器 (不可位寻址)
SFR name Address
bit
B7
B6
B5
B4
B3
T2MOD
0C9H
name
-
B2
-
B1
T2OE
B0
DCEN
T2OE: 定时器2 输出使能位
DECN: 向下计数使能位。定时器2 可配置成向上/ 向下计数器
202
* 用户勿将其置1。这些位在将来80C51 系列产品中用来实现新的特性。在这种情况
下,以后用到保留位,复位时或非有效状态时,它的值应为0;而这些位为有效状态
时,它的值为1。从保留位读到的值是不确定的。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.2.1 定时器2的捕获模式
在捕获模式中,通过T2CON中的EXEN2设置2个选项。如果EXEN2=0,定时器2作为一个16位
定时器或计数器(由T2CON中C/T2位选择),溢出时置位TF2(定时器2溢出标志位)。该位可
用于产生中断(通过使能IE寄存器中的定时器2中断使能位ET2)。如果EXEN2=1,与以上描述
相同,但增加了一个特性,即外部输入T2EX由1变零时,将定时器2中TL2和TH2的当前值各自捕
获到RCAP2L和RCAP2H。另外,T2EX的负跳变使T2CON中的EXF2置位,EXF2也像TF2一样能够产生
中断(其向量与定时器2溢出中断地址相同,定时器2中断服务程序通过查询TF2和EXF2来确定
引起中断的事件),捕获模式如��������������������������������
下�������������������������������
图所示。在该模式中,TL2和TH2无重新装载值,甚至当T2EX
产������������������������������������������������
生捕获事件时,计数器仍以T2EX 的负跳变或振荡频率的1/12(12 时钟模式)或1/6(6时钟
模式)计数。
÷12
SYSclk
÷6
.
d
e
t
i
m
MCU in 12T mode
MCU in 6T mode
T2 Pin
跳变检测
C
T
S
T2EX Pin
C/T2=0
C/T2=1
M
CU
control
control
TR2
TL2
(8 Bits)
capture
Li
TH2
(8 Bits)
TF2
定时器2
中断
RCAP2L RCAP2H
EXF2
EXEN2
图1 定时器2捕获模式
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
203
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.2.2 定时器2的自动重装模式(递增/递减计数器)
16位自动重装模式中,定时器2可通过C/T2配置为定时器/计数器,编程控制递增/递减计
数。计数的方向是由DCEN(递减计数使能位)确定的,DCEN位于T2MOD寄存器中,T2MOD寄存器
各位的功能描述如表3 所示。当DCEN=0 时,定时器2 默认为向上计数;当DCEN=1 时,定时器
2 可通过T2EX 确定递增或递减计数。图2 显示了当DCEN=0 时,定时器2 自动递增计数。在
该模式中,通过设置EXEN2位进行选择。如果EXEN2=0,定时器2 递增计数到0FFFFH,并在溢
出后将TF2置位,然后将RCAP2L和RCAP2H 中的16位值作为重新装载值装入定时器2。RCAP2L和
RCAP2H的值是通过软件预设的。
如果EXEN2=1,16位重新装载可通过溢出或T2EX从1�������������������
到������������������
0的负跳变实现。此负跳变同时EXF2
置位。如果定时器2中断被使能,则当TF2或EXF2置1时产生中断。在图3中,DCEN=1时,定时
器2可增或递减计数。此模式允许T2EX 控制计数的方向。当T2EX 置1 时,定时器2 递增计
数,计数到0FFFFH后溢出并置位TF2,还将产生中断(如果中断被使能)。定时器2的溢出将使
RCAP2L和RCAP2H中的16 位值作为重新装载值放入TL2和TH2。
.
d
e
t
i
m
当T2EX置零时,将使定时器2递减计数。当TL2和TH2计数到等于RCAP2L和RCAP2H时,定时
器产����
生中断。
MCU in 12T mode
÷12
SYSclk
÷6
MCU in 6T mode
C
T
S
T2 Pin
C/T2=0
C/T2=1
U
C
M
control
TH2
(8 Bits)
reload
TR2
跳变检测
TL2
(8 Bits)
Li
RCAP2L RCAP2H
T2EX Pin
TF2
定时器2
中断
EXF2
control
EXEN2
图2 定时器2的自动重装模式 (DCEN=0)
÷12
Down Counting Reload Value
MCU in 12T mode
FFH
Toggle
FFH
EXF2
SYSclk
÷6
MCU in 6T mode
T2 Pin
C/T2=0
C/T2=1
control
TL2
(8 Bits)
Overflow
TH2
(8 Bits)
TF2
Count Direction
1=UP
0=DOWN
TR2
RCAP2L RCAP2H
Up Counting Reload Value
定时器2
中断
T2EX Pin
图3 定时器2的自动重装模式 (DCEN=1)
204
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
位地址及其符号
符号
描述
T2CON
定时器2控制寄存器
C8H TF2 EXF2 RCLK TCLK EXEN2 TR2 C/T2 CP/RL2 0000 0000B
T2MOD
定时器2模式寄存器
C9H
地址
MSB
-
LSB
-
-
-
-
-
T2OE
DECN
复位值
xxxx xx00B
除了波特率发生器模式,T2CON不包括TR2位的设置,TR2位需单独设置来启动定时器。如�
下
表列出了T2作为定时器和计数器的具体设置方法。
T2作定时器T2CON的设置
T2CON
内部控制
外部控制
16位重装
0000 0000B / 00H
0000 1000B / 08H
16位捕获
0000 0001B / 01H
0000 1001B / 09H
0011 0110B / 36H
波特率发生器接收和发送相同波特率 0011 0100B / 34H
0010 0100B / 24H
0010 0110B / 26H
只接收
0001 0100B / 14H
0001 0110B / 16H
只发送
模式
T2作计数器T2MOD的设置
模式
16位
自动重装
C
T
S
U
C
M
.
d
e
t
i
m
Li
T2MOD
内部控制
外部控制
0000 0010B / 02H
0000 1010B / 0AH
0000 0011B / 03H
0000 1011B / 0BH
(1)内部控制:����������������
仅当定时器溢出时进行捕获和重装。
(2)外部控制:���������������������������������������
当定时/计数器溢出并且T2EX(P1.1)发生电平负跳变时产生捕获和重装(定时
器2用于波特率发生器模式时除外)。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
205
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.2.3 定时器2作串行口波特率发生器及其测试程序(C程序及汇编程序)
寄存器T2CON的位TCLK和(或)RCLK允许从定时器1或定时器2获得串行口发送和接收的波
特率。当TCLK=0时,定时器1作为串行口发送波特率发生器;当TCLK=1时,定时器2作为串行口
发送波特率发生器。RCLK对串行口接收波特率有同样的作用。通过这2位,串行口能得到不同
的接收和发送波特率,一个通过定时器1产生,另一个通过定时器2产生。如图4所示为定时器2
工作在波特率发生器模式。与自动重装模式相似,当TH2溢出时,波特率发生器模式使定时器2
寄存器重新装载来自寄存器RCAP2H 和RCAP2L的16位的值,寄存器RCAP2H和RCAP2L的值由软件
预置。当工作于模式1和模式3时,波特率由下面给出的公式所决定:
模式1 和模式3 的波特率=�������������
(定时器2溢出速率)/16
Timer 1
Overflow
÷12
SYSclk
÷6
.
d
e
t
i
m
MCU in 12T mode
MCU in 6T mode
T2 Pin
C/T2=0
C/T2=1
C
T
S
CU
M
跳变检测
T2EX Pin
control
control
TR2
EXF2
TL2
(8 Bits)
Li
TH2
(8 Bits)
Reload
÷2
'0'
'1'
'1'
'1'
'0'
'0'
÷16
SMOD
RCLK
RX Clock
TCLK
RCAP2L RCAP2H
÷16
TX Clock
定时器2
中断
EXEN2
图4 定时器2的独立波特率发生器模式
定时器可配置成“定时”或“计数”方式,在许多应用上,定时器被设置在“定时”方式
(C/T2=0)。当定时器2作为定时器时,它的操作不同于波特率发生器。通常定时器2作为定时
器,它会在每个机器周期递增(1/6 或1/12 振荡频率)。当定时器2 作为波特率发生器时,
它在6 时钟模式下,以振荡器频率递增(12时钟模式时为1/12振荡频率)。
这时的波特率公式如下:
模式1和模式3的波特率 =
振荡器频率
n×[65536-(RCAP2H,RCAP2L)]
式中:n=16(6时钟模式)或32(12时钟模式);[RCAP2H,RCAP2L]是RCAP2H和RCAP2L的
内容,为16 位无符号整数。
如图4所示,定时器2是作为波特率发生器,仅当寄存器T2CON中的RCLK和(或)TCLK=1
时,定时器2作为波特率发生器才有效。注意:TH2溢出并不置位TF2,也不产生中断。这样当
定时器2 作为波特率发生器时,定时器2中断不必被禁止。如果EXEN2(T2外部使能标志)被置
位,在T2EX中由1 到0 的转换会置位EXF2(T2 外部标志位),但并不导致(TH2,TL2)重新
装载(RCAP2H,RCAP2L)。
206
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
当定时器2用作波特率发生器时,如果需要,T2EX可用做附加的外部中断。当计时器工作
在波特率发生器模式下,则不要对TH2和TL2 进行读/ 写,每隔一个状态时间(fosc/2)或由
T2 进入的异步信号,定时器2 将加1。在此情况下对TH2 和TH1 进行读/ 写是不准确的;可对
RCAP2寄存器进行读,但不要进行写,否则将导致自动重装错误。当对定时器2或寄存器RCAP进
行访问时,应关闭定时器(清零TR2)。表4列出了常用的波特率和如何用定时器2得到这些波
特率。
波特率公式汇总
定时器2工作在波特率发生器模式,外部时钟信号由T2脚进入,这时的波特率公式如下:
模式1 和模式3 的波特率=�������������
(定时器2溢出速率)/16
.
d
e
t
i
m
如果定时器2采用内部时钟信号,则波特率公式如下:
波特率 =
SYSclk
n×[65536-(RCAP2H,RCAP2L)]
Li
式中:n=32(12时钟模式)或16(6 时钟模式),SYSclk= 振荡器频率。
自动重装值可由下式得到:
RCAP2H,RCAP2L= 65536 —[SYSclk/(n ×波特率)]
C
T
S
南通国芯微电子有限公司
U
C
M
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
207
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
定时器2作串行口波特率发生器的测试程序(C程序及汇编程序)
1. C程序:
/*------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------------*/
/* --- 演示STC90C58AD系列单片机定时器2作波特率发生器测试程序---*/
/* --- Mobile: (86)13922805190 -----------------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, ------------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 ------------------*/
/*--------------------------------------------------------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
sfr T2CON = 0xC8;
sfr RCAP2L = 0xCA;
sfr RCAP2H = 0xCB;
sfr TL2 = 0xCC;
sfr TH2 = 0xCD;
C
T
S
typedef unsigned char BYTE;
typedef unsigned int WORD;
Li
//timer2 control register
U
C
M
.
d
e
t
i
m
#define FOSC 18432000L
#define BAUD 115200
//System frequency
//UART baudrate
/*Define UART parity mode*/
#define NONE_PARITY 0
#define ODD_PARITY 1
#define EVEN_PARITY 2
#define MARK_PARITY 3
#define SPACE_PARITY 4
//None parity
//Odd parity
//Even parity
//Mark parity
//Space parity
#define PARITYBIT EVEN_PARITY
//Testing even parity
sbit bit9 = P2^2;
bit busy;
//P2.2 show UART data bit9
void SendData(BYTE dat);
void SendString(char *s);
208
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
void main()
{
#if (PARITYBIT == NONE_PARITY)
SCON = 0x50;
//8-bit variable UART
#elif (PARITYBIT == ODD_PARITY) || (PARITYBIT == EVEN_PARITY) || (PARITYBIT == MARK_PARITY)
SCON = 0xda;
//9-bit variable UART, parity bit initial to 1
#elif (PARITYBIT == SPACE_PARITY)
SCON = 0xd2;
//9-bit variable UART, parity bit initial to 0
#endif
TL2 = RCAP2L = (65536-(FOSC/32/BAUD)); //Set auto-reload vaule
TH2 = RCAP2H = (65536-(FOSC/32/BAUD)) >> 8;
T2CON = 0x34;
//Timer2 start run
ES = 1;
//Enable UART interrupt
EA = 1;
//Open master interrupt switch
SendString("STC89-90xx\r\nUart Test !\r\n");
while(1);
}
/*---------------------------UART interrupt service routine
----------------------------*/
void Uart_Isr() interrupt 4 using 1
{
if (RI)
{
RI = 0;
P0 = SBUF;
bit9 = RB8;
}
if (TI)
{
TI = 0;
busy = 0;
}
}
C
T
S
U
C
M
.
d
e
t
i
m
Li
//Clear receive interrupt flag
//P0 show UART data
//P2.2 show parity bit
//Clear transmit interrupt flag
//Clear transmit busy flag
/*---------------------------Send a byte data to UART
Input: dat (data to be sent)
Output:None
----------------------------*/
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
209
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
void SendData(BYTE dat)
{
while (busy);
//Wait for the completion of the previous data is sent
ACC = dat;
//Calculate the even parity bit P (PSW.0)
if (P)
//Set the parity bit according to P
{
#if (PARITYBIT == ODD_PARITY)
TB8 = 0;
//Set parity bit to 0
#elif (PARITYBIT == EVEN_PARITY)
TB8 = 1;
//Set parity bit to 1
#endif
}
else
{
#if (PARITYBIT == ODD_PARITY)
TB8 = 1;
//Set parity bit to 1
#elif (PARITYBIT == EVEN_PARITY)
TB8 = 0;
//Set parity bit to 0
#endif
}
busy = 1;
SBUF = ACC;
//Send data to UART buffer
}
C
T
S
/*---------------------------Send a string to UART
Input: s (address of string)
Output:None
----------------------------*/
void SendString(char *s)
{
while (*s)
{
SendData(*s++);
}
}
210
南通国芯微电子有限公司
U
C
M
.
d
e
t
i
m
Li
//Check the end of the string
//Send current char and increment string ptr
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 汇编程序:
/*------------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------------*/
/* --- 演示STC90C58AD系列单片机定时器2作波特率发生器测试程序---*/
/* --- Mobile: (86)13922805190 -----------------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -----------------------------*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------------*/
/*-------------------------------------------------------------------------------------------*/
T2CON
TR2
EQU
BIT
0C8H
T2CON.2
;timer2 control register
T2MOD
RCAP2L
RCAP2H
TL2
TH2
EQU
EQU
EQU
EQU
EQU
0C9H
0CAH
0CBH
0CCH
0CDH
;timer2 mode register
;/*Define UART parity mode*/
#define NONE_PARITY 0
#define ODD_PARITY 1
#define EVEN_PARITY 2
#define MARK_PARITY 3
#define SPACE_PARITY 4
C
T
S
U
C
M
.
d
e
t
i
m
Li
//None parity
//Odd parity
//Even parity
//Mark parity
//Space parity
#define PARITYBIT EVEN_PARITY //Testing even parity
;----------------------------------------BUSY BIT
20H.0
;transmit busy flag
;----------------------------------------
ORG 0000H
LJMP MAIN
ORG 0023H
LJMP UART_ISR
;----------------------------------------
ORG 0100H
MAIN:
CLR BUSY
CLR EA
MOV SP,
#3FH
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
211
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
#if (PARITYBIT == NONE_PARITY)
MOV SCON,
#50H
;8-bit variable UART
#elif (PARITYBIT == ODD_PARITY) || (PARITYBIT == EVEN_PARITY) || (PARITYBIT == MARK_PARITY)
MOV SCON,
#0DAH
;9-bit variable UART, parity bit initial to 1
#elif (PARITYBIT == SPACE_PARITY)
MOV SCON,
#0D2H
;9-bit variable UART, parity bit initial to 0
#endif
;------------------------------
MOV A,
#0FBH
;65536-18432000/32/115200 = 0xfffb
MOV TL2,
A
MOV RCAP2L, A
MOV A,
#0FFH
MOV TH2,
A
;Set auto-reload vaule
MOV RCAP2H, A
MOV T2CON ,#34H
;Timer2 start run
SETB ES
;Enable UART interrupt
SETB EA
;Open master interrupt switch
;------------------------------
MOV DPTR,
#TESTSTR
;Load string address to DPTR
LCALL SENDSTRING
;Send string
;------------------------------
SJMP $
;----------------------------------------TESTSTR:
;Test string
DB "STC89-90xx Uart Test !",0DH,0AH,0
C
T
S
U
C
M
;/*---------------------------;UART2 interrupt service routine
;----------------------------*/
UART_ISR:
PUSH ACC
PUSH PSW
JNB RI,CHECKTI
CLR RI
MOV P0,SBUF
MOV C,RB8
MOV P2.2,C
CHECKTI:
JNB TI,ISR_EXIT
CLR TI
CLR BUSY
ISR_EXIT:
POP PSW
POP ACC
RETI
212
南通国芯微电子有限公司
.
d
e
t
i
m
Li
;Check RI bit
;Clear RI bit
;P0 show UART data
;P2.2 show parity bit
;Check S2TI bit
;Clear S2TI bit
;Clear transmit busy flag
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
;/*---------------------------;Send a byte data to UART
;Input: ACC (data to be sent)
;Output:None
;----------------------------*/
SENDDATA:
JB
BUSY,$
MOV ACC,A
JNB P,
EVEN1INACC
ODD1INACC:
#if (PARITYBIT == ODD_PARITY)
CLR TB8
#elif (PARITYBIT == EVEN_PARITY)
SETB TB8
#endif
SJMP PARITYBITOK
EVEN1INACC:
#if (PARITYBIT == ODD_PARITY)
SETB TB8
#elif (PARITYBIT == EVEN_PARITY)
CLR TB8
#endif
PARITYBITOK:
;Parity bit set completed
SETB BUSY
MOV SBUF, A
RET
C
T
S
;/*---------------------------;Send a string to UART
;Input: DPTR (address of string)
;Output:None
;----------------------------*/
SENDSTRING:
CLR A
MOVC A,
@A+DPTR
JZ
STRINGEND
INC
DPTR
LCALL SENDDATA
SJMP SENDSTRING
STRINGEND:
RET
;----------------------------------------
END
南通国芯微电子有限公司
临时技术支持:13922829991
研发顾问:13922809991
;Wait for the completion of the previous data is sent
;Calculate the even parity bit P (PSW.0)
;Set the parity bit according to P
;Set parity bit to 0
.
d
e
t
i
m
;Set parity bit to 1
U
C
M
Li
;Set parity bit to 1
;Set parity bit to 0
;Send data to UART buffer
;Get current char
;Check the end of the string
;increment string ptr
;Send current char
;Check next
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
213
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.2.4 定时器2的可编程时钟输出及其测试程序(C程序及汇编程序)
STC90C58AD 系列单片机,可设定定时/计数器2,通过P1.0输出时钟。P1.0除作通用I/O口
外还有两个功能可供选用:用于定时/ 计数器2 的外部计数输入和定时/计数器2 时钟信号输
出。图5 为时钟输出和外部事件计数方式示意图。
÷12
MCU in 12T mode
SYSclk
÷6
control
MCU in 6T mode
TL2
(8 Bits)
TH2
(8 Bits)
TR2
RCAP2L RCAP2H
C/T2
.
d
e
t
i
m
÷2
T2 Pin (P1.0)
T2OE
Transition
Detector
T2EX Pin (P1.1)
EXF2
U
C
M
control
EXEN2
Li
Timer 2 Interrupt
图5 定时器2的可编程时钟输出模式
C
T
S
通过软件对T2CON.1位C/T2复位为0,对T2MOD.1位T2OE置1就可将定时/计数器2选定为时钟
信号发生器,而T2CON.2位TR2控制时钟信号输出开始或结束(TR2为启/停控制位). 由主振频
率(SYSclk)和定时/计数器2定时、自动再装入方式的计数初值决定时钟信号的输出频率。其
设置公式如下:
模式1和模式3的波特率 =
SYSclk
n×[65536-(RCAP2H,RCAP2L)]
* n=2,6 时钟/机器周期;n=4,12 时钟/机器周期
从公式可见,在主振频率(SYSclk)设定后,时钟信号输出频率就取决于定时计数初值的
设定。
在时钟输出模式下,计数器回0 溢出不会产生中断请求。这种功能相当于定时/计数器2用
作波特率发生器,同时又可以作时钟发生器。但必须注意,无论如何波特率发生器和时钟发生
器不能单独确定各自不同的频率。原因是两者都用同一个陷阱寄存器RCAP2H、RCAP2L,不可能
出现两个计数初值。
214
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
定时器2的可编程时钟输出演示程序
1、C程序清单:
/*--------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------*/
/* --- STC90C58AD Series Programmable Clock Output Demo -----*/
/* --- Mobile: (86)13922805190 ------------------------------------------*/
/* --- Fax: 86-755-82905966 ----------------------------------------------*/
/* --- Tel: 86-755-82948412 -----------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------*/
/* If you want to use the program or the program referenced in the */
/* article, please specify in which data and procedures from STC */
/*-------------------------------------------------------------------------------*/
.
d
e
t
i
m
#include "reg51.h"
typedef unsigned char BYTE;
typedef unsigned int WORD;
//----------------------------------------------/* define constants */
#define FOSC 18432000L
#define F38_4KHz
U
C
M
(65536-18432000/4/38400)
/* define SFR */
sfr T2CON = 0xc8;
sbit TF2 = T2CON^7;
sbit TR2 = T2CON^2;
sfr T2MOD = 0xc9;
sfr RCAP2L = 0xca;
sfr RCAP2H = 0xcb;
sfr TL2 = 0xcc;
sfr TH2 = 0xcd;
C
T
S
Li
//timer2 control register
//timer2 mode register
sbit T2 = P1^0;
//Clock Output pin
//----------------------------------------------/* main program */
void main()
{
T2MOD = 0x02;
//enable timer2 output clock
RCAP2L = TL2 = F38_4KHz;
//initial timer2 low byte
RCAP2H = TH2 = F38_4KHz >> 8;
//initial timer2 high byte
TR2 = 1;
//timer2 start running
EA = 1;
//open global interrupt switch
}
while (1);
南通国芯微电子有限公司
//loop
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
215
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2、汇编程序清单:
/*--------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------*/
/* --- STC90C58AD Series Programmable Clock Output Demo -----*/
/* --- Mobile: (86)13922805190 ------------------------------------------*/
/* --- Fax: 86-755-82905966 ----------------------------------------------*/
/* --- Tel: 86-755-82948412 -----------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------*/
/* If you want to use the program or the program referenced in the */
/* article, please specify in which data and procedures from STC */
/*-------------------------------------------------------------------------------*/
;/* define constants */
F38_4KHz EQU 0FF88H
;38.4KHz frequency calculation method of 12T mode (65536-18432000/4/38400)
.
d
e
t
i
m
;/* define SFR */
T2CON EQU
TF2
BIT
TR2
BIT
0C8H
T2CON.7
T2CON.2
T2MOD
RCAP2L
RCAP2H
TL2
TH2
EQU
EQU
EQU
EQU
EQU
0C9H
0CAH
0CBH
0CCH
0CDH
C
T
S
Li
;timer2 control register
U
C
M
;timer2 mode register
T2
BIT P1.0
;Clock Output pin
;----------------------------------------------
ORG 0000H
LJMP MAIN
;----------------------------------------------;/* main program */
MAIN:
MOV T2MOD, #02H
;enable timer2 output clock
MOV T2CON, #00H
;timer2 stop
MOV TL2,
#00H
;initial timer2 low byte
MOV TH2,
#00H
;initial timer2 high byte
MOV RCAP2L, #LOW F38_4KHz
;initial timer2 reload low byte
MOV RCAP2H, #HIGH F38_4KHz
;initial timer2 reload high byte
SETB TR2
;timer2 start running
SJMP $
;----------------------------------------------
END
216
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
7.2.5 定时器/计数器2作定时器的测试程序(C程序及汇编程序)
1、C程序清单:
/*--------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------*/
/* --- STC89-90xx Series 16-bit Timer Demo ---------------------------*/
/* --- Mobile: (86)13922805190 ------------------------------------------*/
/* --- Fax: 86-755-82905966 ----------------------------------------------*/
/* --- Tel: 86-755-82948412 -----------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------*/
/* If you want to use the program or the program referenced in the */
/* article, please specify in which data and procedures from STC */
/*-------------------------------------------------------------------------------*/
.
d
e
t
i
m
#include "reg51.h"
typedef unsigned char BYTE;
typedef unsigned int WORD;
//----------------------------------------------/* define constants */
#define FOSC 18432000L
C
T
S
#define T1MS (65536-FOSC/12/1000)
/* define SFR */
sbit ET2 = IE^5;
sfr T2CON = 0xc8;
sbit TF2 = T2CON^7;
sbit TR2 = T2CON^2;
sfr T2MOD = 0xc9;
sfr RCAP2L = 0xca;
sfr RCAP2H = 0xcb;
sfr TL2 = 0xcc;
sfr TH2 = 0xcd;
sbit TEST_LED = P1^0;
/* define variables */
WORD count;
U
C
M
Li
//1ms timer calculation method in 12T mode
//timer2 control register
//timer2 mode register
//work LED, flash once per second
//1000 times counter
//----------------------------------------------南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
217
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
/* Timer2 interrupt routine */
void tm2_isr() interrupt 5 using 1
{
TF2 = 0;
if (count-- == 0)
{
count = 1000;
TEST_LED = ! TEST_LED;
}
}
//----------------------------------------------/* main program */
void main()
{
RCAP2L = TL2 = T1MS;
RCAP2H = TH2 = T1MS >> 8;
TR2 = 1;
ET2 = 1;
EA = 1;
count = 0;
while (1);
}
C
T
S
临时技术支持:13922829991
研发顾问:13922809991
//1ms * 1000 -> 1s
//reset counter
//work LED flash
.
d
e
t
i
m
//initial timer2 low byte
//initial timer2 high byte
//timer2 start running
//enable timer2 interrupt
//open global interrupt switch
//initial counter
U
C
M
Li
//loop
2、汇编程序清单:
/*--------------------------------------------------------------------------------*/
/* --- STC MCU International Limited -----------------------------------*/
/* --- STC89-90xx Series 16-bit Timer Demo ---------------------------*/
/* --- Mobile: (86)13922805190 ------------------------------------------*/
/* --- Fax: 86-755-82905966 ----------------------------------------------*/
/* --- Tel: 86-755-82948412 -----------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------*/
/* If you want to use the program or the program referenced in the */
/* article, please specify in which data and procedures from STC */
/*-------------------------------------------------------------------------------*/
;/* define constants */
T1MS
EQU 0FA00H
;1ms(1000Hz) timer (65536-18432000/12/1000)
;/* define SFR */
ET2
218
BIT
IE.5
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
T2CON EQU
TF2 BIT
TR2
BIT
0C8H
T2CON.7
T2CON.2
;timer2 control register
T2MOD EQU
RCAP2L EQU
RCAP2H EQU
TL2
EQU
TH2
EQU
0C9H
0CAH
0CBH
0CCH
0CDH
;timer2 mode register
TEST_LED
BIT P1.0
;/* define variables */
COUNT DATA 30H
0000H
MAIN
002BH
TM2_ISR
研发顾问:13922809991
;work LED, flash once per second
.
d
e
t
i
m
;1000 times counter (2 bytes)
;----------------------------------------------ORG
LJMP
ORG
LJMP
临时技术支持:13922829991
C
T
S
;-----------------------------------------------
U
C
M
;/* main program */
MAIN:
MOV T2MOD,#00H
MOV T2CON,#00H
MOV TL2,#00H
MOV TH2,#00H
MOV RCAP2L,#LOW T1MS
MOV RCAP2H,#HIGH T1MS
SETB TR2
SETB ET2
SETB EA
CLR A
MOV COUNT,A
MOV COUNT+1,A
SJMP $
Li
;initial timer2 mode
;timer2 stop
;initial timer2 low byte
;initial timer2 high byte
;initial timer2 reload low byte
;initial timer2 reload high byte
;timer2 start running
;enable timer2 interrupt
;open global interrupt switch
;initial counter
;-----------------------------------------------
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
219
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
;/* Timer2 interrupt routine */
TM2_ISR:
PUSH ACC
PUSH PSW
CLR TF2
MOV A,
COUNT
ORL A,
COUNT+1
JNZ SKIP
MOV COUNT, #LOW 1000
MOV COUNT+1,
#HIGH 1000
CPL TEST_LED
SKIP:
CLR C
MOV A,
COUNT
SUBB A,
#1
MOV COUNT, A
MOV A,
COUNT+1
SUBB A,
#0
MOV COUNT+1,A
POP PSW
POP ACC
RETI
;----------------------------------------------
220
END
C
T
S
南通国芯微电子有限公司
临时技术支持:13922829991
研发顾问:13922809991
;check whether count(2byte) is equal to 0
;1ms * 1000 -> 1s
;work LED flash
.
d
e
t
i
m
;count--
U
C
M
Li
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
第8章 串行口通信
STC90C58AD系列单片机内部集成有一个功能很强的全双工串行通信口,与传统8051单片
机的串口完全兼容。设有������������������������������
2�����������������������������
个互相独立的接收、发送缓冲器,可以同时发送和接收数据。发送
缓冲器只能写入而不能读出,接收缓冲器只能读出而不能写入,,因而两个缓冲器可以共用一
个地址码(����������������������������
99H�������������������������
)。两个缓冲器统称串行通信特殊功能寄存器�����
SBUF�
。
串行通信设有4种工作方式,其中两种方式的波特率是可变的,另两种是固定的,以供不
同应用场合选用。波特率由内部定时器/计数器产生,用软件设置不同的波特率和选择不同的
工作方式。主机可通过查询或中断方式对接收/发送进行程序处理,使用十分灵活。
STC90C58AD系列单片机串行口对应的硬件部分是TxD和RxD引脚。通过设置特殊功能寄存
器AUXR中的UART_P1/AUXR.7位,串行口(UART)功能可以在P3口和P1口之间任意切换。当串
行口功能在P3口实现时,对应的管脚是P3.0/RxD和P3.1/TxD。当串行口功能在P1口实现时,对
应的管脚是P1.6/RxD和P1.7/TxD。
.
d
e
t
i
m
STC90C58AD系列单片机的串行通信口,除用于数据通信外,还可方便地构成一个或多个
并行I/O口,或作串����������������
—���������������
并转换,或用于扩展串行外设等。
8.1 串行口相关寄存器
C
T
S
符号
描述
地址
SCON
Serial Control
98H
SBUF
Serial Buffer
99H
PCON
Power Control
87H
IE
Interrupt Enable
A8H
IPH
SADDR
中断优先级寄存
器高
中断优先级寄存
器低
Slave Address
Mask
Slave Address
A9H
AUXR
Auxiliary register
8EH
IP
SADEN
南通国芯微电子有限公司
B7H
B8H
U
C
M
Li
位地址及符号
MSB
SM0/FE
SM1
SM2
LSB
REN
TB8
POF
GF1
RB8
TI
RI
PD
IDL
复位值
0000 0000B
xxxx xxxxB
SMOD SMOD0
EA
-
ET2
ES
ET1
GF0
EX1
ET0
EX0
PX3H PX2H PT2H PSH PT1H PX1H PT0H PX0H
-
-
PT2
PS
PT1
B9H
PX1
PT0
PX0
00x1 0000B
0x00 0000B
xx00 0000B
xx00 0000B
0000 0000B
0000 0000B
UART_P1
-
-
总机:0513-5501 2928 / 2929 / 2966
-
-
-
EXTRAM ALEOFF 0xxx xx00B
传真:0513-5501 2969 / 2956 / 2947
221
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
1. 串行口控制寄存器SCON和PCON
STC90C58AD系列单片机的串行口设有两个控制寄存器:串行控制寄存器SCON和波特率
选择特殊功能寄存器PCON。
串行控制寄存器SCON用于选择串行通信的工作方式和某些控制功能。其格式如下:
SCON : 串行控制寄存器 (可位寻址)
SFR name
SCON
Address
98H
bit
name
B7
SM0/FE
B6
SM1
B5
SM2
B4
REN
B3
TB8
B2
RB8
B1
TI
B0
RI
SM0/FE:当PCON寄存器中的SMOD0/PCON.6位为1时,该位用于帧错误检测。当检测到一个
无效停止位时,通过UART接收器设置该位。它必须由软件清零。
当PCON寄存器中的SMOD0/PCON.6位为0时,该位和SM1一起指定串行通信的工作
方式,如下表所示。
.
d
e
t
i
m
其中SM0、SM1按下列组合确定串行口的工作方式:
SM0 SM1 工作方式
0
0
方式0
0
1
方式1
1
0
方式2
1
1
方式3
Li
功能说明
波特率
同步移位串行
方式:移位寄
波特率是SYSclk/12,
存器
8位UART,
( 2SMOD/32 )×(定时器1的溢出率�)
波特率可变
9位UART ( 2SMOD / 64) x SYSclk系统工作时钟频率
C
T
S
U
C
M
9位UART,
(2SMOD/32 )x(定时器1的溢出率�)
波特率可变
当������
单片机工作在12T模式����������
时���������
,定时器�����
1的溢出率 = SYSclk/12/( 256 - T H1);
当������
单片机工作在6T模式������������
时, ��������
定时器�����
1的溢出率 = SYSclk / 6 / ( 256 - T H1)
SM2:允许方式2或方式3多机通信控制位。在方式2或方式3时,如SM2位为1,REN位为1,则
从机处于只有接收到RB8位为1(地址帧)时才激活中断请求标志位RI为1,并向主机请
求中断处理。被确认为寻址的丛机则复位SM2位为0,从而才接收RB8为0的数据帧。
在方式1时,如果SM2位为1,则只有在接收到有效的停止位时才置位中断请求标志位RI
为1;在方式0时,SM2 应为0。
REN:允许/禁止串行接收控制位。由软件置位REN,即REN=1为允许串行接收状态,可启动
串行接收器RxD,开始接收信息。软件复位REN,即REN=0,则禁止接收。
TB8: 在方式2或方式3,它为要发送的第9位数据,按需要由软件置位或清0。例如,可用作数
据的校验位或多机通信中表示地址帧/数据帧的标志位。
RB8: 在方式2或方式3,是接收到的第9位数据。在方式1,若SM2=0,则RB8是接收到的停止
位。方式0不用RB8。
TI: 发送中断请求中断标志位。在方式0,当串行发送数据第8位结束时,由内部硬件自动
置位,即TI=1,向主机请求中断,响应中断后必须用软件复位,即TI=0。在其他方式
中,则在停止位开始发送时由内部硬件置位,必须用软件复位。
222
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RI: 接收中断请求标志位。在方式0,当串行接收到第8位结束时由内部硬件自动置位RI=1,
向主机请求中断,响应中断后必须用软件复位,即RI=0。在其他方式中,串行接收到
停止位的中间时刻由内部硬件置位,即RI=1(例外情况见SM2说明),必须由软件复
位,即RI=0。
SCON的所有位可通过整机复位信号复位为全�
“ 0”�
。 SCON的字节地址尾98H,可位寻
址,各位地址为98H~~9FH,可用软件实现位设置。当用指令改变SCON的有关内容时,其改
变的状态将在下一条指令的第一个机器周期的S1P1状态发生作用。如果一次串行发送已经开
始,则输出TB8将是原先的值,不是新改变的值。
串行通信的中断请求:当一帧发送完成,内部硬件自动置位TI,即TI=1,请求中断处理;
当接收完一帧信息时,内部硬件自动置位RI,即RI=1,请求中断处理。由于TI和RI以���
“��
或逻
辑���������������������������
”��������������������������
关系向主机请求中断,所以主机响应中断时事先并不知道是TI还是RI请求的中断,必须在
中断服务程序中查询TI和RI进行判别,然后分别处理。因此,两个中断请求标志位均不能由硬
件自动置位,必须通过软件清0,否则将出现一次请求多次响应的错误。
.
d
e
t
i
m
电源控制寄存器PCON中的SMOD/PCON.7用于设置方式1、方式2、方式3的波特率是否加
倍。
电源控制寄存器PCON格式如下:
PCON : 电源控制寄存器 (不可位寻址)
SFR name Address
bit
B7
B6
B5
B4
B3
B2
B1 B0
PCON
87H
name SMOD SMOD0
POF GF1 GF0 PD IDL
C
T
S
U
C
M
Li
SMOD:波特率选择位。当用软件置位SMOD,即SMOD=1,则使串行通信方式1、2、3的波
特率加倍;SMOD=0,则各工作方式的波特率加倍。复位时SMOD=0。
SMOD0:帧错误检测有效控制位。当SMOD0=1,SCON寄存器中的SM0/FE位用于FE(帧错误
检测)功能;当SMOD0=0,SCON寄存器中的SM0/FE位用于SM0功能,和SM1一起指
定串行口的工作方式。复位时SMOD0=0
2. 串行口数据缓冲寄存器SBUF
STC90C58AD系列单片机的串行口缓冲寄存器(SBUF)的地址是99H,实际是2个缓冲器,写
SBUF的操作完成待发送数据的加载,读SBUF的操作可获得已接收到的数据。两个操作分别对应
两个不同的寄存器,1个是只写寄存器,1个是只读寄存器。
串行通道内设有数据寄存器。在所有的串行通信方式中,在写入SBUF信号的控制下,把
数据装入相同的9位移位寄存器,前面8位为数据字节,其最低位为移位寄存器的输出位。根据
不同的工作方式会自动将�
“1”�
或TB8的值装入移位寄存器的第9位,并进行发送。
串行通道的接收寄存器是一个输入移位寄存器。在方式0时它的字长为8位,其他方式时为
9位。当一帧接收完毕,移位寄存器中的数据字节装入串行数据缓冲器SBUF中,其第9位则装
入SCON寄存器中的RB8位。如果由于SM2使得已接收到的数据无效时,RB8和SBUF中内容不
变。
由于接收通道内设有输入移位寄存器和SBUF缓冲器,从而能使一帧接收完将数据由移位
寄存器装入SBUF后,可立即开始接收下一帧信息,主机应在该帧接收结束前从SBUF缓冲器中
将数据取走,否则前一帧数据将丢失。SBUF以并行方式送往内部数据总线。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
223
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
3. 从机地址控制寄存器SADEN和SADDR
为了方便多机通信,STC90C58AD系列单片机设置了从机地址控制寄存器SADEN和SADDR。
其中SADEN是从机地址掩模寄存器(地址为B9H,复位值为00H),SADDR是从机地址寄存器(地址
为A9H,复位值为00H)。
4. 与串行口中断相关的寄存器IE和IPH、IP
串行口中断允许位ES位于中断允许寄存器IE中,中断允许寄存器的格式如下:
IE : 中断允许寄存器 (可位寻址)
SFR name
Address
bit
B7
B6
B5
B4
B3
B2
B1
B0
IE
A8H
name
EA
-
ET2
ES
ET1
EX1
ET0
EX0
.
d
e
t
i
m
EA : CPU的总中断允许控制位,EA=1,CPU开放中断,EA=0,CPU屏蔽所有的中断申请。
EA的作用是使中断允许形成多级控制。即各中断源首先受EA控制;其次还受各中断源自
己的中断允许控制位控制。
Li
ES : 串行口中断允许位,ES=1,允许串行口中断,ES=0,禁止串行口中断。
U
C
M
串行口中断优先级控制位PS/PSH位于中断优先级控制寄存器IP/IPH中,中断优先级控制寄
存器的格式如下:
C
T
S
IPH: 中断优先级控制寄存器高(不可位寻址)
SFR name Address
IPH
B7H
bit
B7
B6
name PX3H PX2H
B5
B4
PT2H
PSH
B3
B2
B1
B0
PT1H PX1H PT0H PX0H
IP : 中断优先级控制寄存器低 (可位寻址)
SFR name
Address
bit
B7
B6
B5
B4
B3
B2
B1
B0
IP
B8H
name
-
-
PT2
PS
PT1
PX1
PT0
PX0
PSH, PS:
224
串口1中断优先级控制位。
当PSH=0且PS=0时,串口1中断为最低优先级中断(优先级0)
当PSH=0且PS=1时,串口1中断为较低优先级中断(优先级1)
当PSH=1且PS=0时,串口1中断为较高优先级中断(优先级2)
当PSH=1且PS=1时,串口1中断为最高优先级中断(优先级3)
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
5.由AUXR寄存器设置串行口/UART是在P3口还是在P1口
AUXR : Auxiliary Register
Mnemonic
AUXR
Add
bit
B7
8EH name UART_P1
B6
B5
B4
B3
B2
B1
B0
Reset Value
-
-
-
-
-
EXTRAM
ALEOFF
0xxx,xx00
UART_P1: 0, 复位后AUXR.7/UART_P1=0,串行口/UART在P3口[RxD/P3.0,TxD/P3.1]
���
1, 通过设置AUXR.7/UART_P1=1,将串行口/UART从P3口切换到P1口[RxD/P1.6,TxD/P1.7]
EXTRAM: ����������
内部/外部RAM存取
0������������������������������������������������������
,�����������������������������������������������������
允许访问内部扩展0000H-0FFFH单元(4096字节RAM),超过0FFFH的地址空间总是访问外部数
据存储器
1, 禁止访问内部扩展0000H-0FFFH 单元(4096字节RAM),直接访问外部数据存储器数据
ALEOFF����������
:ALE信号输出控制
0, ALE信号正常输出。
1, 禁止ALE 信号输出。但在访问外部数据空间及外部程序空间时有信号输出。
C
T
S
南通国芯微电子有限公司
U
C
M
总机:0513-5501 2928 / 2929 / 2966
.
d
e
t
i
m
Li
传真:0513-5501 2969 / 2956 / 2947
225
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.2 串行口工作模式
STC90C58AD系列单片机的串行通信有4种工作模式,可通过软件编程对SCON中的SM0、
SM1的设置进行选择。其中模式1、模式2和模式3为异步通信,每个发送和接收的字符都带有1
个启动位和1个停止位。在模式0中,串行口被作为1个简单的移位寄存器使用。
8.2.1 串行口工作模式0:同步移位寄存器
在模式0状态,串行通信工作在同步移位寄存器模式,当当单片机工作在6T模式时,其
波特率固定为SYSclk/6。当单片机工作在12T时,其波特率固定为SYSclk/12。串行口数据由
RxD(RxD/P3.0或RxD/P1.6)端输入,同步移位脉冲(SHIFTCLOCK)由TxD(TxD/P3.1或TxD/
P1.7)输出,发送、接收的是8位数据,低位在先。
.
d
e
t
i
m
模式0的发送过程:当主机执行将数据写入发送缓冲器SBUF指令时启动发送,串行口即将
8位数据以SYSclk/12或SYSclk/6的波特率从RxD管脚输出(从低位到高位),发送完中断标志TI
置"1",TxD管脚输出同步移位脉冲(SHIFTCLOCK)。波形如图8-1中“发送”所示。
U
C
M
Li
当写信号有效后,相隔一个时钟,发送控制端SEND有效(高电平),允许RxD发送数据,同
时允许TxD输出同步移位脉冲。一帧(8位)数据发送完毕时,各控制端均恢复原状态,只有TI保
持高电平,呈中断申请状态。在再次发送数据前,必须用软件将TI清0。
C
T
S
模式0接收过程:模式0接收时,复位接收中断请求标志RI,即RI=0,置位允许接收控制
位REN=1时启动串行模式0接收过程。启动接收过程后,RxD为串行输入端,TxD为同步脉冲
输出端。串行接收的波特率为SYSclk/12或SYSclk/6。其时序图如图8-1中“接收”所示。
当接收完成一帧数据(8位)后,控制信号复位,中断标志RI被置"1",呈中断申请状态。当
再次接收时,必须通过软件将RI清0
工作于模式0时,必须清0多机通信控制位SM2,使不影响TB8位和RB8位。由于波特率固
定为SYSclk/12或SYSclk/6,无需定时器提供,直接由单片机的时钟作为同步移位脉冲。
串行口工作模式0的示意图如图8-1所示
由示意图中可见,由TX和RX控制单元分别产生中断请求信号并置位TI=1或RI =1,经��
“�
或
门�������������������������
“������������������������
送主机请求中断,所以主机响应中断后必须软件判别是TI还是RI请求中断,必须软件清0
中断请求标志位TI或RI。
226
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
INTERNAL BUS
WRITE
TO
SBUF
DS Q
CL
RxD
OUTPUT FUNCTION
SBUF
ZERO DETECTOR
SYSclk/12
SYSclk/6
START
0
TX CONTROL
1
在烧录用户程序时在
STC-ISP编程器中设置
SERIAL
PORT
INTERRUPT
REN
RI
TX CLOCK
TI
RX CLOCK
RI
START
SHIFT
SHIFT
SEND
RX CONTROL SHIFT
1 1 1 1 1 1 1 0
INPUT SHIFT REG.
LOAD
SBUF
C
T
S
TxD
OUTPUT FUNCTION
SHIFT
CLOCK
RECEIVE
U
C
M
SHIFT
.
d
e
t
i
m
Li
RxD
INPUT FUNCTION
SBUF
READ
SBUF
INTERNAL BUS
WRITE TO SBUF
SEND
SHIFT
RXD(DATA OUT)
TRANSMIT
D0
D1
D2
D3
D4
D5
D6
D7
TXD(SHIFT CLOCK)
TI
WRITE TO SCON(CLEAR RI)
RI
RECEIVE
RECEIVE
SHIFT
RXD(DATA IN)
D0
D1
D2
D3
D4
D5
D6
D7
TXD(SHIFT CLOCK)
图8-1 串行口模式0功能结构及时序示意图
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
227
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.2.2 串行口工作模式1:8位UART,波特率可变
当软件设置SCON的SM0、SM1为�
“ 01”����������
时,串行通信则以模式1工作。此模式为8位
UART格式,一帧信息为10位:1位起始位,8位数据位(低位在先)和1位停止位。波特率可
变,即可根据需要进行设置。TxD(TxD/P3.1或RxD/P1.7)为发送信息,RxD(RxD/P3.0或RxD/
P1.6)为接收端接收信息,串行口为全双工接受/发送串行口。
图8-2为串行模式1的功能结构示意图及接收/发送时序图
模式1的发送过程:串行通信模式发送时,数据由串行发送端TxD输出。当主机执行一条
写�
“SBUF“����������������
的指令就启动串行通信的发送,写�
“SBUF”�����
信号还把�
“1”���������
装入发送移位寄存器
的第9位,并通知TX控制单元开始发送。发送各位的定时是由16分频计数器同步。
移位寄存器将数据不断右移送TxD端口发送,在数据的左边不断移入�
“ 0”�����
作补充。当
数据的最高位移到移位寄存器的输出位置,紧跟其后的是第9位�
“1”����������
,在它的左边各位全为
“0”���������
,这个状态条件,使TX控制单元作最后一次移位输出,然后使允许发送信号�
“SEND”
失效,完成一帧信息的发送,并置位中断请求位TI,即TI=1,向主机请求中断处理。
.
d
e
t
i
m
Li
模式1的接收过程:当软件置位接收允许标志位REN,即REN=1时,接收器便以选定波特
率的16分频的速率采样串行接收端口RxD,当检测到RxD端口从�
“1”��
→�
“0”�������
的负跳变时就启
动接收器准备接收数据,并立即复位16分频计数器,将1FFH植装入移位寄存器。复位16分频
计数器是使它与输入位时间同步。
U
C
M
16分频计数器的16个状态是将1波特率(每位接收时间)均为16等份,在每位时间的7、
8、9状态由检测器对RxD端口进行采样,所接收的值是这次采样直经����������
“���������
三中取二�����
”����
的值,即3
次采样至少2次相同的值,以此消除干扰影响,提高可靠性。在起始位,如果接收到的值不为
“0”��������������������������
(低电平),则起始位无效,复位接收电路,并重新检测�"1"��
→�"0"���������
的跳变。如果接收到
的起始位有效,则将它输入移位寄存器,并接收本帧的其余信息。
C
T
S
接收的数据从接收移位寄存器的右边移入,已装入的1FFH向左边移出,当起始位�"0"��
移到
移位寄存器的最左边时,使RX控制器作最后一次移位,完成一帧的接收。若同时满足以下两
个条件:
·RI=0;
·SM2=0或接收到的停止位为1。
则接收到的数据有效,实现装载入SBUF,停止位进入RB8,置位RI,即RI=1,向主机请
求中断,若上述两条件不能同时满足,则接收到的数据作废并丢失,无论条件满足与否,接收
器重又检测RxD端口上的�"1"��
→�
"0"��������������������������
的跳变,继续下一帧的接收。接收有效,在响应中断后,必
须由软件清0,即RI=0。通常情况下,串行通信工作于模式1时,SM2设置为�"0"�
。
串行通信模式1的波特率是可变的,可变的波特由定时器/计数器1或独立波特率发生器产
生。
串行通信模式1的波特率=2SMOD/32×(定时器/计数器1溢出率)
当������
单片机工作在12T模式����������
时���������
,定时器�����
1的溢出率 = SYSclk/12/( 256 - TH1);
当������
单片机工作在6T模式�����������
时����������
, 定时器�����
1的溢出率 = SYSclk /6/ ( 256 - TH1)
228
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
INTERNAL BUS
TB8
Timer 1
Overflow
WRITE
TO
SBUF
÷2
DS Q
CL
SBUF
ZERO DETECTOR
SMOD
=1
SMOD
=0
TxD
SHIFT
START
÷16
TX CONTROL
TX CLOCK
SERIAL
PORT
INTERRUPT
SAMPLE
TI
SEND
RI
LOAD
SBUF
Li
RX CONTROL SHIFT
1FFH
CU
BIT
DETECTOR
M
RxD
C
T
S
.
d
e
t
i
m
÷16
RX CLOCK
START
1-TO-0
TRANSITION
DETECTOR
DATA
INPUT SHIFT REG.
(9 BITS)
SHIFT
LOAD
SBUF
SBUF
READ
SBUF
INTERNAL BUS
TX
CLOCK
WRITE TO SBUF
SEND
TRANSMIT
DATA
SHIFT
D0
TXD
START BIT
TI
D1
D2
D3
D4
D5
D6
D7
START BIT
D0
D1
D2
D3
D4
D5
STOP BIT
RX CLOCK
RXD
RECEIVE BIT DETECTOR SAMPLE TIMES
SHIFT
D6
D7
STOP BIT
RI
图8-2 串行口模式1功能结构示意图及接收/发送时序图
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
229
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.2.3 串行口工作模式2:9位UART,波特率固定
当SM0、SM1两位为10时,串行口工作在模式2。串行口工作模式2为9位数据异步通信
UART模式,其一帧的信息由11位组成:1位起始位,8位数据位(低位在先),1位可编程位(第
9位数据)和1位停止位。发送时可编程位(第9位数据)由SCON中的TB8提供,可软件设置为1或
0,或者可将PSW中的奇/偶校验位P值装入TB8(TB8既可作为多机通信中的地址数据标志位,
又可作为数据的奇偶校验位)。接收时第9位数据装入SCON的RB8。TxD为发送端口,RxD为
接收端口,以全双工模式进行接收/发送。
模式2的波特率为:
串行通信模式2波特率=2SMOD/64×(SYSclk系统工作时钟频率)
上述波特率可通过软件对PCON中的SMOD位进行设置,当SMOD=1时,选择1/32(SYSclk)
;当SMOD=0时,选择1/64(SYSclk) ,故而称SMOD为波特率加倍位。可见,模式2的波特率基
本上是固定的。
.
d
e
t
i
m
Li
图8-3为串行通信模式2的功能结构示意图及其接收/发送时序图。
由图8-3可知,模式2和模式1相比,除波特率发生源略有不同,发送时由TB8提供给移位寄
存器第9数据位不同外,其余功能结构均基本相同,其接收/发送操作过程及时序也基本相同。
U
C
M
当接收器接收完一帧信息后必须同时满足下列条件:
·RI=0
C
T
S
·SM2=0或者SM2=1,并且接收到的第9数据位RB8=1。
当上述两条件同时满足时,才将接收到的移位寄存器的数据装入SBUF和RB8中,并置位
RI=1,向主机请求中断处理。如果上述条件有一个不满足,则刚接收到移位寄存器中的数据无
效而丢失,也不置位RI。无论上述条件满足与否,接收器又重新开始检测RxD输入端口的跳变
信息,接收下一帧的输入信息。
在模式2中,接收到的停止位与SBUF、RB8和RI无关。
通过软件对SCON中的SM2、TB8的设置以及通信协议的约定,为多机通信提供了方便。
230
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
INTERNAL BUS
TB8
WRITE
TO
SBUF
DS Q
CL
SBUF
TxD
ZERO DETECTOR
SYSclk/2
STOP BIT
START GEN.
MODE 2
÷16
÷2
TX CLOCK
TI
SERIAL
PORT
INTERRUPT
SMOD=1
SMOD=0
DATA
SEND
1-TO-0
TRANSITION
DETECTOR
START
RX
RI
CLOCK
LOAD
SBUF
Li
RX CONTROL SHIFT
1FFH
CU
BIT
DETECTOR
M
RxD
C
T
S
.
d
e
t
i
m
÷16
SAMPLE
(SMOD IS PCON.7)
SHIFT
TX CONTROL
INPUT SHIFT REG.
(9 BITS)
SHIFT
LOAD
SBUF
SBUF
READ
SBUF
INTERNAL BUS
TX
CLOCK
WRITE TO SBUF
SEND
TRANSMIT
DATA
SHIFT
D0
TXD
START BIT
TI
D1
D2
D3
D4
D5
D6
D7
TB8
STOP BIT
START BIT
D0
D1
D2
D3
D4
D5
D6
D7
STOP BIT GEN
RX CLOCK
RECEIVE
RXD
RB8
STOP BIT
BIT DETECTOR SAMPLE TIMES
SHIFT
RI
图8-3 串行口模式2功能结构示意图及接收/发送时序图
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
231
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.2.4 串行口工作模式3:9位UART,波特率可变
当SM0、SM1两位为11时,串行口工作在模式3。������
串行通信��
模式3为9位数据异步通信UART
模式��������
,�������
其一帧的信息由11位组成:1位起始位,8位数据位(低位在先),1位可编程位(第9位数
据)和1位停止位。发送时可编程位(第9位数据)由SCON中的TB8提供,可软件设置为1或0,或
者可将PSW中的奇/偶校验位P值装入TB8(TB8既可作为多机通信中的地址数据标志位,又可作
为数据的奇偶校验位)。接收时第9位数据装入SCON的RB8。TxD为发送端口,RxD为接收端
口,以全双工模式进行接收/发送。
模式3的波特率为:
串行通信模式3波特率=2SMOD/32×(定时器/计数器1的溢出率)
当������
单片机工作在12T模式����������
时���������
,定时器�����
1的溢出率 = SYSclk/12/( 256 - TH1);
当������
单片机工作在6T模式�����������
时����������
, 定时器�����
1的溢出率 = SYSclk /6/ ( 256 - TH1)
.
d
e
t
i
m
可见,模式3和模式1一样,其波特率可通过软件对定时器/计数器1或独立波特率发生器的
设置进行波特率的选择,是可变的。
Li
图8-4为串行口工作模式3的功能结构示意图及其接收/发送时序图。
由图8-4可知,模式3和模式1相比,除发送时由TB8提供给移位寄存器第9数据位不同外,
其余功能结构均基本相同,其接收����������������
‘���������������
发送操作过程及时序也基本相同。
U
C
M
当接收器接收完一帧信息后必须同时满足下列条件:
·RI=0
C
T
S
·SM2=0或者SM2=1,并且接收到的第9数据位RB8=1。
当上述两条件同时满足时,才将接收到的移位寄存器的数据装入SBUF和RB8中,并置位
RI=1,向主机请求中断处理。如果上述条件有一个不满足,则刚接收到移位寄存器中的数据无
效而丢失,也不置位RI。无论上述条件满足与否,接收器又重新开始检测RxD输入端口的跳变
信息,接收下一帧的输入信息。
在模式3中,接收到的停止位与SBUF、RB8和RI无关。
通过软件对SCON中的SM2、TB8的设置以及通信协议的约定,为多机通信提供了方便。
232
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
INTERNAL BUS
TB8
TIMER 1
OVERFLOW
WRITE
TO
SBUF
DS Q
CL
÷2
SBUF
TxD
ZERO DETECTOR
SMOD
=0
SMOD
=1
SHIFT
START
TX CONTROL
÷16
TX CLOCK
SERIAL
PORT
INTERRUPT
TI
SEND
RI
LOAD
SBUF
.
d
e
t
i
m
÷16
SAMPLE
1-TO-0
TRANSITION
DETECTOR
DATA
RX CLOCK
START
Li
RX CONTROL SHIFT
1FFH
CU
BIT
DETECTOR
RxD
C
T
S
M
INPUT SHIFT REG.
(9 BITS)
SHIFT
LOAD
SBUF
SBUF
READ
SBUF
INTERNAL BUS
TX
CLOCK
WRITE TO SBUF
SEND
TRANSMIT
DATA
SHIFT
D0
TXD
START BIT
TI
D1
D2
D3
D4
D5
D6
D7
TB8
STOP BIT
D1
D2
D3
D4
D5
D6
D7
STOP BIT GEN
RECEIVE
RX CLOCK
÷16 RESET
RXD
START BIT
D0
RB8
STOP BIT
BIT DETECTOR SAMPLE TIMES
SHIFT
RI
图8-4 串行口模式3功能结构示意图及接收/发送时序图
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
233
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.3 串行通信中波特率的设置
STC90C58AD系列单片机串行通信的波特率随所选工作模式的不同而异,对于工作模式0
和模式2,其波特率与系统时钟频率SYSclk和PCON中的波特率选择位SMOD有关,而模式1和
模式3的波特率除与SYSclk和PCON位有关外,还与定时器/计数器1或BRT独立波特率发生器设
置有关。通过对定时器/计数器1或BRT独立波特率发生器的设置,可选择不同的波特率,所以
这种波特率是可变的。
串行通信模式0,其波特率与系统时钟频率SYSclk有关 。
当用户在烧录用户程序时在STC-ISP编程器中设置单片机为6T/双倍速时,其波特率 =
SYSclk/12。
当用户在烧录用户程序时在STC-ISP编程器中设置单片机为12T/单倍速时,其波特率 =
SYSclk/2。
.
d
e
t
i
m
一旦SYSclk选定且单片机在烧录用户程序时在STC-ISP编程器设置好,则串行通信工作模
式0的波特率固定不变。
U
C
M
Li
串行通信工作模式2,其波特率除与SYSclk有关外,还与SMOD位有关。
其基本表达式为:串行通信模式2波特率=2SMOD/64×(SYSclk系统工作时钟频率)
当SMOD=1时,波特率=2/64(SYSclk)=1/32(SYSclk);
C
T
S
当SMOD=0时,波特率=1/64(SYSclk)。
当SYSclk选定后,通过软件设置PCON中的SMOD位,可选择两种波特率。所以,这种模
式的波特率基本固定。
串行通信模式1和3,其波特率是可变的:
模式1、3波特率=2SMOD/32×(���
定时器/计数器1的溢出率或����������������
BRT�������������
独立波特率发生器的溢出率�)
当������
单片机工作在12T模式����������
时���������
,定时器�����
1的溢出率 = SYSclk/12/( 256 - TH1);
当������
单片机工作在6T模式�����������
时����������
, 定时器�����
1的溢出率 = SYSclk /6/ ( 256 - TH1)
通过对定时器/计数器1和BRT独立波特率发生器的设置,可灵活地选择不同的波特率。在
实际应用中多半选用串行模式1或串行模式3。显然,为选择波特率,关键在于定时器/计数器1
和BRT独立波特率发生器的溢出率的计算。SMOD的选择,只需根据需要执行下列指令就可实
现SMOD=0或1;
MOV
MOV
PCON,#00H
PCON,#80H
;使SMOD=0
;使SMOD=1
SMOD只占用电源控制寄存器PCON的最高一位,其他各位的具体设置应根据实际情况而
定。
234
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
为选择波特率,关键在于定时器/计数器1的溢出率。下面介绍如何计算定时器/计数器1的
溢出率。
定时器/计数器1的溢出率定义为:单位时间(秒)内定时器/计数器1回0溢出的次数,即定
时器/计数器1的溢出率=定时器/计数器1的溢出次数/秒。
STC90C58AD系列单片机设有两个定时器/计数器,因定时器/计数器1具有4种工作方式,而
常选用定时器/计数器1的工作方式2(8位自动重装)作为波特率的溢出率。
设置定时器/计数器1工作于定时模式的工作方式2(8位自动重装),TL1的计数输入来自
于SYSclk经12分频或不分频的脉冲。当单片机工作在12T模式,TL1的计数输入来自于SYSclk经
12分频的脉冲;当单片机工作在6T模式,TL1的计数输入来自于SYSclk经6分频的脉冲。可见,
定时器/计数器1的溢出率与SYSclk和自动重装值N有关,SYSclk越大,特别是N越大,溢出率
也就越高。对于一般情况下,
.
d
e
t
i
m
当单片机工作在12T模式时时,定时器/计数器1溢出一次所需的时间为:
(28—N)×12时钟=(28—N)×12×
Li
当单片机工作在6T模式时,定时器/计数器1溢出一次所需的时间为:
U
C
M
(28—N)×6时钟=(28—N)×6×
1
SYSclk
1
SYSclk
于是得定时器/计数器每秒溢出的次数,即
C
T
S
当单片机工作在12T模式时,定时器/计数器1的溢出率=SYSclk/12×(28-N) (次/秒)
当单片机工作在6T模式时, 定时器/计数器1的溢出率=SYSclk×6×(28-N) (次/秒)
式中SYSclk为系统时钟频率,N为再装入时间常数。
显然,选用定时器/计数器0作波特率的溢出率也一样。选用不同工作方式所获得波特率的
范围不同。因为不同方式的计数位数不同,N取值范围不同,且计数方式较复杂。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
235
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
下表给出各种常用波特率与定时器/计数器1各参数之间的关系。
常用波特率与定时器/计数器1各参数关系(T1x12/AUXR.6=0)
常用波特率
系统时钟频率
(MHz)
SMOD
方式0 MAX:1M
12
×
方式2 MAX:375K
62.5K
方式1和3
19.2K
9.6K
4.8K
2.4K
1.2K
137.5
110
110
12
12
11.059
11.059
11.059
11.059
11.059
11.986
6
1
1
1
0
0
0
0
0
0
12
0
MOV
MOV
MOV
SETB
MOV
MOV
U
C
M
TMOD, #20H
TH1, #××H
TL1, #××H
TR1
PCON, #80H
SCON, #50H
C
T
S
C/T
×
方式
×
重新装入值
×
×
0
0
0
0
0
0
0
0
×
2
2
2
2
2
2
2
2
×
FFH
FDH
FDH
FAH
F4H
F8H
1DH
72H
1
FFFBH
Li
.
d
e
t
i
m
0
;设置定时器/计数器1定时、工作方式2
; 设置定时常数N
;
;启动定时器/计数器1
;设置SMOD=1
;设置串行通信方式1
…
…
设置波特率的初始化程序段如下:
定时器1
执行上述程序段后,即可完成对定时器/计数器1的操作方式及串行通信的工作方式和波特
率的设置。
由于用其他工作方式设置波特率计算方法较复杂,一般应用较少,故不一一论述。
236
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.4 串行口的测试程序(C程序及汇编程序)
1. C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机串行口功能 (8-bit/9-bit) ----------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
typedef unsigned char BYTE;
typedef unsigned int WORD;
#define FOSC 18432000L
#define BAUD 9600
C
T
S
/*Define UART parity mode*/
#define NONE_PARITY 0
#define ODD_PARITY 1
#define EVEN_PARITY 2
#define MARK_PARITY 3
#define SPACE_PARITY 4
U
C
M
//System frequency
//UART baudrate
.
d
e
t
i
m
Li
//None parity
//Odd parity
//Even parity
//Mark parity
//Space parity
#define PARITYBIT EVEN_PARITY
//Testing even parity
sbit bit9 = P2^2;
bit busy;
//P2.2 show UART data bit9
void SendData(BYTE dat);
void SendString(char *s);
void main()
{
#if (PARITYBIT == NONE_PARITY)
SCON = 0x50;
//8-bit variable UART
#elif (PARITYBIT == ODD_PARITY) || (PARITYBIT == EVEN_PARITY) || (PARITYBIT == MARK_PARITY)
SCON = 0xda;
//9-bit variable UART, parity bit initial to 1
#elif (PARITYBIT == SPACE_PARITY)
SCON = 0xd2;
//9-bit variable UART, parity bit initial to 0
#endif
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
237
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
TMOD = 0x20;
TH1 = TL1 = -(FOSC/12/32/BAUD);
TR1 = 1;
ES = 1;
EA = 1;
SendString("STC89-90xx\r\nUart Test !\r\n");
while(1);
临时技术支持:13922829991
研发顾问:13922809991
//Set Timer1 as 8-bit auto reload mode
//Set auto-reload vaule
//Timer1 start run
//Enable UART interrupt
//Open master interrupt switch
}
/*---------------------------UART interrupt service routine
----------------------------*/
void Uart_Isr() interrupt 4 using 1
{
if (RI)
{
RI = 0;
P0 = SBUF;
bit9 = RB8;
}
if (TI)
{
TI = 0;
busy = 0;
}
}
//Clear receive interrupt flag
//P0 show UART data
//P2.2 show parity bit
/*---------------------------Send a byte data to UART
Input: dat (data to be sent)
Output:None
----------------------------*/
void SendData(BYTE dat)
{
while (busy);
ACC = dat;
if (P)
{
#if (PARITYBIT == ODD_PARITY)
TB8 = 0;
#elif (PARITYBIT == EVEN_PARITY)
TB8 = 1;
#endif
}
//Wait for the completion of the previous data is sent
//Calculate the even parity bit P (PSW.0)
//Set the parity bit according to P
C
T
S
238
南通国芯微电子有限公司
U
C
M
.
d
e
t
i
m
Li
//Clear transmit interrupt flag
//Clear transmit busy flag
//Set parity bit to 0
//Set parity bit to 1
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
else
{
#if (PARITYBIT == ODD_PARITY)
TB8 = 1;
//Set parity bit to 1
#elif (PARITYBIT == EVEN_PARITY)
TB8 = 0;
//Set parity bit to 0
#endif
}
busy = 1;
SBUF = ACC;
//Send data to UART buffer
}
/*---------------------------Send a string to UART
Input: s (address of string)
Output:None
----------------------------*/
void SendString(char *s)
{
while (*s)
{
SendData(*s++);
}
}
C
T
S
南通国芯微电子有限公司
U
C
M
.
d
e
t
i
m
Li
//Check the end of the string
//Send current char and increment string ptr
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
239
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 汇编程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机串行口功能 (8-bit/9-bit) ---------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
;/*Define UART parity mode*/
#define NONE_PARITY 0
#define ODD_PARITY 1
#define EVEN_PARITY 2
#define MARK_PARITY 3
#define SPACE_PARITY 4
#define PARITYBIT EVEN_PARITY
;----------------------------------------
BUSY BIT
20H.0
;----------------------------------------
ORG 0000H
LJMP MAIN
C
T
S
//None parity
//Odd parity
//Even parity
//Mark parity
//Space parity
U
C
M
.
d
e
t
i
m
Li
//Testing even parity
;transmit busy flag
ORG 0023H
LJMP UART_ISR
;----------------------------------------
ORG 0100H
MAIN:
CLR BUSY
CLR EA
MOV SP,
#3FH
#if (PARITYBIT == NONE_PARITY)
MOV SCON, #50H
;8-bit variable UART
#elif (PARITYBIT == ODD_PARITY) || (PARITYBIT == EVEN_PARITY) || (PARITYBIT == MARK_PARITY)
MOV SCON, #0DAH
;9-bit variable UART, parity bit initial to 1
#elif (PARITYBIT == SPACE_PARITY)
MOV SCON, #0D2H
;9-bit variable UART, parity bit initial to 0
#endif
;-------------------------------
240
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
MOV TMOD, #20H
MOV A,
#0FBH
MOV TH1,
A
MOV TL1,
A
SETB TR1
SETB ES
SETB EA
;------------------------------
MOV DPTR, #TESTSTR
LCALL SENDSTRING
;------------------------------
SJMP $
;----------------------------------------TESTSTR:
DB "STC89-90xx Uart Test !",0DH,0AH,0
;/*---------------------------;UART2 interrupt service routine
;----------------------------*/
UART_ISR:
PUSH ACC
PUSH PSW
JNB RI,
CHECKTI
CLR RI
MOV P0,
SBUF
MOV C,
RB8
MOV P2.2,
C
CHECKTI:
JNB TI,
ISR_EXIT
CLR TI
CLR BUSY
ISR_EXIT:
POP PSW
POP ACC
RETI
C
T
S
临时技术支持:13922829991
研发顾问:13922809991
;Set Timer1 as 8-bit auto reload mode
;256-18432000/12/32/9600
;Set auto-reload vaule
;Timer1 start run
;Enable UART interrupt
;Open master interrupt switch
;Load string address to DPTR
;Send string
.
d
e
t
i
m
;Test string
U
C
M
Li
;Check RI bit
;Clear RI bit
;P0 show UART data
;P2.2 show parity bit
;Check S2TI bit
;Clear S2TI bit
;Clear transmit busy flag
;/*---------------------------;Send a byte data to UART
;Input: ACC (data to be sent)
;Output:None
;----------------------------*/
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
241
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
SENDDATA:
JB
BUSY, $
MOV ACC, A
JNB P,
EVEN1INACC
ODD1INACC:
#if (PARITYBIT == ODD_PARITY)
CLR TB8
#elif (PARITYBIT == EVEN_PARITY)
SETB TB8
#endif
SJMP PARITYBITOK
EVEN1INACC:
#if (PARITYBIT == ODD_PARITY)
SETB TB8
#elif (PARITYBIT == EVEN_PARITY)
CLR TB8
#endif
PARITYBITOK:
SETB BUSY
MOV SBUF, A
RET
C
T
S
242
南通国芯微电子有限公司
研发顾问:13922809991
;Wait for the completion of the previous data is sent
;Calculate the even parity bit P (PSW.0)
;Set the parity bit according to P
;Set parity bit to 0
;Set parity bit to 1
.
d
e
t
i
m
;Set parity bit to 1
;Set parity bit to 0
Li
;Parity bit set completed
U
C
M
;/*---------------------------;Send a string to UART
;Input: DPTR (address of string)
;Output:None
;----------------------------*/
SENDSTRING:
CLR A
MOVC A,
@A+DPTR
JZ
STRINGEND
INC DPTR
LCALL SENDDATA
SJMP SENDSTRING
STRINGEND:
RET
;----------------------------------------
END
临时技术支持:13922829991
;Send data to UART buffer
;Get current char
;Check the end of the string
;increment string ptr
;Send current char
;Check next
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.5 双机通信
STC90C58AD系列单片机的串行通信根据其应用可分为双机通信和多机通信两种。下面先
介绍双机通信。
如果两个8051应用系统相距很近,可将它们的串行端口直接相连(TXD—RXD,RXD—
TXD,GND—GND—�������������������������������
地),即可实现双机通信。为了增加通信距离,减少通道及电源干扰,
可采用RS—232C或RS—422、RS—485标准进行双机通信,两通信系统之间采用光�����
—����
电隔离技
术,以减少通道及电源的干扰,提高通信可靠性。
8051
TxD
RxD
RxD
TxD
GND
GND
U
C
M
.
d
e
t
i
m
8051
Li
为确保通信成功,通信双方必须在软件上有系列的约定通常称为软件通信�������
“������
协议����
”���
。现举
例简介双机异步通信软件�������
“������
协议����
”���
如下:
C
T
S
通信双方均选用2400波特的传输速率,设系统的主频SYSclk=6MHz,甲机发送数据,乙机
接收数据。在双机开始通信时,先由甲机发送一个呼叫信号(例如�
“06H”��������
),以询问乙机是
否可以接收数据;乙机接收到呼叫信号后,若同意接收数据,则发回�
“00H”�������
作为应答信号,
否则发�
“05H”���������������������������
表示暂不能接收数据,;甲机只有在接收到乙机的应答信号�
“00H”����
后才可将
存储在外部数据存储器中的内容逐一发送给乙机,否则继续向乙机发呼叫信号,直到乙机同意
接收。其发送数据格式如下:
字节数n
数据1
数据2
数据3
…
数据n
累加校验和
字节数n:甲机向乙机发送的数据个数;
数据1~数据n:甲机将向乙机发送的n帧数据;
累加校验和:为字节数n、数据1、����
…���
、数据n,这(n+1)个字节内容的算术累加和.
乙机根据接收到的������������
“�����������
校验和��������
”�������
判断已接收到的n个数据是否正确。若接收正确,向甲机回发
“0FH”信号,否则回发“F0H”信号。甲机只有在接收到乙机发回的�
“0FH”���������
信号才算完成发送任
务,返回被调用的程序,否则继续呼叫,重发数据。
不同的通信要求,软件�����������������������������
“����������������������������
协议��������������������������
”�������������������������
内容也不一样,有关需甲、乙双方共同遵守的约定应尽量
完善,以防止通信不能正确判别而失败。
STC90C58AD系列单片机的串行通信,可直接采用查询法,也可采用自动中断法。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
243
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
(1)������������
查询方式双机通信软件举例
①��������
甲机发送子程序段
下图为甲机发送子程序流程图。
开始
定时器,串行口初始化
发送数据
地址指针DPTR,长度计数器
R7,校验寄存器R6置初值
发送完否?
N
Y
.
d
e
t
i
m
发送校验和
发送呼叫信号06H
CU
等待乙机回答
N
是00H?
C
T
S
Y
发字节长度数
M
N
Li
等待乙机回答
传送正确吗?
Y
返回
甲机发送程序设置:
(a) ��������������������������������������������
波特率设置:选用定时器���������������������������������
/��������������������������������
计数器�����������������������������
1����������������������������
定时模式、工作方式�������������������
2������������������
,计数常数�������������
F3H����������
,���������
SMOD=1���
。波
特率为����������
2400������
(位����
/���
秒);
(b) ��������������������
串行通信设置:异步通信方式�������
1������
,允许接收;
244
(c) ��������������������������������������������
内部������������������������������������������
RAM���������������������������������������
和工作寄存器设置:������������������������������
31H���������������������������
和��������������������������
30H�����������������������
单元存放发送的数据块首地址;���������
2FH������
单元存放
发送的数据块个数;����������
R6��������
为累加和寄存器。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
甲机发送子程序清单:
START:
MOV
MOV
MOV
MOV
MOV
SETB
ST-RAM:
MOV
MOV
MOV
MOV
TX-ACK:
MOV
MOV
WAIT1:
JBC
SJMP
RX-YES:
JBC
SJMP
NEXT1:
MOV
CJNE
TX-BYT:
MOV
TMOD,#20H
TH1, #0F3H
TL1, #0F3H
SCON, #50H
PCON, #80H
TR1
;设置定时器/计数器1定时、工作方式2
;设置定时计数常数
;
;串口初始化
;设置SMOD=1
;启动定时
DPH,
DPL,
R7,
R6,
31H
30H
2FH
#00H
;设置外部RAM数据指针
;DPTR初值
;发送数据块数送R7
;累加和寄存器R6清0
A,
#06H
;
SBUF, A
;
T1,
WAIT1
;等待发送完呼叫信号
;未发送完转WATI1
RX – YES
RI,
NEXT1
RX-YES
C
T
S
.
d
e
t
i
m
Li
发送呼叫信号“06H”
U
C
M
;判断乙机回答信号
;未收到回答信号,则等待
A,
A,
SBUF
;接收回答信号送A
#00H, TX-ACK ;判断是否“00H”,否则重发呼叫信号
A,
R7
;
MOV SBUF,
ADD A,
MOV R6,
WAIT2:
JBC
TI,
A
R6
A
; 发送数据块数n
TX-NES
;
JMP
TX-NES:
MOVX
MOV
ADD
MOV
INC
WAIT2
; 等待发送完
A,
SBUF,
A,
R6,
DPTR
@DPTR
A
R6
A
;从外部RAM取发送数据
;发送数据块
南通国芯微电子有限公司
;DPTR指针加1
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
245
STC90C58AD系列单片机指南
WAIT3:
JBC
SJMP
NEXT2:
DJNZ
TX-SUM:
MOV
MOV
WAIT4:
JBC TI,
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
TI,
WAIT3
NEXT2
;判断一数据块发送完否
;等待发送完
R7,
TX-NES
;判断发送全部结束否
A,
R6
SBUF, A
;发送累加和给乙机
RX-0FH
;
SJMP
RX-0FH:
JBC
WAIT4
; 等待发送完
SJMP
IF-0FH:
MOV
RX-0FH
CJNE
RET
RI,
A,
A,
IF-0FH
.
d
e
t
i
m
;
SBUF;
研发顾问:13922809991
; 等待接收乙机回答信号
;
Li
#0FH, ST-RAM ; 判断传输是否正确,否则重新发送
;返回
C
T
S
U
C
M
乙机接收子程序段
接收程序段的设置:
(a) ���������������
波特率设置初始化:同发送程序;
(b) ��������������
串行通信初始化:同发送程序;
(c) ������
寄存器设置:
内部RAM 31H、30H单元存放接收数据缓冲区首地址。
R7——数据块个数寄存器。
R6——累加和寄存器。
(d) ���������
向甲机回答信号:“0FH”为接收正确,“F0H”为传送出错,“00H”为同意接收数
据,“05H”为暂不接收。
246
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
下图为双机通信查询方式乙机接收子程序流程图。
开始
定时器,串行口初始化
接收数据并存入RAM
地址指针DPTR赋值,
校验寄存器清0
地址指针DPTR加1
数据接收完否?
N
Y
.
d
e
t
i
m
接收呼叫信号
接收校验和
是06H?
Y
Li
传送正确吗?
N
向甲机回送15H
向甲机回送00H
C
T
S
接收数据块长度
U
C
M
Y
N
向甲机回送F0H
向甲机回送0FH
返回
接收子程序清单:
TART:
MOV
MOV
MOV
SETB
MOV
TMOD, #20H
TH1, #0F3H
;
TL1, #0F3H
TR1
SCON, #50H
; 定时器/计数器1设置
;启动定时器/计数器1
; 置串行通信方式1,允许接收
MOV
ST-RAM:
MOV
PCON, #80H
; SMOD置位
DPH, 31H
;
DPL, 30H
R6, #00H
; 设置DPTR首地址
;校验和寄存器清0
MOV
MOV
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
247
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RX-ACK:
JBC
RI,
IF-06H
SJMP
RX-ACK
MOV
A,
CJNEA #06H, TX-05H
;判断接收呼叫信号
;等待接收呼叫信号
IF-06H:
SBUF
;呼叫信号送A
;判断呼叫信号正确否?
TX-00H:
MOV
A,
#00H
MOV
WAIT1:
SBUF, A
JBC
TI,
SJMP
WAIT1
;
;
RX-BYS
向甲机发送“00H”,同意接收
;等待应答信号发送完
TX-05H:
MOV
A,
#05H
MOV
SBUF, A
;不正确信号
WAIT2:
JBC
TI,
RX-BYS:
JBC
C
T
S
LJMP RX-ACK
U
C
M
HAVE1
SJMP WAIT2
HAVE1:
RI,
Li
;等待发送完
;因呼叫错,返回重新接收呼叫
HAVE2
SJMP RX-BYS
.
d
e
t
i
m
;向甲机发送“05H”呼叫
;等待接收数据块个数
;
HAVE2:
MOV
A,
SBUF
;
MOV R7,
A
;数据块个数帧送R7,R6
MOV R6,
A
;
RX-NES:
JBC
RI,
HAVE3
SJMP RX-NES
HAVE3:
;
MOV
MOVX @DPTR,A
INC
DPTR
ADD
A,
R6
MOV
DJNZ
R6,
R7,
A
RX-NES
248
A,
;
SBUF
;
;接收到的数据存入外部RAM
南通国芯微电子有限公司
接收数据帧
;
;
; 形成累加和
;判断数据是否接收完
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RX-SUM:
JBC
RI,
HAVE4
SJMP RX-SUM
HAVE4:
;
;
MOV
A,
SBUF
CJNE
TX-RIT:
A,
R6,
MOV
A,
#0FH
MOV
WAIT3:
JBC
SJMP
TX-ERR:
MOV
A,
MOV
SBUF, A
JBC
TI,
;
;
;
#0F0H
LJMP
RET
判断传输是否正确
向甲机发送接收正确信息
.
d
e
t
i
m
等待发送结束
Li
;向甲机发送传输有误信号
U
C
M
C
T
S
ST-RAM
GOOD:
AGAIN
SJMP WAIT4
AGAIN:
;
WAIT4:
;
GOOD
WAIT3
TX-ERR
;
SBUF, A
TI,
等待接收校验和
;等待发送完
;返回重新开始接收
;传输正确返回
(2)中断方式双机通信软件举例
在很多应用场合,双机通信的双方或一方采用中断方式以提高通信效率。由于STC90C58AD系列单片机的串行通信是双工的,且中断系统只提供一个中断矢量入口地址,所以
实际上是中断和查询必须相结合,即接收/发送均可各自请求中断,响应中断时主机并不知道
是谁请求中断,统一转入同一个中断矢量入口,必须由中断服务程序查询确定并转入对应的服
务程序进行处理。
这里,任以上述协议为例,甲方(发送方)任以查询方式通信(从略),乙方(接收方)
则改用中断����������
—���������
查询方式进行通信。
在中断接收服务程序中,需设置三个标志位来判断所接收的信息是呼叫信号还是数据块个
数,是数据还是校验和。增设寄存器:内部RAM32H单元为数据块个数寄存器,33H单元为校
验和寄存器,位地址7FH、7EH、7DH为标志位。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
249
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
乙机接收中断服务程序清单
采用中断方式时,应在主程序中安排定时器/计数器、串行通信等初始化程序。通信接收的数据存放在外
部RAM的首地址也需在主程序中确定。
主程序:
ORG
AJMP START
ORG
0023H
LIMP
SERVE
0000H
;转至主程序起始处
;转中断服务程序处
·
·
·
.
d
e
t
i
m
START:
MOV
TMOD, #20H
MOV
TH1, #0F3H
MOV
MOV
TL1, #0F3H
SCON, #50H
MOV
PCON, #80H
SETB
TR1
SETB
7FH
SETB
7EH
SETB
7DH
MOV
31H,#10H
MOV
MOV
SETB
SETB
30H,#00H
33H,#00H
EA
ES
250
C
T
S
;定义定时器/计数器1定时、工作方式2
;
Li
; 设置波特率为2400位/秒
;设置串行通信方式1,允许接收
U
C
M
;设置SMOD=1
;启动定时器
;
;设置标志位为1
;
; 规定接收的数据存储于外部RAM的
; 起始地址1000H
;累加和单元清0
;
; 开中断
·
·
·
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
中断服务程序:
SERVE:
CLR
EA
;关中断
CLR
RI
;清除接收中断请求标志
PUSH
DPH
;
PUSH DPL
; 现场保护
PUSH A
JB
7FH, RXACK
;判断是否是呼叫信号
JB
7EH, RXBYS
;判断是否是数据块数据
JB
7DH, RXDATA
;判断是否是接收数据帧
MOV
A,
;接收到的校验和
CJNE
A, 33H, TXERR
:判断传输是否正确
MOV
A,
;
;
RXSUM:
SBUF
TXRI:
MOV
WAIT1:
#0FH
SBUF, A
JNB
TI,
WAITI
CLR
TI
SJMP
AGAIN
TXERR:
MOV
MOV
WAIT2:
#0F0H
TI,
CLR
TI
SJMP
AGAIN
;等待发送完毕
;转结束处理
;
;
WAIT2
Li
向甲机发送接收正确信号“0FH”
;清除发送中断请求标志位
SBUF, A
JNB
C
T
S
A,
U
C
M
;
.
d
e
t
i
m
向甲机发送接收出错信号“F0H”
;等待发送完毕
;清除发送中断请求标志
;转结束处理
RXACK:
MOV
A,
SBUF
;判断是否是呼叫信号“06H”
XRL
A,
#06H
;异或逻辑处理
JZ
TXREE
;是呼叫,则转TXREE
TXNACK:
MOV
A,
MOV
SBUF, A
南通国芯微电子有限公司
#05H
;接收到的不是呼叫信号,则向甲机发送
;“05H”,要求重发呼叫
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
251
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
WAIT3:
JNB
TI,
CLR
TI
SJMP
RETURN
WAIT3
; 等待发送结束
;转恢复现场处理
TXREE:
MOV
A,
MOV
SBUF, A
#00H
JNB
TI,
CLR
TI
CLR
7FH
SJMP
RETURN
;接收到的是呼叫信号,发送“00H”
;接收到的是呼叫信号,发送“00H”
WAIT4:
WAIT4
;等待发送完毕
;清除TI标志
;清除呼叫标志
MOV
A,
MOV
32H, A
ADD
A,
MOV
CLR
33H, A
7EH
SJMP
RETURN
RXDATA:
33H
;存入32H单元
U
C
M
C
T
S
Li
;接收到数据块数
;
; 形成累加和
;清除数据块数标志
;转恢复现场处理
MOV
DPH, 31H
MOV
MOV
DPL, 30H
A,
SBUF
252
SBUF
;
; 设置存储数据地址指针
;读取数据帧
MOVX @DPTR, A
INC
DPTR
MOV
31H, DPH
MOV
ADD
30H, DPL
A,
33H
MOV
DJNZ
33H, A
32H, RETURN
; 形成累加和
;判断数据接收完否
CLR
7DH
;清数据接收完标志
SJMP
RETURN
南通国芯微电子有限公司
;将数据存外部RAM
.
d
e
t
i
m
;转恢复现场处理
RXBYS:
;地址指针加1
;
;
;
保存地址指针值
;转恢复现场处理
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
AGAIN:
SETB
7FH
;
SETB
7EH
;恢复标志位
SETB
7DH
;
MOV
33H, #00H
;累加和单元清0
MOV
31H, #10H
;
30H,
;
;
MOV
RETURN:
POP
A
POP
DPL
POP
DPH
SETB
EA
RET1
#00H
恢复接收数据缓冲区首地址
;恢复现场
;
.
d
e
t
i
m
;开中断
;返回
U
C
M
Li
上述程序清单中,ORG为程序段说明伪指令,在程序汇编时,它向汇编程序说明该程序段
的起始地址。
在实际应用中情况多种多样,而且是两台独立的计算机之间进行信息传输。因此,应周密
考虑通信协议,以保证通信的正确性和成功率
C
T
S
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
253
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
8.6 多机通信
在很多实际应用系统中,需要多台微计算机协调工作。STC90C58AD系列单片机的串行
通信方式2和方式3具有多机通信功能,可构成各种分布式通信系统。下图为全双工主从式多
机通信系统的连接框图。
TxD
8051
RxD
TxD
RxD
8051
TxD
U
C
M
.
d
e
t
i
m
Li
RxD
8051
TxD
…
RxD
8051
上图为一台主机和几台从机组成的全双工多机通信系统。主机可与任一台从机通信,而从
机之间的通信必须通过知己转发。
C
T
S
(1)���������
多机通信的基本原理
在多机通信系统中,为保证主机(发送)与多台从机(接收)之间能可靠通信,串行通
信必须具备识别能力。�����������������������������������
MCS-51�����������������������������
系列单片机的串行通信控制寄存器��������������
SCON����������
中设有多机通信选择位
SM2��������������������������������������������
。当程序设置��������������������������������������
SM2=1���������������������������������
,串行通信工作于方式�����������������������
2����������������������
或方式�������������������
8������������������
,发送端通过对�����������
TB8��������
的设置以区别于发
送的是地址帧(�������������������������������������������
TB8=1��������������������������������������
)还是数据帧(�������������������������������
TB8=0��������������������������
),接收端通过对接收到���������������
RB8������������
进行识别:当������
SM2=1�
,
若接收到���������������������������������������������
RB8=1����������������������������������������
,则被确认为呼叫地址帧,将该帧内容装入���������������������
SBUF�����������������
中,并置位������������
RI=1��������
,向������
CPU���
请求中
断,进行地址呼叫处理;若����������������������������������
RB8=0�����������������������������
为数据帧,将不予理睬,接收的信息被丢弃。若��������
SM2=0���
,则无
论是地址帧还是数据帧均接收,并置位�����������������������������
RI=1�������������������������
,向�����������������������
CPU��������������������
请求中断,将该帧内容装入��������
SBUF����
。据此原
理,可实现多机通信。
对于上图的从机式多机通信系统,从机的地址为��������������������
0�������������������
,������������������
1�����������������
,����������������
2���������������
,��������������
…�������������
,������������
n�����������
。实现多机通信的过程如
下:
① 置全部从机的�����������������
�����������������������
SM2=1������������
,处于只接收地址帧状态。
② 主机首先发送呼叫地址帧信息,将����������������������
�������������������������������������
TB8�������������������
设置为����������������
1���������������
,以表示发送的是�������
������
呼叫地址帧。
③ 所有从机接收到呼叫地址帧后,各自将接收到的主机呼叫的地址与本机的地址相比
������������������������������������
较:若比较结果相等,则为被寻址从机,清除�����������������������
SM2=0������������������
,准备接收从主机发送的数据帧,直至全
部数据传输完;若比较不相等,则为非寻址从机,任维持������������������
SM2=1�������������
不变,对其后发来的数据帧不
予理睬,即接收到的数据帧内容不装入����������������������������
SBUF������������������������
,不置位,�������������������
RI=0���������������
,不会产生中断请求,直至被寻址
为止。
254
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
④ 主机在发送完呼叫地址帧后,接着发送一连串的数据帧,其中的�
�����������������������������
TB8=0��������������
,以表示为数据帧。�����
⑤ 当主机改变从机通信时间则再发呼叫地址帧,寻呼其他从机,原先
�����������������������������
被寻址的从机经分析得知主机在寻呼其他从机时,恢复其����������������
SM2=1�����������
,对其后主机发送的数据
帧不予理睬。
上述过程均在软件控制下实现。
(2)��������
多机通信协议简述
�����������������������������
由于串行通信是在二台或多台各自完全独立的系统之间进行信息传
输这就需要根据时间通信要求制定某些约定,作为通信规范遵照执行,协议要求严格、完
善,不同的通信要求,协议的内容也不相同。在多机通信系统中要考虑的问题较多,协议内容
比较复杂。这里仅例举几条作一说明。
.
d
e
t
i
m
Li
上图的主从式多机通信系统,允许配置����������������
255�������������
台从机,各从机的地址分别为00H~FEH。
① 约定地址��������������������������������������
������������������������������������������
FFH�����������������������������������
为全部从机的控制命令,命令各从机恢复�����������������
SM2=1������������
状态,准备接收主机的地
址呼叫。
② 主机和从机的联络过程约定:主机首先发送地址呼叫帧,被寻址的从机回送本机地址
��������������������������������������
给主机,经验证地址相符后主机再向被寻址的从机发送命令字,被寻址的从机根据命
令字要求回送本机的状态,若主机判断状态正常,主机即开始发送或接收数据帧,发
送或接收的第一帧为传输数据块长度。
C
T
S
U
C
M
③ 约定主机发送的命令字为:
������������
00H�����������
:要求从机接收数据块;
01H�����������
:要求从机发送数据块;
·
·
·
其他:非法命令。
④ 从机的状态字格式约定为:
������������
B7 B6 B5 B4 B3 B2 B1 B0
ERR
0
0
0
0
0
TRDY
RRDY
定义:
���������������������
若����������������
ERR=1�����������
,从机接收到非法命令;
若����������������
�����������������
TRDY=1����������
,从机发送准备就绪;
若����������������
�����������������
RRDY=1����������
,从机接收准备就绪;
⑤ 其他:如传输出错措施等。
������������
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
255
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
(3)����
程序举例
��������������������������������������
在实际应用中如传输波特率不太高,系统实时性有一定要求以及希望提高通信效率,则
多半采用中断控制方式,但程序调试较困难,这就要求提高程序编制的正确性。采用查询方
式,则程序调试较方便。这里仅以中断控制方式为例简单介绍主�������������
—������������
从机之间一对一通信软件。
① 主机发送程序
������
该主机要发送的数据存放在内部�����������������������������
RAM��������������������������
中,数据块的首地址为����������������
51H�������������
,数据块长度存放做����
50H�
单
元中,有关发送前的初始化、参数设置等采用子程序格式,所有信息发送均由中断服务程序完
成。当主机需要发送时,在完成发送子程序的调用之后,随即返回主程序继续执行。以后只需
查询���������������������������
PSW·5����������������������
的���������������������
F0�������������������
标志位的状态即可知道数据是否发送完毕。
要求主机向���������������������
#5�������������������
从机发送数据,中断服务程序选用工作寄存存器区1的R0~R7。
.
d
e
t
i
m
主机发送程序清单:
ORG
AJMP MAIN
ORG
0023H
;发送中断服务程序入口
LJMP
SERVE
;转中断服务程序
0000H
Li
.
.
.
MAIN: ...
C
T
S
...
.
.
.
ORG 1000H
TXCALL:
;转主程序
U
C
M
;主程序
;发送子程序入口
MOV
TMOD, #20H
MOV
TH1, #0F3H
;设置波特率为2400位/秒
MOV
TL1, #0F3H
;置位SMOD
;设置定时器/计数器1定时、方式2
MOV
PCON, #80H
SETB
TR1
MOV
SCON, #0D8H
SETB
EA
;开中断总控制位
CLR
ES
;禁止串行通信中断
;
;启动定时器/计数器1
;串行方式8,允许接收,TB8=1
TXADDR:
MOV
SBUF, #05H
JNB
TI,
CLR
TI
;发送呼叫从机地址
WAIT1:
256
WAIT1
南通国芯微电子有限公司
;等待发送完毕
;复位发送中断请求标志
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
RXADDR:
JNB
RI,
CLR
TI
MOV
A,
SBUF
CJNE
A,
#05H, TXADDR
CLR
TB8
CLR
PSW.5
RXADDR
;等待从机回答本机地址
;复位接收中断请求标志
;读取从机回答的本机地址
;判断呼叫地址符否,否则重发
;地址相符,复位TB8=0,准备发数据
;复位F0=0标志位
MOV
08H, #50H
;发送数据地址指针送R0
MOV
0CH, 50H
;数据块长度送R4
INC
0CH
SETB
ES
RET
;数据块长度加1
;允许串行通信中断
SERVE:
CLR
TI
U
C
M
PUSH PSW
PUSH A
CLR
RS1
Li
;中断服务程序段,清中断请求标志TI
;
;
;
;
C
T
S
.
d
e
t
i
m
;返回主程序
.
.
.
现场入栈保护
SETB
TXDATA:
RS0
MOV
SBUF, @R0
JNB
TI,
CLR
TI
;复位TI=0
INC
R0
;地址指针加1
DJNZ
R4,
SETB PSW.5
;已发送完毕置位F0=1
CLR
ES
;关闭串行中断
WAIT2:
WAIT2
RETURN
选择工作寄存器区1
;发送数据块长度及数据
;等待发送完毕
;数据块未发送完,转返回
RETURN:
POP
A
POP
RETI
PSW
南通国芯微电子有限公司
;
;
恢复现场
;返回
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
257
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
②������
从机接收程序
主机发送的地址呼叫帧,所有的从机均接收,若不是呼叫本机地址即从中断返回;若是
本机地址,则回送本机地址给主机作为应答,并开始接收主机发送来的数据块长度帧,并存放
于内部RAM的60H单元中,紧接着接收的数据帧存放于61H为首地址的内部RAM单元中,程序
中还选用20·0H、20·1H位作标志位,用来判断接收的是地址、数据块长度还是数据,选用了
2FH、2EH两个字节单元用于存放数据字节数和存储数据指针。#5从机的接收程序如下,供参
考。
#5从机接收程序清单:
ORG
AJMP START
0000H
ORG
0023H
LJMP
SERVE
ORG
0100H
;转主程序段
;从中断入口转中断服务程序
START:
MOV
TMOD, #20H
MOV
TH1, #0F3H
MOV
TL1, #0F3H
MOV
PCON, #80H
C
T
S
Li
;主程序段:初始化程序,设置定时
;器/计数器1定时、工作方式2,设
;置波特率为2400位/秒的有关初值
;置位SMOD
MOV
SCON, #0F0H
SETB
TR1
;启动定时器/计数器1
SETB
20·0
;
SETB
SETB
20·1
EA
;
;
置标志位为1
SETB
.
.
.
ES
;
开中断
ORG 1000H
;清接收请求中断标志RI=0
;
SERVE:
CLR
RI
PUSH A
258
U
C
M
.
d
e
t
i
m
;设置串行方式3,允许接收,SM2=1
PUSH PSW
CLR
RS1
SETB
JB
RS0
20·0H, ISADDR
; 选择工作寄存器区1
;判断是否是地址帧
JB
20·1H, ISBYTE
;判断是否是数据块长度帧
南通国芯微电子有限公司
;
;
现场保护
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
ISDATA:
MOV
R0,
2EH
MOV
A,
SBUF
MOV
@R0, A
INC
2EH
DJNZ
2FH, RETURN
SETB
20·0H
;
SETB
20·1H
;恢复标志位
SETB
SM2
SJMP
RETURN
;数据指针送R0
;接收数据
;数据指针加1
;判断数据接收完否?
;
;转入恢复现场,返回
ISADDR:
MOV
A,
SBUF
CJNE
MOV
A,
#05H, RETURN
SBUF, #01H
JNB
TI,
CLR
TI
CLR
20·0H
CLR
SM2
SJMP
RETURN
.
d
e
t
i
m
; 是地址呼叫,判断与本机地址
WAIT:
U
C
M
Li
;等待发送结束
;清0TI,20·0,SM2
;清0TI,20·0,SM2
;清0TI,20·0,SM2
C
T
S
ISBYTES:
WAIT
;
相符否,不符则转返回
;相符,发回答信号“01H”
;转返回
MOV
A,
SBUF
MOV
R0,
#60H
MOV
@R0, A
;将数据块长度存入内部RAM
MOV
2FH, A
;60H单元及2FH单元
MOV
2EH, #61H
CLR
20·1H
;接收数据块长度帧
;
;置首地址61H于2EH单元
;清20·1H标志,表示以后接收的为数据
RETURN:
POP
PSW
POP
RETI
A
;
; 恢复现场
;返回
多机通信方式可多种多样,上例仅以最简单的住一从式作了简单介绍,仅供参考。
对于串行通信工作方式0的同步方式,常用于通过移位寄存器进行扩展并行I/O口,或配
置某些串行通信接口的外部设备。例如,串行打印机、显示器等。这里就不一一举例了。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
259
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
第9章 STC90C58AD系列单片机的A/D转换器
9.1 A/D转换器的结构
STC90C58AD系列单片机的A/D转换口在P1口�
(P1.7-P1.0)���������
,有�������
8������
路�����
10���
位高速A/D转换器��
,�
速
度可达到250KHz(25万次����
/���
秒��
)�
。8路电压输入型A/D,可做温度检测、电池电压检测、按键扫
描、频谱检测等。89个时钟可完成一次转换。上电复位后P1口为弱上拉型I/O口,用户可以
通过软件设置将8路中的任何一路设置为A/D转换,不需作为A/D使用的口可继续作为I/O口使
用。
STC90C58AD系列单片机ADC(A/D转换器���������
)��������
的结构如下图所示。
.
d
e
t
i
m
ADC_CONTR Register
-
ADC_SPEED1 ADC_SPEED0 ADC_FLAG
模拟输入信号通道选择
开关CHS2/CHS1/CHS0
ADC7/P1.7
ADC6/P1.6
ADC5/P1.5
ADC4/P1.4
ADC3/P1.3
ADC2/P1.2
ADC1/P1.1
C
T
S
+
U
C
M
ADC_START CHS2 CHS1 CHS0
Li
A/D转换结果寄存器:
ADC_ DATA and ADC_LOW2
逐次比较
寄存器
-
比较器
ADC0/P1.0
10-bit DAC
A/D转换结果寄存器格式如下:
ADC_DATA[7:0]
ADC_B9 ADC_B8 ADC_B7 ADC_B6 ADC_B5 ADC_B4 ADC_B3 ADC_B2
-
260
-
南通国芯微电子有限公司
-
-
-
-
ADC_B1 ADC_B0
总机:0513-5501 2928 / 2929 / 2966
ADC_LOW2[1:0]
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
STC90C58AD系列单片机ADC由多路选择开关、比较器、逐次比较寄存器、10位DAC、转
换结果寄存器(ADC_DATA和ADC_LOW2)以及ADC_CONTR构成。
STC90C58AD系列单片机的ADC是逐次比较型ADC。逐次比较型ADC由一个比较器和D/A转
换器构成,通过逐次比较逻辑,从最高位(MSB)开始,顺序地对每一输入电压与内置D/A转换器
输出进行比较,经过多次比较,使转换所得的数字量逐次逼近输入模拟量对应值。逐次比较型
A/D转换器具有速度高,功耗低等优点。
从上图可以看出,通过模拟多路开关,将通过ADC0~7的模拟量输入送给比较器。用数
/模转换器(DAC)转换的模拟量与本次输入的模拟量通过比较器进行比较,将比较结果保存到
逐次比较器,并通过逐次比较寄存器输出转换结果。A/D转换结束后,最终的转换结果保存
到ADC转换结果寄存器ADC_DATA和ADC_LOW2,同时,置位ADC控制寄存器ADC_CONTR中的A/D转
换结束标志位ADC_FLAG,以供程序查询或发出中断申请。模拟通道的选择控制由ADC控制寄存
器ADC_CONTR中的CHS2 ~ CHS0确定。ADC的转换速度由ADC控制寄存器中的SPEED1和SPEED0确
定。
如果用户取完整的10位结果,则按下面公式计算:
U
C
M
.
d
e
t
i
m
Li
Vin
10-bit A/D Conversion Result:(ADC_DATA[7:0], ADC_LOW2[1:0]) = 1024 x Vcc
C
T
S
如果舍弃ADC_LOW2的低2位,只用ADC_DATA寄存器的8位结果,按下面公式计算:
8-bit A/D Conversion Result:(ADC_DATA[7:0]) = 256 x
Vin
Vcc
式中,Vin为模拟输入通道输入电压,Vcc为单片机实际工作电压,用单片机工作电压作为
模拟参考电压。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
261
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
9.2 与A/D转换相关的寄存器
与STC90C58AD系列单片机A/D转换相关的寄存器列于下表所示。
地
址
位地址及其符号
符号
描述
P1_ADC_EN
允许P1.x作为A/D口
97H
ADC_CONTR
ADC Control Register
C5H -
A/D转换结果寄存器,
高8位
A/D转换结果寄存器,
ADC_LOW2
低2位
ADC_DATA
MSB
复位值
LSB
ADC_P17 ADC_P16 ADC_P15 ADC_P14 ADC_P13 ADC_P12 ADC_P11 ADC_P10
ADC_SPEED1 ADC_SPEED0 ADC_FLAG ADC_START CHS2 CHS1 CHS0
0000,0000
x000 0000B
C6H
0000 0000B
C7H
0000 0000B
.
d
e
t
i
m
1. P1口模拟配置寄存器P1_ADC_EN
P1_ADC_EN寄存器的格式如下:
Li
P1_ADC_EN : 允许P1.x作为A/D转换通道来用的特殊功能寄存器
B7
SFR name Address bit
P1_ADC_EN
97H
B6
B5
U
C
M
B4
B3
B2
B1
B0
name ADC_P17 ADC_P16 ADC_P15 ADC_P14 ADC_P13 ADC_P12 ADC_P11 ADC_P10
ADC_P1x相应位为“1”时,对应的P1.x口作为A/D转换使用,内部上拉电阻自动断开
C
T
S
2. ADC控制寄存器ADC_CONTR
ADC_CONTR寄存器的格式如下:
ADC_CONTR : ADC控制寄存器
SFR name
Address
bit
B7
ADC_CONTR
C5H
name
-
B6
B5
B4
B3
B2
B1
B0
ADC_SPEED1 ADC_SPEED0 ADC_FLAG ADC_START CHS2 CHS1 CHS0
对ADC_CONTR寄存器进行操作,建议直接用MOV赋值语句,不要用‘与’和‘或’语句�
。
ADC_SPEED1,ADC_SPEED0:模数转换器转换速度控制位
ADC_SPEED1 ADC_SPEED0 A/D转换所需时间
1
1
534个时钟周期转换一次
1
0
356个时钟周期转换一次
0
1
178个时钟周期转换一次
0
0
89个时钟周期转换一次
ADC_FLAG: 模数转换器转换结束标志位�����������������������������
,����������������������������
当A/D转换完成后,ADC_FLAG=1,要由软件清0。
ADC_START:模数转换器(ADC)转换启动控制位,设置为“1”时,开始转换,转换结束后为0
262
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
CHS2/CHS1/CHS0:模拟输入通道选择,CHS2/CHS1/CHS0
CHS2
CHS1 CHS0
Analog Channel Select (模拟输入通道选择)
0
0
0
选择 P1.0 作为A/D输入来用
0
0
1
选择 P1.1 作为A/D输入来用
0
1
0
选择 P1.2 作为A/D输入来用
0
1
1
选择 P1.3 作为A/D输入来用
1
0
0
选择 P1.4 作为A/D输入来用
1
0
1
选择 P1.5 作为A/D输入来用
1
1
0
选择 P1.6 作为A/D输入来用
1
1
1
选择 P1.7 作为A/D输入来用
.
d
e
t
i
m
Li
3. A/D转换结果寄存器ADC_DATA、ADC_LOW2
特殊功能寄存器ADC_DATA和ADC_LOW2寄存器用于保存A/D转换结果,其格式如下:
CU
Mnemonic
Add
Name
ADC_DATA
C6h
A/D转换结果寄存器,全部8位有
效,为10位A/D转换结果的高8位
ADC_LOW2
C7h
A/D转换结果寄存器,只有低2位有
效,为10位A/D转换结果的低2位
C
T
S
B7
B6
-
-
x
x
M
B5
B4
B3
B2
B1
B0
-
-
-
-
-
-
x
x
x
x
-
-
此时,如果用户需取完整10位结果,按下面公式计算:
10-bit A/D Conversion Result:(ADC_DATA[7:0], ADC_LOW2[1:0]) = 1024 x
Vin
Vcc
如果用户只需取8位结果,按下面公式计算:
8-bit A/D Conversion Result:(ADC_DATA[7:0])= 256 x
Vin
Vcc
式中,Vin为模拟输入通道输入电压,Vcc为单片机实际工作电压,用单片机工作电压作为
模拟参考电压。
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
263
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
9.3 A/D转换典型应用线路
信号源
1K
47pF以上
1
P1.0/T2/ADC0
Vcc 40
2
P1.1/T2EX/ADC1
P0.0 39
3
P1.2/ADC2
P0.1 38
4
P1.3/ADC3
P0.2 37
5
P1.4/ADC4
P0.3 36
6
P1.5/ADC5
P0.4 35
7
P1.6/RxD/ADC6
P0.5 34
8
P1.7/TxD/ADC7
P0.6 33
9
RST
P0.7 32
EA/P4.6
31
ALE/P4.5
30
PSEN/P4.4
29
P2.7/A15
28
P2.6/A14
27
P2.5/A13
26
P2.4/A12
25
P2.3/A11
24
P2.2/A10
23
19 XTAL1
P2.1/A9
22
20 Gnd
P2.0/A8
21
10 RxD/P3.0
.
d
e
t
i
m
11 TxD/P3.1
12 INT0/P3.2
13 INT1/P3.3
14 T0/P3.4
15 T1/P3.5
CU
16 WR/P3.6
17 RD/P3.7
C
T
S
264
南通国芯微电子有限公司
M
18 XTAL2
Li
A/D转换在P1口,P1.0 - P1.7共8路
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
9.4 A/D做按键扫描应用线路图
Vcc
10K
0V
1K 47pF以上
10K
1/2 Vcc
10K
2/3 Vcc
10K
3/4 Vcc
10K
5/4 Vcc
1
P1.0/T2/ADC0
Vcc 40
2
P1.1/T2EX/ADC1
P0.0 39
3
P1.2/ADC2
P0.1 38
4
P1.3/ADC3
P0.2 37
5
P1.4/ADC4
P0.3 36
6
P1.5/ADC5
P0.4 35
7
P1.6/RxD/ADC6
P0.5 34
8
P1.7/TxD/ADC7
P0.6 33
9
RST
EA/P4.6
31
11 TxD/P3.1
ALE/P4.5
30
12 INT0/P3.2
PSEN/P4.4
29
13 INT1/P3.3
P2.7/A15
28
P2.6/A14
27
P2.5/A13
26
P2.4/A12
25
P2.3/A11
24
P2.2/A10
23
19 XTAL1
P2.1/A9
22
20 Gnd
P2.0/A8
21
14 T0/P3.4
15 T1/P3.5
CU
16 WR/P3.6
17 RD/P3.7
M
18 XTAL2
C
T
S
南通国芯微电子有限公司
P0.7 32
10 RxD/P3.0
.
d
e
t
i
m
Li
A/D转换在P1口,P1.0 - P1.7共8路
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
265
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
1
P1.0/T2/ADC0
Vcc 40
2
P1.1/T2EX/ADC1
P0.0 39
3
P1.2/ADC2
P0.1 38
4
P1.3/ADC3
P0.2 37
5
P1.4/ADC4
P0.3 36
6
P1.5/ADC5
P0.4 35
7
P1.6/RxD/ADC6
P0.5 34
8
P1.7/TxD/ADC7
P0.6 33
9
RST
EA/P4.6
31
11 TxD/P3.1
ALE/P4.5
30
12 INT0/P3.2
PSEN/P4.4
29
13 INT1/P3.3
P2.7/A15
28
14 T0/P3.4
P2.6/A14
27
15 T1/P3.5
P2.5/A13
26
16 WR/P3.6
P2.4/A12
25
17 RD/P3.7
P2.3/A11
24
18 XTAL2
P2.2/A10
23
P2.1/A9
22
P2.0/A8
21
+5V
R1
520Ω
47pF
sw1
C
T
S
R1
10KΩ
ADCx
47pF
R2
520Ω
0
L
sw2
0`0.5
R3
1.8KΩ
R4
R5
R6
3.3KΩ 5.4KΩ 8.2KΩ
sw3
sw4
.
d
te
i
m
i
sw1
0.5`1
1`1.5
sw5
sw6
1.5`2.0 2.0`2.5
此电路可以实现单个按键扫描和组合按
键检测功能,但是具体电阻值应根据实
际需要进行选择
U
C
M
20 Gnd
研发顾问:13922809991
+5V
P0.7 32
10 RxD/P3.0
19 XTAL1
R0
ADCx 10KΩ
临时技术支持:13922829991
本电路图采用10个按键等间隔分压,每个按键正负误差余量允
许在±0.25V范围内变化,可以有效避免因为电阻误差或温度
漂移等造成的按键检测失效,如果要求按键检测更加稳定可
靠,可以减少按键数量放宽各个按键检测电压允许误差量。
R2
1.2KΩ
sw2
R3
1.6KΩ
sw3
R4
1.8KΩ
sw4
R5
3KΩ
sw5
R6
4KΩ
sw6
R7
6.5Ω
sw7
R8
10KΩ
sw8
R9
30KΩ
sw9
R10
100KΩ
sw10
sw11
0
9.5 A/D转换模块的参考电压源
STC12C5410AD系列单片机的参考电压源是输入工作电压Vcc,所以一般不用外接参考电
压源。如7805的输出电压是5V,但实际电压可能是4.88V 到4.96V,用户需要精度比较高的
话,可在出厂时将实际测出的工作电压值记录在单片机内部的EEPROM里面,以供计算。
如果有些用户的Vcc不固定,如电池供电,电池电压在5.3V-4.2V之间漂移,则Vcc不固
定,就需要在8路A/D转换的一个通道外接一个稳定的参考电压源,来计算出此时的工作电压
Vcc,再计算出其他几路A/D转换通道的电压。如可在ADC转换通道的第七通道外接一个1.25V
(或1V,或...)的基准参考电压源,由此求出此时的工作电压Vcc,再计算出其它几路A/D
转换通道的电压�������������������
(理论依据是短时间之内,Vcc不变)�
。
266
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
9.6 A/D转换测试程序(C程序和汇编程序)
1. C程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机 A/D转换功能----------------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
/*--ADC查询方式-------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
#define FOSC 18432000L
#define BAUD 9600
typedef unsigned char
typedef unsigned int
BYTE;
WORD;
C
T
S
/*Declare SFR associated with the ADC */
sfr
ADC_CONTR = 0xC5;
sfr
ADC_RES
= 0xC6;
sfr
ADC_LOW2 = 0xC7;
sfr
P1ASF
= 0x97;
U
C
M
.
d
e
t
i
m
Li
//ADC control register
//ADC high 8-bit result register
//ADC low 2-bit result register
//P1 secondary function control register
/*Define ADC operation const for ADC_CONTR*/
#define ADC_FLAG
0x10
//ADC complete flag
#define ADC_START 0x08
//ADC start control bit
#define ADC_SPEEDHH 0x00
//89 clocks
#define ADC_SPEEDH 0x20
//178 clocks
#define ADC_SPEEDL 0x40
//356 clocks
#define ADC_SPEEDLL 0x60
//534 clocks
void InitUart();
void InitADC();
void SendData(BYTE dat);
BYTE GetADCResult(BYTE ch);
void Delay(WORD n);
void ShowResult(BYTE ch);
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
267
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
void main()
{
InitUart();
InitADC();
while (1)
{
ShowResult(0);
ShowResult(1);
ShowResult(2);
ShowResult(3);
ShowResult(4);
ShowResult(5);
ShowResult(6);
ShowResult(7);
}
}
临时技术支持:13922829991
研发顾问:13922809991
//Init UART, use to show ADC result
//Init ADC sfr
/*---------------------------Send ADC result to UART
----------------------------*/
void ShowResult(BYTE ch)
{
SendData(ch);
SendData(GetADCResult(ch));
//Show Channel0
//Show Channel1
//Show Channel2
//Show Channel3
//Show Channel4
//Show Channel5
//Show Channel6
//Show Channel7
U
C
M
C
T
S
.
d
e
t
i
m
Li
//Show Channel NO.
//Show ADC high 8-bit result
//if you want show 10-bit result, uncomment next line
//
SendData(ADC_LOW2);
//Show ADC low 2-bit result
}
/*---------------------------Get ADC result
----------------------------*/
BYTE GetADCResult(BYTE ch)
{
ADC_CONTR = ADC_SPEEDLL | ch | ADC_START;
_nop_();
//Must wait before inquiry
_nop_();
_nop_();
_nop_();
while (!(ADC_CONTR & ADC_FLAG));//Wait complete flag
ADC_CONTR &= ~ADC_FLAG;
//Close ADC
return
ADC_RES;
//Return ADC result
}
268
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
/*---------------------------Initial UART
----------------------------*/
void InitUart()
{
SCON = 0x5a;
//8 bit data ,no parity bit
TMOD = 0x20;
//T1 as 8-bit auto reload
TH1 = TL1 = -(FOSC/12/32/BAUD);
//Set Uart baudrate
TR1 = 1;
//T1 start running
}
.
d
e
t
i
m
/*---------------------------Initial ADC sfr
----------------------------*/
void InitADC()
{
P1ASF = 0xff;
ADC_RES = 0;
ADC_CONTR = ADC_SPEEDLL;
Delay(2);
}
C
T
S
CU
M
Li
//Open 8 channels ADC function
//Clear previous result
//ADC power-on and delay
//Wait for the previous data is sent
/*---------------------------Send one byte data to PC
Input: dat (UART data)
Output:----------------------------*/
void SendData(BYTE dat)
{
while (!TI);
TI = 0;
SBUF = dat;
//Clear TI flag
//Send current data
}
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
269
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
/*---------------------------Software delay function
----------------------------*/
void Delay(WORD n)
{
WORD x;
while (n--)
{
x = 5000;
while (x--);
}
C
T
S
270
.
d
e
t
i
m
}
南通国芯微电子有限公司
U
C
M
Li
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
2. 汇编程序:
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机 A/D转换功能----------------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
/*--ADC查询方式-------------------------------------------*/
.
d
e
t
i
m
;/*Declare SFR associated with the ADC */
ADC_CONTR EQU 0C5H
ADC_RES
EQU 0C6H
ADC_LOW2 EQU 0C7H
P1ASF
EQU 097H
;ADC control register
;ADC high 8-bit result register
;ADC low 2-bit result register
;P1 secondary function control register
;/*Define ADC operation const for ADC_CONTR*/
ADC_FLAG
EQU 10H
ADC_START EQU 08H
ADC_SPEEDHH EQU 00H
ADC_SPEEDH EQU 20H
ADC_SPEEDL EQU 40H
ADC_SPEEDLL EQU 60H
;ADC complete flag
;ADC start control bit
;89 clocks
;178 clocks
;356 clocks
;534 clocks
C
T
S
U
C
M
;----------------------------------------
ORG 0000H
LJMP MAIN
;----------------------------------------
ORG 0100H
MAIN:
LCALL INIT_UART
LCALL INIT_ADC
;------------------------------NEXT:
MOV A,#0
LCALL SHOW_RESULT
MOV A,
#1
LCALL SHOW_RESULT
MOV A,
#2
南通国芯微电子有限公司
Li
;Init UART, use to show ADC result
;Init ADC sfr
;Show channel0 result
;Show channel1 result
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
271
STC90C58AD系列单片机指南
LCALL
MOV
LCALL
MOV
LCALL
MOV
LCALL
MOV
LCALL
MOV
LCALL
SJMP NEXT
技术支持网站:www.STCMCU.com
SHOW_RESULT
A,
#3
SHOW_RESULT
A,
#4
SHOW_RESULT
A,
#5
SHOW_RESULT
A,
#6
SHOW_RESULT
A,
#7
SHOW_RESULT
;Show channel2 result
;Show channel3 result
;Show channel4 result
;Show channel5 result
;Show channel6 result
;Show channel7 result
;/*---------------------------;Send ADC result to UART
;Input: ACC (ADC channel NO.)
;Output:;----------------------------*/
SHOW_RESULT:
LCALL SEND_DATA
LCALL GET_ADC_RESULT
LCALL SEND_DATA
C
T
S
临时技术支持:13922829991
U
C
M
;//if you want show 10-bit result, uncomment next 2 lines
;
MOV A,
ADC_LOW2
;
LCALL SEND_DATA
RET
研发顾问:13922809991
.
d
e
t
i
m
Li
;Show Channel NO.
;Get high 8-bit ADC result
;Show result
;Get low 2-bit ADC result
;Show result
;/*---------------------------;Read ADC conversion result
;Input: ACC (ADC channel NO.)
;Output:ACC (ADC result)
;----------------------------*/
GET_ADC_RESULT:
ORL A,
#ADC_SPEEDLL | ADC_START
MOV ADC_CONTR,
A
;Start A/D conversion
NOP
;Must wait before inquiry
NOP
NOP
NOP
272
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
WAIT:
MOV A,
ADC_CONTR
JNB
ACC.4, WAIT
ANL ADC_CONTR,
#NOT ADC_FLAG
MOV A,
RET
ADC_RES
;Wait complete flag
;ADC_FLAG(ADC_CONTR.4)
;Clear ADC_FLAG
;Return ADC result
;/*---------------------------;Initial ADC sfr
;----------------------------*/
INIT_ADC:
MOV P1ASF, #0FFH
MOV ADC_RES,
#0
MOV ADC_CONTR,
#ADC_SPEEDLL
MOV A,
LCALL DELAY
RET
#2
U
C
M
C
T
S
;/*---------------------------;Initial UART
.
d
e
t
i
m
;Open 8 channels ADC function
;Clear previous result
Li
;ADC power-on and delay
;----------------------------*/
INIT_UART:
MOV SCON, #5AH
MOV TMOD, #20H
MOV A,
#-5
MOV TH1,
A
MOV TL1,
A
SETB TR1
RET
;8 bit data ,no parity bit
;T1 as 8-bit auto reload
;Set Uart baudrate -(18432000/12/32/9600)
;Set T1 reload value
;T1 start running
;/*---------------------------;Send one byte data to PC
;Input: ACC (UART data)
;Output:;----------------------------*/
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
273
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
SEND_DATA:
JNB
TI,
CLR
TI
MOV SBUF,
RET
$
A
;Wait for the previous data is sent
;Clear TI flag
;Send current data
;/*---------------------------;Software delay function
;----------------------------*/
DELAY:
MOV R2,
CLR
MOV R0,
A
MOV R1,
A
A
DELAY1:
DJNZ R0,
DELAY1
DJNZ
R1,
DELAY1
DJNZ R2,
DELAY1
RET
END
274
.
d
e
t
i
m
A
C
T
S
南通国芯微电子有限公司
U
C
M
Li
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
第10章 STC90C58AD系列EEPROM的应用
STC90C58AD����������������������������������������
系列单片机内部集成了的EEPROM是与程序空间是分开的,利用ISP/IAP技术可
将内部Data Flash当EEPROM,擦写次数在10万次以上。EEPROM可分为若干个扇区,每个扇区包
含512字节。使用时,建议同一次修改的数据放在同一个扇区,不是同一次修改的数据放在不
同的扇区,不一定要用满。数据存储器的擦除操作是按扇区进行的。
EEPROM可用于保存一些需要在应用过程中修改并且掉电不丢失的参数数据。在用户程序
中,可以对EEPROM进行字节读/字节编程/扇区擦除操作。�����������������
在工作电压Vcc偏低时,建议不要进
行EEPROM/IAP操作。
10.1 IAP及EEPROM新增特殊功能寄存器介绍
符号
描述
地址
ISP/IAP Flash Data
Register
ISP/IAP Flash AdISP_ADDRH
dress High
ISP/IAP Flash AdISP_ADDRL
dress Low
ISP/IAP Flash ComISP_CMD
mand Register
ISP/IAP Flash ComISP_TRIG
mand Trigger
ISP/IAP Control
ISP_CONTR
Register
ISP_DATA
E3H
E4H
E5H
U
C
M
-
-
-
LSB
Li
E2H
C
T
S
南通国芯微电子有限公司
.
d
e
t
i
m
位地址及符号
MSB
1111 1111B
0000 0000B
0000 0000B
-
-
-
MS1
MS0
E6H
E7H
复位值
xxxx xx00B
xxxx xxxxB
ISPEN
SWBS
SWRST
总机:0513-5501 2928 / 2929 / 2966
-
-
WT2 WT1
WT0
000x x000B
传真:0513-5501 2969 / 2956 / 2947
275
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
1. ISP/IAP数据寄存器ISP_DATA
ISP_DATA : ISP/IAP操作时的数据寄存器。
ISP/IAP 从Flash读出的数据放在此处,向Flash写的数据也需放在此处
2. ISP/IAP地址寄存器ISP_ADDRH和ISP_ADDRL
ISP_ADDRH : ISP/IAP 操作时的地址寄存器高八位。�������
该寄存器地址为E3H,复位后值为00H.
ISP_ADDRL : ISP/IAP 操作时的地址寄存器低八位。�������
该寄存器地址为E4H,复位后值为00H.
3. ISP/IAP命令寄存器ISP_CMD
ISP/IAP命令寄存器IAP_CMD格式如下:
SFR name
Address
bit
B7
B6
B5
B4
B3
ISP_CMD
E5H
name
-
-
-
-
-
B2
B1
.
d
e
t
i
m
MS2
MS1
B0
MS0
MS2
MS1
MS0
0
0
0
命令 / 操作 模式选择
Standby 待机模式,无ISP操作
0
0
1
从用户的应用程序区对"Data Flash/EEPROM区"进行字节读
0
1
0
从用户的应用程序区对"Data Flash/EEPROM区"进行字节编程
0
1
1
从用户的应用程序区对"Data Flash/EEPROM区"进行扇区擦除
U
C
M
Li
程序在系统ISP程序区时可以对用户应用程序区/数据Flash区(EEPROM)进行字节读/字节编程
/扇区擦除;程序在用户应用程序区时,仅可以对数据Flash 区(EEPROM)进行字节读/字节编程
/扇区擦除。已经固化有ISP引导码,并设置为上电复位进入ISP
C
T
S
4. ISP/IA命令触发寄存器ISP_TRIG
ISP_TRIG: ISP/IAP 操作时的命令触发寄存器。
在ISPEN(ISP_CONTR.7) = 1 时,对ISP_TRIG先写入46h,再写入B9h,ISP/IAP 命令才会生效。
ISP/IAP操作完成后,ISP地址高八位寄存器ISP_ADDRH、ISP地址低八位寄存器ISP_ADDRL
和ISP命令寄存器ISP_CMD的内容不变。如果接下来要对下一个地址的数据进行ISP/IAP操作,
需手动将该地址的高8位和低8位分别写入ISP_ADDRH和ISP_ADDRL寄存器。
每次ISP操作时,都要对ISP_TRIG先写入46H,再写入B9H,ISP/IAP命令才会生效。
276
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
5. ISP/IAP命令寄存器ISP_CONTR
ISP/IAP控制寄存器IAP_CONTR格式如下:
SFR name
Address
IAP_CONTR
E7H
bit
B7
B6
B5
name ISPEN SWBS SWRST
B4
B3
B2
B1
B0
-
-
WT2
WT2
WT0
ISPEN: ISP/IAP功能允许位。0:禁止IAP/ISP读/写���
/��
擦除Data Flash/EEPROM
1: 允许IAP/ISP读/写���
/��
擦除Data Flash/EEPROM
SWBS: 软件选择从用户应用程序区启动(送0),还是从������������
系统����������
ISP�������
监控�����
程序区启动(送1)。
要与SWRST直接配合才可以实现
SWRST: 0: 不操作; 1: 产生软件系统复位,硬件自动���
复位�
。
;在用户应用程序区(AP区)软件复位并从系统ISP监控程序区开始执行程序
MOV ISP_CONTR, #01100000B ;SWBS = 1(选择ISP区), SWRST = 1(软复位)
;在系统ISP监控程序区软件复位并从用户应用程序区(AP 区)开始执行程序
MOV ISP_CONTR, #00100000B ;SWBS = 0(选择AP区), SWRST = 1(软复位)
设置等待时间
WT2 WT1 WT0
0
0
0
0
1
1
0
0
1
0
1
0
.
d
e
t
i
m
Li
CPU等待时间(机器周期),(1个机器周期=12个CPU工作时钟 )
Sector Erase Recommended System Clock
Program/编程
Read/读
扇区擦除
跟等待参数对应的推荐系统
(=72uS)
(=13.1304ms)
时钟
5MHz
6个机器周期 30个机器周期 5471个机器周期
10MHz
11个机器周期 60个机器周期 10942个机器周期
20MHz
22个机器周期 120个机器周期 21885个机器周期
40MHz
43个机器周期 240个机器周期 43769个机器周期
南通国芯微电子有限公司
C
T
S
U
C
M
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
277
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
10.2 STC90C58AD系列单片机EEPROM空间大小及地址
STC90C58AD系列单片机内部可用EEPROM的地址与程序空间是分开的:程序在用户应用程序
区时,可以对EEPROM进行IAP/ISP操作。
具体某个型号单片机内部EEPROM大小及详细地址请参阅:
1. STC90C58AD系列单片机内部EEPROM详细地址表
2. STC90C58AD系列单片机内部EEPROM空间大小选型一览表
STC90C58AD系列单片机内部EEPROM选型一览表
EEPROM字节数 扇区数 起始扇区首地址 结束扇区末尾地址
型号
STC90C51AD
STC90LE51AD
STC90C52AD
STC90LE52AD
STC90C54RAD
STC90LE54AD
STC90C58AD
STC90LE58AD
STC90C510AD
STC90LE510AD
STC90C512AD
STC90LE512AD
STC90C514AD
STC90LE514AD
5K
10
2000h
5K
10
2000h
45K
90
4000h
29K
58
i
m
i
L
8000h
33FFh
F3FFh
F3FFh
13K
CU
26
C000h
F3FFh
5K
10
E000h
F3FFh
M
21K
C
T
S
.
d
te
33FFh
42
A000h
F3FFh
STC90C51AD系列单片机内部EEPROM详细地址表
具体某型号有多少扇区的EEPROM,参照前面的EEPROM空间大小选型一览表, 每个扇区0.5 K字节
第一扇区
第二扇区
第三扇区
第四扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
2000h
21FFh
2200h
23FFh
2400h
25FFh
2600h
27FFh
第五扇区
第六扇区
第七扇区
第八扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
2800h
29FFh
2A00h
2BFFh
2C00h
2DFFh
2E00h
2FFFh
第九扇区
第十扇区
起始地址
结束地址
起始地址
结束地址
3000h
31FFh
3200h
33FFh
278
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
STC90C58AD系列单片机内部EEPROM详细地址表
具体某型号有多少扇区的EEPROM,参照前面的EEPROM空间大小选型一览表, 每个扇区0.5 K字节
第一扇区
第二扇区
第三扇区
第四扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
8000h
81FFh
8200h
83FFh
8400h
85FFh
8600h
87FFh
第五扇区
第六扇区
第七扇区
第八扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
8800h
89FFh
8A00h
8BFFh
8C00h
8DFFh
8E00h
8FFFh
第九扇区
第十扇区
第十一扇区
第十二扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
9000h
91FFh
9200h
93FFh
9400h
95FFh
9600h
97FFh
第十三扇区
第十四扇区
第十五扇区
第十六扇区
.
d
e
t
i
m
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
9800h
99FFh
1A00h
9BFFh
9C00h
9DFFh
9E00h
9FFFh
第十七扇区
第十八扇区
第十九扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
A000h
A1FFh
A200h
A3FFh
A400h
A5FFh
第二十一扇区
第二十二扇区
U
C
M
第二十三扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
A800h
A9FFh
AA00h
ABFFh
AC00h
ADFFh
第二十五扇区
起始地址
结束地址
B000h
B1FFh
第二十九扇区
起始地址
结束地址
B800h
B9FFh
第三十三扇区
C
T
S
第二十六扇区
第二十七扇区
Li
第二十扇区
起始地址
结束地址
A600h
A7FFh
第二十四扇区
起始地址
结束地址
AE00h
AFFFH
第二十八扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
B200h
B3FFh
B400h
B5FFh
B600h
B7FFH
第三十扇区
第三十一扇区
第三十二扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
BA00h
BBFFh
BC00h
BDFFh
BE00h
BFFFH
第三十四扇区
第三十五扇区
第三十六扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
C000h
C1FFh
C200h
C3FFh
C400h
C5FFh
C600h
C7FFH
第三十七扇区
第三十八扇区
第三十九扇区
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
C800h
C9FFh
CA00h
CBFFh
CC00h
CDFFh
CE00h
CFFFH
第四十二扇区
第四十三扇区
第四十四扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
D000h
D1FFh
D200h
D3FFh
D400h
D5FFh
D600h
D7FFH
第四十五扇区
第四十六扇区
第四十七扇区
第四十八扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
D800h
D9FFh
DA00h
DBFFh
DC00h
DDFFh
DE00h
DFFFH
第四十九扇区
第五十扇区
第五十一扇区
第五十二扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
E000h
E1FFh
E200h
E3FFh
E400h
E5FFh
E600h
E7FFH
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
建议同一次修
改的数据放在
同一扇区,不
是同一次修改
的数据放在不
同的扇区,不
必用满, 当
然可全用
第四十扇区
起始地址
第四十一扇区
每个扇区
512字节
传真:0513-5501 2969 / 2956 / 2947
279
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
STC90C58AD系列单片机内部EEPROM详细地址表
具体某型号有多少扇区的EEPROM,参照前面的EEPROM空间大小选型一览表, 每个扇区0.5 K字节
第五十三扇区
第五十四扇区
第五十五扇区
第五十六扇区
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
起始地址
结束地址
E800h
E9FFh
EA00h
EBFFh
EC00h
EDFFh
EE00h
EFFFH
第五十七扇区
结束地址
起始地址
结束地址
F000h
F1FFh
F200h
F3FFh
C
T
S
280
建议同一次修改
的数据放在同一
扇区,不是同一
次修改的数据放
在不同的扇区,
不必用满, 当然
可全用
第五十八扇区
起始地址
南通国芯微电子有限公司
U
C
M
每个扇区
512字节
.
d
e
t
i
m
Li
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
10.3 IAP及EEPROM汇编简介
;用DATA还是EQU声明新增特殊功能寄存器地址要看你用的汇编器/编译器
IAP_DATA
DATA
0E2h;
IAP_DATA
EQU
0E2h
IAP_ADDRH
DATA
0E3h; 或
IAP_ADDRH
EQU
0E3h
IAP_ADDRL
DATA
0E4h; 或
IAP_ADDRL
EQU
0E4h
IAP_CMD
DATA
0E5h; 或
IAP_CMD
EQU
0E5h
IAP_TRIG
DATA
0E6h; 或
IAP_TRIG
EQU
0E6h
IAP_CONTR
DATA
0E7h; 或
IAP_CONTR
EQU
0E7h
或
.
d
e
t
i
m
;定义ISP/IAP命令及等待时间
ISP_IAP_BYTE_READ
EQU
1
;字节读
ISP_IAP_BYTE_PROGRAM EQU
2
;字节编程,前提是该字节是空,0FFh
ISP_IAP_SECTOR_ERASE EQU
3
;扇区擦除,要某字节为空,要擦一扇区
WAIT_TIME
0
;设置等待时间,30MHz以下0,24M以下1,
;20MHz以下2,12M以下3,6M以下4,3M以下5,2M以下6,1M以下7,
MOV
IAP_ADDRH,
#BYTE_ADDR_HIGH
;送地址高字节
MOV
IAP_ADDRL,
#BYTE_ADDR_LOW
;送地址低字节
MOV
IAP_CONTR,
#WAIT_TIME
;设置等待时间
ORL
IAP_CONTR,
#10000000B
;允许ISP/IAP操作
MOV
IAP_CMD,
#ISP_IAP_BYTE_READ
EQU
C
T
S
;字节读
U
C
M
Li
地址需要改变时
才需重新送地址
此两句可以合成一句,
并且只送一次就够了
;送字节读命令,命令不需改变时,不需重新送命令
�����������������������
MOV
IAP_TRIG,
#46h ;先送46h,再送B9h到ISP/IAP触发寄存器,每次都需如此
MOV
IAP_TRIG,
#0B9h ;送完B9h后,ISP/IAP命令立即被触发起动
;CPU等待IAP动作完成后,才会继续执行程序。
NOP
A,
ISP_DATA
MOV
南通国芯微电子有限公司
;数据读出到IAP_DATA寄存器后,CPU继续执行程序
;将读出的数据送往Acc
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
281
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
;以下语句可不用,只是出于安全考虑而已
MOV
IAP_CONTR,
#00000000B
;禁止ISP/IAP操作
MOV
IAP_CMD,
#00000000B
;去除ISP/IAP命令
;MOV
IAP_TRIG,
#00000000B
;防止ISP/IAP命令误触发
;MOV
IAP_ADDRH,
#0FFh
;送地址高字节单元为FFH,指向非EEPROM区
;MOV
IAP_ADDRL,
#0FFh
;送地址低字节单元为FFH,防止误操作
;字节编程,该字节为FFh/空时,可对其编程,否则不行,要先执行扇区擦除
MOV
IAP_DATA,
#ONE_DATA
;送字节编程数据到IAP_DATA,
;只有数据改变时才需重新送
MOV
IAP_ADDRH,
#BYTE_ADDR_HIGH
MOV
IAP_ADDRL,
#BYTE_ADDR_LOW
MOV
IAP_CONTR,
#WAIT_TIME
ORL
IAP_CONTR,
#10000000B
MOV
IAP_CMD,
#ISP_IAP_BYTE_PROGRAM ;送字节编程命令
MOV
IAP_TRIG,
#46h
MOV
IAP_TRIG,
#0B9h ;送完B9h后,ISP/IAP命令立即被触发起动
C
T
S
U
C
M
.
d
e
t
i
m
;送地址高字节
Li
;送地址低字节
地址需要改变时
才需重新送地址
;设置等待时间
;允许ISP/IAP操作
此两句可合成
一句,并且只
送一次就够了
;先送46h,再送B9h到ISP/IAP触发寄存器,每次都需如此
;CPU等待IAP动作完成后,才会继续执行程序.
NOP
;字节编程成功后,CPU继续执行程序
;以下语句可不用,只是出于安全考虑而已
MOV
IAP_CONTR,
#00000000B
;禁止ISP/IAP操作
MOV
IAP_CMD,
#00000000B
;去除ISP/IAP命令
;MOV
IAP_TRIG,
#00000000B
;防止ISP/IAP命令误触发
;MOV
IAP_ADDRH,
#0FFh ;送地址高字节单元为FFH,;指向非EEPROM区,防止误操作
;MOV
IAP_ADDRL,
#0FFh ;送地址低字节单元为FFH,指向非EEPROM区,防止误操作
282
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
;扇区擦除,没有字节擦除,只有扇区擦除,512字节/扇区,每个扇区用得越少越方便
;如果要对某个扇区进行擦除,而其中有些字节的内容需要保留,则需将其先读到单片机
;内部的RAM中保存,再将该扇区擦除,然后将须保留的数据写回该扇区,所以每个扇区
;中用的字节数越少越好,操作起来越灵活越快.
;扇区中任意一个字节的地址都是该扇区的地址,无需求出首地址.
MOV
IAP_ADDRH,
#SECTOR_FIRST_BYTE_ADDR_HIGH ;送扇区起始地址高字节
MOV
IAP_ADDRL,
#SECTOR_FIRST_BYTE_ADDR_LOW ;送扇区起始地址低字节
MOV
IAP_CONTR,
ORL
;地址需要改变时才需重新送地址
#WAIT_TIME
;设置等待时间
IAP_CONTR,
#10000000B
;允许ISP/IAP
MOV
IAP_CMD,
#ISP_IAP_SECTOR_ERASE
.
d
e
t
i
m
Li
此两句可以合
成一句,并且只
送一次就够了
;送扇区擦除命令,命令不需改变时,不需重新送命令
U
C
M
MOV
IAP_TRIG,
#46h
;先送46h,再送B9h到ISP/IAP触发寄存器,每次都需如此
MOV
C
T
S
IAP_TRIG,
#0B9h ;送完B9h后,ISP/IAP命令立即被触发起动
;CPU等待IAP动作完成后,才会继续执行程序.
NOP
;扇区擦除成功后,CPU继续执行程序
;以下语句可不用,只是出于安全考虑而已
MOV
IAP_CONTR,
#00000000B
;禁止ISP/IAP操作
MOV
IAP_CMD,
#00000000B
;去除ISP/IAP命令
;MOV
IAP_TRIG,
#00000000B
;防止ISP/IAP命令误触发
;MOV
IAP_ADDRH,
#0FFh
;送地址高字节单元为FFH,指向非EEPROM区
;MOV
IAP_ADDRL,
#0FFh
;送地址低字节单元为FFH,防止误操作
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
283
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
小常识: (STC单片机的Data Flash 当EEPROM功能使用)
3个基本命令----字节读,字节编程,扇区擦除
字节编程:将“1”�����������������������������������
写成“1”或�����������������������������
“0”,�������������������������
将������������������������
“0”���������������������
写成“0”。���������������
如果�������������
某������������
字节是FFH,�����
才����
可���
对其进
如果该字节���
不是FF� H��������������������������
���������������������������
,则须先将整个扇区擦除,因为只有“扇区擦除”才可以将
行字节编程。��������
“0”变为“1”。
扇区擦除:只有“扇区擦除”才可能将“0”擦除为“1”。
大建议:
.
d
e
t
i
m
1.同一次修改的数据放在同一扇区中,不是同一次修改的数据放在另外的扇区,就不须读出保
护。
Li
2.如果一个扇区只用一个字节,那就是真正的EEPROM,STC单片机的Data Flash比外部EEPROM要
快很多,读一个字节/编程一个字节大概是10uS/60uS/10mS。
U
C
M
3.如果在一个扇区中存放了大量的数据,某次只需要修改其中的一个字节或一部分字节时,则
另外的不需要修改的数据须先读出放在STC单片机的RAM中,然后擦除整个扇区,再将需要保留
的数据和需修改的数据��������������������������������
按字节逐字节��������������������������
写回该扇区中(�������������������
只有字节写命令,无连续字节写命令���
)。这
时每个扇区使用的字节数是使用的越少越方便(不需读出一大堆需保留数据)。
C
T
S
常问的问题:
1:IAP指令完成后,地址是否会自动“加1”或“减1”?
答:不会
2:送46和B9触发后,下一次IAP命令是否还需要送46和B9触发?
答:是,一定要。
284
南通国芯微电子有限公司
总机:0513-5501 2928 / 2929 / 2966
传真:0513-5501 2969 / 2956 / 2947
STC90C58AD系列单片机指南
技术支持网站:www.STCMCU.com
临时技术支持:13922829991
研发顾问:13922809991
10.4 EEPROM测试程序(C程序及汇编程序)
1. C程序:
;STC90C58AD系列单片机EEPROM/IAP 功能测试程序演示
/*------------------------------------------------------------------------------------*/
/* --- STC MCU International Limited ---------------------------------------*/
/* --- 演示STC90C58AD系列单片机 EEPROM/IAP功能--------------*/
/* --- Mobile: (86)13922805190 -----------------------------------------------*/
/* --- Fax: 86-755-82905966 ---------------------------------------------------*/
/* --- Tel: 86-755-82948412 ----------------------------------------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------------*/
/* 如果要在程序中使用或在文章中引用该程序, -------------------- ---*/
/* 请在程序中或文章中注明使用了STC的资料及程序 -----------*/
/*-------------------------------------------------------------------------------------*/
#include "reg51.h"
#include "intrins.h"
typedef unsigned char BYTE;
typedef unsigned int WORD;
U
C
M
/*Declare SFR associated with the IAP */
sfr IAP_DATA = 0xE2;
//Flash data register
sfr IAP_ADDRH = 0xE3;
//Flash address HIGH
sfr IAP_ADDRL = 0xE4;
//Flash address LOW
sfr IAP_CMD = 0xE5;
//Flash command register
sfr IAP_TRIG = 0xE6;
//Flash command trigger
sfr IAP_CONTR = 0xE7;
//Flash control register
C
T
S
.
d
e
t
i
m
Li
/*Define ISP/IAP/EEPROM command*/
#define CMD_IDLE 0
//Stand-By
#define CMD_READ 1
//Byte-Read
#define CMD_PROGRAM 2
//Byte-Program
#define CMD_ERASE 3
//Sector-Erase
/*Define ISP/IAP/EEPROM operation const for IAP_CONTR*/
//#define ENABLE_IAP 0x80
//if SYSCLK