

## **SN8P2722**

用户参考手册

Version 1.0

SONiX8 位单片机

SONiX 公司保留对以下所有产品在可靠性,功能和设计方面的改进作进一步说明的权利。SONiX 不承担由本手册所涉及的产品或电路的运用和使用所引起的任何责任,SONiX 的产品不是专门设计来应用于外科植入、生命维持和任何SONiX 产品的故障会对个体造成伤害甚至死亡的领域。如果将 SONiX 的产品应用于上述领域,即使这些是由 SONiX 在产品设计和制造上的疏忽引起的,用户应赔偿所有费用、损失、合理的人身伤害或死亡所直接或间接产生的律师费用,并且用户保证 SONiX 及其雇员、子公司、分支机构和销售商与上述事宜无关。



## 修正记录

| 版本      | 日期      | 内容          |
|---------|---------|-------------|
| VER 1.0 | 2008年3月 | 初版。         |
| VER 1.0 | 2008年5月 | 修改烧录信息章节内容。 |



## 目 录

| 1  | 产品机   | <b>死述</b>                  | 5    |
|----|-------|----------------------------|------|
|    | 1.1   | 功能特性                       | 5    |
|    | 1.2   | 系统结构框图                     | 6    |
|    | 1.3   | 引脚配置                       |      |
|    | 1.4   | 引脚描述                       |      |
|    | 1.5   | 引脚电路结构图                    |      |
| 2  |       | 上理器(CPU)                   |      |
| _  | 2.1   | 存储器                        |      |
|    | 2.1.1 |                            |      |
|    | 2.1.1 |                            |      |
|    |       |                            |      |
|    | 2.1.3 | 编译选项                       |      |
|    | 2.1.4 | 数据存储器 (RAM)                |      |
|    | 2.1.5 | 系统寄存器                      |      |
|    | 2.2   | 寻址模式                       |      |
|    | 2.2.1 | 立即寻址                       |      |
|    | 2.2.2 | 直接寻址                       |      |
|    | 2.2.3 | 间接寻址                       |      |
|    | 2.3   | 堆栈                         |      |
|    | 2.3.1 | 概述                         |      |
|    | 2.3.2 | 堆栈寄存器                      | . 25 |
|    | 2.3.3 | 堆栈操作举例                     |      |
| 3  | 复位.   |                            | . 27 |
|    | 3.1   | 概述                         | . 27 |
|    | 3.2   | 上电复位                       | . 28 |
|    | 3.3   | 看门狗复位                      | . 28 |
|    | 3.4   | 掉电复位                       | 29   |
|    | 3.4.1 | 概述                         | 29   |
|    | 3.4.2 | 系统工作电压                     |      |
|    | 3.4.3 | 掉电复位性能改进                   |      |
|    | 3.5   | 外部复位                       |      |
|    | 3.6   | 外部复位电路                     |      |
|    | 3.6.1 | RC复位电路                     |      |
|    | 3.6.2 | 二极管及RC复位电路                 |      |
|    | 3.6.3 | - 扱音及NO支性名詞<br>- 総正二极管复位电路 |      |
|    | 3.6.4 | 电压偏置复位电路                   |      |
|    | 3.6.5 | 外部IC复位                     |      |
| 4  |       | 対                          |      |
| -4 |       |                            |      |
|    | 4.1   | 概述                         |      |
|    |       |                            |      |
|    | 4.3   | OSCM寄存器                    |      |
|    | 4.4   | 系统高速时钟                     |      |
|    | 4.4.1 | 内部高速RC振荡器                  |      |
|    | 4.4.2 | 外部高速时钟                     |      |
|    | 4.5   | 系统低速时钟                     |      |
| _  | 4.5.1 | 系统时钟测试                     |      |
| 5  |       | [作模式                       |      |
|    | 5.1   | 概述                         |      |
|    | 5.2   | 系统模式切换举例                   | 43   |
|    | 5.3   | 唤醒时间                       |      |
|    | 5.3.1 | 概述                         | . 44 |
|    | 5.3.2 | 唤醒时间                       | .44  |
| 6  | 中断.   |                            | 45   |
|    | 6.1   | 概述                         | 45   |
|    | 6.2   | 中断使能寄存器INTEN               | 45   |
|    | 6.3   | 中断请求寄存器INTRQ               | 46   |
|    | 6.4   | GIE 全局中断                   |      |
|    | 6.5   | PUSH, POP处理                |      |
|    | 6.6   | INTO (P0.0) 中断             |      |
|    | 6.7   | T0 中断                      |      |
|    | 6.8   | TC0 中断                     |      |
|    |       |                            | - 0  |





|    | 6.9   | ADC中断                                   | . 51 |
|----|-------|-----------------------------------------|------|
|    | 6.10  | 多中断操作举例                                 |      |
| 7  |       | <b>シ</b> 上可体に干り                         |      |
| ų  |       |                                         |      |
|    | 7.1   | I/O口模式                                  |      |
|    | 7.2   | I/O口上拉电阻                                |      |
|    | 7.3   | I/O口数据寄存器                               | . 55 |
|    | 7.4   | P4 与ADC共用引脚                             | . 56 |
| 8  | 定时    |                                         | 57   |
|    | 8.1   | 看门狗定时器                                  |      |
|    | 8.2   | 定时器TO                                   |      |
|    | _     |                                         |      |
|    | 8.2.1 | " = "                                   |      |
|    | 8.2.2 | 7 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - |      |
|    | 8.2.3 | T0C计数寄存器                                | . 59 |
|    | 8.2.4 | T0 操作流程                                 | . 59 |
|    | 8.3   | 定时/计数器TC0                               | .60  |
|    | 8.3.1 |                                         |      |
|    | 8.3.2 | <i>"-</i> =                             |      |
|    |       |                                         |      |
|    | 8.3.3 |                                         |      |
|    | 8.3.4 |                                         |      |
|    | 8.3.5 |                                         |      |
|    | 8.3.6 | TC0 操作举例                                | . 65 |
|    | 8.4   | PWM0                                    | . 66 |
|    | 8.4.1 |                                         |      |
|    | 8.4.2 |                                         |      |
|    | 8.4.3 |                                         |      |
|    | 8.4.4 |                                         |      |
| ^  |       |                                         |      |
| 9  |       | 道ADC                                    |      |
|    | 9.1   | 概述                                      |      |
|    | 9.2   | ADM寄存器                                  | . 70 |
|    | 9.3   | ADR 寄存器                                 | .71  |
|    | 9.4   | ADB寄存器                                  | .71  |
|    | 9.5   | P4CON寄存器                                |      |
|    | 9.6   | ADC转换时间                                 |      |
|    | 9.7   | ADC操作实例                                 |      |
|    | 9.8   |                                         |      |
| 40 |       | ADC电路                                   |      |
| 10 |       | K蜂鸣器(BUZZER)输出                          |      |
|    | 10.1  | 概述                                      |      |
|    | 10.2  | BZM模式寄存器                                |      |
| 11 | 指     | ·令表                                     | . 75 |
| 12 | 申     | 气特性                                     | . 76 |
|    | 12.1  | 极限参数                                    | . 76 |
|    | 12.2  | 电气特性                                    |      |
| 13 |       | P2722 开发工具                              |      |
| ΙQ | 13.1  | - Z1 Z2                                 |      |
|    | 13.1  |                                         | _    |
|    |       | 在线仿真器(ICE)和EV-KIT应用注意事项                 |      |
| 14 |       | 烧录信息                                    |      |
|    | 14.1  | 烧录转接板信息                                 | . 80 |
|    | 14.2  | 烧录引脚信息                                  |      |
| 15 | 芯     | 片正印命名规则                                 | . 83 |
|    | 15.1  | 概述                                      |      |
|    | 15.2  | 芯片型号说明                                  |      |
|    | 15.2  | 命名举例                                    |      |
|    |       |                                         |      |
|    | 15.4  | 日期码规则                                   | -    |
| 16 |       | 装信息                                     |      |
|    | 16.1  | P-DIP 20 PIN                            |      |
|    | 16.2  | SOP 20 PIN                              |      |
|    | 16.3  | SSOP 20 PIN                             | . 87 |



## 1 产品概述

## 1.1 功能特性

◆ 存储器

ROM: 2K \* 16 位。 RAM: 128 字节。

◆ 8层堆栈缓存器。

◆ 4个中断源

3 个内部中断源: T0、TC0、ADC。 1 个外部中断源: INT0。

◆ I/O 端口配置

双向输入输出口: P0、P4、P5。 具有唤醒功能端口: P0 电平触发。 内置上拉电阻端口: P0、P4、P5。 外部中断引脚: P0.0。 ADC 输入引脚: AIN0~AIN4。

◆ Fcpu(指令周期) Fcpu = Fosc/4、Fosc/8、Fosc/16。

◆ 功能强大的指令系统

指令长度为 1 个字。 大部分指令执行只需 1 个周期。 跳转指令 JMP 可在整个 ROM 区执行。 查表指令 MOVC 可寻址整个 ROM 区。 ◆ 2个8位定时器

T0: 基本定时器。

TC0: 自动装载定时/计数器/PWM/蜂鸣器输出。

- ◆ 单通道 8 位 PWM 输出
- ◆ 单通道 2KHz/4KHz 蜂鸣器输出
- ◆ 内置看门狗定时器,其时钟源由内部低速 RC 振荡器提供 (16KHz @3V, 32KHz @5V)
- ◆ 5 通道 12 位 ADC.

#### ◆ 4种时钟系统

外部高速时钟: RC 模式, 高达 10 MHz。 外部高速时钟: 晶振模式, 高达 16 MHz。 内部高速时钟: RC 模式, 高达 16 MHz。 内部低速时钟: RC 振荡器 16KHz (3V), 32KHz (5V)。

◆ 4 种工作模式

普通模式: 高、低速时钟同时工作。 低速模式: 只有低速时钟工作。 睡眠模式: 高、低速时钟均不工作。 绿色模式: 由定时器周期性唤醒。

◆ 封装形式

P-DIP 20 pin. SOP 20 pin. SSOP 20 pin.

#### 特性选择列表

| 单片机型号    | ROM   | РОМ | ROM RAM 堆栈 |    |     | 定时器 |     |        | ADC    | 2K/4K  | PWM  | 唤醒功能                | 封装形式 |
|----------|-------|-----|------------|----|-----|-----|-----|--------|--------|--------|------|---------------------|------|
| 一 千刀が至う  |       | KAW | 一堆仅        | T0 | TC0 | TC1 | 1/0 | ADC    | Buzzer | TCnOUT | 引脚数目 | <b>到</b> 表形式        |      |
| SN8P2711 | 1K*16 | 64  | 4          | -  | V   | ٧   | 12  | 5+1 ch | -      | 2      | 5    | PDIP14/SOP14/SSOP16 |      |
| SN8P2722 | 2K*16 | 128 | 8          | ٧  | V   | -   | 18  | 5-ch   | ٧      | 1      | 8    | PDIP20/SOP20/SSOP20 |      |



## 1.2 系统结构框图





## 1.3 引脚配置

SN8P2722P (PDIP 20 pins) SN8P2722S (SOP 20 pins) SN8P2722X (SSOP 20 pins)

|              |           |   |    | =               |  |  |  |  |  |  |  |
|--------------|-----------|---|----|-----------------|--|--|--|--|--|--|--|
| VSS          | 1         | U | 20 | VDD             |  |  |  |  |  |  |  |
| XIN/P0.1     | 2         |   | 19 | P0.0/INT0       |  |  |  |  |  |  |  |
| XOUT/P0.2    | 3         |   | 18 | P4.4/AIN4       |  |  |  |  |  |  |  |
| RST/VPP/P0.3 | 4         |   | 17 | P4.3/AIN3       |  |  |  |  |  |  |  |
| P0.4/BZ      | 5         |   | 16 | P4.2/AIN2       |  |  |  |  |  |  |  |
| P0.5         | 6         |   | 15 | P4.1/AIN1       |  |  |  |  |  |  |  |
| P0.6         | 7         |   | 14 | P4.0/AIN0       |  |  |  |  |  |  |  |
| P0.7         | 8         |   | 13 | P5.4/TC0OUT/PWM |  |  |  |  |  |  |  |
| P5.0         | 9         |   | 12 | P5.3            |  |  |  |  |  |  |  |
| P5.1         | 10        |   | 11 | P5.2            |  |  |  |  |  |  |  |
| •            | SN8P2722P |   |    |                 |  |  |  |  |  |  |  |

SN8P2722S SN8P2722X

## 1.4 引脚描述

| 引脚名称                  | 类型   | 说明                                         |
|-----------------------|------|--------------------------------------------|
| VDD, VSS              | Р    | 电源输入端。                                     |
|                       |      | P0.3:禁止外部复位时为单向输入引脚,施密特触发, <b>无内置上拉电阻。</b> |
| P0.3/RST/VPP          | I, P | RST: 系统复位输入引脚,施密特触发,低电平有效,通常保持高电平。         |
|                       |      | VPP: 烧录时为 12.3V 电源输入引脚。                    |
| XIN/P0.1              | I/O  | XIN: 使能外部振荡器(晶振或 RC)时为振荡信号输入引脚。            |
| 7(114/1 0.1           | 1,0  | P0.1: 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻,具有唤醒功能。 |
| XOUT/P0.2             | I/O  | XOUT: 使能外部晶振模式时为振荡信号输出引脚。                  |
| 7,00171 0.2           | "0   | P0.2: 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻,具有唤醒功能。 |
|                       | I/O  | P0.0: 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻,具有唤醒功能。 |
| P0.0/INT0             |      | INTO:外部中断触发引脚(施密特触发)。                      |
|                       |      | TCO 事件计数器的信号输入引脚。                          |
| P0.4/BZ               | I/O  | P0.4: 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻,具有唤醒功能。 |
|                       | _    | BZ: 2KHz/4KHz buzzer 输出引脚。                 |
| P0[7:5]               | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。              |
| P4[4:0]/AIN[4:0]      | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。              |
| 1 4[4.0]// til 4[4.0] | 1,0  | AIN[4:0]: ADC 的输入通道。                       |
| P5[3:0]               | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。              |
|                       |      | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。              |
| P5.4/PWM/TC0OUT       | I/O  | PWM: PWM 输出引脚。                             |
|                       |      | TC0OUT: TC0 / 2 信号输出引脚。                    |



## 1.5 引脚电路结构图

P0.1、P0.2 结构:



P0.3 结构:



P0、P5 结构:



P4 结构:





# **2** 中央处理器(CPU)

## 2.1 存储器

## 2.1.1 程序存储器

☞ ROM: 2K

|                         | I COIN |                  |
|-------------------------|--------|------------------|
| 0000H                   | 复位向量   | 用户复位向量<br>用户程序开始 |
| 0001H                   |        |                  |
|                         | 通用存储区域 |                  |
| 0007H                   |        |                  |
| 0008H                   | 中断向量   | 用户中断向量           |
| 0009H                   |        | 用户程序             |
| 000FH<br>0010H<br>0011H | 通用存储区域 |                  |
| 07FCH                   |        | 用户程序结束           |
| 07FDH<br>07FEH<br>07FFH | 保留     |                  |

**ROM** 

## 2.1.1.1 复位向量(0000H)

具有一个字长的系统复位向量(0000H)。

- ☞ 上电复位 (NT0=1, NPD=0);
- ☞ 看门狗复位(NT0=0, NPD=0);
- ☞ 外部复位(NT0=1, NPD=1)。

发生上述任一种复位后,程序将从 0000H 处重新开始执行,系统寄存器也都将恢复为默认值。根据 PFLAG 寄存器中的 NT0 和 NPD 标志位的内容可以判断系统复位方式。下面一段程序演示了如何定义 ROM 中的复位向量。

▶ 例:定义复位向量。



#### 2.1.1.2 中断向量(0008H)

中断向量地址为 0008H。一旦有中断响应,程序计数器 PC 的当前值就会存入堆栈缓存器并跳转到 0008H 开始执行中断服务程序。0008H 处的第一条指令必须是"JMP"或"NOP"。下面的示例程序说明了如何编写中断服务程序。

\* 注:"PUSH","POP"指令用于存储和恢复 ACC/PFLAG,NT0、NTD 不受影响。PUSH/POP 缓存器是唯一的,且仅有一层。

;程序结束。

▶ 例:定义中断向量,中断服务程序紧随 ORG 8H 之后。

.CODE

ORG 0 JMP STAR

P START ; 跳至用户程序。

ORG 8H ;中断向量。

PUSH ; 保存 ACC 和 PFLAG。

POP ; 恢复 ACC 和 PFLAG。

RETI ; 中断结束。

START: ; 用户程序开始。

JMP START ; 用户程序结束。

▶ 例:定义中断向量,中断程序在用户程序之后。

**ENDP** 

.CODE

ORG 0

JMP START ; 跳至用户程序。

… ORG 8H ; 中断向量。

JMP MY\_IRQ ; 跳至中断程序。

ORG 10H

; 用户程序开始。

JMP START ; 用户程序结束。

···

MY\_IRQ: ;中断程序开始。

PUSH ; 保存 ACC 和 PFLAG。

POP ; 恢复 ACC 和 PFLAG。

RETI;中断程序结束。

ENDP ;程序结束。

- ▶ 注:从上面的程序中容易得出 SONiX 的编程规则,有以下几点:
  - 1. 地址 0000H 的"JMP"指令使程序从头开始执行;
  - 2. 地址 0008H 是中断向量;
  - 3. 用户的程序应该是一个循环。



## 2.1.1.3 查表

在 SONiX 单片机中,对 ROM 区中的数据进行查找,寄存器 Y 指向所找数据地址的中间字节(bit8~bit15),寄存 器 Z 指向所找数据地址的低字节(bit0~bit7)。执行完 MOVC 指令后,所查找数据低字节内容被存入 ACC 中,而数据高 字节内容被存入 R 寄存器。

例: 查找 ROM 地址为"TABLE1"的值。

**B0MOV** Y, #TABLE1\$M **B0MOV** Z, #TABLE1\$L

MOVC

;设置 TABLE1 地址高字节。 ;设置 TABLE1 地址低字节。

; 查表, R = 00H, ACC = 35H。

; 查找下一地址。

**INCMS** Ζ **JMP** @F

**INCMS** 

NOP

; Z 没有溢出。

; Z 溢出(FFH → 00), → Y=Y+1

@@: MOVC

DW

0035H 5105H 2012H

DW

DW

;定义数据表(16位)数据。

: 查表, R = 51H, ACC = 05H。

注:当寄存器 Z 溢出 (从 0FFH 变为 00H) 时,寄存器 Y 并不会自动加 1。因此, Z 溢出时,Y 必须由程序加 1,下面的宏 INC\_YZ 能够对 Y 和 Z 寄存器自动处理。

例:宏 INC\_YZ。

INC\_YZ

TABLE1:

**MACRO** 

**INCMS** 7

**JMP** 

@F ;没有溢出。

**INCMS** 

NOP

;没有溢出。

@@:

**ENDM** 

例:通过"INC\_YZ"对上例进行优化。

**B0MOV** Y, #TABLE1\$M

**B0MOV** Z, #TABLE1\$L

;设置 TABLE1 地址中间字节。 ;设置 TABLE1 地址低字节。

MOVC

; 查表, R = 00H, ACC = 35H。

INC\_YZ

;查找下一地址数据。

@@: MOVC ; 查表, R = 51H, ACC = 05H。

TABLE1:

DW 0035H DW 5105H DW 2012H

; 定义数据表(16位)数据。



**GETDATA**:

下面的程序通过累加器对Y,Z寄存器进行处理来实现查表功能,但需要特别注意进位时的处理。

▶ 例:由指令 B0ADD/ADD 对 Y 和 Z 寄存器加 1。

B0MOV Y, #TABLE1\$M ; 设置 TABLE1 地址中间字节。 B0MOV Z, #TABLE1\$L ; 设置 TABLE1 地址低字节。

B0MOV A, BUF ;  $Z = Z + BUF_o$ 

BOADD Z, A

B0BTS1 FC ; 检查进位标志。 JMP GETDATA ; FC = 0。

SINCMS Y ; FC = 0.

NOP

MOVC ; 存储数据, 如果 BUF = 0, 数据为 0035H。

;如果 BUF = 1,数据=5105H。 ;如果 BUF = 2,数据=2012H。

 TABLE1:
 DW
 0035H
 ; 定义数据表(16 位)数据。

DW 5105H DW 2012H

• • •



## 2.1.1.4 跳转表

跳转表能够实现多地址跳转功能。由于 PCL 和 ACC 的值相加即可得到新的 PCL,因此,可以通过对 PCL 加上不同 的 ACC 值来实现多地址跳转。ACC 值若为 n,PCL+ACC 即表示当前地址加 n,执行完当前指令后 PCL 值还会自加 1, 可参考以下范例。如果 PCL+ACC 后发生溢出, PCH 则自动加 1。由此得到的新的 PC 值再指向跳转指令列表中新的地 址。这样,用户就可以通过修改 ACC 的值轻松实现多地址的跳转。

注: PCH 只支持 PC 增量运算,而不支持 PC 减量运算。当 PCL+ACC 后如有进位,PCH 的值会自动加 1。PCL-ACC 后若有借 位,PCH 的值将保持不变,用户在设计应用时要加以注意。

#### 例:跳转表。

**ORG** 0100H ;跳转表从 ROM 前端开始。 **B0ADD** PCL, A ; PCL = PCL + ACC, PCL 溢出时 PCH 加 1。 A0POINT **JMP** ; ACC = 0,跳至 A0POINT。 **JMP** A1POINT ; ACC = 1, 跳至 A1POINT。 **JMP** A2POINT ; ACC = 2, 跳至 A2POINT。 **JMP** A3POINT ; ACC = 3, 跳至 A3POINT。

SONiX 单片机提供一个宏以保证可靠执行跳转表功能, 它会自动检测 ROM 边界并将跳转表移至适当的位置。但采用 该宏程序会占用部分 ROM 空间。

#### 例:宏"MACRO3.H"中, "@JMP\_A"的应用。

**B0MOV** A, BUF0 "BUF0"从0至4。 @JMP\_A 列表个数为 5。 ; ACC = 0, 跳至 A0POINT。 **A0POINT JMP JMP** A1POINT ; ACC = 1,跳至 A1POINT。 ; ACC = 2,跳至 A2POINT。 **JMP** A2POINT **JMP** A3POINT ; ACC = 3,跳至 A3POINT。 **JMP** A4POINT ; ACC = 4, 跳至 A4POINT。

如果跳转表恰好位于 ROM BANK 边界处(00FFH~0100H),宏指令"@JMP\_A"将调整跳转表到适当的位置(0100H)。

"DUEO" ILO ZILA

#### 例:如果跳转表跨越 ROM 边界,将引起程序错误。

**MACRO** VAL @JMP\_A IF ((\$+1) !& 0XFF00) !!= ((\$+(VAL)) !& 0XFF00) **JMP** (\$ | 0XFF) **ORG** (\$ | 0XFF) **ENDIF** ADD PCL, A **ENDM** 

#### 注: "VAL"为跳转表列表中列表个数。

DOM 40\ /

#### "@JMP\_A"运用举例 例:

; 编译前 ROM 地址

|              | BOMOA  | A, BUF0 | ; "BUF0" 从 0 到 4。     |
|--------------|--------|---------|-----------------------|
|              | @JMP_A | 5       | ;列表个数为5。              |
| 00FDH        | JMP    | A0POINT | ; ACC = 0,跳至 A0POINT。 |
| 00FEH        | JMP    | A1POINT | ; ACC = 1,跳至 A1POINT。 |
| 00FFH        | JMP    | A2POINT | ; ACC = 2,跳至 A2POINT。 |
| 0100H        | JMP    | A3POINT | ; ACC = 3,跳至 A3POINT。 |
| 0101H        | JMP    | A4POINT | ; ACC = 4,跳至 A4POINT。 |
| (4) W -      |        |         |                       |
| ;编译后         |        |         |                       |
| DOM thit tip |        |         |                       |

A DIJEO

ROM 地址

**B0MOV** A, BUF0 ; "BUF0"从0到4。 ;列表个数为5。 @JMP A 5 0100H **JMP A0POINT** ; ACC = 0, 跳至 A0POINT。 0101H **JMP** A1POINT ; ACC = 1,跳至 A1POINT。 ; ACC = 2, 跳至 A2POINT。 **JMP A2POINT** 0102H **JMP** 0103H A3POINT ; ACC = 3, 跳至 A3POINT。 **JMP** A4POINT ; ACC = 4, 跳至 A4POINT。 0104H



## 2.1.2 CHECKSUM 计算

ROM 末端位置的几个字限制使用,进行 Checksum 计算时,用户应避免对该单元的访问。.

▶ 例:示例程序演示了如何对 00H 到用户程序结束进行 Checksum 计算。

MOV A,#END\_USER\_CODE\$L

BOMOV END\_ADDR1, A ; 用户程序结束地址低位地址存入end\_addr1。

MOV A,#END\_USER\_CODE\$M

BOMOV END\_ADDR2, A ; 用户程序结束地址中间地址存入end\_addr2。

CLR Y ; 清 Y。 CLR Z ; 清 Z。

@@:

MOVC

BOBSET FC ; 清标志位 C。

ADD DATA1, A ;

MOV A, R

ADC DATA2, A ;

JMP END\_CHECK ; 检查 YZ 地址是否为代码的结束地址。

AAA:

INCMS Z

END\_CHECK:

MOV A, END\_ADDR1

CMPRS A, Z ; 检查 Z 地址是否为用户程序结束地址低位地址。

JMP AAA ; 否,则进行 Checksum 计算。

MOV A, END\_ADDR2

CMPRS A, Y ; 是则检查 Y 的地址是否为用户程序结束地址中间地址。

JMP AAA ; 否,则进行 Checksum 计算。 JMP CHECKSUM\_END ; 是则 Checksum 计算结束。

Y ADD 1:

INCMS Y ;

NOP

JMP @B ; 跳转到 Checksum 计算。

CHECKSUM\_END:

• • •

END\_USER\_CODE: ;程序结束。



## 2.1.3 编译选项

| 编译选项          | 内容        | 功能说明                                                    |  |  |  |  |  |  |  |  |
|---------------|-----------|---------------------------------------------------------|--|--|--|--|--|--|--|--|
|               | IHRC_16M  | 内部高速振荡器采用 16MHz RC 振荡电路,XIN/XOUT(P0.2/P0.3)为普通的 I/O 引脚。 |  |  |  |  |  |  |  |  |
|               | RC        | 外部高速时钟振荡器采用廉价的 RC 振荡电路,XOUT(P0.2)为普通的 I/O 引脚。           |  |  |  |  |  |  |  |  |
| High_Clk      | 32K X'tal | 外部高速时钟振荡器采用低频晶体/陶瓷振荡器(如 32.768Hz)。                      |  |  |  |  |  |  |  |  |
|               | 12M X'tal | 外部高速时钟振荡器采用高频晶体/陶瓷振荡器(如 12MHz)。                         |  |  |  |  |  |  |  |  |
|               | 4M X'tal  | 外部高速时钟振荡器采用标准晶体/陶瓷振荡器(如 4Mhz)。                          |  |  |  |  |  |  |  |  |
|               | Always_On | 始终开启看门狗定时器,即使在睡眠模式和绿色模式下也处于开启状态。                        |  |  |  |  |  |  |  |  |
| Watch_Dog     | Enable    | 开启看门狗定时器,但在睡眠和绿色模式时关闭。                                  |  |  |  |  |  |  |  |  |
|               | Disable   | 闭看门狗定时器。                                                |  |  |  |  |  |  |  |  |
|               | Fhosc/4   | 指令周期=4个时钟周期。                                            |  |  |  |  |  |  |  |  |
| Fcpu          | Fhosc/8   | 台令周期=8个时钟周期。                                            |  |  |  |  |  |  |  |  |
|               | Fhosc/16  | 指令周期=16 个时钟周期                                           |  |  |  |  |  |  |  |  |
| Reset_Pin     | Reset     | 使能外部复位引脚.                                               |  |  |  |  |  |  |  |  |
| rkeset_r iii  | P03       | P0.3 为单向输入引脚,无上拉电阻。                                     |  |  |  |  |  |  |  |  |
| Security      | Enable    | ROM 代码加密。                                               |  |  |  |  |  |  |  |  |
| Security      | Disable   | ROM 代码不加密。                                              |  |  |  |  |  |  |  |  |
| Noise Filter  | Enable    | 开启杂讯滤波功能。                                               |  |  |  |  |  |  |  |  |
| Noise_i litei | Disable   | 禁止杂讯滤波功能。                                               |  |  |  |  |  |  |  |  |
|               | LVD_L     | VDD 低于 2.0V 时,LVD 复位系统。                                 |  |  |  |  |  |  |  |  |
|               | LVD_M     | VDD 低于 2.0V 时, LVD 复位系统;                                |  |  |  |  |  |  |  |  |
| LVD           |           | PFLAG 寄存器的 LVD24 位作为 2.4V 低电压监测器。                       |  |  |  |  |  |  |  |  |
|               | LVD_H     | VDD 低于 2.4V 时,LVD 复位系统;                                 |  |  |  |  |  |  |  |  |
|               | L V D_11  | PFLAG 寄存器的 LVD36 位作为 3.6V 低电压监测器。                       |  |  |  |  |  |  |  |  |

### ▶ 注:

- 1. 在干扰严重环境下,强烈建议开启杂迅滤波器,并将"Watch\_Dog"选项设置为"Always\_On";
- 2. 编译选项 Fcpu 仅针对高速时钟,在低速模式下 Fcpu = FILRC/4。

## 2.1.4 数据存储器 (RAM)

## ☞ RAM: 128 字节

|        | 地址                               | RAM                 |                                        |
|--------|----------------------------------|---------------------|----------------------------------------|
|        | 000H<br>"<br>"<br>"<br>"<br>07FH | 通用区                 |                                        |
| BANK 0 | 080H<br>"<br>"<br>"<br>"<br>0FFH | 系统寄存器<br>bank 0 结束区 | Bank0 的 080H~0FFH 是系统寄存器<br>区(128 字节)。 |



## 2.1.5 系统寄存器

## 2.1.5.1 系统寄存器表

|   | 0     | 1     | 2     | 3     | 4     | 5     | 6     | 7     | 8     | 9     | Α     | В     | С     | D     | Е     | F     |
|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 8 | -     | -     | R     | Z     | Υ     | -     | PFLAG | -     | -     | -     | -     | -     | -     | -     | -     | -     |
| 9 | -     | 1     | -     | -     | -     | -     | 1     | -     | 1     | -     | 1     | -     | -     | -     | -     | -     |
| Α | -     | 1     | 1     | -     | -     | -     | ı     | -     | 1     | -     | 1     | -     | -     | -     | -     | P4CON |
| В | -     | ADM   | ADB   | ADR   | -     | -     | -     | -     | P0M   | -     | -     | -     | -     | -     | -     | PEDGE |
| С | -     | -     | -     | -     | P4M   | P5M   | -     | -     | INTRQ | INTEN | OSCM  | -     | WDTR  | TC0R  | PCL   | PCH   |
| D | P0    | -     | -     | -     | P4    | P5    | -     | -     | TOM   | T0C   | TC0M  | TC0C  | BZM   | -     | -     | STKP  |
| Ε | P0UR  | 1     | -     | -     | P4UR  | P5UR  | 1     | @YZ   | 1     | -     | 1     | -     | -     | -     | -     | -     |
| F | STK7L | STK7H | STK6L | STK6H | STK5L | STK5H | STK4L | STK4H | STK3L | STK3H | STK2L | STK2H | STK1L | STK1H | STK0L | STK0H |

## 2.1.5.2 系统寄存器说明

R = 工作寄存器及 ROM 查表数据缓存器 Y, Z = 专用寄存器,@YZ 间接寻址寄存器,ROM 寻址寄存器

 PFLAG
 = ROM 页及特殊标志寄存器
 P4CON
 = P4 配置控制寄存器

 ADB
 = ADC 数据缓存器
 ADM
 = ADC 模式寄存器

 PnM
 = Pn 模式控制寄存器
 ADR
 = ADC 分辨率选择寄存器

 INTRQ
 = 中断请求净存器
 PEDGE
 = P0.0 边沿触发寄存器

 PEDGE
 = P0.0 边沿触发寄存器

 OSCM
 = 振荡器模式寄存器
 INTEN
 = 中断使能寄存器

 WDTR
 = 看门狗定时器清零寄存器
 PCH, PCL = 程序计数器

 Pn
 = Pn 数据缓存器
 PnUR
 = Pn 上拉电阻控制寄存器

 TOM
 = T0 模式寄存器
 TOC
 = T0 计数寄存器

 TCOM
 = TC0 模式寄存器
 TCOC
 = TC0 计数寄存器

 TCOM
 = TC0 模式寄存器
 TCOC
 = TC0 计数寄存器

 TCOR
 = TC0 自动装载数据缓存器
 BZM
 = 蜂鸣器控制寄存器

 STK0~STK7 = 堆栈缓存器
 @YZ
 = 间接寻址寄存器

STKP = 堆栈指针



#### 2.1.5.3 系统寄存器位定义

| 地址   | Bit7    | Bit6       | Bit5     | Bit4     | Bit3     | Bit2    | Bit1     | Bit0     | R/W | 备注    |
|------|---------|------------|----------|----------|----------|---------|----------|----------|-----|-------|
| 082H | RBIT7   | RBIT6      | RBIT5    | RBIT4    | RBIT3    | RBIT2   | RBIT1    | RBIT0    | R/W | R     |
| 083H | ZBIT7   | ZBIT6      | ZBIT5    | ZBIT4    | ZBIT3    | ZBIT2   | ZBIT1    | ZBIT0    | R/W | Z     |
| 084H | YBIT7   | YBIT6      | YBIT5    | YBIT4    | YBIT3    | YBIT2   | YBIT1    | YBIT0    | R/W | Y     |
| 086H | NT0     | NPD        | LVD36    | LVD24    | 15110    | C       | DC       | Z        | R/W | PFLAG |
| 0AFH |         |            | 2.200    | P4CON4   | P4CON3   | P4CON2  | P4CON1   | P4CON0   | R/W | P4CON |
| 0B1H | ADENB   | ADS        | EOC      | GCHS     | 1 400110 | CHS2    | CHS1     | CHS0     | R/W | ADM   |
| 0B1H | ADB11   | ADB10      | ADB9     | ADB8     | ADB7     | ADB6    | ADB5     | ADB4     | R   | ADB   |
| 0B3H | ADDII   | ADCKS1     | ADD9     | ADCKS0   | ADB7     | ADB0    | ADB3     | ADB4     | R/W | ADR   |
| 0B8H | P07M    | P06M       | P05M     | P04M     | ADDO     | P02M    | P01M     | P00M     | R/W | POM   |
| 0BFH | 1 07101 | 1 00101    | 1 00111  | P00G1    | P00G0    | 1 02101 | 1 0 1101 | 1 00101  | R/W | PEDGE |
| 0C4H |         |            |          | P44M     | P43M     | P42M    | P41M     | P40M     | R/W | P4M   |
| 0C5H |         |            |          | P54M     | P53M     | P52M    | P51M     | P50M     | R/W | P5M   |
| 0C8H | ADCIRQ  |            | TC0IRQ   | TOIRQ    | 1 33101  | 1 OZIVI | 1 31101  | P00IRQ   | R/W | INTRQ |
| 0C9H | ADCIEN  |            | TCOIEN   | TOIRQ    |          |         |          | POOIEN   | R/W | INTEN |
| 0CAH | ADOILIV |            | TOOILIV  | CPUM1    | CPUM0    | CLKMD   | STPHX    | 1 OOILIV | R/W | OSCM  |
| 0CCH | WDTR7   | WDTR6      | WDTR5    | WDTR4    | WDTR3    | WDTR2   | WDTR1    | WDTR0    | W   | WDTR  |
| 0CDH | TC0R7   | TC0R6      | TC0R5    | TC0R4    | TC0R3    | TC0R2   | TC0R1    | TC0R0    | W   | TC0R  |
| 0CEH | PC7     | PC6        | PC5      | PC4      | PC3      | PC2     | PC1      | PC0      | R/W | PCL   |
| 0CFH | 1 07    | . 00       | . 00     |          | . 00     | PC10    | PC9      | PC8      | R/W | PCH   |
| 0D0H | P07     | P06        | P05      | P04      | P03      | P02     | P01      | P00      | R/W | P0    |
| 0D4H | 107     | 1 00       | 1 00     | P44      | P43      | P42     | P41      | P40      | R/W | P4    |
| 0D5H |         |            |          | P54      | P53      | P52     | P51      | P50      | R/W | P5    |
| 0D8H | T0ENB   | T0rate2    | T0rate1  | T0rate0  | . 00     | . 02    |          | 1 00     | R/W | TOM   |
| 0DAH | TC0ENB  | TC0rate2   | TC0rate1 | TC0rate0 | TC0CKS   | ALOAD0  | TC0OUT   | PWM0OUT  | R/W | TC0M  |
| 0DBH | TC0C7   | TC0C6      | TC0C5    | TC0C4    | TC0C3    | TC0C2   | TC0C1    | TC0C0    | R/W | TC0C  |
| 0DCH | BZEN    | BZrate1    | BZrate0  |          |          |         |          |          | R/W | BZM   |
| 0DFH | GIE     |            |          |          |          | STKPB2  | STKPB1   | STKPB0   | R/W | STKP  |
| 0E0H | P07R    | P06R       | P05R     | P04R     |          | P02R    | P01R     | P00R     | W   | P0UR  |
| 0E4H |         |            |          | P44R     | P43R     | P42R    | P41R     | P40R     | W   | P4UR  |
| 0E5H |         |            |          | P54R     | P53R     | P52R    | P51R     | P50R     | W   | P5UR  |
| 0E7H | @YZ7    | @YZ6       | @YZ5     | @YZ4     | @YZ3     | @YZ2    | @YZ1     | @YZ0     | R/W | @YZ   |
| 0F0H | S7PC7   | S7PC6      | S7PC5    | S7PC4    | S7PC3    | S7PC2   | S7PC1    | S7PC0    | R/W | STK7L |
| 0F1H |         |            |          |          |          | S7PC10  | S7PC9    | S7PC8    | R/W | STK7H |
| 0F2H | S6PC7   | S6PC6      | S6PC5    | S6PC4    | S6PC3    | S6PC2   | S6PC1    | S6PC0    | R/W | STK6L |
| 0F3H |         |            |          |          |          | S6PC10  | S6PC9    | S6PC8    | R/W | STK6H |
| 0F4H | S5PC7   | S5PC6      | S5PC5    | S5PC4    | S5PC3    | S5PC2   | S5PC1    | S5PC0    | R/W | STK5L |
| 0F5H |         |            |          |          |          | S5PC10  | S5PC9    | S5PC8    | R/W | STK5H |
| 0F6H | S4PC7   | S4PC6      | S4PC5    | S4PC4    | S4PC3    | S4PC2   | S4PC1    | S4PC0    | R/W | STK4L |
| 0F7H |         |            |          |          |          | S4PC10  | S4PC9    | S4PC8    | R/W | STK4H |
| 0F8H | S3PC7   | S3PC6      | S3PC5    | S3PC4    | S3PC3    | S3PC2   | S3PC1    | S3PC0    | R/W | STK3L |
| 0F9H |         |            |          |          |          | S3PC10  | S3PC9    | S3PC8    | R/W | STK3H |
| 0FAH | S2PC7   | S2PC6      | S2PC5    | S2PC4    | S2PC3    | S2PC2   | S2PC1    | S2PC0    | R/W | STK2L |
| 0FBH |         | , <u>-</u> |          |          |          | S2PC10  | S2PC9    | S2PC8    | R/W | STK2H |
| 0FCH | S1PC7   | S1PC6      | S1PC5    | S1PC4    | S1PC3    | S1PC2   | S1PC1    | S1PC0    | R/W | STK1L |
| 0FDH |         | -          |          |          |          | S1PC10  | S1PC9    | S1PC8    | R/W | STK1H |
| 0FEH | S0PC7   | S0PC6      | S0PC5    | S0PC4    | S0PC3    | S0PC2   | S0PC1    | S0PC0    | R/W | STK0L |
| 0FFH |         |            |          |          |          | S0PC10  | S0PC9    | S0PC8    | R/W | STK0H |

### 注:

- 所有寄存器名都已在 SN8ASM 编译器中做了宣告;
   在 SN8ASM 编译器中,对寄存器的位进行操作,必须以 "F" 开头(如:B0BCLR FT0IEN);
   指令 "b0bset"、 "b0bclr"、 "bset"、 "bclr" 只能用于可读写的(R/W)寄存器。



### 2.1.5.4 累加器

8 位数据寄存器 ACC 用来执行 ALU 与数据存储器之间数据的传送操作。如果操作结果为零(Z)或有进位产生(C 或 DC),程序状态寄存器 PFLAG 中相应位会发生变化。

ACC 并不在 RAM 中, 因此在立即寻址模式中不能用 "B0MOV" 指令对其进行读写。

### ▶ 例:读/写 ACC。

;数据写入ACC。

MOV A, #0FH

;读取 ACC 中的数据并存入 BUF。

MOV BUF, A B0MOV BUF, A

; BUF 中的数据写入 ACC。

MOV A, BUF B0MOV A, BUF

系统执行中断操作时,ACC 和 PFLAG 中的数据不会自动存储,用户需通过程序将中断入口处的 ACC 和 PFLAG 中的数据送入存储器进行保存。可通过"PUSH"和"POP"指令对 ACC 和 PFLAG 等系统寄存器进行存储及恢复。

#### 》 例: ACC 和工作寄存器中断保护操作。

INT\_SERVICE:

PUSH ; 保存 PFLAG 和 ACC。

... .

POP ; 恢复 ACC 和 PFLAG。

RETI ; 退出中断。



## 2.1.5.5 程序状态寄存器 PFLAG

寄存器 PFLAG 中包含 ALU 运算状态信息、系统复位状态信息和 LVD 检测信息,其中,位 NT0 和 NPD 显示系统复位状态信息,包括上电复位、LVD 复位、外部复位和看门狗复位;位 C、DC 和 Z 显示 ALU 的运算信息。位 LVD24 和 LVD36 显示了单片机供电电压状况。

| 086H  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PFLAG | NT0   | NPD   | LVD36 | LVD24 | -     | С     | DC    | Z     |
| 读/写   | R/W   | R/W   | R     | R     | -     | R/W   | R/W   | R/W   |
| 复位后   | Х     | Х     | 0     | 0     | -     | 0     | 0     | 0     |

Bit [7:6] NTO, NPD: 复位状态标志。

| NT0 | NPD | 复位状态   |
|-----|-----|--------|
| 0   | 0   | 看门狗复位  |
| 0   | 1   | 保留     |
| 1   | 0   | LVD 复位 |
| 1   | 1   | 外部复位   |

Bit 5 **LVD36**: 3.6V LVD 工作电压标志, LVD 编译选项为 LVD\_H 时有效。

0=系统工作电压 VDD 超过 3.6V, 低电压检测器没有工作;

1=系统工作电压 VDD 低于 3.6V,说明此时低电压检测器已处于监控状态。

Bit 4 LVD24: 2.4V LVD 工作电压标志, LVD 编译选项为 LVD\_M 时有效。

0=系统工作电压 VDD 超过 2.4V, 低电压检测器没有工作;

1=系统工作电压 VDD 低于 2.4V,说明此时低电压检测器已处于监控状态。

Bit 2 **C:** 进位标志。

1 = 加法运算后有进位、减法运算没有借位发生或移位后移出逻辑"1"或比较运算的结果 ≥ 0:

0 = 加法运算后没有进位、减法运算有借位发生或移位后移出逻辑"0"或比较运算的结果 < 0。

**DC:** 辅助进位标志。

1 = 加法运算时低四位有进位,或减法运算后没有向高四位借位;

0 = 加法运算时低四位没有进位,或减法运算后有向高四位借位。

Bit 0 **Z:** 零标志。

1 = 算术/逻辑/分支运算的结果为零;

0 = 算术/逻辑/分支运算的结果非零。

★ 注:关于标志位 C、DC 和 Z 的更多信息请参阅指令集相关内容。



## 2.1.5.6 程序计数器 PC

程序计数器 PC 是一个 11 位二进制程序地址寄存器,分高 3 位和低 8 位。专门用来存放下一条需要执行指令的内存地址。通常,程序计数器会随程序中指令的执行自动增加。

若程序执行 CALL 和 JMP 指令时, PC 指向特定的地址。

|     | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PC  | -      | -      | -      | -      | -      | PC10   | PC9   | PC8   | PC7   | PC6   | PC5   | PC4   | PC3   | PC2   | PC1   | PC0   |
| 复位后 | -      | -      | -      | -      | -      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|     |        | PCH    |        |        |        |        |       |       |       |       | PO    | CL    |       |       |       |       |

#### ☞ 单地址跳转

在 SONiX 单片机里面,有 9 条指令(CMPRS、INCS、INCMS、DECS、DECMS、BTS0、BTS1、B0BTS0 和 B0BTS1)可完成单地址跳转功能。如果这些指令执行结果为真,那么 PC 值加 2 以跳过下一条指令。

如果位检测为真,则跳过下一条指令。

**B0BTS1** FC ; 若 Carry\_flag = 1, 跳过下一条指令。

JMP COSTEP ; 否则跳到 COSTEP。

COSTEP: NOP

B0MOV A, BUF0 ;

BOBTSO FZ ; 若 Zero flag = 0, 跳过下一条指令。

JMP C1STEP ; 否则跳到 C1STEP。

C1STEP: NOP

如果 ACC 等于指定的立即数则 PC 值加 2, 跳过下一条指令。

**CMPRS** A, #12H ; 若 ACC = 12H, 跳过下一条指令。

JMP COSTEP ; 否则跳到 COSTEP。

COSTEP: NOP

执行加 1 指令后,结果为零时,PC 的值加 2,跳过下一条指令。

INCS:

INCS BUF0

JMP COSTEP

COSTEP: NOP

INCMS:

INCMS BUF0

JMP COSTEP

COSTEP: NOP

执行减1指令后,结果为零时,PC的值加2,跳过下一条指令。

**DECS:** 

**DECS** BUF0

JMP COSTEP

COSTEP: NOP

**DECMS:** 

DECMS BUF0

JMP COSTEP :

COSTEP: NOP



### ☞ 多地址跳转

执行 JMP 或 ADD M,A(M=PCL)指令可实现多地址跳转。执行 ADD M, A、ADC M, A 或 B0ADD M, A 后,若 PCL 溢出,PCH 会自动进位。对于跳转表及其它应用,用户可以通过上述 3 条指令计算 PC 的值而不需要担心 PCL 溢出的问题。

注:PCH 仅支持 PC 的递增运算而不支持递减运算。当 PCL+ACC 执行完 PCL 有进位时,PCH 会自动加 1;但执行 PCL-ACC有借位发生,PCH 的值会保持不变。

▶ 例: PC = 0323H (PCH = 03H, PCL = 23H)。

; PC = 0323H

MOV A, #28H B0MOV PCL, A

PCL, A ; 跳到地址 0328H。

• • •

; PC = 0328H

MOV A, #00H

BOMOV PCL, A ; 跳到地址 0300H。

. . .

▶ 例: PC = 0323H (PCH = 03H, PCL = 23H)。

; PC = 0323H

BOADD PCL, A ; PCL = PCL + ACC, PCH 的值不变。

 JMP
 A0POINT
 ; ACC = 0, 跳到 A0POINT。

 JMP
 A1POINT
 ; ACC = 1, 跳到 A1POINT。

 JMP
 A2POINT
 ; ACC = 2, 跳到 A2POINT。

 JMP
 A3POINT
 ; ACC = 3, 跳到 A3POINT。

...

Version 1.2



## 2.1.5.7 Y, Z 寄存器

寄存器Y和Z都是8位缓存器,主要用途如下:

- 普通工作寄存器;
- RAM 数据寻址指针@YZ;
- 配合指令 MOVC 对 ROM 数据进行查表。

| 084H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| Υ    | YBIT7 | YBIT6 | YBIT5 | YBIT4 | YBIT3 | YBIT2 | YBIT1 | YBIT0 |
| 读/写  | R/W   |
| 复位后  | X     | Х     | Х     | Х     | Х     | Х     | X     | Х     |

| 083H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| Z    | ZBIT7 | ZBIT6 | ZBIT5 | ZBIT4 | ZBIT3 | ZBIT2 | ZBIT1 | ZBIT0 |
| 读/写  | R/W   |
| 复位后  | Х     | X     | Х     | Х     | X     | Х     | X     | X     |

▶ 例:用 Y、Z作为数据指针,访问 bank0 中 025H 处的内容。

B0MOV Y, #00H ; Y 指向 RAM bank 0。 B0MOV Z, #25H ; Z 指向 25H。 B0MOV A, @YZ ; 数据送入 ACC。

▶ 例:利用数据指针@YZ对RAM数据清零。

B0MOV Y, #0 ; Y = 0, 指向 bank 0。

B0MOV Z, #7FH ; Z = 7FH, RAM 区的最后单元。

CLR\_YZ\_BUF:

CLR @YZ ; @YZ 清零。

DECMS Z ;

JMP CLR\_YZ\_BUF ; 不为零。

CLR @YZ

END\_CLR: ;

...

### 2.1.5.8 R 寄存器

8 位缓存器 R 主要有以下两个功能:

- 作为工作寄存器使用;
- 存储执行查表指令后的高字节数据。

(执行 MOVC 指令,指定 ROM 单元的高字节数据会被存入 R 寄存器而低字节数据则存入 ACC。)

| 082H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| R    | RBIT7 | RBIT6 | RBIT5 | RBIT4 | RBIT3 | RBIT2 | RBIT1 | RBIT0 |
| 读/写  | R/W   |
| 复位后  | Х     | X     | Х     | X     | Х     | Х     | Х     | X     |



## 2.2 寻址模式

## 2.2.1 立即寻址

将立即数送入 ACC 或指定的 RAM 单元。

▶ 例: 立即数 12H 送入 ACC。

MOV

A, #12H

▶ 例: 立即数 12H 送入寄存器 R。

**B0MOV** 

R, #12H

注: 立即数寻址中,指定的 RAM 单元必须是 80H~87H 的工作寄存器。

## 2.2.2 直接寻址

通过 ACC 对 RAM 单元数据进行操作。

》 例: 地址 12H 处的内容送入 ACC。

B0MOV A, 12H

▶ 例: ACC 中数据写入 RAM 的 12H 单元。

B0MOV 12H, A

## 2.2.3 间接寻址

通过指针寄存器(Y/Z)访问 RAM 数据。

▶ 例:用 @YZ 实现间接寻址。

B0MOV Y, #0 ; Y 清零以寻址 RAM bank 0。

B0MOV Z, #12H ; 设定寄存器地址。

B0MOV A, @YZ



## 2.3 堆栈

## 2.3.1 概述

SN8P2722 的堆栈缓存器共有 8 层,程序进入中断或执行 CALL 指令时,用来存储程序计数器 PC 的值。寄存器 STKP 为堆栈指针,指向堆栈缓存器顶层,STKnH 和 STKnL 分别是各堆栈缓存器高、低字节。





## 2.3.2 堆栈寄存器

堆栈指针 STKP 是一个 3 位寄存器, 存放被访问的堆栈单元地址, 11 位数据存储器 STKnH 和 STKnL 用于暂存堆栈数据。以上寄存器都位于 bank 0。

使用入栈指令 PUSH 和出栈指令 POP 可对堆栈缓存器进行操作。堆栈操作遵循后进先出(LIFO)的原则,入栈时堆 栈指针 STKP 的值减 1,出栈时 STKP 的值加 1,这样,STKP 总是指向堆栈缓存器顶层单元。

系统进入中断或执行 CALL 指令之前,程序计数器 PC 的值被存入堆栈缓存器中进行入栈保护。

| 0DFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|------|-------|-------|-------|-------|-------|--------|--------|--------|
| STKP | GIE   | ı     | -     | -     | -     | STKPB2 | STKPB1 | STKPB0 |
| 读/写  | R/W   | -     | -     | -     | -     | R/W    | R/W    | R/W    |
| 复位后  | 0     | -     | -     | -     | -     | 1      | 1      | 1      |

Bit[2:0] **STKPBn:** 堆栈指针(n=0~2)。

Bit 7 GIE: 全局中断控制位。

0 = 禁止; 1 = 使能。

> 例:系统复位时,堆栈指针寄存器内容为默认值,但强烈建议在程序初始部分重新设定,如下面所示:

MOV A, #00000111B B0MOV STKP, A

| 0F0H~0FFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|--------|-------|-------|
| STKnH     | -     | -     | -     | -     | -     | SnPC10 | SnPC9 | SnPC8 |
| 读/写       | -     | -     | -     | -     | -     | R/W    | R/W   | R/W   |
| 复位后       | -     | -     | -     | -     | -     | 0      | 0     | 0     |

| 0F0H~0FFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| STKnL     | SnPC7 | SnPC6 | SnPC5 | SnPC4 | SnPC3 | SnPC2 | SnPC1 | SnPC0 |
| 读/写       | R/W   |
| 复位后       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

STKn = STKnH, STKnL  $(n = 7 \sim 0)$  .



## 2.3.3 堆栈操作举例

执行程序调用指令 CALL 和响应中断服务时,堆栈指针 STKP 的值减 1,指针指向下一个堆栈缓存器。同时,对程序计数器 PC 的内容进行入栈保存。

| 堆栈层数 |        | STKP   |        | 堆栈线   | 爰存器   | 说明     |
|------|--------|--------|--------|-------|-------|--------|
| 堆拟运蚁 | STKPB2 | STKPB1 | STKPB0 | 高字节   | 低字节   | 60 ·93 |
| 0    | 1      | 1      | 1      | Free  | Free  | -      |
| 1    | 1      | 1      | 0      | STK0H | STK0L | -      |
| 2    | 1      | 0      | 1      | STK1H | STK1L | -      |
| 3    | 1      | 0      | 0      | STK2H | STK2L | -      |
| 4    | 0      | 1      | 1      | STK3H | STK3L | -      |
| 5    | 0      | 1      | 0      | STK4H | STK4L | -      |
| 6    | 0      | 0      | 1      | STK5H | STK5L | -      |
| 7    | 0      | 0      | 0      | STK6H | STK6L | -      |
| 8    | 1      | 1      | 1      | STK7H | STK7L | -      |
| > 8  | 1      | 1      | 0      | ı     | -     | 堆栈溢出   |

对应每个入栈操作,都有一个出栈操作来恢复程序计数器PC的值。RETI指令用于中断服务程序中,RET用于子程序调用。出栈时,STKP加1并指向下一个空闲堆栈缓存器。堆栈恢复操作如下表所示:

| 堆栈层数 |        | STKP   |        | 堆栈组   | 爰存器   | 说明    |
|------|--------|--------|--------|-------|-------|-------|
| 堆拟运蚁 | STKPB2 | STKPB1 | STKPB0 | 高字节   | 低字节   | JC 93 |
| 8    | 1      | 1      | 1      | STK7H | STK7L | -     |
| 7    | 0      | 0      | 0      | STK6H | STK6L | -     |
| 6    | 0      | 0      | 1      | STK5H | STK5L | -     |
| 5    | 0      | 1      | 0      | STK4H | STK4L | -     |
| 4    | 0      | 1      | 1      | STK3H | STK3L | -     |
| 3    | 1      | 0      | 0      | STK2H | STK2L | -     |
| 2    | 1      | 0      | 1      | STK1H | STK1L | -     |
| 1    | 1      | 1      | 0      | STK0H | STK0L | -     |
| 0    | 1      | 1      | 1      | Free  | Free  | -     |



# 3 复位

## 3.1 概述

SN8P2722 有以下几种复位方式:

- 上电复位;
- 看门狗复位;
- 掉电复位;
- 外部复位(仅在外部复位引脚处于使能状态)。

上述任一种复位发生时,所有的系统寄存器恢复默认状态,程序停止运行,同时程序计数器 PC 清零。复位结束后,系统从向量 0000H 处重新开始运行。PFLAG 寄存器的 NTO 和 NPD 两个标志位能够给出系统复位状态的信息。用户可以编程控制 NTO 和 NPD,从而控制系统的运行路径。

| 086H  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PFLAG | NT0   | NPD   | LVD36 | LVD24 | -     | С     | DC    | Z     |
| 读/写   | R/W   | R/W   | R     | R     | -     | R/W   | R/W   | R/W   |
| 复位后   | Х     | Х     | 0     | 0     | -     | 0     | 0     | 0     |

Bit [7:6] **NTO, NPD:** 复位状态标志。

| NT0 | NPD | 复位情况       | 说明             |
|-----|-----|------------|----------------|
| 0   | 0   | 看门狗复位      | 看门狗溢出          |
| 0   | 1   | 保留         | -              |
| 1   | 0   | 上电及 LVD 复位 | 电源电压低于 LVD 检测值 |
| 1   | 1   | 外部复位       | 外部复位引脚检测到低电平   |

任何一种复位情况都需要一定的响应时间,系统提供完善的复位流程以保证复位动作的顺利进行。对于不同类型的振荡器,完成复位所需要的时间也不同。因此,VDD的上升速度和不同晶振的起振时间都不固定。RC振荡器的起振时间最短,晶体振荡器的起振时间则较长。在用户终端使用的过程中,应注意考虑主机对上电复位时间的要求。





## 3.2 上电复位

上电复位与 LVD 操作密切相关。系统上电的过程呈逐渐上升的曲线形式,需要一定时间才能达到正常电平值。下面给出上电复位的正常时序:

- 上电:系统检测到电源电压上升并等待其稳定;
- **外部复位(仅限于外部复位引脚使能状态)**:系统检测外部复位引脚状态。如果不为高电平,系统保持复位状态直到外部复位引脚释放;
- **系统初始化:** 所有的系统寄存器被置为初始值;
- 振荡器开始工作:振荡器开始提供系统时钟:
- 执行程序:上电结束,程序开始运行。

## 3.3 看门狗复位

看门狗复位是系统的一种保护设置。在正常状态下,由程序将看门狗定时器清零。若出错,系统处于未知状态,看门狗定时器溢出,此时系统复位。看门狗复位后,系统重启进入正常状态。看门狗复位的时序如下:

- **看门狗定时器状态:**系统检测看门狗定时器是否溢出,若溢出,则系统复位:
- 系统初始化: 所有的系统寄存器被置为默认状态;
- 振荡器开始工作:振荡器开始提供系统时钟;
- 执行程序:上电结束,程序开始运行。

#### 看门狗定时器应用注意事项:

- 对看门狗清零之前,检查 I/O 口的状态和 RAM 的内容可增强程序的可靠性;
- 不能在中断中对看门狗清零,否则无法侦测到主程序跑飞的状况;
- 程序中应该只在主程序中有一次清看门狗的动作,这种架构能够最大限度的发挥看门狗的保护功能。
- ¥ 注:关于看门狗定时器的详细内容,请参阅"看门狗定时器"有关章节。



## 3.4 掉电复位

## 3.4.1 概述

掉电复位针对外部因素引起的系统电压跌落情形(例如,干扰或外部负载的变化),掉电复位可能会引起系统工作状态不正常或程序执行错误。



掉电复位示意图

电压跌落可能会进入系统死区。系统死区意味着电源不能满足系统的最小工作电压要求。上图是一个典型的掉电复位示意图。图中,VDD 受到严重的干扰,电压值降的非常低。虚线以上区域系统正常工作,在虚线以下的区域内,系统进入未知的工作状态,这个区域称作死区。当 VDD 跌至 V1 时,系统仍处于正常状态;当 VDD 跌至 V2 和 V3 时,系统进入死区,则容易导致出错。以下情况系统可能进入死区:

#### DC 运用中:

DC 运用中一般都采用电池供电,当电池电压过低或单片机驱动负载时,系统电压可能跌落并进入死区。这时,电源不会进一步下降到 LVD 检测电压,因此系统维持在死区。

#### AC 运用中:

系统采用 AC 供电时,DC 电压值受 AC 电源中的噪声影响。当外部负载过高,如驱动马达时,负载动作产生的干扰也影响到 DC 电源。VDD 若由于受到干扰而跌落至最低工作电压以下时,则系统将有可能进入不稳定工作状态。

在 AC 运用中,系统上、下电时间都较长。其中,上电时序保护使得系统正常上电,但下电过程却和 DC 运用中情形类似,AC 电源关断后,VDD 电压在缓慢下降的过程中易进入死区。

## 3.4.2 系统工作电压

为了改善系统掉电复位的性能,首先必须明确系统具有的最低工作电压值。系统最低工作电压与系统执行速度有关,不同的执行速度下最低工作电压值也不同。



系统工作电压与执行速度关系图

如上图所示,系统正常工作电压区域一般高于系统复位电压,同时复位电压由低电压检测(LVD)电平决定。当系统 执行速度提高时,系统最低工作电压也相应提高,但由于系统复位电压是固定的,因此在系统最低工作电压与系统复位电 压之间就会出现一个电压区域,系统不能正常工作,也不会复位,这个区域即为死区。



## 3.4.3 掉电复位性能改进

如何改善系统掉电复位性能,有以下几点建议:

- LVD 复位;
- 看门狗复位;
- 降低系统工作速度:
- 采用外部复位电路(稳压二极管复位电路,电压偏移复位电路,外部 IC 复位)。
- \* 注:"稳压二极管复位电路"、"电压偏移复位电路"和"外部 IC 复位"能够完全避免掉电复位出错。

LVD 复位:



低电压检测(LVD)是 SONiX 8 位单片机内置的掉电复位保护装置,当 VDD 跌落并低于 LVD 检测电压值时,LVD 被触发,系统复位。不同的单片机有不同的 LVD 检测电平,LVD 检测电平值仅为一个电压点,并不能覆盖所有死区范围。因此采用 LVD 依赖于系统要求和环境状况。电源变化较大时,LVD 能够起到保护作用,如果电源变化触发 LVD,系统工作仍出错,则 LVD 就不能起到保护作用,就需要采用其它复位方法。

LVD 设计为三层结构(2.0V/2.4V/3.6V),由 LVD 编译选项控制。对于上电复位和掉电复位,2.0V LVD 始终处于使能状态; 2.4V LVD 具有 LVD 复位功能,并能通过标志位显示 VDD 状态; 3.6V LVD 具有标记功能,可显示 VDD 的工作状态。LVD 标志功能只是一个低电压检测装置,标志位 LVD24 和 LVD36 给出 VDD 的电压情况。对于低电压检测应用,只需查看 LVD24 和 LVD36 的状态即可检测电池状况。

| 086H  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PFLAG | NT0   | NPD   | LVD36 | LVD24 | ı     | С     | DC    | Z     |
| 读/写   | R/W   | R/W   | R     | R     | -     | R/W   | R/W   | R/W   |
| 复位后   | Х     | Х     | 0     | 0     | -     | 0     | 0     | 0     |

Bit 5 LVD36: 3.6V LVD 工作电压标志, LVD 编译选项为 LVD H 时有效。

0=系统工作电压 VDD 超过 3.6V, 低电压检测器没有工作;

1=系统工作电压 VDD 低于 3.6V,说明此时低电压检测器已处于监控状态。

Bit 4 LVD24: 2.4V LVD 工作电压标志, LVD 编译选项为 LVD\_M 时有效。

0 =系统工作电压 VDD 超过 2.4V, 低电压检测器没有工作;

1=系统工作电压 VDD 低于 2.4V, 说明此时低电压检测器已处于监控状态。



| LVD     | LVD 编译选项 |       |       |  |  |
|---------|----------|-------|-------|--|--|
| LVD     | LVD_L    | LVD_M | LVD_H |  |  |
| 2.0V 复位 | 有效       | 有效    | 有效    |  |  |
| 2.4V 标志 | -        | 有效    | -     |  |  |
| 2.4V 复位 | -        | -     | 有效    |  |  |
| 3.6V 标志 | =        | -     | 有效    |  |  |

#### LVD\_L

如果 VDD < 2.0V, 系统复位; LVD24 和 LVD36 标志位无意义。

#### LVD M

如果 VDD < 2.0V, 系统复位;

LVD24: 如果 VDD > 2.4V, LVD24 =0; 如果 VDD <= 2.4V, LVD24=1;

LVD36 标志位无意义。

#### LVD\_H

如果 VDD < 2.4V, 系统复位;

LVD36: 如果 VDD > 3.6V, LVD36=0; 如果 VDD <= 3.6V, LVD36=1;

LVD24 标志位无意义。

#### \* 注:

- a) LVD 复位结束后, LVD24 和 LVD36 都将被清零;
- b) LVD 2.4V 和 LVD3.6V 检测电平值仅作为设计参考,不能用作芯片工作电压值的精确检测。

#### 看门狗复位:

看门狗定时器用于保证系统正常工作。通常,会在主程序中将看门狗定时器清零,但不要在多个分支程序中清看门狗。 若程序正常运行,看门狗不会复位。当系统进入死区或程序运行出错的时候,看门狗定时器继续计数直至溢出,系统复位。 如果看门狗复位后电源仍处于死区,则系统复位失败,保持复位状态,直到系统工作状态恢复到正常值。

## 降低系统工作速度:

系统工作速度越快最低工作电压值越高,从而加大工作死区的范围,因此降低系统工作速度不失为降低系统进入死区 几率的有效措施。所以,可选择合适的工作速度以避免系统进入死区,这个方法需要调整整个程序使其满足系统要求。

## 附加外部复位电路:

外部复位也能够完全改善掉电复位性能。有三种外部复位方式可改善掉电复位性能:稳压二极管复位电路,电压偏移复位电路和外部 IC 复位。它们都采用外部复位信号控制单片机可靠复位。



## 3.5 外部复位

外部复位功能由编译选项 "Reset\_Pin" 控制。将该编译选项置为 "Reset",可使能外部复位功能。外部复位引脚为施密特触发结构,低电平有效。复位引脚处于高电平时,系统正常运行。当复位引脚输入低电平信号时,系统复位。外部复位操作在上电和正常工作模式时有效。需要注意的是,在系统上电完成后,外部复位引脚必须输入高电平,否则系统将一直保持在复位状态。外部复位的时序如下:

- **外部复位(当且仅当外部复位引脚为使能状态)**:系统检测复位引脚的状态,如果复位引脚不为高电平,则系统会一直保持在复位状态,直到外部复位结束;
- **系统初始化:** 初始化所有的系统寄存器;
- 振荡器开始工作:振荡器开始提供系统时钟;
- **执行程序:** 上电结束,程序开始运行。

外部复位可以在上电过程中使系统复位。良好的外部复位电路可以保护系统以免进入未知的工作状态,如 AC 应用中的掉电复位等。



## 3.6 外部复位电路

## 3.6.1 RC 复位电路



上图为一个由电阻 R1 和电容 C1 组成的基本 RC 复位电路,它在系统上电的过程中能够为复位引脚提供一个缓慢上升的复位信号。这个复位信号的上升速度低于 VDD 的上电速度,为系统提供合理的复位时序,当复位引脚检测到高电平时,系统复位结束,进入正常工作状态。

注: 此 RC 复位电路不能解决非正常上电和掉电复位问题。

## 3.6.2 二极管及 RC 复位电路



上图中,R1 和C1 同样是为复位引脚提供输入信号。对于电源异常情况,二极管正向导通使C1 快速放电并与VDD保持一致,避免复位引脚持续高电平、系统无法正常复位。

\* 注:"基本 RC 复位电路"和"二极管及 RC 复位电路"中的电阻 R2 都是必不可少的限流电阻,以避免复位引脚 ESD (Electrostatic Discharge)或 EOS(Electrical Over-stress)击穿 。



## 3.6.3 稳压二极管复位电路



稳压二极管复位电路是一种简单的 LVD 电路,基本上可以完全解决掉电复位问题。如上图电路中,利用稳压管的击穿电压作为电路复位检测值,当 VDD 高于 "Vz + 0.7V"时,三极管集电极输出高电平,单片机正常工作;当 VDD 低于 "Vz + 0.7V"时,三极管集电极输出低电平,单片机复位。稳压管规格不同则电路复位检测值不同,根据电路的要求选择合适的二极管。

## 3.6.4 电压偏置复位电路



电压偏置复位电路是一种简单的 LVD 电路,基本上可以完全解决掉电复位问题。与稳压二极管复位电路相比,这种复位电路的检测电压值的精确度有所降低。电路中,R1 和 R2 构成分压电路,当 VDD 高于和等于分压值"0.7V x (R1 + R2) / R1"时,三极管集电极 C 输出高电平,单片机正常工作; VDD 低于"0.7V x (R1 + R2) / R1"时,集电极 C 输出低电平,单片机复位。

对于不同应用需求,选择适当的分压电阻。单片机复位引脚上电压的变化与 VDD 电压变化之间的差值为 0.7V。如果 VDD 跌落并低于复位引脚复位检测值,那么系统将被复位。如果希望提升电路复位电平,可将分压电阻设置为 R2>R1, 并选择 VDD 与集电极之间的结电压高于 0.7V。分压电阻 R1 和 R2 在电路中要耗电,此处的功耗必须计入整个系统的功耗中。

⊭ 注:在电源不稳定或掉电复位的情况下,"稳压二极管复位电路"和"偏压复位电路"能够保护电路在电压跌落时避免系统出错。当 电压跌落至低于复位检测值时,系统将被复位。从而保证系统正常工作。



## 3.6.5 外部 IC 复位



外部复位也可以选用 IC 进行外部复位,但是这样一来系统成本将会增加。针对不用的应用要求选择适当的复位 IC,如上图所示外部 IC 复位电路,能够有效的降低电源变化对系统的影响。



# 4 系统时钟

## 4.1 概述

SN8P2722 内带双时钟系统: 高速时钟和低速时钟。高速时钟由外部振荡电路或内置 16MHZ 高速 RC 振荡电路(IHRC 16MHz) 提供,低速时钟则由内置低速 RC 振荡电路(ILRC 16KHz@3V, 32KHz@5V) 提供。当系统在低速模式下工作时,时钟信号 4 分频之后作为系统指令周期 Fcpu。

- **普通模式(高速时钟): Fcpu = Fhosc / N,** N = 4 ~ 16, Fcpu 编译选项决定 N 的值。
- ☞ 低速模式(低速时钟): Fcpu = Flosc/4。

在干扰较严重的条件下,杂讯滤波功能能够对外部干扰进行隔离以保护系统的正常工作。

## 4.2 时钟框图



- HOSC: High Clk 编译选项。
- Fhosc: 外部高速时钟/内部高速 RC 时钟频率。
- Flosc: 内部低速 RC 时钟频率(16KHz@3V, 32KHz@5V)。
- Fosc: 系统时钟频率。Fcpu: 指令执行频率。



## 4.3 OSCM 寄存器

寄存器 OSCM 控制振荡器的状态和系统模式。

| 0CAH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| OSCM | -     | -     | -     | CPUM1 | CPUM0 | CLKMD | STPHX | -     |
| 读/写  | -     | -     | -     | R/W   | R/W   | R/W   | R/W   | -     |
| 复位后  | -     | -     | -     | 0     | 0     | 0     | 0     | -     |

Bit 1 STPHX: 内部/外部高速振荡器控制位。

0 = 运行;

1 = 停止。内部低速 RC 振荡器仍然运行。

Bit 2 CLKMD: 高/低速时钟模式控制位。

0 = 普通(双时钟)模式,系统时钟来自高速时钟;

1 = 低速模式,系统时钟来自低速时钟。

Bit[4:3] **CPUM[1:0]:** CPU 工作模式控制位。

00 = 普通模式;

01 = 睡眠模式;

10 = 绿色模式;

11 = 系统保留。

例:停止高速振荡器。

BOBSET FSTPHX ; 停止内部/外部高速振荡器。

例:系统进入睡眠模式时,高速振荡器和内部低速振荡器都被停止。

BOBSET FCPUMO



## 4.4 系统高速时钟

内部 16MHZ RC 振荡器或外部振荡器都可作为系统高速时钟源,由编译选项"High Clk"控制。

| High_Clk | 说明                                             |
|----------|------------------------------------------------|
| IHRC_16M | 内部 16MHz RC 振荡器作为系统时钟源,XIN 和 XOUT 引脚为通用 I/O 口。 |
| RC       | 外部 RC 振荡器为系统高速时钟,XOUT 引脚为通用 I/O 口。             |
| 32K      | 外部 32768Hz 低速振荡器为系统高速时钟。                       |
| 12M      | 外部高速振荡器作为系统高速时钟,典型频率为 12MHz。                   |
| 4M       | 外部振荡器作为系统高速时钟,典型频率为 4MHz。                      |

#### 4.4.1 内部高速 RC 振荡器

编译选项"IHRC\_16M"控制单片机的内置 RC 高速时钟(16MHz),在"IHRC\_16M"模式下,系统时钟来自内部 16MHz RC 振荡器,XIN/XOUT 引脚作为普通的 I/O 引脚。

● IHRC: 系统高速时钟来自内置 16MHz RC 振荡器,XIN/XOUT 引脚作为普通的 I/O 引脚。



#### 4.4.2 外部高速时钟

外部高速时钟共三种模式:石英/陶瓷振荡器,RC及外部时钟源,由编译选项 High\_Clk 控制具体模式的选择。石英/陶瓷振荡器和 RC 振荡器的上升时间各不相同。RC 振荡器的上升时间相对较短。振荡器上升时间与复位时间的长短密切相关。



#### 4.4.2.1 石英/陶瓷振荡器

石英/陶瓷振荡器由 XIN/XOUT 口驱动,对于高速、普通和低速三种不同工作模式,振荡器的驱动电流也不同。不同的工作模式下,编译选项"High\_Clk"支持不同的频率: 12MHz, 4MHz 及 32KHz。



☀ 注:上图中, XIN/XOUT/VSS 引脚与石英/陶瓷振荡器以及电容 C 之间的距离越近越好。



#### 4.4.2.2 RC 振荡器

通过编译选项 High\_Clk 的设置可控制 RC 振荡器的选择,RC 振荡器输出频率最高可达 10MHz。改变 R 可改变输出 频率的大小,电容 C 的最佳容量为 50P~100P,引脚 XOUT 为通用 I/O 口,如下图所示:



注: 电容 C 和电阻 R 应尽可能的靠近单片机的 VDD。

#### 4.4.2.3 外部时钟源

单片机可选择外部时钟信号作为系统时钟,由编译选项 High\_Clk 控制,从 XIN 脚送入。XOUT 引脚作为普通的 I/O口。



▶ 注:外部振荡电路中的 GND 必须尽可能的接近单片机的 VSS 端口。



## 4.5 系统低速时钟

系统低速时钟源即内置的低速振荡器,采用 RC 振荡电路。低速时钟的输出频率受系统电压和环境温度的影响,通常为 5V 时输出 32KHz, 3V 时输出 16KHz。输出频率与工作电压之间的关系如下图所示。



低速时钟可作为看门狗定时器的时钟源。由 CLKMD 控制系统低速工作模式。

- ☞ Flosc = 内部低速 RC 振荡器(16KHz @3V、32KHz @5V)。
- ☞ 低速模式 Fcpu = Flosc / 4。

系统工作在睡眠模式时,可以停止低速 RC 振荡器。

▶ 例:停止内部低速振荡器。

B0BSET FCPUM0

注: 不可以单独停止内部低速时钟; 由寄存器 OSCM 的位 CPUM0 和 CPUM1(32K, 禁止看门狗)设置决定内部低速时钟的状态。

### 4.5.1 系统时钟测试

在设计过程中,用户可通过软件指令周期 Fcpu 对系统时钟速度进行测试。

▶ 例:外部振荡器的 Fcpu 指令周期测试。

BOBSET POM.0 ; PO.0 置为输出模式以输出 Fcpu 的触发信号。

@@:

B0BSET P0.0 B0BCLR P0.0 JMP @B

· 注:不能直接从 XIN 引脚测试 RC 振荡频率,因为探针的连接会影响测试的准确性。



# 5 系统工作模式

## 5.1 概述

SN8P2722 可在以下 4 种模式下工作。

- ●普通模式(高速模式);
- ●低速模式;
- ●睡眠模式;
- ●绿色模式。



#### 系统模式切换框图

#### 工作模式描述

| 系统模式   | 普通模式                  | 低速模式                  | 绿色模式                  | 睡眠模式                  | 注释             |
|--------|-----------------------|-----------------------|-----------------------|-----------------------|----------------|
| EHOSC  | 运行                    | STPHX 控制              | STPHX 控制              | 停止                    |                |
| IHRC   | 运行                    | STPHX 控制              | STPHX 控制              | 停止                    |                |
| ILRC   | 运行                    | 运行                    | 运行                    | 停止                    |                |
| CPU 指令 | 运行                    | 运行                    | 停止                    | 停止                    |                |
| T0     | *有效                   | *有效                   | *有效                   | 无效                    | * T0ENB=1 时有效  |
| TC0    | *有效                   | *有效                   | 无效                    | 无效                    | * TC0ENB=1 时有效 |
| 看门狗    | 由 Watch_Dog<br>编译选项控制 | 由 Watch_Dog<br>编译选项控制 | 由 Watch_Dog<br>编译选项控制 | 由 Watch_Dog<br>编译选项控制 | 参考编译选项描述       |
| 内部中断   | 都有效                   | 都有效                   | T0                    | 都无效                   |                |
| 外部中断   | 都有效                   | 都有效                   | 都有效                   | 都无效                   |                |
| 唤醒功能   | -                     | -                     | P0, T0, 复位            | P0, 复位                |                |

- EHOSC: 外部高速时钟。
- **IHRC**:内部高速时钟(16M RC 振荡器)。
- ILRC: 内部低速时钟(RC振荡器: 3V时 16K,5V时 32K)。



## 系统模式切换举例

例: 系统由普通/低速模式转换到睡眠模式。 **BOBSET** FCPUM0

注:系统进入睡眠模式后,只有具有唤醒功能的引脚和复位信号能够将系统唤醒并回到普通模式中

例:系统由普通模式转换为低速模式。

**BOBSET FCLKMD** ;设置 CLKMD 为 1,将其切换为低速模式。

**BOBSET FSTPHX** ; 停止外部高速振荡器以降低功耗。

例:系统由低速模式转换到普通模式 (外部高速振荡器仍然工作)。

B0BCLR **FCLKMD** ;设置 CLKMD 为 0。

例: 系统由低速模式转换到普通模式(外部高速振荡器停止工作)。

在外部高速时钟停振的情况下,系统回到普通模式时至少需要延迟 10ms 以稳定振荡器。

**B0BCLR FSTPHX** ; 启动外部振荡器。

MOV A. #27 ; 若 VDD = 5V, 内部 RC=32KHz (典型值), 系统将延迟。

**B0MOV** Z, A

**DECMS** @@: Ζ ; 0.125ms X 81 = 10.125ms 以保证外部时钟稳定。

> **JMP** @B

**FCLKMD B0BCLR** ; 系统回到普通模式。

例:系统由普通模式/低速模式进入绿色模式。

**BOBSET** FCPUM1 ;置 CPUM1 = 1。

注:绿色模式下如果禁止 T0 的唤醒功能,则只有具有唤醒功能的引脚和复位引脚可以将系统唤醒(具有唤醒功能的引脚将系统 返回到上一个工作模式,复位引脚将系统返回到普通模式)。

例:系统由普通/低速模式进入绿色模式,并开启 T0 唤醒功能。

;设置 T0 定时器的唤醒功能。

: 进入绿色模式。

**B0BCLR FT0IEN** ;禁止T0中断。 **B0BCLR** FT0ENB ;关闭 T0 定时器。

A,#20H MOV

**B0MOV** T0M,A ; T0 时钟 = Fcpu / 64。

MOV A,#64H

**B0MOV** T0C,A ;设置 TOC 初始值= 64H(TO 中断间隔 = 10 ms)。

**B0BCLR** FT0IEN ; 禁止 T0 中断。

**B0BCLR** FT0IRQ ; T0 中断请求寄存器清零。

**B0BSET** FT0ENB ; 开启 T0 定时器。

FCPUM0 **B0BCLR** 

:设置 CPUMx = 10。

**B0BSET** FCPUM1

注:绿色模式下如果使能 T0 的唤醒功能,则具有唤醒功能的引脚、复位引脚和 T0 都能够将系统唤醒回到上一工作模式。T0 的 唤醒周期可编程控制,请注意对 T0ENB 的设置。



## 5.3 唤醒时间

#### 5.3.1 概述

系统在睡眠模式下并不执行程序。唤醒触发信号可以将系统唤醒进入普通模式或低速模式。唤醒触发信号来自外部触发信号(P0 的电平变化)和内部触发信号(T0 定时溢出)。

- 从睡眠模式唤醒后只能进入普通模式,且将其唤醒的触发只能是外部触发信号(P0 电平变化);
- 由绿色模式唤醒回到系统前一工作模式(普通模式或低速模式)可以用外部触发或者内部触发。

#### 5.3.2 唤醒时间

系统进入睡眠模式后,高速时钟停止运行。把系统从睡眠模式下唤醒时,单片机需要等待 2048 个外部高速振荡器时钟周期以使振荡电路进入稳定工作状态,等待的这一段时间就称为唤醒时间。唤醒时间结束后,系统才进入到普通模式。

\* 注:将系统从绿色模式中唤醒是不需要唤醒时间的,因为在绿色模式下高速时钟仍然正常工作。

唤醒时间计算如下:

唤醒时间 = 1/Fosc \* 2048 (sec) + 高速时钟启动时间

- ☀ 注:高速时钟的启动时间与 VDD 和振荡器类型有关。
- 例:将系统从睡眠模式中唤醒,并设置系统进入普通模式。唤醒时间计算如下。

唤醒时间= 1/Fosc \* 2048 = 0.512 ms (Fosc = 4MHz) 总的唤醒时间 = 0.512 ms + 振荡器启动时间





## 中断

## 6.1 概述

SN8P2722 共有 4 个中断源: 3 个内部中断(T0/TC0/ADC)和 1 个外部中断(INT0)。外部中断可以将系统从睡眠模式唤醒进入高速模式,在返回高速模式前,外部中断请求被锁定。一旦程序进入中断,寄存器 STKP 的位 GIE 将被硬件自动清零以避免再次响应其它中断。系统退出中断,即执行完 RETI 指令后,硬件自动将 GIE 置"1",以响应下一个中断。中断请求存放在寄存器 INTRQ 中。



\* 注:程序响应中断时,位 GIE 必须处于有效状态。

## 6.2 中断使能寄存器 INTEN

中断请求控制寄存器 INTEN 包括所有中断的使能控制位。INTEN 的有效位被置为"1",则系统进入该中断服务程序,程序计数器入栈,程序转至 0008H 即中断程序。程序运行到指令 RETI 时,中断结束,系统退出中断服务。

| 0C9H  | Bit 7  | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  |
|-------|--------|-------|--------|-------|-------|-------|-------|--------|
| INTEN | ADCIEN | Ī     | TC0IEN | TOIEN | ı     | ı     | ı     | P00IEN |
| 读/写   | R/W    | -     | R/W    | R/W   | =     | -     | -     | R/W    |
| 复位后   | 0      | -     | 0      | 0     | -     | -     | -     | 0      |

Bit 0 **P00IEN:** P0.0 外部中断 (INT0) 控制位。

0 = 禁止;

1 = 使能。

Bit 4 **TOIEN:** TO 中断控制位。

0 = 禁止;

1 = 使能。

Bit 5 **TC0IEN:** TC0 中断控制位。

0 = 禁止;

1 = 使能。

Bit 7 ADCIEN: ADC 中断控制位。

0 = 禁止;

1 = 使能。



## 6.3 中断请求寄存器 INTRQ

中断请求寄存器 INTRQ 中存放各中断请求标志。一旦有中断请求发生,INTRQ 中的相应位将被置"1",该请求被响应后,程序应将该标志位清零。根据 INTRQ 的状态,程序判断是否有中断发生,并执行相应的中断服务。

| 0C8H  | Bit 7  | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  |
|-------|--------|-------|--------|-------|-------|-------|-------|--------|
| INTRQ | ADCIRQ | Ī     | TC0IRQ | T0IRQ | -     | ı     | ı     | P00IRQ |
| 读/写   | R/W    | -     | R/W    | R/W   | -     | -     | -     | R/W    |
| 复位后   | 0      | -     | 0      | 0     | -     | -     | -     | 0      |

Bit 0 **P00IRQ:** P0.0 中断 (INT0) 请求标志位。

0 = INT0 无中断请求; 1 = INT0 有中断请求。

Bit 4 **TOIRQ:** TO 中断请求标志位。

0 = T0 无中断请求; 1 = T0 有中断请求。

Bit 5 **TC0IRQ:** TC0 中断请求标志位。

0 = TC0 无中断请求; 1 = TC0 有中断请求。

Bit 7 **ADCIRQ:** ADC 中断请求标志位。

0 = ADC 无中断请求; 1 = ADC 有中断请求。

## 6.4 GIE 全局中断

只有当全局中断控制位 GIE 置"1"的时候程序才能响应中断请求。 一旦有中断发生,程序计数器 (PC) 指向中断向量地址 (0008H), 堆栈层数加 1。

| 0DFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|------|-------|-------|-------|-------|-------|--------|--------|--------|
| STKP | GIE   | -     | ı     | -     | ı     | STKPB2 | STKPB1 | STKPB0 |
| 读/写  | R/W   | -     | -     | -     | -     | R/W    | R/W    | R/W    |
| 复位后  | 0     | -     | ı     | -     | ı     | 1      | 1      | 1      |

Bit 7 GIE: 全局中断控制位。

0 = 禁止全局中断;

1 = 使能全局中断。

▶ 例:设置全局中断控制位(GIE)。

B0BSET FGIE

;使能 GIE。

\* 注:在所有中断中,GIE 都必须处于使能状态。



## 6.5 PUSH, POP 处理

有中断请求发生并被响应后,程序转至 0008H 执行中断子程序。响应中断之前,必须保存 ACC、PFLAG 的内容。芯片提供 PUSH 和 POP 指令进行入栈保存和出栈恢复,从而避免中断结束后可能的程序运行错误。

\* 注:"PUSH"、"POP"指令仅对 ACC 和 PFLAG 作中断保护,而不包括 NT0 和 NPD。PUSH/POP 缓存器是唯一的且仅有一层。

▶ 例:对 ACC 和 PAFLG 进行入栈保护。

ORG 0 JMP START

ORG 8H

JMP INT\_SERVICE

ORG 10H

START:

...

INT\_SERVICE:

PUSH ; 保存 ACC 和 PFLAG。

• • •

POP ; 恢复 ACC 和 PFLAG。

RETI ; 退出中断。

ENDP



## 6.6 INTO (P0.0) 中断

INTO 被触发,则无论 POOIEN 处于何种状态,POOIRQ 都会被置"1"。如果 POOIRQ=1 且 POOIEN=1,系统响应该中断;如果 POOIRQ=1 而 POOIEN=0,系统并不会执行中断服务。在处理多中断时尤其需要注意。

如果中断的触发方向和唤醒功能的触发方向是一样的,则在系统由 P0.0 从睡眠模式和绿色模式唤醒时,INTO 的中断请求(INTOIRQ)就会被锁定。系统会在唤醒后马上进入中断向量地址执行中断服务程序。

#### 注: INT0 的中断请求被 P0.0 的唤醒触发功能锁定。

#### ▶ 注: P0.0 的中断触发边沿由 PEDGE 控制。

| 0BFH  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PEDGE | ī     | ī     | -     | P00G1 | P00G0 | -     | -     | 1     |
| 读/写   | -     | -     | -     | R/W   | R/W   | -     | -     | -     |
| 复位后   | -     | -     | -     | 1     | 0     | -     | -     | -     |

Bit[4:3] **P00G[1:0]:** P0.0 中断触发控制位。

00 = 保留;

01 = 上升沿触发;

10 = 下降沿触发;

11 = 上升/下降沿触发(电平触发)。

》 例: INT0 中断请求设置, 电平触发。

MOV A, #18H

B0MOV PEDGE, A ; 设置 INTO 为电平触发。

B0BCLR FP00IRQ ; 清 INT0 中断请求标志。

BOBSET FP00IEN ; 使能 INT0 中断。

BOBSET FGIE ; 使能 GIE。

➢ 例: INTO 中断。

ORG 8H

JMP INT\_SERVICE

INT\_SERVICE:

.. ; 保存 ACC 和 PFLAG。

JMP EXIT\_INT ; P00IRQ = 0,退出中断。

B0BCLR FP00IRQ ; 清 P00IRQ。

. ; INT0 中断服务程序。

EXIT\_INT:

;恢复 ACC 和 PFLAG。

RETI ; 退出中断。



## 6.7 T0 中断

TOC 溢出时,无论 TOIEN 处于何种状态,TOIRQ 都会置"1"。若 TOIEN 和 TOIRQ 都置"1",系统就会响应 TO的中断;若 TOIEN = 0,则无论 TOIRQ 是否置"1",系统都不会响应 TO 中断。尤其需要注意多种中断下的情形。

▶ 例:设置 T0 中断。

BOBCLR FTOIEN ;禁止T0中断。 BOBCLR FTOENB ; 关闭TO。

MOV A, #20H ;

 BOMOV
 TOM, A
 ; 设置 T0 时钟= Fcpu / 64。

 MOV
 A, #64H
 ; 初始化 T0C = 64H。

 BOMOV
 TOC, A
 ; 设置 T0 间隔时间= 10 ms。

BOBCLR FTOIRQ ; TOIRQ 清零。 BOBSET FTOIEN ; 使能 TO 中断。 BOBSET FTOENB ; 开启定时器 TO。

BOBSET FGIE ; 使能 GIE。

▶ 例: T0 中断服务程序。

ORG 8H

JMP INT\_SERVICE

INT\_SERVICE:

… ; 保存 ACC 和 PFLAG。

B0BTS1FT0IRQ; 检查是否有 T0 中断请求标志。JMPEXIT\_INT; T0IRQ = 0, 退出中断。

B0BCLR FT0IRQ ; 清 T0IRQ。

MOV A, #64H B0MOV TOC, A ;

...

EXIT\_INT:

... ; 恢复 ACC 和 PFLAG。

RETI ; 退出中断。



## 6.8 TC0 中断

TCOC 溢出时,无论 TCOIEN 处于何种状态,TCOIRQ 都会置"1"。若 TCOIEN 和 TCOIRQ 都置"1",系统就会 响应 TC0 的中断;若 TC0IEN = 0,则无论 TC0IRQ 是否置"1",系统都不会响应 TC0 中断。尤其需要注意多种中断下 的情形。

;禁止 TC0 中断。

; TC0 时钟=Fcpu / 64。

; TC0C 初始值=64H。

; TC0 间隔= 10 ms。

例: TC0 中断请求设置。

**B0BCLR** FTC0IEN **B0BCLR** FTC0ENB MOV

A, #20H

**B0MOV** TC0M, A A, # 64H MOV TC0C, A B0MOV

**B0BCLR** FTC0IRQ ;清 TC0 中断请求标志。 FTC0IEN **BOBSET** ; 使能 TC0 中断。

**B0BSET** FTC0ENB

**BOBSET FGIE** ; 使能 GIE。

例: TC0 中断服务程序。

**ORG** H8

JMP INT\_SERVICE

INT\_SERVICE:

EXIT\_INT:

;保存ACC和PFLAG。

B0BTS1 FTC0IRQ ; 检查是否有 TC0 中断请求标志。 **JMP** EXIT INT ; TC0IRQ = 0, 退出中断。

**B0BCLR** FTC0IRQ ;清TC0IRQ。

MOV A, #64H

**B0MOV** TC0C, A ;清 TC0C。 ; TC0 中断程序。

;恢复ACC和PFLAG。

**RETI** ;退出中断。



## 6.9 ADC 中断

当 ADC 转换完成后,无论 ADCIEN 是否使能,ADCIQR 都会置"1"。若 ADCIEN 和 ADCIQR 都置"1",那么系统就会响应 ADC 中断。若 ADCIEN = 0,不管 ADCIRQ 是否置"1",系统都不会进入 ADC 中断。用户应注意多种中断下的处理。

➢ 例: ADC 中断设置。

BOBCLR FADCIEN ; 禁止 ADC 中断。

MOV A, #10110000B ;

BOMOV ADM, A ; 允许 P4.0 ADC 输入,使能 ADC 功能。

MOV A, #00000000B ; 设置 AD 转换速率 = Fcpu/16。 B0MOV ADR, A

,

BOBCLR FADCIRQ ; 清除 ADC 中断请求标志。

BOBSET FADCIEN ; 使能 ADC 中断。 BOBSET FGIE ; 使能 GIE。

BOBSET FADS ; 开始 AD 转换。

▶ 例: ADC 中断服务程序。

ORG 8H ;中断向量地址。

JMP INT\_SERVICE

INT\_SERVICE:

;保存 ACC 和 PFLAG。

B0BTS1 FADCIRQ ; 检查是否有 ADC 中断。 JMP EXIT\_INT ; ADCIRQ = 0,退出中断。

B0BCLR FADCIRQ ; 清 ADCIRQ。

; ADC 中断服务程序。

EXIT\_INT:

,恢复 ACC 和 PFLAG。

RETI ; 退出中断。



## 6.10多中断操作举例

在同一时刻,系统中可能出现多个中断请求。此时,用户必须根据系统的要求对各中断进行优先权的设置。中断请求 标志 IRQ 由中断事件触发,当 IRQ 处于有效值"1"时,系统并不一定会响应该中断。各中断触发事件如下表所示:

| 中断     | 有效触发       |
|--------|------------|
| P00IRQ | 由 PEDGE 控制 |
| T0IRQ  | TOC 溢出     |
| TC0IRQ | TC0C 溢出    |
| ADCIRQ | AD 转换结束    |

多个中断同时发生时,需要注意的是:首先,必须预先设定好各中断的优先权;其次,利用 IEN 和 IRQ 控制系统是 否响应该中断。在程序中,必须对中断控制位和中断请求标志进行检测。

#### 例: 多中断条件下检测中断请求。

B0BTS1

ORG

**JMP** INT\_SERVICE

INT\_SERVICE:

**INTADCHK:** 

INT\_EXIT:

;保存ACC和PFLAG。 ...

INTPOOCHK: ; 检查是否有 INTO 中断请求。

**FP00IEN** 

; 检查是否使能 INTO 中断。 **JMP** INTT0CHK ; 跳到下一个中断。

B0BTS0 FP00IRQ ; 检查是否有 INT0 中断请求。

INTP00 **JMP** ; 进入 INTO 中断。

INTTOCHK: 检查是否有 T0 中断请求。

B0BTS1 **FT0IEN** 检查是否使能 T0 中断。 **JMP** INTTC0CHK ; 跳到下一个中断。

B0BTS0 FT0IRQ ; 检查是否有 T0 中断请求。

**JMP** INTT0 ; 进入 T0 中断。

**INTTC0CHK:** ; 检查是否有 TC0 中断请求。

> B0BTS1 **FTC0IEN** ; 检查是否使能 TC0 中断。

> JMP **INTADCHK** ; 跳到下一个中断。

B0BTS0 FTC0IRQ ; 检查是否有 TC0 中断请求。

**JMP** INTTC0 ; 进入 TC0 中断。

; 检查是否有 ADC 中断请求。

B0BTS1 **FADCIEN** ; 检查是否使能 ADC 中断。 **JMP** INT EXIT

B0BTS0 **FADCIRQ** ;检查是否有 ADC 中断请求。

**JMP** INTADC ; 进入 ADC 中断。

;恢复ACC和PFLAG。 ...

> **RETI** ;退出中断。



## **7** ио □

## 7.1 I/O 口模式

寄存器 PnM 控制 I/O 口的工作模式。

| 0B8H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P0M  | P07M  | P06M  | P05M  | P04M  | -     | P02M  | P01M  | P00M  |
| 读/写  | R/W   | R/W   | R/W   | R/W   | -     | R/W   | R/W   | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | -     | 0     | 0     | 0     |

| 0C4H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P4M  | ī     | -     | -     | P44M  | P43M  | P42M  | P42M  | P40M  |
| 读/写  | -     | -     | -     | R/W   | R/W   | R/W   | R/W   | R/W   |
| 复位后  | -     | -     | -     | 0     | 0     | 0     | 0     | 0     |

| 0C5H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P5M  | -     | -     | -     | P54M  | P53M  | P52M  | P51M  | P50M  |
| 读/写  | -     | -     | -     | R/W   | R/W   | R/W   | R/W   | R/W   |
| 复位后  | -     | -     | -     | 0     | 0     | 0     | 0     | 0     |

Bit[7:0] **PnM[7:0]:** Pn 模式控制位(n = 0~5)。

0 = 输入模式; 1 = 输出模式。

注:

- 1. 用户可通过位操作指令(B0BSET, B0BCLR)对 I/O 口进行编程控制;
- 2. P0.3 只能作为输入引脚,寄存器 P0M.3 的值保持为"1"。
- ▶ 例: I/O 模式选择。

CLR POM ; 所有端口设为输入模式。

CLR P4M CLR P5M

MOV A, #0FFH ; 所有端口设为输出模式。

B0MOV P0M, A B0MOV P4M,A B0MOV P5M, A

B0BCLR P4M.0 ; P4.0 设为输入模式。

BOBSET P4M.0 ; P4.0 设为输出模式。



## 7.2 I/O 口上拉电阻

| 0E0H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P0UR | P07R  | P06R  | P05R  | P04R  | -     | P02R  | P01R  | P00R  |
| 读/写  | W     | W     | W     | W     | -     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | -     | 0     | 0     | 0     |

| 0E4H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P4UR | -     | ī     | -     | P44R  | P43R  | P42R  | P41R  | P40R  |
| 读/写  | -     | -     | -     | W     | W     | W     | W     | W     |
| 复位后  | -     | -     | -     | 0     | 0     | 0     | 0     | 0     |

| 0E5H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P5UR | -     | -     | -     | P54R  | P53R  | P52R  | P51R  | P50R  |
| 读/写  | -     | -     | -     | W     | W     | W     | W     | W     |
| 复位后  | -     | -     | -     | 0     | 0     | 0     | 0     | 0     |

\* 注:P0.3 只可用作输入引脚,无上拉电阻,寄存器 P0UR.3 保持为"1"。

》 例: I/O 上拉寄存器。

MOV A, #0FFH ; 使能 P0、4、5 的上拉电阻。

BOMOV POUR, A BOMOV P4UR,A BOMOV P5UR, A



## 7.3 I/O 口数据寄存器

| 0D0H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P0   | P07   | P06   | P05   | P04   | P03   | P02   | P01   | P00   |
| 读/写  | R/W   | R/W   | R/W   | R/W   | R     | R/W   | R/W   | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0D4H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P4   | -     | -     | -     | P44   | P43   | P42   | P41   | P40   |
| 读/写  | -     | -     | -     | R/W   | R/W   | R/W   | R/W   | R/W   |
| 复位后  | -     | -     | -     | 0     | 0     | 0     | 0     | 0     |

| 0D5H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P5   | -     | Ī     | =     | P54   | P53   | P52   | P51   | P50   |
| 读/写  | -     | -     | -     | R/W   | R/W   | R/W   | R/W   | R/W   |
| 复位后  | -     | -     | -     | 0     | 0     | 0     | 0     | 0     |

注: 当使能外部复位时, P03 的值保持为 1。

例: 从输入口读取数据。

 B0MOV
 A, P0
 ; 从 P0 读数据。

 B0MOV
 A, P4
 ; 从 P4 读数据。

 B0MOV
 A, P5
 ; 从 P5 读数据。

▶ 例:写数据到输出端。

MOV A, #0FFH ; 立即数 0FFH 写入所有输出口。

B0MOV P0, A B0MOV P4, A B0MOV P5, A

▶ 例:写1位数据到输出口。

B0BSET P4.0 ; P4.0 和 P5.3 置 "1"。

B0BSET P5.3

B0BCLR P4.0 ; P4.0 和 P5.3 置 "0"。

B0BCLR P5.3



## 7.4 P4 与 ADC 共用引脚

P4 口和 ADC 的输入口共用。同一时间只能设置 P4 口的一个引脚作为 ADC 的测量信号输入口(通过 ADM 寄存器来设置),其它引脚则作为普通 I/O 使用。具体应用中,当输入一个模拟信号到 CMOS 结构端口,尤其当模拟信号为 1/2 VDD时,将可能产生额外的漏电流。同样,当 P4 口外接多个模拟信号时,也会产生额外的漏电流。在睡眠模式下,上述漏电流会严重影响到系统的整体功耗。P4CON 为 P4 口的配置寄存器。将 P4CON[7:0]置"1",其对应的 P4 口将被设置为纯模拟信号输入口,从而避免上述漏电流的情况。

| 0AFH  | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|--------|--------|--------|--------|--------|
| P4CON | -     | -     | -     | P4CON4 | P4CON3 | P4CON2 | P4CON1 | P4CON0 |
| 读/写   | -     | -     | -     | R/W    | R/W    | R/W    | R/W    | R/W    |
| 复位后   | -     | -     | -     | 0      | 0      | 0      | 0      | 0      |

Bit[4:0] **P4CON[4:0]**: P4.n 控制位。

0 = P4.n 作为模拟信号输入引脚(ADC输入引脚)或普通 I/O 引脚;

1 = P4.n 只能作为模拟信号输入引脚,不能作为普通 I/O 引脚。

▸ 注:当 P4.n 作为普通 I/O 口而不是 ADC 输入引脚时,P4CON.n 必须置为 0,否则 P4.n 的普通 I/O 信号会被隔离开来。

P4 的 ADC 模拟输入由寄存器 ADM 的 GCHS 和 CHSn 位控制,若 GCHS = 0,P4.n 为普通的 I/O 引脚,若 GCHS = 1,CHSn 所对应的 P4.n 用作 ADC 模拟信号输入引脚。

| 0B1H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADM  | ADENB | ADS   | EOC   | GCHS  | -     | CHS2  | CHS1  | CHS0  |
| 读/写  | R/W   | R/W   | R/W   | R/W   | -     | R/W   | R/W   | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | -     | 0     | 0     | 0     |

Bit 4 GCHS: ADC 输入通道选择位。

0 = 禁止 AIN 通道;

1 = 开启 AIN 通道。

Bit[2:0] CHS[2:0]: ADC 输入通道选择位。

000 = AIN0: 001 = AIN1: 010 = AIN2: 011 = AIN3: 100 = AIN4: 101 = AIN5.

☀ 注:在设置 P4.n 为普通的 I/O 引脚时,必须保证 P4.n 的 ADC 功能已经被禁止。

▶ 例:设置 P4.1 为普通的输入引脚, P4CON.1 必须置为 0。

; 检查 GCHS 和 CHS[2:0]的状态。

B0BCLR FGCHS ; 若 CHS[2:0]指向 P4.1 (CHS[2:0] = 001B), GCHS=0。

;若 CHS[2:0]没有指向 P4.1 (CHS[2:0] ≠ 001B),则忽略 GCHS 的状态。

;清 P4CON。

BOBCLR P4CON.1 ; 使能 P4.1 的普通 I/O 功能。

; 开启 P4.1 的输入功能。

B0BCLR P4M.1 ; 设置 P4.1 为输入模式。

▶ 例:设置 P4.1 为普通的输出模式, P4CON.1 必须置为 0。

; 检查 GCHS 和 CHS[2:0]的状态。

B0BCLR FGCHS ; 若 CHS[2:0]指向 P4.1 (CHS[2:0] = 001B) ,GCHS=0。

;若 CHS[2:0]没有指向 P4.1 (CHS[2:0] ≠ 001B),则忽略 GCHS 的状态。

;清 P4CON。

B0BCLR P4CON.1 ; 使能 P4.1 的普通 I/O 功能。

;设置 P4.1 为输出模式以避免误操作。

BOBSET P4.1 ; 设置 P4.1 为 1。

;或

B0BCLR P4.1 ; 设置 P4.1 为 0。

; 开启 P4.1 的输出模式。

B0BSET P4M.1 ; 设置 P4.1 为输出模式。



## 8 定时器

## 8.1 看门狗定时器

看门狗定时器 WDT 是一个 4 位二进制计数器,用于监控程序的正常执行。如果由于干扰,程序进入了未知状态,看门狗定时器溢出,系统复位。看门狗的工作模式由编译选项控制,其时钟源由内部低速 RC 振荡器(16KHz @3V,32KHz @5V)提供。

#### 看门狗溢出时间 = 8192 /内部低速振荡器周期(sec)

| VDD | 内部低速 RC Freq. | 看门狗溢出时间 |
|-----|---------------|---------|
| 3V  | 16KHz         | 512ms   |
| 5V  | 32KHz         | 256ms   |

· 注:如果看门狗被置为"Always\_On"模式,那么看门狗在睡眠模式和绿色模式下仍然运行。

看门狗清零的方法是对看门狗计数器清零寄存器 WDTR 写入清零控制字 5AH。

| 0CCH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| WDTR | WDTR7 | WDTR6 | WDTR5 | WDTR4 | WDTR3 | WDTR2 | WDTR1 | WDTR0 |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

; 看门狗定时器清零。

》 例:如下是对看门狗定时器的操作,在主程序开头对看门狗清零。

MOV A,#5AH
B0MOV WDTR,A
...
CALL SUB1
CALL SUB2
...
...
JMP MAIN

#### 看门狗定时器应用注意事项如下:

MOV

**CALL** 

**CALL** 

- 对看门狗清零之前, 检查 I/O 口的状态和 RAM 的内容可增强程序的可靠性;
- 不能在中断中对看门狗清零,否则无法侦测到主程序跑飞的状况;
- 程序中应该只在主程序中有一次清看门狗的动作,这种架构能够最大限度的发挥看门狗的保护功能。

#### 》 例:如下是对看门狗定时器的操作,在主程序开头对看门狗清零。

main:

; 检测 I/O 口的状态。 ; 检测 RAM 的内容。

Err: JMP \$ ; I/O 或 RAM 出错,不清看门狗等看门狗计时溢出。

Correct: ; I/O 和 RAM 正常,看门狗清零 。

; A, 5AH ; 在整个程序中只有一处地方清看门狗。

SUB1

SUB2

BOMOV WDTR, A

... ... JMP MAIN



## 8.2 定时器 T0

#### 8.2.1 概述

8 位二进制计数器 T0 溢出时(由 0FFH 计到 00H),T0 在继续计数的同时给出一个溢出信号触发 T0 中断。计数器 T0 主要有以下功能:

- ▼ 8位可编程定时器:根据选定的时钟频率定时产生中断;
- ☞ 绿色模式唤醒功能:在 T0ENB=1 的条件下,T0 的溢出可将系统从绿色模式中唤醒。



#### 8.2.2 TOM 模式寄存器

| 0D8H | Bit 7 | Bit 6   | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|---------|---------|---------|-------|-------|-------|-------|
| TOM  | T0ENB | T0rate2 | T0rate1 | T0rate0 | -     | -     | -     | -     |
| 读/写  | R/W   | R/W     | R/W     | R/W     | -     | -     | -     | -     |
| 复位后  | 0     | 0       | 0       | 0       | -     | -     | -     | -     |

Bit [6:4] **TORATE[2:0]:** TO 分频选择位。

000 = fcpu/256;

001 = fcpu/128;

... ;

110 = fcpu/4;

111 = fcpu/2.

Bit 7 **T0ENB:** T0 启动控制位。

0 = 关闭 T0 计数器;

1 = 开启 T0 计数器。



## 8.2.3 TOC 计数寄存器

T0C 用于控制 T0 的间隔时间。

| 0D9H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| T0C  | T0C7  | T0C6  | T0C5  | T0C4  | T0C3  | T0C2  | T0C1  | T0C0  |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

T0C 初始值计算公式如下:

T0C 初始值= 256 - (T0 中断间隔时间 \* 输入时钟)

▶ 例:中断间隔时间设置为 10ms,高速时钟选择外部 4MHz,Fcpu=Fosc/4,T0RATE=010(Fcpu/64)。

TOC 初始值 = 256 - (TO 中断间隔时间 \* 输入时钟)

= 256 - (10ms \* 4MHz / 4 / 64)

 $= 256 - (10^{-2} * 4 * 10^{6} / 4 / 64)$ 

= 100

= 64H

#### T0 定时间隔列表

|        |          |           | 1 = 11 1111 111 |           |                |
|--------|----------|-----------|-----------------|-----------|----------------|
| T0RATE | TOCLOCK  | 高速模式(Fcp  | ou = 4MHz / 4)  | 低速模式(Fcpu | = 32768Hz / 4) |
| TORATE | TOCLOCK  | 最大溢出间隔    | 单步间隔= max/256   | 最大溢出间隔    | 单步间隔= max/256  |
| 000    | Fcpu/256 | 65.536 ms | 256 us          | 8000 ms   | 31250 us       |
| 001    | Fcpu/128 | 32.768 ms | 128 us          | 4000 ms   | 15625 us       |
| 010    | Fcpu/64  | 16.384 ms | 64 us           | 2000 ms   | 7812.5 us      |
| 011    | Fcpu/32  | 8.192 ms  | 32 us           | 1000 ms   | 3906.25 us     |
| 100    | Fcpu/16  | 4.096 ms  | 16 us           | 500 ms    | 1953.125 us    |
| 101    | Fcpu/8   | 2.048 ms  | 8 us            | 250 ms    | 976.563 us     |
| 110    | Fcpu/4   | 1.024 ms  | 4 us            | 125 ms    | 488.281 us     |
| 111    | Fcpu/2   | 0.512 ms  | 2 us            | 62.5 ms   | 244.141 us     |

#### 8.2.4 TO 操作流程

☞ T0 停止计数,禁止 T0 中断并将 T0 中断请求标志清零。

BOBCLR FTOENB BOBCLR FTOIRN BOBCLR FTOIRQ

☞ 设置 T0 计时速率。

MOV A,#0xxx00b ; T0M 的 bit4~bit6 位可控制 T0 的计数速率为 x000xxxxb~x111xxxxb。

B0MOV T0M,A

☞ 设置 T0 中断间隔时间。

MOV A,#7FH B0MOV T0C,A

☞ 设置 T0 工作模式。

BOBSET FTOIEN

☞ 开启 T0。

BOBSET FTOENB



## 8.3 定时/计数器 TC0

#### 8.3.1 概述

定时/计数器 TC0 具有双时钟源,可根据实际需要选择内部时钟或外部时钟作为计时标准。其中,内部时钟来自 Fcpu,外部时钟 INT0 由 P0.0 引脚(下降沿触发)输入。寄存器 TC0M 控制时钟源的选择。当 TC0 从 0FFH 溢出到 00H 时,TC0 在继续计数的同时产生一个溢出信号,触发 TC0 中断请求。

#### TC0 的主要作用如下:

- 8 位可编程定时器:根据选定的时钟频率在特定时间产生中断信号;
- 外部事件计数:对外部事件计数;
- ☞ 蜂鸣器输出;
- PWM 输出。





#### 8.3.2 TC0M 模式寄存器

| 0DAH | Bit 7  | Bit 6    | Bit 5    | Bit 4    | Bit 3  | Bit 2  | Bit 1  | Bit 0   |
|------|--------|----------|----------|----------|--------|--------|--------|---------|
| TC0M | TC0ENB | TC0rate2 | TC0rate1 | TC0rate0 | TC0CKS | ALOAD0 | TC0OUT | PWM0OUT |
| 读/写  | R/W    | R/W      | R/W      | R/W      | R/W    | R/W    | R/W    | R/W     |
| 复位后  | 0      | 0        | 0        | 0        | 0      | 0      | 0      | 0       |

Bit 0 **PWM0OUT:** PWM 输出控制。

0 = 禁止 PWM 输出;

1 = 使能 PWM 输出, PWM 输出占空比由 TC0OUT 和 ALOAD0 控制。

Bit 1 TC0OUT: TC0 超时输出信号控制。仅当 PWM0OUT = 0 时有效。

0 = 禁止, P5.4 作为输入/输出口; 1 = 使能, P5.4 输出 TC0OUT 信号。

Bit 2 ALOAD0: 自动装载控制。仅当 PWM0OUT = 0 时有效。

0 = 禁止 TC0 自动装载; 1 = 使能 TC0 自动装载。

Bit 3 **TC0CKS:** TC0 时钟信号控制位。

0 = 内部时钟(Fcpu 或 Fosc); 1 = 外部时钟,由 P0.0/INT0 输入。

Bit [6:4] TCORATE[2:0]: TCO 分频选择位。

000 = fcpu/256;

001 = fcpu/128;

... ;

110 = fcpu/4;

111 = fcpu/2.

Bit 7 TC0ENB: TC0 启动控制位。

0 = 禁止 TC0 定时器;

1 = 开启 TC0 定时器。

\* 注:若 TC0CKS=1,则 TC0 用作外部事件计数器,此时不需要考虑 TC0RATE 的设置,P0.0 口无中断信号(P00IRQ=0)。



#### 8.3.3 TC0C 计数寄存器

TC0C 控制 TC0 的时间间隔。

| 0DBH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| TC0C | TC0C7 | TC0C6 | TC0C5 | TC0C4 | TC0C3 | TC0C2 | TC0C1 | TC0C0 |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

TC0C 初始值的计算公式如下:

TC0C 初始值 = N - (TC0 中断间隔时间 \* 输入时钟)

N为TC0二进制计数范围。各模式下参数的设定如下表所示:

| TC0CKS | PWM0 | ALOAD0 | TC0OUT | N   | TC0C 范围  | TC0C 二进制计数范围        | 注释          |
|--------|------|--------|--------|-----|----------|---------------------|-------------|
|        | 0    | Х      | Х      | 256 | 00H~0FFH | 00000000b~1111111b  | 每计数 256 次溢出 |
|        | 1    | 0      | 0      | 256 | 00H~0FFH | 00000000b~1111111b  | 每计数 256 次溢出 |
| 0      | 1    | 0      | 1      | 64  | 00H~3FH  | xx000000b~xx111111b | 每计数 64 次溢出  |
|        | 1    | 1      | 0      | 32  | 00H~1FH  | xxx00000b~xxx11111b | 每计数 32 次溢出  |
|        | 1    | 1      | 1      | 16  | 00H~0FH  | xxxx0000b~xxxx1111b | 每计数 16 次溢出  |
| 1      | -    | -      | -      | 256 | 00H~0FFH | 00000000b~1111111b  | 每计数 256 次溢出 |

▶ 例: TC0 中断时间设为 10ms,时钟源选择 Fcpu(TC0KS = 0),无 PWM 输出(PWM0=0),高速时钟 = 4MHz. Fcpu = Fosc/4,TC0RATE = 010(Fcpu/64)。

TC0C 初始值 = N - (TC0 中断时间 \* 输入时钟)

= 256 - (10ms \* 4MHz / 4 / 64)

**= 256 - (10-2 \* 4 \* 106 / 4 / 64)** 

= 100

= 64H

#### TC0 中断时间对应表

| TOORATE | TC0CLOCK | 高速模式(     | (Fcpu = 4MHz / 4) | 低速模式(F   | 低速模式 (Fcpu = 32768Hz / 4) |  |  |
|---------|----------|-----------|-------------------|----------|---------------------------|--|--|
| TOURATE | TOUCLOCK | 最大溢出间隔时间  | 单步间隔时间 = max/256  | 最大溢出间隔时间 | 单步间隔时间 = max/256          |  |  |
| 000     | Fcpu/256 | 65.536 ms | 256 us            | 8000 ms  | 31250 us                  |  |  |
| 001     | Fcpu/128 | 32.768 ms | 128 us            | 4000 ms  | 15625 us                  |  |  |
| 010     | Fcpu/64  | 16.384 ms | 64 us             | 2000 ms  | 7812.5 us                 |  |  |
| 011     | Fcpu/32  | 8.192 ms  | 32 us             | 1000 ms  | 3906.25 us                |  |  |
| 100     | Fcpu/16  | 4.096 ms  | 16 us             | 500 ms   | 1953.125 us               |  |  |
| 101     | Fcpu/8   | 2.048 ms  | 8 us              | 250 ms   | 976.563 us                |  |  |
| 110     | Fcpu/4   | 1.024 ms  | 4 us              | 125 ms   | 488.281 us                |  |  |
| 111     | Fcpu/2   | 0.512 ms  | 2 us              | 62.5 ms  | 244.141 us                |  |  |



#### 8.3.4 TC0R 自动装载寄存器

TC0 的自动装载功能由 TC0M 的 ALOAD0 位控制。当 TC0C 溢出时,TC0R 的值自动装入 TC0C 中。这样,用户在使用的过程中就不需要在中断中重新赋值。

TC0 为双重缓存器结构。若程序对 TC0R 进行了修改,那么修改后的 TC0R 值先被暂存在 TC0R 的第一个缓存器中,直到当前 TC0 溢出后,才被真正存入 TC0R 缓存器中,从而避免 TC0 中断时间出错以及 PWM 和蜂鸣器误动作。

#### · 注:在 PWM 模式下,系统自动开启自动装载功能。位寄存器 ALOAD0 用于控制溢出范围。

| 0CDH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| TC0R | TC0R7 | TC0R6 | TC0R5 | TC0R4 | TC0R3 | TC0R2 | TC0R1 | TC0R0 |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### TCOR 初始值计算公式如下:

TC0R 初始值 = N - (TC0 中断间隔时间 \* 输入时钟)

上式中,N为TC0的最大计数范围。TC0的溢出时间有如下六种可能情况:

| TC0CKS | PWM0 | ALOAD0 | TC0OUT | N   | TC0R 计数范围 | TC0R 二进制计数范围        |
|--------|------|--------|--------|-----|-----------|---------------------|
|        | 0    | Х      | Х      | 256 | 00H~0FFH  | 00000000b~1111111b  |
|        | 1    | 0      | 0      | 256 | 00H~0FFH  | 00000000b~1111111b  |
| 0      | 1    | 0      | 1      | 64  | 00H~3FH   | xx000000b~xx111111b |
|        | 1    | 1      | 0      | 32  | 00H~1FH   | xxx00000b~xxx11111b |
|        | 1    | 1      | 1      | 16  | 00H~0FH   | xxxx0000b~xxxx1111b |
| 1      | -    | -      | -      | 256 | 00H~0FFH  | 00000000b~1111111b  |

▶ 例: TC0 中断间隔时间设置为 10ms,时钟源选 Fcpu(TC0KS = 0),无 PWM 输出(PWM0 = 0),高速时钟为外部 4MHz,Fcpu = Fosc/4,TC0RATE = 010(Fcpu/64)。

TCOR 初始值 = N - (TCO 中断间隔时间 \* 输入时钟源)

= 256 - (10ms \* 4MHz / 4 / 64)

 $= 256 - (10^{-2} * 4 * 10^{6} / 4 / 64)$ 

= 100

= 64H



#### 8.3.5 TC0 时钟频率输出(蜂鸣器输出)

对 TC0 时钟频率进行适当设置可得到特定频率的蜂鸣器输出(TC0OUT),并通过引脚 P5.4 输出。单片机内部设置 TC0 的溢出频率经过 2 分频后作为 TC0OUT 的频率,即 TC0 每溢出 2 次 TC0OUT 输出一个完整的脉冲,此时,P5.4 的 I/O 功能自动被禁止。TC0OUT 输出波形如下:



若外部高速时钟选择 4MHz,系统时钟源采用外部时钟 Fosc/4,程序中设置 TC0RATE2~TC0RATE1 = 110, TC0C = TC0R = 131,则 TC0 的溢出频率为 2KHz,TC0OUT 的输出频率为 1KHz。下面给出范例程序。

#### ▶ 例:设置 TC0OUT (P5.4)。

| MOV<br>B0MOV               | A,#01100000B<br>TC0M,A        | ; TC0 速率=Fcpu/4。                                                             |
|----------------------------|-------------------------------|------------------------------------------------------------------------------|
| MOV<br>B0MOV<br>B0MOV      | A,#131<br>TC0C,A<br>TC0R,A    | ;自动加载参考值设置。                                                                  |
| B0BSET<br>B0BSET<br>B0BSET | FTC0OUT<br>FALOAD0<br>FTC0ENB | ; TC0 的输出信号由 P5.4 输出,禁止 P5.4 的普通 I/O 功能。<br>;使能 TC0 自动装载功能。<br>: 开启 TC0 定时器。 |

\* 注:蜂鸣器的输出有效时, "PWM0OUT"必须被置为 0。



#### 8.3.6 TC0 操作举例

TC0 定时器可用于定时器中断、事件计数、TC0OUT 和 PWM。下面分别举例说明。

▶ 例:停止 TC0 计数器,禁止 TC0 中断并将 TC0 中断请求标志清零。

BOBCLR FTCOENB BOBCLR FTCOIEN BOBCLR FTCOIRQ

▶ 例:设置 TC0 的速率(不包含事件计数模式)。

MOV A, #0xxx0000b ; TC0M 的 bit4~bit6 控制 TC0 的速率范围为 x000xxxxb~x111xxxxb。

BOMOV TCOM,A ; 禁止 TCO 中断。

▶ 例:设置 TC0 的时钟源。

BOBCLR FTCOCKS ;选择内部时钟。

或

BOBSET FTCOCKS ; 选择外部时钟。

> 例: TC0 自动装载模式设置。

BOBCLR FALOADO ;禁止自动装载功能。

或

或

或

或

或

BOBSET FALOADO ; 使能 TCO 自动装载。

▶ 例: TC0 中断间隔时间设置。

MOV A,#7FH ; TC0 模式决定 TC0C 和 TC0R 的值。

BOMOV TCOC,A ; 设置 TCOC。 BOMOV TCOR,A ; 设置 TCOR。

B0BCLR FALOAD0 ; ALOAD0, TC0OUT = 00, PWM 周期 = 0~255。

B0BCLR FTC0OUT

B0BCLR FALOAD0 ; ALOAD0, TC0OUT = 01, PWM 周期 = 0~63。

B0BSET FTC0OUT

B0BSET FALOAD0 ; ALOAD0, TC0OUT = 10, PWM 周期 = 0~31。

B0BCLR FTC0OUT

B0BSET FALOAD0 ; ALOAD0, TC0OUT = 11, PWM 周期 = 0~15。

BOBSET FTCOOUT

▶ 例:设置 TC0 模式。

BOBSET FTCOIEN ; 使能 TCO 中断功能。

或 B0BSET FTC0OUT

BOBSET FTCOOUT ; 使能 TCOOUT (蜂鸣器) 功能。

B0BSET FPWM0OUT ; 使能 PWM 功能。

▶ 例:开启 TC0。

BOBSET FTCOENB



#### 8.4 **PWM0**

#### 8.4.1 概述

PWM 信号输出到 PWM0OUT(P5.4 引脚),TC0OUT 和 ALOAD0 标志位控制 PWM 输出的阶数(256、64、32 和 16)。8 位计数器 TC0C 计数过程中不断与 TC0R 相比较,当 TC0C 计数到两者相等时,PWM 输出低电平,当 TC0C 再次从零开始计数时,PWM 被强制输出高电平。PWM0 输出占空比 = TC0R/计数量程(计数量程 = 256、64、32 或 16)。参考寄存器保持输入 00H 可使 PWM 的输出长时间维持在低电平,通过修改 TC0R 可改变 PWM 输出占空比。

\* 注:TC0 为双重缓存器结构,调整 TC0R 的值可以改变 PWM 的输出占空比。用户可随时改变 TC0R 的值,但是只有在 TC0 溢出 后,这一修改值才真正被写入 TC0R 中。

| ALOAD0 | TC0OUT | PWM 占空比范围     | TC0C 有效值 | TC0R 有效值 | MAX. PWM 输出频率<br>(Fcpu = 4MHz) | 注释          |
|--------|--------|---------------|----------|----------|--------------------------------|-------------|
| 0      | 0      | 0/256~255/256 | 00H~0FFH | 00H~0FFH | 7.8125K                        | 每计数 256 次溢出 |
| 0      | 1      | 0/64~63/64    | 00H~3FH  | 00H~3FH  | 31.25K                         | 每计数 64 次溢出  |
| 1      | 0      | 0/32~31/32    | 00H~1FH  | 00H~1FH  | 62.5K                          | 每计数 32 次溢出  |
| 1      | 1      | 0/16~15/16    | 00H~0FH  | 00H~0FH  | 125K                           | 每计数 16 次溢出  |

#### PWM 输出占空比随 TC0R 的变化而变化: 0/256~255/256。





## 8.4.2 TCOIRQ 和 PWM 输出占空比

在 PWM 模式下,TC0IRQ 的频率与 PWM 的占空比有关,具体情况如下图所示:





#### 8.4.3 PWM 输出占空比与 TC0R 的变化

在 PWM 模式下,系统随时比较 TC0C 和 TC0R 的异同。若 TC0C<TC0R,PWM 输出高电平,反之则输出低电平。当 TC0C 发生改变的时候,PWM 将在下一周期改变输出占空比。如果 TC0R 保持恒定,那么 PWM 输出波形也保持稳定。



上图所示是 TCOR 恒定时的波形。每当 TCOC 溢出时, PWM 都输出高电平, TCOC ≥ TCOR 时, PWM 即输出低电平。 下面所示是 TCOR 发生变化时对应的波形图:



在 period 2 和 period 4 中,显示新的占空比(TC0R),但 PWM 在 period 2 和 period 4 的占空比要在下一个 period 才会改变。这样,可以避免 PWM 不随设定改变或在同一个周期内改变两次,从而避免系统发生不可预知的误动作。



#### 8.4.4 PWM 编程举例

▶ 例: PWM 输出设置。外部高速振荡器输出频率 = 4MHZ, Fcpu = Fosc/4, PWM 输出占空比 = 30/256, 输出频率 1KHZ, PWM 时钟源来自外部时钟, TC0 速率 = Fcpu/4, TC0RATE2~TC0RATE1 = 110, TC0C = TC0R = 30。

MOV A,#01100000B

B0MOV TC0M,A ; TC0速率=Fcpu/4。

MOV A,#30 ; PWM 输出占空比=30/256。

B0MOV TC0C,A B0MOV TC0R,A

B0BCLR FTC0OUT ; 占空比变化范围为 0/256~255/256。

BOBCLR FALOADO

BOBSET FPWMOOUT ; PWMO 输出至 P5.4,禁止 P5.4 I/O 功能。

BOBSET FTCOENB

☀ 注:TC0R 为只写寄存器,不能用 INCMS 和 DECMS 指令对其进行操作。

》 例: 改变 TC0R 的内容。

MOV A, #30H B0MOV TC0R, A

INCMS BUF0

NOP

B0MOV A, BUF0 B0MOV TC0R, A



## 9 5 通道 ADC

## 9.1 概述

SN8P2722 的模数转换(A/D)模块可以提供 5 个模拟输入通道,高达 4096 阶的分辨率,能将一个模拟信号转换成相应的 12 位数字信号。进行 AD 转换时,首先要选择输入通道(AIN0~AIN4),然后将 GCHS 和 ADS 置为"1",并启动 AD 转换。当 AD 转换结束后,系统会自动的把 EOC 置为"1",并将转换结果存入寄存器 ADB 中。



- \*注:分辨率为 12 位时,转换时间需 16 个输入时钟。
- \* 注:模拟输入电压必须在 VDD 和 VSS 之间。
- \* 注: ADC 设计时应注意:
  - 1. ADC 的输入/输出引脚设置为输入模式。
  - 2. 禁止 ADC 输入引脚的上拉电阻。
  - 3. 在进入睡眠模式前禁止 ADC (ADENB = 0) 以省电。
  - 4. 在省电模式下设置 P4CON 的有关位以避免额外功耗。
  - 5. 允许 ADC (ADENB = 1) 后延迟 100us 等待 ADC 电路稳定。

## 9.2 ADM 寄存器

| 0B1H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADM  | ADENB | ADS   | EOC   | GCHS  | ı     | CHS2  | CHS1  | CHS0  |
| 读/写  | R/W   | R/W   | R/W   | R/W   | =     | R/W   | R/W   | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | -     | 0     | 0     | 0     |

Bit 7 ADENB: ADC 控制位。

0 = 禁止; 1 = 允许。

Bit 6 ADS: ADC 启动位。

0 = 停止; 1 = 转换开始。

Bit 5 **EOC:** ADC 状态控制位。

0 = 转换过程中;

1 = 转换结束, ADS 复位。

Bit 4 **GCHS:** ADC 输入通道控制位。

0 = 禁止 AIN 通道; 1 = 使能 AIN 通道。

Bit[2:0] CHS[2:0]: ADC 输入通道选择位。

000 = AIN0; 001 = AIN1; 010 = AIN2; 011 = AIN3; 100 = AIN4.

☀ 注: 若 ADENB = 1,用户应设置 P4.n/AINn 为输入模式 且禁止上拉电阻,系统不会自动设置。若已经设置了 P4CON.n。P4.n/AINn 的数字功能(包括上拉电阻)被隔离。



## 9.3 ADR 寄存器

| 0B3H | Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|--------|-------|--------|-------|-------|-------|-------|
| ADR  | -     | ADCKS1 | ı     | ADCKS0 | ADB3  | ADB2  | ADB1  | ADB0  |
| 读/写  | -     | R/W    | -     | R/W    | R     | R     | R     | R     |
| 复位后  | -     | 0      | -     | 0      | X     | Х     | X     | X     |

Bit 6.4 **ADCKS [1:0]:** ADC 时钟源选择位。

| ADCKS1 | ADCKS0 | ADC 时钟源 |
|--------|--------|---------|
| 0      | 0      | Fcpu/16 |
| 0      | 1      | Fcpu/8  |
| 1      | 0      | Fcpu/1  |
| 1      | 1      | Fcpu/2  |

Bit [3:0] ADB [3:0]: ADC 数据缓存器。 ADB11~ADB4(8 位 ADC); ADB11~ADB0(12 位 ADC)。

注:寄存器 ADR 的 ADB[3:0]的初始值是未知的。

## 9.4 ADB 寄存器

| 0B2H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADB  | ADB11 | ADB10 | ADB9  | ADB8  | ADB7  | ADB6  | ADB5  | ADB4  |
| 读/写  | R     | R     | R     | R     | R     | R     | R     | R     |
| 复位后  | X     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |

Bit[7:0] ADB[7:0]: ADC 12 位分辨率的高字节数据缓存器。

8 位数据缓存器 ADB 用来保存 AD 转换结果的高 8 位(bit4~bit11),转换结果的低 4 位则保存在 ADR 寄存器中。 ADB 为只读寄存器,在 8 位 ADC 模式下,AD 转换结果保存在寄存器 ADB 中;在 12 位模式下,则分别保存在寄存器 ADB 和 ADR 中。

#### AIN 的输入电压 v.s. ADB 的输出数据

| AIN n           | ADB11 | ADB10 | ADB9 | ADB8 | ADB7 | ADB6 | ADB5 | ADB4 | ADB3 | ADB2 | ADB1 | ADB0 |
|-----------------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| 0/4096*VREFH    | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| 1/4096*VREFH    | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 1    |
|                 |       |       |      |      |      |      |      |      |      |      |      |      |
|                 |       |       |      |      |      |      |      |      |      |      |      |      |
|                 |       |       |      |      |      |      |      |      |      |      |      |      |
| 4094/4096*VREFH | 1     | 1     | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 0    |
| 4095/4096*VREFH | 1     | 1     | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    |

针对不同的应用,用户可能需要精度介于 8 位到 12 位之间的 AD 转换器。对于这种情况,可以通过对保存在 ADR 和ADB 中的转换结果进行处理得到。首先,用户必须选择 12 位分辨率的模式,进行 AD 转换,然后在转换结果中去掉最低的几位得到需要的结果。如下表所示:

| ADC 分辨率                          | ADB   |       |      |      |      |      |      |      |      | ADR  |      |      |  |
|----------------------------------|-------|-------|------|------|------|------|------|------|------|------|------|------|--|
| ADO 万 赤平                         | ADB11 | ADB10 | ADB9 | ADB8 | ADB7 | ADB6 | ADB5 | ADB4 | ADB3 | ADB2 | ADB1 | ADB0 |  |
| 8-bit                            | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | Х    | Х    | Х    | Х    |  |
| 9-bit                            | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | Х    | Х    | Х    |  |
| 10-bit                           | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | Х    | Х    |  |
| 11-bit                           | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | Х    |  |
| 12-bit                           | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |
| <b>)</b> = 可选位, <b>x</b> = 未使用的位 |       |       |      |      |      |      |      |      |      |      |      |      |  |

注:寄存器 ADB 各位的初始值是未知的。



## 9.5 P4CON 寄存器

P4 口和 ADC 的输入口共享。同一时间只能设置 P4 口的一个引脚作为 ADC 的测量信号输入口(通过 ADM 寄存器来设置),其它引脚则作为普通 I/O 使用。具体应用中,当输入一个模拟信号到 CMOS 结构端口,尤其当模拟信号为 1/2 VDD时,将可能产生额外的漏电流。同样,当 P4 口外接多个模拟信号时,也会产生额外的漏电流。在睡眠模式下,上述漏电流会严重影响到系统的整体功耗。P4CON 为 P4 口的配置寄存器。将 P4CON[7:0]置"1",其对应的 P4 口将被设置为纯模拟信号输入口,从而避免上述漏电流的情况。

| 0AEH  | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|-------|-------|--------|--------|--------|--------|--------|
| P4CON | -     | -     | -     | P4CON4 | P4CON3 | P4CON2 | P4CON1 | P4CON0 |
| 读/写   | -     | -     | -     | R/W    | R/W    | R/W    | R/W    | R/W    |
| 复位后   | -     | -     | -     | 0      | 0      | 0      | 0      | 0      |

Bit[4:0] **P4CON[4:0]:** P4.n 配置控制位。

0 = P4.n 作为模拟输入(ADC 输入)引脚或者数字 I/O 引脚;

1 = P4.n 只能作为模拟输入引脚,不能作为数字 I/O 引脚。

★ 注:当 P4.n 为基本 I/O 而不是 ADC 通道时,P4CON.n 必须置"0",否则 P4.n 的数字 I/O 信号会被隔离。

## 9.6 ADC 转换时间

12 位 AD 转换时间 = 1/ (ADC clock /4) \*16 sec

**Fcpu = 4MHz**(高速时钟,Fosc = 16MHz,Fcpu = Fosc/4)

| ADLEN      | ADCKS1 | ADCKS0 | ADC Clock | ADC 转换时间                  |  |  |  |  |
|------------|--------|--------|-----------|---------------------------|--|--|--|--|
|            | 0      | 0      | Fcpu/16   | 1/(4MHz/16/4)*16 = 256 us |  |  |  |  |
| 1 (10 bit) | 0      | 1      | Fcpu/8    | 1/(4MHz/8/4)*16 = 128 us  |  |  |  |  |
| 1 (12-bit) | 1      | 0      | Fcpu/1    | 1/(4MHz/4)*16 = 16 us     |  |  |  |  |
|            | 1      | 1      | Fcpu/2    | 1/(4MHz/2/4)*16 = 32 us   |  |  |  |  |



# 9.7 ADC 操作实例

### ▶ 例:设置 AIN0 为 12 位 ADC 输入并在进入省电模式后关闭 AD 转换。

ADC0:

BOBSET FADENB ; 使能 ADC 电路。

CALL Delay100uS ; 延迟 100us 等待 ADC 电路开始转换。

MOV A, #0FEh B0MOV P4UR, A ; 禁止 P4.0 上拉电阻。

B0BCLR FP40M ; 设置 P4.0 为输入模式。 MOV A, #01h

BOMOV P4CON, A ; 设置 P4.0 为模拟输入模式。

MOV A, #60H

B0MOV ADR, A ; 设置 12 位 ADC, ADC 时钟源 = Fosc。 MOV A.#90H

BOMOV ADM,A ; 允许 ADC 并设置 AINO 输入。 BOBSET FADS ; 开始转换。

WADC0:

 B0BTS1
 FEOC
 ;

 JMP
 WADC0
 ;

 B0MOV
 A,ADB
 ;

 B0MOV
 Adc\_Buf\_Hi, A

BOMOV A,ADR ;
AND A, 0Fh

B0MOV Adc\_Buf\_Low, A Power\_Down:

B0BCLR FCPUM1

BOBSET FCPUMO ; 进入睡眠模式。

## 9.8 ADC 电路



在 ADC 输入引脚接入 0.1uF 的电容可以滤除电源端的杂汛。



# 10<sub>2K/4K</sub> 蜂鸣器(Buzzer)输出

## 10.1概述

SN8P2722 内置蜂鸣器产生模块,输出频率为 2KHz 或 4KHz。通过 BZM 寄存器可以调整蜂鸣器的输出频率。蜂鸣器输出引脚与普通 I/O 引脚共用。当 BZEN=1 时,引脚输出蜂鸣器信号。当 BZEN=0 时,引脚返回上一个 I/O 状态(输入模式,输出高或输出低)。



蜂鸣器输出频率可由 Fcpu (指令周期) 分频获得,用户可通过蜂鸣器分频选择位 (BZrate) 设定。Fcpu 决定蜂鸣器的频率,频率选择列表如下:

| BZrate [1:0] | 蜂鸣器除频数                                | 蜂鸣器分频       |             |             |  |  |
|--------------|---------------------------------------|-------------|-------------|-------------|--|--|
| DZIALE [1.0] | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Fcpu = 1MHz | Fcpu = 2MHz | Fcpu = 4MHz |  |  |
| 00           | Fcpu/256                              | 4KHz        | 8KHz        | 16KHz       |  |  |
| 01           | Fcpu/512                              | 2KHz        | 4KHz        | 8KHz        |  |  |
| 10           | Fcpu/1024                             | 1KHz        | 2KHz        | 4KHz        |  |  |
| 11           | Fcpu/2048                             | 0.5KHz      | 1KHz        | 2KHz        |  |  |

为了获得蜂鸣器输出 2KHz 和 4KHz 的频率,需要选择合适的 Fcpu 分频数,可参考上表中所列 2KHz/4KHz 蜂鸣器输出。

## 10.2BZM 模式寄存器

| 0DCH | Bit 7 | Bit 6   | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|---------|---------|-------|-------|-------|-------|-------|
| BZM  | BZEN  | BZrate1 | BZrate0 | •     | ı     | -     | -     | -     |
| 读/写  | R/W   | R/W     | R/W     | -     | -     | -     | -     | -     |
| 复位后  | 0     | 0       | 0       | -     | -     | -     | -     | -     |

Bit 7 BZEN: 蜂鸣器输出控制位。

0 = 禁止蜂鸣器的输出功能,并将该引脚设置为普通的 I/O 引脚;

1 = 使能蜂鸣器的输出功能,并禁止该引脚的普通 I/O 功能。

Bit[6:5] **BZrate[1:0]**: 蜂鸣器分频选择位。

00 = Fcpu/256;

01 = Fcpu/512;

10 = Fcpu/1024;

11 = Fcpu/2048.

注:

- 1. 若 BZEN=1, P0.4 作为蜂鸣器输出引脚并关闭普通 I/O 功能。
- 2. 若 BZEN=0, P0.4 为普通 I/O 引脚,并在禁止 Buzzer 输出功能后将该引脚转换回上一个 I/O 模式。



# 11 指令表

| ##                                                                                                                                                                                                                                                                                                                                                                         | -<br>-<br>-<br>-<br>- |                  | <b>Z</b> √ - √                                   |          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|--------------------------------------------------|----------|
| M       MOV       M,A       M ← A         B       BOMOV       A,M       A ← M (bank 0)         V       BOMOV       M,A       M (bank 0) ← A         MOV       A,I       A ← I         BOMOV       M,I       M ← I, "M"只支持 80H~87H 之间的寄存器(如 PFLAG,R,Y,Z)         XCH       A,M       A ←→M         BOXCH       A,M       A ←→M (bank 0)         MOVC       R, A ← ROM [Y,Z] | -                     |                  | -<br>√                                           | 1 1 1    |
| O B0MOV A,M A ← M (bank 0)  B0MOV M,A M (bank 0) ← A  MOV A,I A ← I  B0MOV M,I M ← I, "M"只支持 80H~87H 之间的寄存器(如 PFLAG,R,Y,Z)  XCH A,M A ←→M  B0XCH A,M A ←→M (bank 0)  MOVC R, A ← ROM [Y,Z]                                                                                                                                                                                 | -                     | -<br>-<br>-      | + -                                              | 1        |
| V       B0MOV       M,A       M (bank 0) ← A         MOV       A,I       A ← I         B0MOV       M,I       M ← I, "M"只支持 80H~87H 之间的寄存器(如 PFLAG,R,Y,Z)         XCH       A,M       A ←→M         B0XCH       A,M       A ←→M (bank 0)         MOVC       R, A ← ROM [Y,Z]                                                                                                | -                     | -<br>-<br>-      | + -                                              | 1        |
| E MOV A,I A ← I B0MOV M,I M ← I, "M"只支持 80H~87H 之间的寄存器(如 PFLAG,R,Y,Z)  XCH A,M A ←→M B0XCH A,M A ←→M (bank 0)  MOVC R, A ← ROM [Y,Z]                                                                                                                                                                                                                                       | -                     | -                |                                                  |          |
| B0MOV       M,I       M ← I, "M"只支持 80H~87H 之间的寄存器 (如 PFLAG,R,Y,Z)         XCH       A,M       A ←→M         B0XCH       A,M       A ←→M (bank 0)         MOVC       R, A ← ROM [Y,Z]                                                                                                                                                                                      | -                     | <del>  -</del>   |                                                  |          |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                      |                       | _                | 1 -                                              | 1        |
| $\begin{array}{c cccc} BOXCH & A,M & A \longleftrightarrow M \text{ (bank 0)} \\ MOVC & R,A \leftarrow ROM \text{ [Y,Z]} \end{array}$                                                                                                                                                                                                                                      | -                     | <del>  -</del>   | -                                                | 1        |
| MOVC R, A $\leftarrow$ ROM [Y,Z]                                                                                                                                                                                                                                                                                                                                           |                       | <u> </u>         | -                                                | 1+N      |
| 1,,                                                                                                                                                                                                                                                                                                                                                                        | -                     | -                | -                                                | 1+N      |
| ■                                                                                                                                                                                                                                                                                                                                                                          | -                     | -                | -                                                | 2        |
| , it is an explorer megality of the plant of                                                                                                                                                                                                                                                                                                                               | V                     | √                | V                                                | 1        |
| A ADC M,A M ← A + M + C, 如果产生进位则 C=1, 否则 C=0                                                                                                                                                                                                                                                                                                                               | V                     | √                |                                                  | 1+N      |
| R ADD A,M A $\leftarrow$ A + M,如果产生进位则 C=1,否则 C=0                                                                                                                                                                                                                                                                                                                          | V                     | √                |                                                  | 1        |
| I ADD M,A M ← A + M, 如果产生进位则 C=1, 否则 C=0                                                                                                                                                                                                                                                                                                                                   | V                     |                  |                                                  | 1+N      |
| T B0ADD M,A M (bank 0) ← M (bank 0) + A, 如果产生进位则 C=1,否则 C=0                                                                                                                                                                                                                                                                                                                | √                     |                  |                                                  | 1+N      |
| H ADD A,I A ← A + I, 如果产生进位则 C=1, 否则 C=0                                                                                                                                                                                                                                                                                                                                   | √                     | √                |                                                  | 1        |
| M SBC A,M A ← A - M - /C,如果产生借位则 C=0,否则 C=1                                                                                                                                                                                                                                                                                                                                | √                     | <b>V</b>         |                                                  | 1        |
| E SBC M,A M ← A - M - /C, 如果产生借位则 C=0, 否则 C=1                                                                                                                                                                                                                                                                                                                              | √                     | √                | $\sqrt{}$                                        | 1+N      |
| T SUB A,M A ← A - M, 如果产生借位则 C=0, 否则 C=1                                                                                                                                                                                                                                                                                                                                   | V                     | √                | √                                                | 1        |
| I SUB M,A M ← A - M, 如果产生借位则 C=0, 否则 C=1                                                                                                                                                                                                                                                                                                                                   | \ \                   | V                | V                                                | 1+N      |
| C SUB A,I A ← A - I, 如果产生借位则 C=0, 否则 C=1                                                                                                                                                                                                                                                                                                                                   | ,                     | V                | V                                                | 1        |
| P A ∠ A * M                                                                                                                                                                                                                                                                                                                                                                | コ・ZF 标志位受 ACC 内       | Ť                |                                                  |          |
| MUL A,M 容影响                                                                                                                                                                                                                                                                                                                                                                |                       | -                | $\sqrt{}$                                        | 2        |
| AND A,M A $\leftarrow$ A and M                                                                                                                                                                                                                                                                                                                                             | -                     | +-               | √                                                | 1        |
| L AND M,A M ← A and M                                                                                                                                                                                                                                                                                                                                                      |                       | <del>  -</del>   | \<br>√                                           | 1+N      |
|                                                                                                                                                                                                                                                                                                                                                                            |                       | ÷                |                                                  | 1        |
|                                                                                                                                                                                                                                                                                                                                                                            |                       | +                | √                                                | 1        |
|                                                                                                                                                                                                                                                                                                                                                                            |                       | +                | √<br>./                                          | 1+N      |
|                                                                                                                                                                                                                                                                                                                                                                            | -                     | <u> </u>         | √<br>./                                          | 1+11     |
| 7 7. ( 7. 5. )                                                                                                                                                                                                                                                                                                                                                             |                       |                  | 1                                                |          |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                     | -                     | -                | √<br>./                                          | 1<br>1+N |
|                                                                                                                                                                                                                                                                                                                                                                            | -                     | -                | √<br>√                                           | 1+11     |
|                                                                                                                                                                                                                                                                                                                                                                            |                       | +                |                                                  |          |
| SWAP M A (b3~b0, b7~b4) ←M(b7~b4, b3~b0)                                                                                                                                                                                                                                                                                                                                   | -                     | -                | -                                                | 1        |
| P SWAPM M M(b3~b0, b7~b4) ← M(b7~b4, b3~b0)                                                                                                                                                                                                                                                                                                                                | -                     | +-               | -                                                | 1+N      |
| R RRC M A←RRC M                                                                                                                                                                                                                                                                                                                                                            | V                     | -                | -                                                | 1        |
| O RRCM M M←RRC M                                                                                                                                                                                                                                                                                                                                                           | V                     | -                | -                                                | 1+N      |
| C RLC M A←RLC M                                                                                                                                                                                                                                                                                                                                                            |                       | -                | -                                                | 1        |
| E RLCM M M ← RLC M                                                                                                                                                                                                                                                                                                                                                         | √                     | <u> </u>         | -                                                | 1+N      |
| S CLR M M←0                                                                                                                                                                                                                                                                                                                                                                | -                     | <u>↓</u> -       | -                                                | 1        |
| S BCLR M.b M.b ← 0                                                                                                                                                                                                                                                                                                                                                         | -                     | -                | -                                                | 1+N      |
| BSET M.b M.b ← 1                                                                                                                                                                                                                                                                                                                                                           | -                     | -                | -                                                | 1+N      |
| B0BCLR M.b M(bank 0).b ← 0                                                                                                                                                                                                                                                                                                                                                 | -                     | <u> </u>         | -                                                | 1+N      |
| B0BSET M.b M(bank 0).b ← 1                                                                                                                                                                                                                                                                                                                                                 | -                     | <u> </u>         | -                                                | 1+N      |
| CMPRS A,I ZF,C ← A - I, 如果 A = I,则跳过下一条指令                                                                                                                                                                                                                                                                                                                                  | √                     | -                | $\sqrt{}$                                        | 1 + S    |
| B CMPRS A,M $ZF,C \leftarrow A - M$ , 如果 $A = M$ ,则跳过下一条指令                                                                                                                                                                                                                                                                                                                 | √                     | -                |                                                  | 1 + S    |
| R INCS M A ← M + 1, 如果 A = 0,则跳过下一条指令                                                                                                                                                                                                                                                                                                                                      | -                     | -                | -                                                | 1+ S     |
| A INCMS M M $\leftarrow$ M + 1, 如果 M = 0,则跳过下一条指令                                                                                                                                                                                                                                                                                                                          | -                     | -                | -                                                | 1+N+S    |
| N DECS M A $\leftarrow$ M - 1, 如果 A = 0,则跳过下一条指令                                                                                                                                                                                                                                                                                                                           | -                     | -                | -                                                | 1+ S     |
| C DECMS M M ← M - 1, 如果 M = 0,则跳过下一条指令                                                                                                                                                                                                                                                                                                                                     | -                     | -                | _                                                | 1+N+S    |
| H BTS0 M.b 如果 M.b = 0, 则跳过下一条指令                                                                                                                                                                                                                                                                                                                                            | -                     | -                | _                                                | 1 + S    |
| BTS1 M.b 如果 M.b = 1, 则跳过下一条指令                                                                                                                                                                                                                                                                                                                                              | -                     | -                | +-+                                              | 1 + S    |
| B0BTS0 M.b 如果 M(bank 0).b = 0,则跳过下一条指令                                                                                                                                                                                                                                                                                                                                     |                       | ٠.               | <del>                                     </del> | 1 + S    |
| BOBTS1 M.b 如果 M(bank 0).b = 1,则跳过下一条指令                                                                                                                                                                                                                                                                                                                                     |                       | +-               | -                                                | 1+S      |
| DODIOI WIO   知本 WI(Dalik U).U = 1,则或过于 常钼マ                                                                                                                                                                                                                                                                                                                                 | -                     | -                | -                                                | 2        |
|                                                                                                                                                                                                                                                                                                                                                                            |                       | -                | -                                                | 2        |
| JMP d PC15/14 ← RomPages1/0, PC13~PC0 ← d                                                                                                                                                                                                                                                                                                                                  | l l                   | 1 -              | ∣                                                | ۷        |
| JMP         d         PC15/14 ← RomPages1/0, PC13~PC0 ← d           CALL         d         Stack ← PC15~PC0, PC15/14 ← RomPages1/0, PC13~PC0 ← d                                                                                                                                                                                                                           | -                     | +-               | $\overline{}$                                    |          |
|                                                                                                                                                                                                                                                                                                                                                                            | -                     | <u> </u>         | -                                                | 2        |
| JMP         d         PC15/14 ← RomPages1/0, PC13~PC0 ← d           CALL         d         Stack ← PC15~PC0, PC15/14 ← RomPages1/0, PC13~PC0 ← d           M         RET         PC ← Stack           I         RETI         PC ← Stack, 使能全局中断控制位                                                                                                                         |                       | -                | -                                                | 2        |
| JMP         d         PC15/14 ← RomPages1/0, PC13~PC0 ← d           CALL         d         Stack ← PC15~PC0, PC15/14 ← RomPages1/0, PC13~PC0 ← d           M         RET         PC ← Stack           I         RETI         PC ← Stack, 使能全局中断控制位           S         PUSH         进栈操作,保存 ACC 和 PFLAG (除 NT0, NPD 位)                                                     | -                     | -                | + +                                              |          |
| JMP         d         PC15/14 ← RomPages1/0, PC13~PC0 ← d           CALL         d         Stack ← PC15~PC0, PC15/14 ← RomPages1/0, PC13~PC0 ← d           M         RET         PC ← Stack           I         RETI         PC ← Stack, 使能全局中断控制位                                                                                                                         | -                     | -<br>-<br>-<br>- | + +                                              | 2        |

注: 1. "M"是系统寄存器或 RAM,若是系统寄存器,则 N = 0,否则 N = 1。

<sup>2.</sup> 若满足跳转条件, S = 1, 否则 S = 0。



# **12**电气特性

# 12.1极限参数

| Supply voltage (Vdd)                 | 0.3V ~ 6.0V  |
|--------------------------------------|--------------|
| Input in voltage (Vin)               |              |
| Operating ambient temperature (Topr) |              |
| SN8P2722P, SN8P2722S, SN8P2722X      | 0°C ~ + 70°C |
| SN8P2722PD, SN8P2722SD, SN8P2722XD   |              |
| Storage ambient temperature (Tstor)  |              |

# 12.2电气特性

(All of voltages refer to Vss, Vdd = 5.0V, fosc = 4MHz,fcpu=1MHZ,ambient temperature is 25°C unless otherwise note.)

| PARAMETER                                    | SYM.               | DESCI                                                     | RIPTION                                              | MIN.       | TYP.     | MAX.     | UNIT                 |
|----------------------------------------------|--------------------|-----------------------------------------------------------|------------------------------------------------------|------------|----------|----------|----------------------|
| Operating valtage                            | Vdd                | Normal mode, Vpp = Vdd, 2                                 | 25℃                                                  | 2.4        | 5.0      | 5.5      | V                    |
| Operating voltage                            | Vaa                | Normal mode, Vpp = Vdd, -                                 |                                                      | 2.5        | 5.0      | 5.5      | V                    |
| RAM Data Retention voltage                   | Vdr                |                                                           |                                                      | 1.5        | -        | -        | V                    |
| Vdd rise rate                                | Vpor               | Vdd rise rate to ensure inter                             | rnal power-on reset                                  | 0.05       | -        | -        | V/ms                 |
|                                              | ViL1               | All input ports                                           | •                                                    | Vss        | -        | 0.3Vdd   | V                    |
| Input Low Voltage                            | ViL2               | Reset pin                                                 |                                                      | Vss        | -        | 0.2Vdd   | V                    |
|                                              | ViL3               | P4 ADC shared pin                                         |                                                      | Vss        | -        | 0.5Vdd   | V                    |
|                                              | ViH1               | All input ports                                           |                                                      | 0.7Vdd     | -        | Vdd      | V                    |
| Input High Voltage                           | ViH2               | Reset pin                                                 |                                                      | 0.9Vdd     | -        | Vdd      | >                    |
|                                              | ViH3               | P4 ADC shared pin                                         |                                                      | 0.5Vdd     | -        | Vdd      | >                    |
| Reset pin leakage current                    | llekg              | Vin = Vdd                                                 |                                                      | -          | -        | 2        | uA                   |
| I/O port pull-up resistor                    | Rup                | Vin = Vss , Vdd = 3V                                      |                                                      | 100        | 200      | 300      | ΚΩ                   |
|                                              |                    | Vin = Vss , Vdd = 5V                                      |                                                      | 50         | 100      | 150      | 1722                 |
| I/O port input leakage current               | llekg              | Pull-up resistor disable, Vin                             | = Vdd                                                | -          | -        | 2        | uA                   |
| I/O output source current                    | IoH                | Vop = Vdd - 0.5V                                          |                                                      | 8          | 12       | -        | mA                   |
| sink current                                 | loL                | Vop = Vss + 0.5V                                          |                                                      | 8          | 15       | -        | 1117 (               |
| INTn trigger pulse width                     | Tint0              | INTO interrupt request pulse                              |                                                      | 2/fcpu     | -        | -        | cycle                |
|                                              | ldd1               | Run Mode                                                  | Vdd= 5V, 4Mhz                                        | -          | 2.5      | 5        | mA                   |
|                                              |                    | (No loading,Fcpu = Fosc/4)                                |                                                      | -          | 1        | 2        | mA                   |
|                                              |                    | Slow Mode                                                 | Vdd= 5V, 32Khz                                       | -          | 20       | 40       | uA                   |
|                                              | ldd2               | (Internal low RC, Stop high clock)                        | Vdd= 3V, 16Khz                                       | -          | 5        | 10       | uA                   |
| 0                                            |                    |                                                           | Vdd= 5V, 25°C                                        | -          | 0.8      | 1.6      | uA                   |
| Supply Current                               | ldd3               | Sleep Mode                                                | Vdd= 3V, 25°C                                        | -          | 0.7      | 1.4      | uA                   |
| (Disable ADC)                                | luus               | Sleep Mode                                                | Vdd= 5V, -40°C~ 85°C                                 | -          | 10       | 21       | uA                   |
|                                              |                    |                                                           | Vdd= 3V, -40°C~ 85°C                                 | -          | 10       | 21       | uA                   |
|                                              | ldd4               | One and Marks                                             | Vdd= 5V, 4Mhz                                        | -          | 0.6      | 1.2      | mA                   |
|                                              |                    | Green Mode<br>(No loading,Fcpu = Fosc/4                   | Vdd= 3V, 4Mhz                                        | -          | 0.25     | 0.5      | mA                   |
|                                              | 1004               | Watchdog Disable)                                         | Vdd=5V, ILRC 32Khz                                   | -          | 15       | 30       | uA                   |
|                                              |                    | Waterlady Disable)                                        | Vdd=3V, ILRC 16Khz,                                  | -          | 3        | 6        | uA                   |
| Internal High Oscillator Freq.               | Fihrc              | Internal Hihg RC (IHRC)                                   | 25°C,<br>Vdd= 5V,<br>Fcpu = 1MHz                     | 15.68      | 16       | 16.32    | Mhz                  |
|                                              |                    |                                                           | -40 ℃~85 ℃,<br>Vdd= 2.4V~5.5V,<br>Fcpu = 1MHz~16 MHz | 13         | 16       | 19       | Mhz                  |
|                                              | Vdet0              | Low voltage reset level.                                  |                                                      | 1.6        | 2.0      | 2.3      | V                    |
| LVD Voltage                                  | Vdet1              | Low voltage reset level. Fcp Low voltage indicator level. |                                                      | 2.0        | 2.3      | 3        | ٧                    |
|                                              | Vdet2              | Low voltage indicator level.                              |                                                      | 2.7        | 3.3      | 4.5      | ٧                    |
| AIN0 ~ AIN5 input voltage                    | Vani               | Vdd = 5.0V                                                |                                                      | 0          | -        | Vrefh1~5 | V                    |
| ADC enable time                              | Tast               | Ready to start convert after                              | set ADENB = "1"                                      | 100        | -        | -        | us                   |
| ADC current consumption                      | 1                  | Vdd=5.0V                                                  |                                                      | -          | 0.6      | -        | mA                   |
| ADO current consumption                      | I <sub>ADC</sub>   | Vdd=3.0V                                                  |                                                      | -          | 0.4      | -        | mA                   |
| ADC Clock Frequency                          | F <sub>ADCLK</sub> | VDD=5.0V                                                  |                                                      | 32K<br>32K |          | 8M<br>5M | Hz<br>Hz             |
| ADC Conversion Cycle Time                    | F <sub>ADCYL</sub> | VDD=3.0V<br>VDD=2.4V~5.5V                                 |                                                      | 64         |          | JIVI     | 1/F <sub>ADCLK</sub> |
| ADC Conversion Cycle Time  ADC Sampling Rate |                    | VDD=2.4V~5.5V<br>VDD=5.0V                                 |                                                      | 04         |          | 125      | K/sec                |
| (Set FADS=1 Frequency)                       | $F_{ADSMP}$        | VDD=3.0V<br>VDD=3.0V                                      |                                                      |            |          | 80       | K/sec<br>K/sec       |
| Differential Nonlinearity                    | DNL                | VDD=5.0V , AVREFH=3.2V                                    | / F =7.8K                                            | ±1         | ±2       | ±16      | LSB                  |
| Integral Nonlinearity                        | INL                | VDD=5.0V , AVREFH=3.2V                                    |                                                      | ±1         | ±2<br>±4 | ±16      | LSB                  |
| No Missing Code                              | NMC                | VDD=5.0V , AVREFH=3.2V                                    |                                                      | 8          | 10       | 12       | Bits                 |
| INO IVIIOSITIY COUC                          | INIVIC             | 1 2 2 2 2 3 3 4 4 1 1 1 3 2 V                             | , I ADSMP - I.OIL                                    | U          | 10       | 14       | סווט                 |

<sup>\*</sup>These parameters are for design reference, not tested.



### ► Internal 16MHz Oscillator RC Type Temperature Characteristic.

Power Voltage (VDD) = 5V.

Machine Cycle (Fcpu) = Fhosc/4.

Typical Temperature = 25°C.

Typical Internal 16MHz Oscillator RC Type Frequency = 16MHz.

Testing Temperature Range = −40°C ~ + 90°C



### > Internal 16MHz Oscillator RC Type Power Voltage and Machine Cycle Characteristic.

Temperature = 25°C.

Typical Power Voltage (VDD) = 5V.

Typical Machin Cycle (Fcpu) = Fhosc / 4.

Typical Internal 16MHz Oscillator RC Type Frequency = 16MHz.

Testing Power Voltage Range (VDD) = 3V~5.5V.

Testing Machine Cycle Range (Fcpu) = Fhosc/1~Fhosc/16.





# **13**SN8P2722 开发工具

SONIX 提供适用于 SN8P2722 开发的在线仿真器(ICE),集成开发环境(IDE)和 EV-kit 来仿真它的全部功能。在 线仿真器和 EV-kit 为外部器件,集成开发环境用户界面友好,可用于调试和仿真,开发工具版本如下所示:

- ICE: SN8ICE2K:
- EV-kit: SN8P2722 EV-kit Rev. A;
- IDE: SONIX IDE M2IDE V115 (简体版);
- Writer: MPIII 烧录器。

### 13.1SN8P2722 EV-kit

SN8P2722 EV-kit 包括在线仿真器(ICE)接口,可编程 I/O(GPIO)接口和蜂鸣器(Buzzer)模块。

● 蜂鸣器模块:仿真 2KHz/4KHz 的蜂鸣器输出功能。

SN8P2722 EV-kit 原理图如下:



SN8P2722 V3 Transition Board WRxxxx SN8P2722 EV Kit REV:A

- CON1、JP3: ICE 接口与 SN8ICE2K 相连接。
- U4: SN8P2722 DIP 形式接口与用户目标板相连接。
- CON2: 可编程 I/O 引脚接口。
- JP2:与 MPIII 烧录器连接的烧录接口。
- S1: LVD24 与 LVD36 仿真开关。
- BZ1: 蜂鸣器模块。



# 13.2在线仿真器(ICE)和 EV-KIT 应用注意事项

SN8P2722 蜂鸣器输出引脚与 P0.4 可编程 I/O 引脚共用。在仿真环境下,P0.4 的 I/O 功能模块没有与蜂鸣器输出模块相连接。蜂鸣器输出功能需要用 SN8P2722 EV-kit 来完成。

- SN8P2722 EV-kit 上具有蜂鸣器输出模块, EV-kit 的 P0.4 引脚不输出蜂鸣器信号。
- P0.4 的 I/O 功能来自 SN8P2722-EV-kit 上 I/O 输出模块。



# **14**OTP 烧录信息

# 14.1烧录转接板信息



注 1: JP1 连接 MP 烧录转接板, JP3 连接 OTP MCU。

注 2: JP2 连接外部烧录转接板。当 OTP MCU 的 PIN 超过 48PIN,或者烧录 Dice MCU 时,请采用外部烧录转接板,连接到 JP2 进行烧录。

下面两个图演示了如何焊接烧录转接板。



图 2





注:

- 1、印有IC型号的这一面为转接板的正面。
- 2、180 度的母座必须焊接在 MP 转接板的背面。请参考图 2 和图 3。



图 4 MP 转接板 (连接到 JP1&JP3)

| JP3 | (连接 | 48-pin | text | tool) |
|-----|-----|--------|------|-------|
|-----|-----|--------|------|-------|

| DIP 1 | 1  | 48 | DIP48 |
|-------|----|----|-------|
| DIP 2 | 2  | 47 | DIP47 |
| DIP 3 | 3  | 46 | DIP46 |
| DIP 4 | 4  | 45 | DIP45 |
| DIP 5 | 5  | 44 | DIP44 |
| DIP 6 | 6  | 43 | DIP43 |
| DIP 7 | 7  | 42 | DIP42 |
| DIP 8 | 8  | 41 | DIP41 |
| DIP 9 | 9  | 40 | DIP40 |
| DIP10 | 10 | 39 | DIP39 |
| DIP11 | 11 | 38 | DIP38 |
| DIP12 | 12 | 37 | DIP37 |
| DIP13 | 13 | 36 | DIP36 |
| DIP14 | 14 | 35 | DIP35 |
| DIP15 | 15 | 34 | DIP34 |
| DIP16 | 16 | 33 | DIP33 |
| DIP17 | 17 | 32 | DIP32 |
| DIP18 | 18 | 31 | DIP31 |
| DIP19 | 19 | 30 | DIP30 |
| DIP20 | 20 | 29 | DIP29 |
| DIP21 | 21 | 28 | DIP28 |
| DIP22 | 22 | 27 | DIP27 |
| DIP23 | 23 | 26 | DIP26 |
| DIP24 | 24 | 25 | DIP25 |

### JP1/JP2

| <u>JF 1/JFZ</u> |    |    |             |  |  |  |  |
|-----------------|----|----|-------------|--|--|--|--|
| VDD             | 1  | 2  | VSS         |  |  |  |  |
| CLK/PGCLK       | 3  | 4  | CE          |  |  |  |  |
| PGM/OTPCLK      | 5  | 6  | OE/ShiftDat |  |  |  |  |
| D1              | 7  | 8  | D0          |  |  |  |  |
| D3              | 9  | 10 | D2          |  |  |  |  |
| D5              | 11 | 12 | D4          |  |  |  |  |
| D7              | 13 | 14 | D6          |  |  |  |  |
| VDD             | 15 | 16 | VPP         |  |  |  |  |
| HLS             | 17 | 18 | RST         |  |  |  |  |
| -               | 19 | 20 | ALSB/PDB    |  |  |  |  |

JP1 连接 MP 烧录转接板 JP2 连接外部转接板



# 14.2烧录引脚信息

|                       | SN8P2722 烧录信息       |               |                |                   |  |  |  |  |
|-----------------------|---------------------|---------------|----------------|-------------------|--|--|--|--|
| 名科                    | Κ                   | SN8P2722P,S,X |                |                   |  |  |  |  |
| MPIII W               | /riter              |               |                | OTP IC / JP3 引脚分布 |  |  |  |  |
| JP1/JP2 Pin<br>Number | JP1/JP2<br>Pin Name | IC Pin Number | IC Pin<br>Name | JP3 Pin Number    |  |  |  |  |
| 1                     | VDD                 | 20            | VDD            | 34                |  |  |  |  |
| 2                     | GND                 | 1             | VSS            | 15                |  |  |  |  |
| 3                     | CLK                 | 8             | P0.7           | 22                |  |  |  |  |
| 4                     | CE                  |               | ı              | -                 |  |  |  |  |
| 5                     | PGM                 | 7             | P0.6           | 21                |  |  |  |  |
| 6                     | OE                  | 6             | P0.5           | 20                |  |  |  |  |
| 7                     | D1                  |               | ı              | -                 |  |  |  |  |
| 8                     | D0                  |               | ı              | -                 |  |  |  |  |
| 9                     | D3                  |               | ı              | -                 |  |  |  |  |
| 10                    | D2                  |               | -              | •                 |  |  |  |  |
| 11                    | D5                  |               | ı              | •                 |  |  |  |  |
| 12                    | D4                  |               | 1              | -                 |  |  |  |  |
| 13                    | D7                  |               | 1              | -                 |  |  |  |  |
| 14                    | D6                  |               | -              | -                 |  |  |  |  |
| 15                    | VDD                 | 20            | VDD            | 34                |  |  |  |  |
| 16                    | VPP                 | 4             | RST            | 18                |  |  |  |  |
| 17                    | HLS                 |               | -              | -                 |  |  |  |  |
| 18                    | RST                 |               | -              | -                 |  |  |  |  |
| 19                    | -                   |               | -              | -                 |  |  |  |  |
| 20                    | ALSB/PDB            | 3             | P0.2           | 17                |  |  |  |  |



# 15芯片正印命名规则

## 15.1 概述

SONiX 8 位单片机产品具有多种型号,本章将给出所有 8 位单片机分类命名规则,适用于空片 OTP 型单片机。

## 15.2芯片型号说明





## 15.3命名举例

| 名称          | ROM 类型 | 器件(Device) | 封装形式  | 温度范围     | 材料                    |
|-------------|--------|------------|-------|----------|-----------------------|
| SN8P2722PB  | OTP    | 2722       | P-DIP | 0℃~70℃   | 无铅封装(PB-Free Package) |
| SN8P2722SB  | OTP    | 2722       | SOP   | 0℃~70℃   | 无铅封装(PB-Free Package) |
| SN8P2722XB  | OTP    | 2722       | SSOP  | 0℃~70℃   | 无铅封装(PB-Free Package) |
| SN8P2722PG  | OTP    | 2722       | P-DIP | 0℃~70℃   | 绿色封装(Green Package)   |
| SN8P2722SG  | OTP    | 2722       | SOP   | 0℃~70℃   | 绿色封装(Green Package)   |
| SN8P2722XG  | OTP    | 2722       | SSOP  | 0℃~70℃   | 绿色封装(Green Package)   |
| SN8P2722PDB | OTP    | 2722       | P-DIP | -40℃~85℃ | 无铅封装(PB-Free Package) |
| SN8P2722SDB | OTP    | 2722       | SOP   | -40℃~85℃ | 无铅封装(PB-Free Package) |
| SN8P2722XDB | OTP    | 2722       | SSOP  | -40℃~85℃ | 无铅封装(PB-Free Package) |
| SN8P2722PDG | OTP    | 2722       | P-DIP | -40℃~85℃ | 绿色封装(Green Package)   |
| SN8P2722SDG | OTP    | 2722       | SOP   | -40℃~85℃ | 绿色封装(Green Package)   |
| SN8P2722XDG | OTP    | 2722       | SSOP  | -40℃~85℃ | 绿色封装(Green Package)   |

# 15.4日期码规则





# 16封装信息

## 16.1P-DIP 20 PIN





| SYMBOLS  | MIN        | NOR    | MAX   | MIN        | NOR    | MAX    |
|----------|------------|--------|-------|------------|--------|--------|
| STWIDULS |            | (inch) |       |            | (mm)   |        |
| Α        | -          | -      | 0.210 | -          | -      | 5.334  |
| A1       | 0.015      | -      | -     | 0.381      | -      | -      |
| A2       | 0.125      | 0.130  | 0.135 | 3.175      | 3.302  | 3.429  |
| D        | 0.980      | 1.030  | 1.060 | 24.892     | 26.162 | 26.924 |
| E        |            | 0.300  |       |            | 7.620  |        |
| E1       | 0.245      | 0.250  | 0.255 | 6.223      | 6.350  | 6.477  |
| L        | 0.115      | 0.130  | 0.150 | 2.921      | 3.302  | 3.810  |
| e B      | 0.335      | 0.355  | 0.375 | 8.509      | 9.017  | 9.525  |
| θ°       | <b>0</b> ° | 7°     | 15°   | <b>0</b> ° | 7°     | 15°    |



## 16.2SOP 20 PIN



| SYMBOLS    | MIN        | NOR        | MAX   | MIN        | NOR        | MAX    |
|------------|------------|------------|-------|------------|------------|--------|
| 3 I WIBULS | ·          | (inch)     | ·     |            | (mm)       | ·      |
| Α          | 0.093      | 0.099      | 0.104 | 2.362      | 2.502      | 2.642  |
| A1         | 0.004      | 0.008      | 0.012 | 0.102      | 0.203      | 0.305  |
| D          | 0.496      | 0.502      | 0.508 | 12.598     | 12.751     | 12.903 |
| E          | 0.291      | 0.295      | 0.299 | 7.391      | 7.493      | 7.595  |
| Н          | 0.394      | 0.407      | 0.419 | 10.008     | 10.325     | 10.643 |
| L          | 0.016      | 0.033      | 0.050 | 0.406      | 0.838      | 1.270  |
| θ°         | <b>0</b> ° | <b>4</b> ° | 8°    | <b>0</b> ° | <b>4</b> ° | 8°     |



## **16.3SSOP 20 PIN**



| SYMBOLS | MIN        | NOR   | MAX   | MIN        | NOR   | MAX   |
|---------|------------|-------|-------|------------|-------|-------|
|         | (inch)     |       |       | (mm)       |       |       |
| Α       | 0.053      | 0.063 | 0.069 | 1.350      | 1.600 | 1.750 |
| A1      | 0.004      | 0.006 | 0.010 | 0.100      | 0.150 | 0.250 |
| A2      | -          | -     | 0.059 | -          | -     | 1.500 |
| b       | 0.008      | 0.010 | 0.012 | 0.200      | 0.254 | 0.300 |
| С       | 0.007      | 0.008 | 0.010 | 0.180      | 0.203 | 0.250 |
| D       | 0.337      | 0.341 | 0.344 | 8.560      | 8.660 | 8.740 |
| E       | 0.228      | 0.236 | 0.244 | 5.800      | 6.000 | 6.200 |
| E1      | 0.150      | 0.154 | 0.157 | 3.800      | 3.900 | 4.000 |
| [e]     | 0.025      |       |       | 0.635      |       |       |
| h       | 0.010      | 0.017 | 0.020 | 0.250      | 0.420 | 0.500 |
| L       | 0.016      | 0.025 | 0.050 | 0.400      | 0.635 | 1.270 |
| L1      | 0.039      | 0.041 | 0.043 | 1.000      | 1.050 | 1.100 |
| ZD      | 0.059      |       |       | 1.500      |       |       |
| Y       | -          | -     | 0.004 | -          | -     | 0.100 |
| θ°      | <b>0</b> ° | -     | 8°    | <b>0</b> ° | -     | 8°    |



SONiX 公司保留对以下所有产品在可靠性,功能和设计方面的改进作进一步说明的权利。 SONiX 不承担由本手册所涉及的产品或电路的运用和使用所引起的任何责任,SONiX 的产品不 是专门设计来应用于外科植入、生命维持和任何 SONiX 产品的故障会对个体造成伤害甚至死亡 的领域。如果将 SONiX 的产品应用于上述领域,即使这些是由 SONiX 在产品设计和制造上的 疏忽引起的,用户应赔偿所有费用、损失、合理的人身伤害或死亡所直接或间接产生的律师费 用,并且用户保证 SONiX 及其雇员、子公司、分支机构和销售商与上述事宜无关。

#### 总公司:

地址:台湾新竹县竹北市台元街 36 号 10 楼之一

电话: 886-3-5600-888 传真: 886-3-5600-889

### 台北办事处:

地址: 台北市松德路 171 号 15 楼之 2

电话: 886-2-2759 1980 传真: 886-2-2759 8180

### 香港办事处:

地址:香港新界沙田沙田乡宁会路 138 # 新城市中央广场第一座 7 楼 705 室

电话: 852-2723 8086 传真: 852-2723 9179

#### 松翰科技 (深圳) 有限公司

地址:深圳市南山区高新技术产业园南区 T2-B 栋 2 层

电话: 86-755-2671 9666 传真: 86-755-2671 9786

### 技术支持:

Sn8fae@SONiX.com.tw