

# MC32F7062B 用户手册

# 基于 RISC 内核的 8 位精简指令集微控制器

Rev.1.0.2

本资料内容为晟矽微电子(以下简称"我公司")版权所有。

我公司将力求本资料的内容做到准确无误,但同时保留在不通知用户的情况下,对本资料内容的修改权。如您需要获得最新的资料,请及时联系我公司。

我公司将尽最大努力为您提供高品质、高稳定性的产品。尽管如此,由于一般半导体器件的电气敏感性及易受到外部物理损伤等固有特性存在,所以难免造成半导体器件出现故障或失效的可能。当您使用我公司产品时,有责任按照本资料以及相关资料中提到的"规则"来设计一个稳定及安全可靠的系统环境。另外,在遇到超规格(本资料中未描述到内容)的使用,请您提前咨询我公司,以免因我公司产品在一些特殊设备中或者特殊环境下的使用,导致财产损失、人员伤亡等严重后果的发生。因超规格的使用、未经咨询授权我公司产品的使用,我公司对此不承担任何法律责任。



# 目录

| 1 | 产品概    | 要           | 4        |
|---|--------|-------------|----------|
|   | 1.1    | 产品特性        | 4        |
|   | 1.2    | 系统框图        | 7        |
|   | 1.3    | 订购信息        | 7        |
|   | 1.4    | 引脚排列        | 8        |
|   | 1.5    | 端口说明        | <u>9</u> |
| 2 | 电气特    | 性           | 11       |
|   | 2.1    | 极限参数        | 11       |
|   | 2.2    | 直流电气特性      | 11       |
|   | 2.3    | 交流电气特性      | 12       |
|   | 2.4    | ADC 特性参数    | 12       |
|   | 2.5    | CMP 特性参数    | 13       |
|   | 2.6    | EEPROM 特性参数 | 13       |
| 3 | CPU 与  | 存储器         | 15       |
|   | 3.1    | 指令集         | 15       |
|   | 3.2    | 程序存储器       | 17       |
|   | 3.3    | 数据存储器       | 18       |
|   | 3.4    | 堆栈          |          |
|   | 3.5    | 控制寄存器       | 19       |
|   | 3.6    | 用户配置字       | 23       |
| 4 | 系统时等   | 钟           | 24       |
|   | 4.1    | 内部高频 RC 振荡器 | 24       |
|   | 4.2    | 内部低频 RC 振荡器 | 24       |
|   | 4.3    | 系统工作模式      | 24       |
|   | 4.4    | 低功耗模式       |          |
| 5 | 复位     |             | 27       |
|   | 5.1    | 复位条件        | 27       |
|   | 5.2    | 上电复位        |          |
|   | 5.3    | 外部复位        | 27       |
|   | 5.4    | 低电压复位       | 27       |
|   | 5.5    | 看门狗复位       | 28       |
| 6 | I/O 端口 | ]           | 29       |
|   | 6.1    | 通用 I/O 功能   | 29       |
|   | 6.2    | 内部上/下拉电阻    | 30       |
|   | 6.3    | 端口模式控制      |          |
| 7 |        | TIMER       |          |
|   | 7.1    | 看门狗定时器 WDT  |          |
|   | 7.2    | 定时器 T0      |          |
|   |        |             |          |



|    | 7.3   | 定时器 T1       | 35 |
|----|-------|--------------|----|
|    | 7.4   | 定时器 T2       | 38 |
|    | 7.5   | 定时器 T3       | 41 |
| 8  | 模数转   | 换器 ADC       | 46 |
|    | 8.1   | ADC 概述       | 46 |
|    | 8.2   | ADC 相关寄存器    | 46 |
|    | 8.3   | ADC 操作步骤     | 50 |
|    | 8.4   | ADC 零点偏移修调流程 | 50 |
| 9  | 模拟比   | 较器 CMP       | 51 |
|    | 9.1   | CMP 概述       | 51 |
|    | 9.2   | CMP 相关寄存器    | 51 |
|    | 9.3   | CMP 失调电压调校流程 | 53 |
| 10 | 低电压   | 检测 LVD       | 54 |
| 11 | EEPRO | M 存储器        | 55 |
|    | 11.1  | EEPROM 概述    | 55 |
|    | 11.2  | EEPROM 相关寄存器 |    |
|    | 11.3  | EEPROM 操作示例  | 56 |
| 12 | FLASH | 烧录编程         | 58 |
|    | 12.1  | FLASH 在板编程   | 58 |
| 13 | 中断    |              | 60 |
|    | 13.1  | 外部中断         | 60 |
|    | 13.2  | 定时器中断        | 60 |
|    | 13.3  | T1 捕捉中断      | 60 |
|    | 13.4  | 键盘中断         | 60 |
|    | 13.5  | ADC 中断       | 61 |
|    | 13.6  | CMP 中断       | 61 |
|    | 13.7  | LVD 中断       | 61 |
|    | 13.8  | 中断相关寄存器      | 62 |
| 14 | 特性曲:  | 线            | 65 |
|    | 14.1  | I/O 特性       | 65 |
|    | 14.2  | 功耗特性         | 67 |
|    | 14.3  | 模拟电路特性       | 70 |
| 15 | 封装尺   | 寸            | 76 |
|    | 15.1  | SOP20        | 76 |
|    | 15.2  | DIP20        | 76 |
|    | 15.3  | TSSOP20      | 77 |
|    | 15.4  | SOP16        | 77 |
|    | 15.5  | SOP8         | 78 |
| 16 | 修订记   | 录            | 79 |
|    |       |              |    |



# 1 产品概要

#### 1.1 产品特性

- 8 位 CPU 内核
  - ◇ 精简指令集,8级深度硬件堆栈
  - ◇ CPU 为双时钟,可在系统高/低频时钟之间切换
  - ◆ 系统高频时钟下 FCPU 可配置为 FHOSC 的 2/4/8/16/32/64 分频
  - ◆ 系统低频时钟下 FCPU 固定为 FLOSC 的 2 分频

#### ■ 程序存储器

- ♦ 4K×16 位 FLASH 型程序存储器,可通过间接寻址读取程序存储器内容
- ◆ 支持在板带电烧录编程,擦写次数至少1万次

#### ■ 数据存储器

- ◆ 256 字节 SRAM 型通用数据存储器,支持直接寻址、间接寻址等多种寻址方式
- ◆ 128 字节 EEPROM 型数据存储器,支持单独烧录和软件读写,擦写次数至少1万次

#### ■ 3组共18个I/O

- ♦ P0 (P00~P07), P1 (P10~P17), P2 (P20~P21)
- ◇ 所有端口均支持施密特输入,均支持推挽输出
- ◆ P17 可复用为外部复位 RST 输入
- ◇ 所有端口均内置上拉和下拉电阻,均可单独使能
- ◆ P20/P21 可复用为外部中断输入,支持外部中断唤醒功能
- ◇ 所有端口均支持键盘中断唤醒功能,并可单独使能

#### ■ 系统时钟源

- ◆ 内置高频 RC 振荡器(32MHz),可用作系统高频时钟源
- ◇ 内置低频 RC 振荡器(32KHz),可用作系统低频时钟源

#### ■ 系统工作模式

- 令 高速模式: CPU 在高频时钟下运行,低频时钟源工作
- ◆ 低速模式: CPU 在低频时钟下运行,高频时钟源可选停止或工作
- ◆ HOLD 模式(低功耗模式):CPU 暂停,高频时钟源停止,低频时钟源工作
- ◆ 休眠模式 (低功耗模式): CPU 暂停, 高/低频时钟源均停止

#### ■ 内部自振式看门狗计数器(WDT)

- ♦ 溢出时间可配置: 16ms/64ms/256ms/1024ms
- ◇ 工作模式可配置:始终开启、始终关闭、低功耗模式下关闭

#### ■ 4个定时器

- ◆ 8 位定时器 T0,可实现外部计数和 BUZ 功能
- ◆ 16 位定时器 T1,可实现外部计数、BUZ 和内/外部信号输入捕捉功能
- ◆ 8 位定时器 T2, 可实现 PWM 功能
- ◆ 8 位定时器 T3,可实现 3 路共周期独立占空比的 PWM 功能
- 1 个 12 位高精度 SAR 型 ADC
  - ♦ 14 路外部通道: ANO~AN13; 2 路内部通道: GND、VDD



- ◆ 参考电压可选: VDD、内部参考电压 VIR(2V)
- ◆ ADC 时钟: FCPU 的 2/4/8/16 分频
- ◇ 支持零点校准
- 1 个模拟比较器 CMP(负端输入增加 1、1/2 分压)
  - ◆ 输入共模 0~(VDD-1.4V),支持失调电压自消除调校(调校精度±2mV),输出无回滞且支持去抖处理
  - ◆ 正端输入可选择外部输入电压、或 VDD 内部分压电压
  - ◇ 负端输入可选择外部输入电压
  - ◆ 输出端电平可选择上升沿或下降沿触发中断,可从端口输出且支持输出取反

#### ■ 中断

- ◆ 外部中断(INTO~INT1),键盘中断(所有 IO)
- ◇ 定时器中断 (T0~T3), T1 捕捉中断
- ◇ ADC 中断,CMP 中断,LVD 中断(支持唤醒)
- 低电压检测 LVD
  - ♦ 2.0V/2.2V/2.4V/2.6V/2.8V/3.2V/3.6V/4.0V
- 低电压复位 LVR
- 工作电压(@HIRC)
  - $\diamond$  VLVR24 ~ 5.5V @ Fcpu = 0~8MHz
  - $\Rightarrow$  VLVR20 ~ 5.5V @ Fcpu = 0~4MHz
  - $\diamond$  VLVR18 ~ 5.5V @ Fcpu = 0~2MHz
- 封装形式
  - ♦ SOP20/DIP20/TSSOP20/SOP16/SOP8

| :    | 模块/功能                                                  | MC32F7062                     | MC32F7062B                                                          |
|------|--------------------------------------------------------|-------------------------------|---------------------------------------------------------------------|
| Core | cpu 最高主频 16M 主频时钟 高频时钟源分频,由用户配置字控制 re 系统时钟源选择,由用户配置字控制 |                               | cpu 最高主频 <mark>8M</mark><br>高频时钟源分频,由用户配置字控制<br>系统时钟源选择固定 HIRC+LIRC |
|      | 内核&指令集                                                 | 精简指令集,8级深度硬件堆栈                | 相同                                                                  |
|      | ROM                                                    | 4Kx16                         | 相同                                                                  |
| 存储器  | SRAM                                                   | 256                           | 相同                                                                  |
|      | EEPROM                                                 | 256,烧写次数 10w                  | 128 ,烧写次数 1w                                                        |
|      | HIRC                                                   | HIRC 32M/2M                   | HIRC 32M                                                            |
|      | TillC                                                  | 支持软件微调                        | 不支持软件微调                                                             |
| 时钟源  | LIRC                                                   | LIRC 32KHz                    | 相同                                                                  |
|      | EXT                                                    | HOSC 455K/4M~16M              | 不支持                                                                 |
|      | LXT                                                    | LOSC 32.768KHz                | 11.810                                                              |
| 复位   | 复位                                                     | POR/LVR/RST/WDT               | 相同                                                                  |
| 友世   | LVR 电压                                                 | 1.8V/2.0V/2.4V/2.7V/3.0V/3.2V | 相同                                                                  |

*晟矽微电* 5/79



| <b>1</b> | 莫块/功能          | MC32F7062                   | MC32F7062B                            |
|----------|----------------|-----------------------------|---------------------------------------|
|          | 数量             | 18                          | 相同                                    |
|          | 模式             | 4 种(高速/低速/HOLD/STOP)        | 相同                                    |
| I/O      | 上/下拉           | 全上拉/全下拉                     | 相同                                    |
|          | 键盘中断           | P1 端口                       | 所有端口                                  |
|          | 外部中断           | INTO/1                      | 相同                                    |
|          | 8 位 T0         | 支持外部计数+BUZ                  | 相同                                    |
|          | 16 位 T1        | 支持外部计数+BUZ+内/外信号捕捉          | 相同                                    |
|          | 8 位 T2         | 支持 1 对 8+3 模式的带死区互补 PWM     | 支持1路PWM                               |
| 定时器      |                | 3 路共周期独立占空比的 PWM            |                                       |
|          | 8 位 T3         | 1路可扩展为1对8+3模式的带死区互          | 支持 3 路共周期独立占空比的 PWM, 1                |
|          | 0 <u>14</u> 13 | 补 PWM,可从 3 组端口输出            | 路支持2个端口输出                             |
|          |                | 支持 CMP 刹车输出保护               |                                       |
|          | 输入通道           | 14 路外部通道:AN0~AN13           | 相同                                    |
| -        |                | 2 路内部通道: GND、VDD/4          |                                       |
| ADC      | 参考电压           | VDD、内部参考电压 VIR(2V/3V/4V)、   | VDD、内部参考电压 VIR(2V)                    |
| -        |                | 外部参考电压 VER(VERI 输入)         |                                       |
|          | 其他             |                             | ADC 支持内部增益 1/1、3/4、1/2、1/4            |
| -        | 外设数量           | 1路 (CMP0)                   | 1路(CMP0)                              |
|          | 正反相输入通道        | 4 路正相输入: CMPN0~ CMPN 3      | 正相输入支持 1/2 分压,其余相同                    |
|          |                | 3 路反向输入:GND/VDD 分压/CMPP     |                                       |
| 模拟比较器    | 输入共模电压         | 0 ~ (VDD-1.4V)              | 相同                                    |
|          | 失调和回滞          | 支持失调电压自消除调校(调校精度            | 相同                                    |
|          |                | ±2mV),输出无回滞且支持去抖处理          |                                       |
|          | PWM 刹车         | 支持 T3 输出保护                  | 不支持                                   |
|          | 外设数量           | 1 (OPA0)                    | 不支持                                   |
|          |                | 1 路反向输入: OPAN               |                                       |
| 运算放大器    | 正反向输入通道        | 4 路正向输入: OPAP/GND/OPAPR/VDD | -                                     |
|          |                | 分压                          |                                       |
| -        | 内部放大增益         | -                           | -                                     |
|          | 输出通道           | 1路: OPAO                    | -                                     |
| ı        | LVD            | 支持                          | 相同                                    |
| 通讯       | -              | 不支持                         | 不支持                                   |
|          | EEPROM 编程      | EEPROM 支持片上 IAP 编程          | 相同                                    |
| 其他       |                | EEPROM 读/写操作时,CPU 不暂停工作     | EEPROM 读/写操作时,CPU 将 <mark>暂停工作</mark> |
|          | 带电烧录           | 支持                          | 支持,增加烧写口配置寄存器                         |

*晟矽微电* 6/79



| 模块/功能     | MC32F7062           | MC32F7062B          |
|-----------|---------------------|---------------------|
|           | 上下拉电阻: 16k          | 上下拉电阻: 13.5k        |
|           | Istop 功耗@LVR 开:11uA | Istop 功耗@LVR 开:37uA |
| 电气特性      | CMP 响应时间 2us(max)   | CMP 响应时间 2us(tpy)   |
|           | ADC 最低工作电压: 2.7v    | ADC 最低工作电压:2.5v     |
|           | EEPROM 单地址写入时间:5ms  | EEPROM 单地址写入时间:8ms  |
| 工作温度      | -40°C~85°C          | -40°C~85°C          |
| 2 线烧写/仿真口 | 2组                  | 2组                  |

### 1.2 系统框图



# 1.3 订购信息

| 产品名称         | 村<br>生<br>江<br>本<br>柱 | 各注 |
|--------------|-----------------------|----|
| / HH-11-1/0° | エコイベハノエい              | 田江 |

*晟矽微电* 7/79



| MC32F7062B0M | SOP20   |  |
|--------------|---------|--|
| MC32F7062B0E | DIP20   |  |
| MC32F7062B0Y | TSSOP20 |  |
| MC32F7062B0K | SOP16   |  |
| MC32F7062B2K | SOP16   |  |
| MC32F7062B0H | SOP8    |  |

### 1.4 引脚排列

MC32F7062B0M/B0E/B0Y



SOP20/DIP20/TSSOP20

MC32F7062B0K



*晟矽微电* 8/79



#### MC32F7062B2K





注: 若封装中有引脚为多个 I/O 端口共用,则应用时需确保共用引脚的端口在工作模式、内部上/下拉电阻、复用功 能、数模端口等设置上相互之间不会产生冲突。

#### 1.5 端口说明

| 端口名称        | 类型 | 功能说明                |
|-------------|----|---------------------|
| VDD         | Р  | 电源                  |
| GND         | Р  | 地                   |
| P0, P1, P2  | D  | GPIO(推挽输出),内部上/下拉   |
| INT0~INT1   | DI | 外部中断输入              |
| TC0~TC1     | DI | 定时器 T0~T1 的外部计数输入   |
| BUZ0        | DO | 定时器 T0 的 BUZ 输出     |
| BUZ1        | DO | 定时器 T1 的 BUZ 输出     |
| PWM2        | DO | 定时器 T2 的 PWM 输出     |
| PWM3A~PWM3C | DO | 定时器 T3 的 3 路 PWM 输出 |
| AN0~AN13    | Al | ADC 外部输入通道          |
| CMPP        | Al | CMP 正端外部输入          |
| CMPN0~CMPN3 | Al | CMP 负端外部输入通道        |
| СМРО        | DO | CMP 输出              |
| RST         | DI | 外部复位输入              |

晟矽微电 9/79



MC32F7062B 产品概要

| PCK0/PDT0, PCK1/PDT1      | D | 编程时钟/数据接口;在线仿真接口 |
|---------------------------|---|------------------|
| 1 0110/1 01031 0111/1 011 |   |                  |

注: P-电源端口; D-数字端口, DI-数字输入, DO-数字输出; A-模拟端口, AI-模拟输入, AO-模拟输出。



*晟矽微电* 10/79



# 2 电气特性

# 2.1 极限参数

| 参数          | 符号      | 值            | 单位 |
|-------------|---------|--------------|----|
| 电源电压        | VDD     | -0.3~6.0     | V  |
| I/O 输入电压    | Vin     | -0.3~VDD+0.3 | V  |
| 工作温度        | Та      | -40~85       | °C |
| 储存温度        | Tstg    | -65~150      | °C |
| 流入 VDD 最大电流 | IVDDmax | 60           | mA |
| 流出 GND 最大电流 | IGNDmax | 60           | mA |

注:若芯片工作条件超过极限值,则将造成永久性损坏;若芯片长时间工作在极限条件下,则将影响其可靠性。

# 2.2 直流电气特性

VDD=5V, Ta=25°C

| 特性           | 符号    | 端口         | 条件                           | 最小     | 典型    | 最大             | 单位    |          |       |                |     |     |        |                |
|--------------|-------|------------|------------------------------|--------|-------|----------------|-------|----------|-------|----------------|-----|-----|--------|----------------|
|              |       |            | Fcpu=8MHz@Fhirc(32M)/4       | VLVR24 |       | 5.5            |       |          |       |                |     |     |        |                |
|              |       |            | Fcpu=4MHz@Fhirc(32M)/8       | VLVR20 |       | 5.5            |       |          |       |                |     |     |        |                |
| <b>工作</b> 由厅 | VDD   | VDD        | Fcpu=2MHz@Fhirc(32M)/16      | VLVR18 |       | 5.5            | M     |          |       |                |     |     |        |                |
| 工作电压         | VDD   | VUU        | Fcpu=1MHz@Fhirc(32M)/32      | VLVR18 |       | 5.5            | V     |          |       |                |     |     |        |                |
|              |       |            | Fcpu=500KHz@Fhirc(32M)/64    | VLVR18 |       | 5.5            |       |          |       |                |     |     |        |                |
|              |       |            | Fcpu=16KHz@FLIRC(32K)/2      | VLVR18 |       | 5.5            |       |          |       |                |     |     |        |                |
| 输入漏电流        | Ileak | 所有输入脚      | VDD=5V                       | -1     |       | 1              | μΑ    |          |       |                |     |     |        |                |
| 松、高点亚        | 101   |            | 用户配置字 SMTVS 选择               | 0.8VDD |       |                | V     |          |       |                |     |     |        |                |
| 输入高电平        | vin   | Vih        | vin                          | vin    | 所有输入脚 | 用户配置字 SMTVS 选择 | 2.0   |          |       | ٧              |     |     |        |                |
| 松)低电亚        | Vil   | Vil        | Vil                          | Vil    | Vil   | 引平 Vil         | 7 Vil | Vil 所有输。 | 红女女、珊 | 用户配置字 SMTVS 选择 |     |     | 0.2VDD | ٧              |
| 输入低电平        |       |            |                              |        |       |                |       |          | VII   | VII            | VII | VII | 加有那八脚  | 用户配置字 SMTVS 选择 |
| 上拉电阻         | Rpu   | P0, P1, P2 | VDD=5V, Vin=0                |        | 13.5  |                | ΚΩ    |          |       |                |     |     |        |                |
| 下拉电阻         | Rpd   | P0, P1, P2 | Vin=VDD=5V                   |        | 13.5  |                | ΚΩ    |          |       |                |     |     |        |                |
| 输出源电流        | Ioh   | 推挽输出脚      | Voh=VDD-0.6V                 |        | 20    |                | mA    |          |       |                |     |     |        |                |
| 输出灌电流        | Iol   | 所有输出脚      | Vol=0.6V                     |        | 30    |                | mA    |          |       |                |     |     |        |                |
|              |       |            | VDD=5V, Fcpu=8MHz@HIRC(32M)  |        | 2.6   |                | mA    |          |       |                |     |     |        |                |
|              |       |            | VDD=5V, Fcpu=4MHz@HIRC(32M)  |        | 1.8   |                | mA    |          |       |                |     |     |        |                |
| 运行模式功耗       | Irun  | VDD        | VDD=5V, Fcpu=2MHz@HIRC(32M)  |        | 1.4   |                | mA    |          |       |                |     |     |        |                |
|              |       |            | VDD=5V, Fcpu=1MHz@HIRC(32M)  |        | 1.2   |                | mA    |          |       |                |     |     |        |                |
|              |       |            | VDD=5V, Fcpu=16KHz@LIRC(32K) |        | 22    |                | μΑ    |          |       |                |     |     |        |                |

晟矽微电 11/79



|          |       | I   |                               |      | 1   |      |    |
|----------|-------|-----|-------------------------------|------|-----|------|----|
| HOLD 功耗  | Ihold | VDD | VDD=5V, CPU 停, HIRC 关, LIRC 开 |      | 3   |      | μΑ |
|          |       |     | 休眠模式, WDT/LVR 关               |      | 1   | 3    | μΑ |
| 休眠模式功耗   | Istop | VDD | 休眠模式, WDT 开, LVR 关            |      | 3.5 | 6    | μΑ |
|          |       |     | 休眠模式, WDT 关, LVR 开            |      | 37  | -    | μΑ |
| 低压检测电压   | VLVD  | VDD | LVDVS 选择                      | -10% |     | +10% | V  |
| LVD 响应时间 | TLVD  |     |                               |      |     | 10   | us |
| 低压复位电压   | VLVR  | VDD | LVRVS 配置                      | -5%  |     | +5%  | V  |
| LVD/LVR  |       | VDD |                               |      | C0/ | 120/ |    |
| 回滞电压     |       | VDD |                               |      | 6%  | 12%  |    |

注:条件项中,无关模块默认关闭,无关端口设为低电平无负载输出或内部上/下拉电阻无效且外接 GND 的输入。

# 2.3 交流电气特性

| 特性        | 符号     | 条件                          | 最小    | 典型 | 最大    | 单位  |
|-----------|--------|-----------------------------|-------|----|-------|-----|
|           |        | VDD=5V, T=25°C              | -1.5% |    | +1.5% |     |
| HIRC 振荡频率 | FHIRC1 | VDD=2.2V~5.5V, T=-20°C~70°C | -3%   | 32 | +3%   | MHz |
|           |        | VDD=2.2V~5.5V, T=-40°C~85°C | -5%   |    | +5%   |     |
| LIRC 振荡频率 | FLIRC  | VDD=5V, T=25°C              | -50%  | 32 | +50%  | KHz |

# 2.4 ADC 特性参数

VDD=5V, Ta=25°C

| 特性                      | 符号   | 条件                             | 最小  | 典型 | 最大         | 单位     |
|-------------------------|------|--------------------------------|-----|----|------------|--------|
| ADC 有效工作电压              | VADC | T=-40°C~85°C                   | 2.5 |    | 5.5        | V      |
| 积分非线性误差                 | INL  | VREF=VDD, FADC=1MHz, Tcon=27µs |     |    | <u>±</u> 4 | LSB    |
| 微分非线性误差                 | DNL  | VREF=VDD, FADC=1MHz, Tcon=27μs |     |    | ±2         | LSB    |
| 零点偏移误差                  | EZ   | VREF=VDD, FADC=1MHz, Tcon=27μs |     |    | ±4         | LSB    |
| 增益误差                    | ET   | VREF=VDD, FADC=1MHz, Tcon=27μs |     |    | <u>±</u> 4 | LSB    |
| ++100.161               | F    | VDD=5V,参考电压选择 VDD              |     |    | 2          | MHz    |
| 转换时钟                    | FADC | VDD=5V,参考电压选择内部参考源             |     |    | 1          | MHz    |
| 转换时间                    | Tcon |                                | 14  |    | 27         | 1/Fadc |
| ADC 输入电压                | Vain | AN0~AN13                       | GND |    | VREF       | V      |
| ADC 外部输入阻抗 <sup>注</sup> | Rain | 参见附注公式和表格                      |     |    | 500        | kΩ     |
| ADC 采样开关电阻              | Radc |                                |     |    | 20k        | kΩ     |
| ADC 内部采样和保持电容           | CADC |                                |     |    | 3          | pF     |
| ADC 动态电流                | ladd | VDD=5V, AD 转换中                 |     | 1  | 3          | mA     |

晟矽微电 12/79

电气特性



| ADC 静态电流   | lads | VDD=5V, ADC 关闭           |         | 0.1 | 1     | μΑ |
|------------|------|--------------------------|---------|-----|-------|----|
| 模拟信号源推荐阻抗  | Zain |                          |         |     | 10    | ΚΩ |
|            | VREF | 选择 VDD                   |         | VDD |       |    |
| ADC 参考电压   |      | 选择内部参考电压 ViR, T=25℃      | -1.5%   | _   | +1.5% | V  |
|            |      | 选择内部参考电压 ViR, T=-40℃~85℃ | -2%     | 2   | +2%   |    |
| VIR 有效工作电压 | Vvir | 选择内部参考电压 VIR             | VIR+0.5 |     | 5.5   | V  |

注:公式: RAIN 最大值公式

 $R_{AIN} < T_S / (f_{ADC} * C_{ADC} * ln(2^{N+2})) - R_{ADC}$ 

其中,N=12,表示 12 位分辨率,Ts 为采样时钟,fADC 为 ADC 转换时钟(单位 MHz),CADC 为内部采样保持电容(单位 uF),RADC 为内部采样开关阻抗(单位 k $\Omega$ )。

f<sub>ADC</sub>=1M/2M 时最大 R<sub>AIN</sub>

| 采样时间 Ts(f <sub>ADC</sub> clock cycle) | 采样时间 ts(us) | R <sub>AIN</sub> (kΩ) @ f <sub>ADC</sub> =1M | R <sub>AIN</sub> (kΩ) @ f <sub>ADC</sub> =2M |
|---------------------------------------|-------------|----------------------------------------------|----------------------------------------------|
| 2                                     | 1           | 48.7                                         | 14.3                                         |
| 4                                     | 2           | 117.4                                        | 48.7                                         |
| 8                                     | 4           | 254.8                                        | 117.4                                        |
| 15                                    | 7.5         | 495.2                                        | 237.6                                        |

# 2.5 CMP 特性参数

VDD=5V, Ta=25°C

| 100 01, 14 20 0 |         |              |     |    |         |    |
|-----------------|---------|--------------|-----|----|---------|----|
| 特性              | 符号      | 条件           | 最小  | 典型 | 最大      | 单位 |
| 比较器有效工作电压       | Vсмр    | T=-40°C~85°C | 2.7 |    | 5.5     | ٧  |
| 工作电流            | Ісмр    |              |     | 90 |         | μΑ |
|                 |         | 未调校          | -15 |    | +15     |    |
| 输入失调电压          | Voffset | 已调校, CMPOE=0 | -2  |    | +2      | mV |
|                 |         | 已调校, CMPOE=1 | -5  |    | +5      |    |
| 输入共模电压          | Vcom    |              | 0   |    | VDD-1.4 | V  |
| 响应时间            | TRESP   |              |     |    | 2       | μs |
| 比较器启动时间         |         |              |     |    | 200     | μs |
| 通道切换等待时间        | Tccw    |              | 2   |    |         | μs |

# 2.6 EEPROM 特性参数

VDD=5V, Ta=25°C

| 特性           | 符号    | 条件           | 最小  | 典型 | 最大  | 单位 |
|--------------|-------|--------------|-----|----|-----|----|
| EEPROM 读操作电压 | VEERD | T=-40°C~85°C | 2.0 |    | 5.5 | ٧  |
| EEPROM 写操作电压 | VEEWR | T=-40°C~85°C | 2.0 |    | 5.5 | V  |

*晟矽微电* 13/79



| EEPROM 写操作电流   | leewr  | T=-40°C~85°C                |       | 2 | mA    |
|----------------|--------|-----------------------------|-------|---|-------|
| EEPROM 静态电流    | leestp | T=25°C                      |       | 1 | μΑ    |
| EEPROM 单地址写入时间 | TEEWR  | VDD=2.0V~5.5V, T=-40°C~85°C |       | 8 | ms    |
| EEPROM 擦写次数    |        | VDD=5V, T=25°C              | 10000 |   | cycle |
| EEPROM 数据保存时间  |        |                             | 10    |   | year  |





# 3 CPU 与存储器

# 3.1 指令集

芯片的指令集为精简指令集。

除程序跳转类指令外,其他指令均为单周期指令,即执行时间为 1 个指令周期(CPU 时钟周期);所有指令均为单字指令,即指令码仅占用 1 个程序存储器地址空间。

### 指令汇总表

| 助记符      | 说明                      | 操作                                                                        | 周期 | 长度 | 标志     |
|----------|-------------------------|---------------------------------------------------------------------------|----|----|--------|
| ADDAR R  | R 和 A 相加,结果存入 A         | R+A→A                                                                     | 1  | 1  | C,DC,Z |
| ADDRA R  | R 和 A 相加,结果存入 R         | R+A→R                                                                     | 1  | 1  | C,DC,Z |
| ADCAR R  | R 和 A 相加(带 C 标志),结果存入 A | R+A+C→A                                                                   | 1  | 1  | C,DC,Z |
| ADCRA R  | R 和 A 相加(带 C 标志),结果存入 R | R+A+C→R                                                                   | 1  | 1  | C,DC,Z |
| RSUBAR R | R和A相减,结果存入A             | R-A→A                                                                     | 1  | 1  | C,DC,Z |
| RSUBRA R | R和A相减,结果存入R             | R-A→R                                                                     | 1  | 1  | C,DC,Z |
| RSBCAR R | R 和 A 相减(带 C 标志),结果存入 A | R-A-/C→A                                                                  | 1  | 1  | C,DC,Z |
| RSBCRA R | R和A相减(带C标志),结果存入R       | R-A-/C→R                                                                  | 1  | 1  | C,DC,Z |
| ASUBAR R | A 和 R 相减,结果存入 A         | A-R→A                                                                     | 1  | 1  | C,DC,Z |
| ASUBRA R | A 和 R 相减,结果存入 R         | A-R→R                                                                     | 1  | 1  | C,DC,Z |
| ASBCAR R | A 和 R 相减(带 C 标志),结果存入 A | A-R-/C→A                                                                  | 1  | 1  | C,DC,Z |
| ASBCRA R | A 和 R 相减(带 C 标志),结果存入 R | A-R-/C→R                                                                  | 1  | 1  | C,DC,Z |
| ANDAR R  | R 和 A 与操作,结果存入 A        | R and A→A                                                                 | 1  | 1  | Z      |
| ANDRA R  | R 和 A 与操作,结果存入 R        | R and A→R                                                                 | 1  | 1  | Z      |
| ORAR R   | R 和 A 或操作,结果存入 A        | R or A→A                                                                  | 1  | 1  | Z      |
| ORRA R   | R 和 A 或操作,结果存入 R        | R or A→R                                                                  | 1  | 1  | Z      |
| XORAR R  | R 和 A 异或操作,结果存入 A       | R xor A→A                                                                 | 1  | 1  | Z      |
| XORRA R  | R 和 A 异或操作,结果存入 R       | R xor A→R                                                                 | 1  | 1  | Z      |
| COMAR R  | 对 R 取反,结果存入 A           | R 取反→A                                                                    | 1  | 1  | Z      |
| COMR R   | 对 R 取反,结果存入 R           | R 取反→R                                                                    | 1  | 1  | Z      |
| RLA      | A 循环左移(带 C 标志)          | $A[7] \rightarrow C$ ; $A[6:0] \rightarrow A[7:1]$ ; $C \rightarrow A[0]$ | 1  | 1  | С      |
| RLAR R   | R 循环左移(带 C 标志),结果存入 A   | $R[7] \rightarrow C$ ; $R[6:0] \rightarrow A[7:1]$ ; $C \rightarrow A[0]$ | 1  | 1  | С      |
| RLR R    | R 循环左移(带 C 标志),结果存入 R   | $R[7] \rightarrow C$ ; $R[6:0] \rightarrow R[7:1]$ ; $C \rightarrow R[0]$ | 1  | 1  | С      |
| RRA      | A 循环右移(带 C 标志)          | $A[0]\rightarrow C; A[7:1]\rightarrow A[6:0]; C\rightarrow A[7]$          | 1  | 1  | С      |
| RRAR R   | R 循环右移(带 C 标志),结果存入 A   | $R[0]\rightarrow C; R[7:1]\rightarrow A[6:0]; C\rightarrow A[7]$          | 1  | 1  | С      |
| RRR R    | R 循环右移(带 C 标志),结果存入 R   | $R[0]\rightarrow C; R[7:1]\rightarrow R[6:0]; C\rightarrow R[7]$          | 1  | 1  | С      |
| SWAPAR R | 交换 R 的高低半字节,结果存入 A      | R[7:4]→A[3:0]; R[3:0]→A[7:4]                                              | 1  | 1  | -      |
|          |                         |                                                                           |    |    |        |

*晟矽微电* 15/79



| CMADD    |     | <b>☆梅 ρ 协</b> 壹 / ( ) / □ + + - / −   −   −   −   −   −   −   −   −   − | D[7 4] , D[2 0] , D[2 0] , D[7 4] |     |   |        |
|----------|-----|-------------------------------------------------------------------------|-----------------------------------|-----|---|--------|
| SWAPR    |     | 交换 R 的高低半字节,结果存入 R                                                      | R[7:4]→R[3:0]; R[3:0]→R[7:4]      | 1   | 1 | -      |
| MOVRA    |     | 将 A 存入 R                                                                | A→R                               | 1   | 1 | -      |
| MOVAR    |     | 将 R 存入 A                                                                | R→A                               | 1   | 1 | Z      |
| MOVR     | R   | 将 R 存入 R                                                                | R→R                               | 1   | 1 | Z      |
| CLRA     |     | 将A清零                                                                    | 0→A                               | 1   | 1 | Z      |
| CLRR     | R   | 将R清零                                                                    | 0→R                               | 1   | 1 | Z      |
| INCA     |     | A 自加 1                                                                  | A+1→A                             | 1   | 1 | -      |
| INCR     | R   | R 自加 1                                                                  | R+1→R                             | 1   | 1 | Z      |
| INCAR    | R   | R 加 1,结果存入 A                                                            | R+1→A                             | 1   | 1 | Z      |
| DECA     |     | A 自减 1                                                                  | A-1→A                             | 1   | 1 | -      |
| DECR     | R   | R 自减 1                                                                  | R-1→R                             | 1   | 1 | Z      |
| DECAR    | R   | R 减 1,结果存入 A                                                            | R-1→A                             | 1   | 1 | Z      |
| JZA      |     | A 自加 1: 结果为 0 则跳过下一条指令                                                  | A+1→A: 结果为 0 则 PC+2→PC            | 1/2 | 1 | -      |
| JZR      | R   | R 自加 1: 结果为 0 则跳过下一条指令                                                  | R+1→R: 结果为 0 则 PC+2→PC            | 1/2 | 1 | -      |
| JZAR     | R   | R 加 1,结果存入 A: 结果为 0 则跳过下一条指令                                            | R+1→A: 结果为 0 则 PC+2→PC            | 1/2 | 1 | -      |
| DJZA     |     | A 自减 1: 结果为 0 则跳过下一条指令                                                  | A-1→A: 结果为 0 则 PC+2→PC            | 1/2 | 1 | -      |
| DJZR     | R   | R 自减 1: 结果为 0 则跳过下一条指令                                                  | R-1→R: 结果为 0 则 PC+2→PC            | 1/2 | 1 | -      |
| DJZAR    | R   | R 减 1,结果存入 A: 结果为 0 则跳过下一条指令                                            | R-1→A: 结果为 0 则 PC+2→PC            | 1/2 | 1 | -      |
| BCLR     | R,b | 将 R 的第 b 位清 0                                                           | 0→R[b]                            | 1   | 1 | -      |
| BSET     | R,b | 将 R 的第 b 位置 1                                                           | 1→R[b]                            | 1   | 1 | -      |
| JBCLR    | R,b | 若 R 的第 b 位为 0,则跳过下一条指令                                                  | 若 R[b]=0,则 PC+2→PC                | 1/2 | 1 | -      |
| JBSET    | R,b | 若 R 的第 b 位为 1,则跳过下一条指令                                                  | 若 R[b]=1,则 PC+2→PC                | 1/2 | 1 | -      |
| ADDAI    | I   | I 和 A 相加,结果存入 A                                                         | I+A→A                             | 1   | 1 | C,DC,Z |
| ADCAI    | J.  | I 和 A 相加(带 C 标志),结果存入 A                                                 | I+A+C→A                           | 1   | 1 | C,DC,Z |
| ISUBAI   | ı   | I 和 A 相减,结果存入 A                                                         | I-A→A                             | 1   | 1 | C,DC,Z |
| ISBCAI I |     | I 和 A 相减(带 C 标志),结果存入 A                                                 | I-A-/C→A                          | 1   | 1 | C,DC,Z |
| ASUBAI   | IC  | A 和 I 相减,结果存入 A                                                         | A-I→A                             | 1   | 1 | C,DC,Z |
| ASBCAI   |     | A 和 I 相减(带 C 标志),结果存入 A                                                 | A-I-/C→A                          | 1   | 1 | C,DC,Z |
| ANDAI    | 1   | I 和 A 与操作,结果存入 A                                                        | I and A→A                         | 1   | 1 | Z      |
| ORAI     | I   | I 和 A 或操作,结果存入 A                                                        | IorA→A                            | 1   | 1 | Z      |
| XORAI    | 1   | I 和 A 异或操作,结果存入 A                                                       | I xor A→A                         | 1   | 1 | Z      |
| MOVAI    | ı   | 将I存入A                                                                   | l→A                               | 1   | 1 | -      |
| CALL     | K   | 子程序调用                                                                   | PC+1→TOS; K→PC[12:0]              | 2   | 1 | -      |
| GOTO     |     | 无条件跳转                                                                   | K→PC[12:0]                        | 2   | 1 | -      |
| RETURN   |     | 从子程序返回                                                                  | TOS→PC                            | 2   | 1 | -      |
|          | •   |                                                                         | <del>-</del>                      |     |   |        |



| RETAI I | 从子程序返回,并将 I 存入 A           | TOS→PC; I→A       | 2 | 1 | -     |
|---------|----------------------------|-------------------|---|---|-------|
| RETIE   | 从中断返回                      | TOS→PC; 1→GIE     | 2 | 1 | -     |
| NOP     | 空操作                        | 空操作               | 1 | 1 | -     |
| DAA     | BCD 码加法操作后,将 A 的值调整为 BCD 码 | A(HEX 码)→A(BCD 码) | 1 | 1 | С     |
| DSA     | BCD 码减法操作后,将 A 的值调整为 BCD 码 | A(HEX 码)→A(BCD 码) | 1 | 1 | -     |
| CLRWDT  | 将看门狗计数器清零                  | 0→WDTCNT          | 1 | 1 | TO,PD |
| STOP    | 进入低功耗模式                    | 0→WDTCNT; CPU 暂停  | 1 | 1 | TO,PD |

MC32F7062B

#### 注:

- 1、 A-算术逻辑单元累加器 ALU,R-数据存储器,I-立即数,K-程序存储器地址,TOS-堆栈栈顶;
- 2、 对于条件跳转类指令,若跳转条件成立,则执行时间需 2 个指令周期,否则仅需 1 个指令周期;
- 3、 禁止采用对 C,DC,Z 标志有影响的指令访问寄存器 PFLAG;

### 3.2 程序存储器

芯片的程序存储器为 FLASH 型存储器,4K×16 位的地址空间范围为 0000H~0FFFH。程序存储器地址分配如下图所示:

| 复位起始地址(0000H)            |  |
|--------------------------|--|
| 通用程序区<br>(0001H - 0007H) |  |
| 中断入口地址(0008H)            |  |
| 通用程序区<br>(0009H - 0FFFH) |  |

程序存储器支持间接寻址,可通过寄存器 INDF3 访问地址为(FSR1×256+FSR0)的程序存储器内容,高 8 位将缓存于寄存器 HIBYTE,低 8 位将缓存于寄存器 A。

例如,采用间接寻址读取程序存储器 0155H 地址中内容,高 8 位存入通用数据存储器 11H 地址中,低 8 位存入通用数据存储器 10H 地址中:

| MOVAI | 01H    |                                 |
|-------|--------|---------------------------------|
| MOVRA | FSR1   | ;将 01H 写入 FSR1                  |
| MOVAI | 55H    |                                 |
| MOVRA | FSR0   | ;将 55H 写入 FSR0                  |
| MOVAR | INDF3  | ;读取(FSR1×256+FSR0)所指地址的程序存储器中内容 |
|       |        | ; 高 8 位缓存于 HIBYTE,低 8 位缓存于 A    |
| MOVRA | 10H    | ;将 A 中缓存的低 8 位存入通用数据存储器 10H 地址中 |
| MOVAR | HIBYTE | ;读取 HIBYTE 中缓存的高 8 位            |
| MOVRA | 11H    | ; 高 8 位存入通用数据存储器 11H 地址中        |
|       |        |                                 |

*晟矽微电* 17/79





### 3.3 数据存储器

芯片的数据存储器包括通用数据存储器 GPR(256 字节)和特殊功能寄存器 SFR,地址映射如下表所示。其中 GPR 可直接寻址或通过 INDF0/INDF2 间接寻址,SFR 可直接寻址或通过 INDF1/INDF2 间接寻址。

数据存储器还包括掉电非易失的 EEPROM 型数据存储器(256 字节),需通过 SFR 进行读写操作,详细说明请参见后续章节。

#### 数据存储器区地址映射表

| 地址        | 类型  | 0/8   | 1/9   | 2/A    | 3/B    | 4/C     | 5/D     | 6/E     | 7/F     |
|-----------|-----|-------|-------|--------|--------|---------|---------|---------|---------|
| 000H-0FFH | GPR |       |       |        | 通用数据   | 存储器区    |         |         |         |
| 100H-17FH | 保留  |       |       |        | 保      | :留      |         |         |         |
| 180H-187H |     | INDF0 | INDF1 | INDF2  | HIBYTE | FSR0    | FSR1    | PCL     | PFLAG   |
| 188H-18FH |     | MCR   | INDF3 | INTE0  | INTF0  | OSCMR   |         | INTE1   | INTF1   |
| 190H-197H |     | IOP0  | OEP0  | PUP0   | PDP0   | IOP1    | OEP1    | PUP1    | PDP1    |
| 198H-19FH |     | IOP2  | OEP2  | PUP2   | PDP2   | P1KBCR  |         |         |         |
| 1A0H-1A7H | CED | T0CR  | T0CNT | T0LOAD |        | LVDCR   | CMPCR0  | CMPCR1  | CMPCLR  |
| 1A8H-1AFH | SFR | T1CR0 | T1CR1 | T1CNTH | T1CNTL | T1LOADH | T1LOADL | P0KBCR  | P2KBCR  |
| 1B0H-1B7H |     | T2CR  | T2CNT | T2LOAD | T2DATA | PWM2CR0 |         |         | AFCR    |
| 1B8H-1BFH |     | T3CR  | T3CNT | T3LOAD | T3DATA | T3DATB  | T3DATC  | PWM3CR0 | PWM3CR1 |
| 1C0H-1C7H |     |       |       |        |        | EECR    | EEPR    | EEAR    | EEDR    |
| 1C8H-1CFH |     | ADCR0 | ADCR1 | ADRH   | ADRL   | OSADJCR | P0ADCR  | P1ADCR  | P2ADCR  |
| 1D0H-1F7H | 保留  |       |       |        |        | :留      |         |         |         |
| 1F8H-1FFH | SFR |       |       |        |        |         |         | DBGCR   | DBGPR   |

注:上表中灰色部分的存储器地址为系统寄存器及保留区,禁止对其中未定义的地址进行读写操作。

#### 数据存储器寻址方式地址组成

| 15 | 14 | 13 | 12 | 11                    | 10 | 9 | 8 | 7 | 6 | 5   | 4    | 3  | 2 | 1 | 0 | 寻址方式     |
|----|----|----|----|-----------------------|----|---|---|---|---|-----|------|----|---|---|---|----------|
| /  | /  | /  | >  | /                     | /  | / |   |   | 取 | 自指令 | 令的 9 | 位地 | 址 |   |   | 直接寻址方式   |
| 1  | 1  |    |    | / / / 0 FSRO 间接寻址方式 0 |    |   |   |   |   |     |      |    |   |   |   |          |
| /  | 1  | /  | /  | /                     | /  | / | 1 |   |   |     | FS   | R1 |   |   |   | 间接寻址方式 1 |
|    |    |    | FS | R1                    |    |   |   |   |   |     | FS   | R0 |   |   |   | 间接寻址方式 2 |

直接寻址方式,是以指令的低 9 位为数据存储器地址,通过指令访问,寻址范围 0~1FFH。例如,采用直接寻址方式 将数据 55H 写入数据存储器 010H 地址中:

MOVAI 55H

MOVRA 10H ; 将 55H 写入数据存储器 10H 地址中

间接寻址方式 0,是以 FSR0 为数据存储器地址指针,通过 INDF0 访问,寻址范围 0~0FFH。例如,采用间接寻址方

*晟矽微电* 18/79





式 0 将数据 55H 写入数据存储器 010H 地址中:

MOVAI 10H MOVRA FSR0 MOVAI 55H

MOVRA INDFO ;将 55H 写入 FSR0 所指地址的数据存储器中

间接寻址方式 1,是以 FSR1 为数据存储器地址指针,通过 INDF1 访问,寻址范围 100H~1FFH。例如,采用间接寻址方式 1 将数据 55H 写入数据存储器 110H 地址中:

MOVAI 10H MOVRA FSR1 MOVAI 55H

MOVRA INDF1 ; 将 55H 写入(FSR1+256)所指地址的数据存储器中

间接寻址方式 2,是以[FSR1:FSR0]为数据存储器地址指针,通过 INDF2 访问,寻址范围 0~FFFFH。例如,采用间接寻址方式 2 将数据 55H 写入数据存储器 0010H 地址中:

MOVAI 00H
MOVRA FSR1
MOVAI 10H
MOVRA FSR0
MOVAI 55H
MOVRA INDF2

;将55H写入(FSR1×256+FSR0)所指地址的数据存储器中

注:间接寻址方式 2 最大可寻址 FFFFH,但访问数据存储器中未定义的地址时,读出数据不确定,写入操作可能会 更改其他地址中的内容。

#### 3.4 堆栈

芯片的堆栈为 8 级深度的硬件堆栈。当 CPU 响应中断或执行子程序调用指令时,会自动将下一条指令的 PC 值压栈保存; 当 CPU 执行中断返回或子程序返回指令时,会自动将栈顶内容出栈载入 PC。

### 3.5 控制寄存器

#### 数据指针寄存器 0

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| FSR0 | FSR07  | FSR06  | FSR05  | FSR04  | FSR03  | FSR02  | FSR01  | FSR00  |
| R/W  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值  | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0] FSR0[7:0] - 数据指针寄存器 0

FSRO: 间接寻址方式 0 的指针,或间接寻址方式 2、3 的指针低 8 位。

*晟矽微电* 19/79





#### 数据指针寄存器 1

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| FSR1 | FSR17  | FSR16  | FSR15  | FSR14  | FSR13  | FSR12  | FSR11  | FSR10  |
| R/W  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值  | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0]

FSR1[7:0] - 数据指针寄存器 1

FSR1: 间接寻址方式 1 的指针,或间接寻址方式 2、3 的指针高 8 位。

#### 间接寻址寄存器 0

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| INDF0 | INDF07 | INDF06 | INDF05 | INDF04 | INDF03 | INDF02 | INDF01 | INDF00 |
| R/W   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值   | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0]

INDF0[7:0] - 间接寻址寄存器 0

INDF0: INDF0 不是物理寄存器,对 INDF0 操作实际是对 FSR0 所指向地址的数据存储器进行操作,从而实现间接寻址功能。

#### 间接寻址寄存器1

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| INDF1 | INDF17 | INDF16 | INDF15 | INDF14 | INDF13 | INDF12 | INDF11 | INDF10 |
| R/W   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值   | Х      | X      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0]

INDF1[7:0] - 间接寻址寄存器 1

INDF1: INDF1 不是物理寄存器,对 INDF1 操作实际是对 (FSR1+256) 所指向地址的数据存储器进行操作,从而实现间接寻址功能。

#### 间接寻址寄存器 2

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| INDF2 | INDF27 | INDF26 | INDF25 | INDF24 | INDF23 | INDF22 | INDF21 | INDF20 |
| R/W   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值   | Х      | X      | X      | X      | X      | X      | X      | X      |

BIT[7:0]

INDF2[7:0] - 间接寻址寄存器 2

INDF2: INDF2 不是物理寄存器,对 INDF2 操作实际是对(FSR1×256+FSR0)所指向地址的数据存储器进行操作,从而实现间接寻址功能。

#### 间接寻址寄存器3

*晟矽微电* 20/79



|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| INDF3 | INDF37 | INDF36 | INDF35 | INDF34 | INDF33 | INDF32 | INDF31 | INDF30 |
| R/W   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值   | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0]

INDF3[7:0] - 间接寻址寄存器 3

INDF3: INDF3 不是物理寄存器,对 INDF3 操作实际是对(FSR1×256+FSR0)所指向地址的程序存储器进 行操作,从而实现间接寻址功能。

注:对寄存器 INDF3 仅可执行读取操作,且仅可使用读取指令(MOVAR INDF3),所读程序存储器内容的高 8 位存 入寄存器 HIBYTE,低 8 位存入寄存器 A。

#### 字操作高字节缓存器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| HIBYTE | HIBYTE7 | HIBYTE6 | HIBYTE5 | HIBYTE4 | HIBYTE3 | HIBYTE2 | HIBYTE1 | HIBYTE0 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| 初始值    | Х       | Х       | Х       | Х       | Х       | X       | Х       | Х       |

BIT[7:0]

HIBYTE[7:0] - 字操作高字节缓存器

HIBYTE: 用于缓存通过 INDF3 访问程序存储器时所读取内容的高 8 位。

#### 程序指针计数器低字节

|     | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-----|--------|--------|--------|--------|--------|--------|--------|--------|
| PCL | PC7    | PC6    | PC5    | PC4    | PC3    | PC2    | PC1    | PC0    |
| R/W | 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[7:0] PC[7:0] - 程序指针计数器低 8 位

程序指针计数器 (PC) 有以下几种操作模式:

♦ 顺序运行指令: PC = PC + 1;

♦ 程序跳转指令 GOTO/CALL: PC = 指令码低 13 位;

◆ 返回指令 RETIE/RETURN/RETAI: PC = 堆栈栈顶 (TOS);

#### 对 PCL 操作指令:

→ 对 PCL 操作的加法指令: PC = (PC[12:0]+ALU[7:0]);

→ 对 PCL 操作的其他指令: PC = (PC[12:8]:ALU[7:0](ALU 运算结果));

#### CPU 状态寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| PFLAG | -      | -      | -      | -      | -      | Z      | DC     | С      |
| R/W   | -      | -      | -      | -      | -      | R/W    | R/W    | R/W    |

晟矽微电 21/79



CPU 与存储器



|--|

BIT[2] Z - 零标志位

0: 算术或逻辑运算的结果不为零;

1: 算术或逻辑运算的结果为零;

BIT[1] DC - 半字节进位/借位标志位

0: 加法运算中半字节无进位;减法运算中半字节有借位;

1: 加法运算中半字节有进位;减法运算中半字节无借位;

BIT[0] C - 进位/借位标志位

0: 加法运算中无进位;减法运算中有借位;移位操作中移出位为0;

1: 加法运算中有进位;减法运算中无借位;移位操作中移出位为1;

#### 杂项控制寄存器

|     | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-----|--------|--------|--------|--------|--------|--------|--------|--------|
| MCR | GIE    | -      | ТО     | PD     | INT1M1 | INT1M0 | INT0M1 | INT0M0 |
| R/W | R/W    | -      | R      | R      | R/W    | R/W    | R/W    | R/W    |
| 初始值 | 0      | -      | 0      | 0      | 0      | 0      | 0      | 0      |

BIT[7] GIE - 中断总使能位

0: 屏蔽所有中断;

1: 由相应的中断使能位决定 CPU 是否响应中断源所触发的中断;

BIT[5] TO - 看门狗溢出标志位

0: 上电复位,或执行 CLRWDT/STOP 指令;

1: 发生 WDT 溢出;

BIT[4] PD - 进入低功耗模式标志位

0: 上电复位,或执行 CLRWDT 指令;

1: 执行 STOP 指令;

BIT[3:2] INT1M[1:0] - 外部中断 INT1 触发方式选择位

| INT1M[1:0] | INT1 触发方式 |  |  |  |  |
|------------|-----------|--|--|--|--|
| 00         | 上升沿触发     |  |  |  |  |
| 01         | 下降沿触发     |  |  |  |  |
| 1X         | 电平变化触发    |  |  |  |  |

BIT[1:0] INTOM[1:0] - 外部中断 INTO 触发方式选择位

| INT0M[1:0] | INTO 触发方式 |  |  |  |  |
|------------|-----------|--|--|--|--|
| 00         | 上升沿触发     |  |  |  |  |
| 01         | 下降沿触发     |  |  |  |  |
| 1X         | 电平变化触发    |  |  |  |  |

*晟矽微电* 22/79



# 3.6 用户配置字

芯片为保证系统正常工作,会将关键模块的配置信息预先存储于单独的存储器区域内,在上电或其他复位发生后将配置信息载入寄存器中,通过寄存器控制关键模块的工作状态。该部分存储器中用户可选的内容即为用户配置字,可在烧录用户程序代码时进行配置与烧录。

MC32F7062B

芯片的用户配置字,定义如下:

| 符号      |                                   | 功能说明              |                |  |  |  |  |
|---------|-----------------------------------|-------------------|----------------|--|--|--|--|
|         | 高频时钟下 FCPU 分频选择                   | :                 |                |  |  |  |  |
| FCPUS   | Fcpu=Fhosc/4;                     | Fcpu=Fhosc/8;     |                |  |  |  |  |
|         | Fcpu=Fhosc/16;                    | Fcpu=Fhosc/32;    | Fcpu=Fhosc/64; |  |  |  |  |
| RSTEN   | RST 外部复位端口设置:                     |                   |                |  |  |  |  |
| KSTEN   | P17 为外部复位脚;                       | P17 为输入/转         | 俞出脚;           |  |  |  |  |
| LVRMD   | LVR 模式设置:                         |                   |                |  |  |  |  |
| LVKMD   | LVR 始终开启;                         | LVR 在运行模式下开启,     | 在低功耗模式下关闭;     |  |  |  |  |
| LVDVC   | LVR 复位电压选择:(LVR F                 | 电压应满足由 Fcpu 决定的工作 | 电压特性)          |  |  |  |  |
| LVRVS   | 1.8V; 2.0V; 2.4V; 2.              | 7V; 3.0V; 3.2V;   |                |  |  |  |  |
|         | WDT 模式设置:                         |                   |                |  |  |  |  |
| WDTM    | WDT 始终关闭;                         |                   |                |  |  |  |  |
| WDTM    | WDT 在运行模式下开                       | 启,在低功耗模式下关闭;      |                |  |  |  |  |
|         | WDT 始终开启;                         |                   |                |  |  |  |  |
| WDTT    | WDT 溢出时间选择:                       |                   |                |  |  |  |  |
| VVDII   | 16ms; 64ms; 256m                  | s; 1024ms;        |                |  |  |  |  |
| SMTVS   | 端口施密特阈值选择:                        |                   |                |  |  |  |  |
| SIVITVS | 2.0V/0.8V;                        | 0.8VDD/0.2VDI     | );             |  |  |  |  |
| ENCR    | 程序代码加密设置:                         |                   |                |  |  |  |  |
| ENCR    | 程序代码加密;                           | 程序代码不加额           | 宓;             |  |  |  |  |
|         | PCK0/PDT0 编程扩展设置                  | :                 |                |  |  |  |  |
| DBGPIN0 | 端口仅在复位时用作编                        | 扁程端口,芯片仅在复位时才可    | 「进入编程/仿真模式;    |  |  |  |  |
|         | 可通过寄存器位将端口                        | 1切换为编程端口或通用端口;    |                |  |  |  |  |
|         | PCK1/PDT1 编程扩展设置                  | :                 |                |  |  |  |  |
| DBGPIN1 | 端口仅在复位时用作编程端口,芯片仅在复位时才可进入编程/仿真模式; |                   |                |  |  |  |  |
|         | 可通过寄存器位将端口                        | ]切换为编程端口或通用端口;    |                |  |  |  |  |

*晟矽微电* 23/79



# 4 系统时钟

芯片内部电路均在系统高频时钟 FHOSC 或系统低频时钟 FLOSC 下工作,系统及部分外设模块的时钟源还可在 FHOSC 和 FLOSC 之间切换。

系统高频时钟 FHOSC 固定为内部高频 RC 振荡器 HIRC(32MHz)时钟 FHIRC。

系统低频时钟 FLOSC 固定为内部低频 RC 振荡器 LIRC(32KHz)时钟 FLIRC。

CPU 的时钟源可在系统高频时钟 FHOSC 和系统低频时钟 FLOSC 之间切换。FHOSC 下 CPU 的时钟频率 FCPU 通过配置字 FCPUS 选择;FLOSC 下 FCPU 则固定为 FLOSC 的 2 分频。

WDT(看门狗)电路的时钟源固定为内部低频 RC 振荡器 LIRC。

#### 系统时钟示意图



#### 4.1 内部高频 RC 振荡器

芯片内置1个高精度 HIRC 振荡器(32MHz),可用作系统高频时钟源。

### 4.2 内部低频 RC 振荡器

芯片内置 1 个振荡频率典型值为 32KHz 的 LIRC 振荡器,可用作系统低频时钟源,也用于系统上电延时控制、看门 狗定时器(WDT)等电路。

### 4.3 系统工作模式

芯片支持高速模式、低速模式、HOLD模式和休眠模式等多种系统工作模式。

| _ //  ##   5 | III NI=15 5 W                      | ~/\_#\I\\               |  |  |  |
|--------------|------------------------------------|-------------------------|--|--|--|
| 工作模式         | 模式切换条件                             | 系统工作状态                  |  |  |  |
|              | 任意模式下,系统复位                         |                         |  |  |  |
| ŀ            | 低速模式下,CLKS 清 0                     | CPU 高速运行,高/低频时钟源均工作     |  |  |  |
|              | HOLD/休眠模式下,CPU 唤醒(@CLKS=0)         |                         |  |  |  |
| (広)本         | 高速模式下,CLKS 置 1                     | CPU 低速运行,低频时钟源工作,高频时钟源由 |  |  |  |
| 低速           | HOLD/休眠模式下,CPU 唤醒(@CLKS=1)         | 使能位 HFEN 决定             |  |  |  |
| HOLD         | 高/低速模式下,执行 STOP 指令(@HFEN=0,LFEN=1) | CPU 暂停,高频时钟源停止,低频时钟源工作  |  |  |  |

*晟矽微电* 24/79



休眠 高/低速模式下,执行 STOP 指令(@HFEN=0,LFEN=0) CPU 暂停,高/低频时钟源均停止

注:

- 1、 WDT 时钟源为 LIRC, WDT 开启时 LIRC 将一直工作而不受系统工作模式影响;
- 2、 禁止在 HFEN=1 时执行 STOP 指令, 否则 CPU 将无法正常唤醒;

#### 工作模式切换示意图



#### 高低频时钟切换时序图



#### 振荡器模式寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| OSCMR | -      | -      | STBL   | STBH   | -      | CLKS   | LFEN   | HFEN   |
| R/W   | -      | -      | R      | R      | -      | R/W    | R/W    | R/W    |
| 初始值   | -      | -      | X      | 1      | -      | 0      | 0      | 0      |

BIT[5] STBL - 低频时钟源振荡状态标志位

0: 低频时钟源停振或未稳定;

1: 低频时钟源已稳定振荡;

BIT[4] STBH - 高频时钟源振荡状态标志位

0: 高频时钟源停振或未稳定;

1: 高频时钟源已稳定振荡;

*晟矽微电* 25/79



BIT[2] CLKS - CPU 时钟源选择位

0: 系统高频时钟作为 CPU 时钟源;

1: 系统低频时钟作为 CPU 时钟源;

BIT[1] LFEN - 低频时钟源使能位

0: 在休眠/HOLD 模式下,低频时钟源暂停工作;

1: 低频时钟源始终工作;

BIT[0] HFEN - 高频时钟源使能位

0: 在低速/休眠/HOLD 模式下,高频时钟源暂停工作;

1: 高频时钟源始终工作;

#### 4.4 低功耗模式

芯片的高速模式、低速模式为运行模式,而休眠模式、HOLD模式则为低功耗模式。 执行 STOP 指令可使系统进入低功耗模式,同时对系统会产生以下影响:

- ♦ CPU 停止运行;
- ◇ 根据不同模式停止相应时钟源的振荡;
- ♦ RAM 内容保持不变;
- ◇ 所有的输入/输出端口保持原有状态;
- ◇ 定时器若其时钟源未停止,则可继续工作;

#### 以下情况可使系统退出低功耗模式:

- ◇ 芯片复位;
- ◆ WDT 溢出(若低功耗模式下 WDT 及其时钟源保持继续工作);
- ◆ 外部中断请求发生(若有外部中断功能并有效);
- ◆ 定时器中断请求发生(若低功耗模式下定时器及其时钟源保持继续工作);
- ◆ 键盘中断请求发生(若有键盘中断功能并有效);
- ◇ 比较器 CMP 中断请求发生(若低功耗模式下比较器保持继续工作);
- ◆ LVD 中断请求发生(若低功耗模式下 LVD 保持继续工作);

#### 注:

- 1、低功耗模式下触发中断请求时,若对应的中断使能位关闭,则不会退出低功耗模式;若对应的中断使能位开启而中断总使能位关闭,则仅唤醒 CPU 执行下一条指令;若对应的中断使能位和中断总使能位均开启,则唤醒 CPU 后将执行中断服务程序;
- 2、 未使用或未封出的引脚,应将其对应的 I/O 端口设置为输出、输入上拉或输入下拉等稳定状态,以免因引脚浮空 而产生漏电流或非预期的中断唤醒;

*晟矽微电* 26/79



# 5 复位

#### 5.1 复位条件

芯片共有如下几种复位方式:

- ◆ 上电复位 POR;
- ◆ 低电压复位 LVR;
- ◆ 外部复位;
- ♦ WDT 看门狗复位;

任何一种复位发生后,系统进入复位状态,执行初始化操作并重置 SFR 为复位初始值;复位条件解除后,系统退出 复位状态,CPU 重新从程序存储器 0000H 地址处开始运行。

芯片发生复位后会关闭系统主时钟振荡器,复位解除后才重新开启振荡器,因为振荡器起振和稳定需要一定的时间, 所以系统将保持一定时间的复位延时(典型值为 16ms)以待振荡器稳定振荡后才开始工作。

注:若应用系统在上电或掉电回升时芯片的 VDD 电压上升较慢,则应在复位后 CPU 开始工作时先进行软件延时,以确保芯片开始工作时 VDD 电压已稳定在 FCPU 对应的工作电压范围内。

#### 5.2 上电复位

芯片的上电复位电路可以适应系统快速上电或慢速上电等情况,即使上电过程中发生电源电压抖动的情况也能保证系统可靠的复位。

上电复位过程主要包括以下几个步骤:

- (1) 检测系统电源电压,等待电压高于上电复位电压 VPOR 并保持稳定;
- (2) 若 LVR 功能开启,则需等待电压高于低电压复位电压 VLVR 并保持稳定;
- (3) 若有外部复位功能并已开启,则需等待外部复位引脚电压高于 Vih;
- (4) 初始化所有初始值确定的寄存器;
- (5) 开启主时钟振荡器,并等待一段时间以待振荡器稳定;
- (6) 上电复位结束, CPU 开始执行指令;

#### 5.3 外部复位

芯片的外部复位功能可通过配置字 RSTEN 开启,引脚设为外部复位脚即为开启外部复位功能,端口内部上拉电阻将自动使能。外部复位输入端口 RST 为施密特结构,低电平有效,即当端口输入为高电平时系统正常运行,输入为低电平时系统复位。

#### 5.4 低电压复位

芯片的低电压复位电压 VLVR 可通过配置字 LVRVS 选择。LVR 检测电路具有一定的回滞特性,回滞电压约为 6%(典型值),当电源电压下降至 VLVR 时发生 LVR 复位,反之电源电压需上升至 VLVR+6%后 LVR 复位才解除。

*晟矽微电* 27/79



# 5.5 看门狗复位

芯片的看门狗定时器(WDT)复位是一种对系统运行程序的保护机制。正常情况下,用户程序需定时对 WDT 执行清零操作,以避免 WDT 溢出。若发生异常情况,程序未及时清零 WDT,则芯片将因 WDT 溢出而产生看门狗复位,系统初始化后重新运行程序,从而返回受控状态。

注:低功耗模式下 CPU 暂停工作,若此时发生 WDT 溢出,则仅唤醒 CPU 而不复位芯片。



晟矽微电 28/79



# 6 I/O 端口

## 6.1 通用 I/O 功能

芯片的输入/输出端口包括两组 8 位端口 P0、P1,和一组 2 位端口 P2。所有端口均支持施密特输入,均支持推挽输出。

除用作通用数字 I/O 端口外,部分端口还可复用为外部中断输入、PWM 输出、或 ADC 模拟输入等功能。

#### 端口数据寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| IOP0 | P07D   | P06D   | P05D   | P04D   | P03D   | P02D   | P01D   | P00D   |
| R/W  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值  | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0] P0nD - P0n 端口数据位(n=7-0)

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| IOP1 | P17D   | P16D   | P15D   | P14D   | P13D   | P12D   | P11D   | P10D   |
| R/W  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值  | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0] P1nD - P1n 端口数据位(n=7-0)

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| IOP2 | -      | ·      | -      | -      | 1      | 1      | P21D   | P20D   |
| R/W  | -      | -      | -      | -      | -      | -      | R/W    | R/W    |
| 初始值  | -      |        | -      | -      | -      | -      | Х      | Х      |

BIT[1:0] P2nD - P2n 端口数据位(n=1-0)

#### 端口方向寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| OEP0 | P070E  | P060E  | P050E  | P040E  | P030E  | P020E  | P010E  | P00OE  |
| R/W  | 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[7:0] P0nOE - P0n 端口输出使能位(n=7-0)

0: 端口作为输入口,读端口操作将读取端口的电平状态;1: 端口作为输出口,读端口操作将读取端口的数据位值;

| П |        |        |        |        |        |        |        |        |
|---|--------|--------|--------|--------|--------|--------|--------|--------|
|   | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |

晟矽微电 29/79





| OEP1 | P170E | P160E | P150E | P140E | P130E | P120E | P110E | P100E |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| R/W  | 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[7:0]

P1nOE – P1n 端口输出使能位(n=7-0)

0: 端口作为输入口,读端口操作将读取端口的电平状态; 1: 端口作为输出口,读端口操作将读取端口的数据位值;

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| OEP2 | 1      | 1      | 1      | 1      | 1      | -      | P210E  | P200E  |
| R/W  | -      | -      | -      | -      | -      | - ^    | R/W    | R/W    |
| 初始值  | -      | -      | -      | -      | -      |        | 0      | 0      |

BIT[1:0]

P2nOE – P2n 端口输出使能位(n=1-0)

0: 端口作为输入口,读端口操作将读取端口的电平状态;

1: 端口作为输出口,读端口操作将读取端口的数据位值;

#### 内部上/下拉电阻 6.2

所有端口均具有内部上拉和下拉电阻,且均可单独控制其上/下拉电阻在端口处于输入状态时是否有效。端口处于输 出状态时,上/下拉电阻及其控制位无效。

#### 上拉电阻控制寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| PUP0 | P07PU  | P06PU  | P05PU  | P04PU  | P03PU  | P02PU  | P01PU  | P00PU  |
| R/W  | 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[7:0]

P0nPU - P0n 端口上拉电阻控制位(n=7-0)

0: 端口内部上拉电阻无效;

1: 端口内部上拉电阻有效;

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| PUP1 | P17PU  | P16PU  | P15PU  | P14PU  | P13PU  | P12PU  | P11PU  | P10PU  |
| R/W  | 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[7:0]

P1nPU – P1n 端口上拉电阻控制位(n=7-0)

0: 端口内部上拉电阻无效;

1: 端口内部上拉电阻有效;

晟矽微电 30/79



MC32F7062B I/O 端口



|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| PUP2 | -      | -      | -      | -      | -      | -      | P21PU  | P20PU  |
| R/W  | -      | -      | -      | -      | -      | -      | R/W    | R/W    |
| 初始值  | -      | -      | -      | -      | -      | -      | 0      | 0      |

BIT[1:0]

P2nPU - P2n 端口上拉电阻控制位(n=1-0)

0: 端口内部上拉电阻无效;1: 端口内部上拉电阻有效;

#### 下拉电阻控制寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| PDP0 | P07PD  | P06PD  | P05PD  | P04PD  | P03PD  | P02PD  | P01PD  | P00PD  |
| R/W  | 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[7:0]

P0nPD - P0n 端口下拉电阻控制位(n=7-0)

0: 端口内部下拉电阻无效;

1: 端口内部下拉电阻有效;

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| PDP1 | P17PD  | P16PD  | P15PD  | P14PD  | P13PD  | P12PD  | P11PD  | P10PD  |
| R/W  | 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[7:0]

P1nPD - P1n 端口下拉电阻控制位(n=7-0)

0: 端口内部下拉电阻无效;

1: 端口内部下拉电阻有效;

|      | Bit[7]   | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|----------|--------|--------|--------|--------|--------|--------|--------|
| PDP2 | -        | -      | -      | -      | -      | -      | P21PD  | P20PD  |
| R/W  | -        | -      | -      | -      | -      | -      | R/W    | R/W    |
| 初始值  | <b>,</b> | -      | -      | -      | -      | -      | 0      | 0      |

BIT[1:0]

P2nPD – P2n 端口下拉电阻控制位(n=1-0)

0: 端口内部下拉电阻无效;1: 端口内部下拉电阻有效;

### 6.3 端口模式控制

部分端口除可作为数字端口外,还可复用为模拟端口。端口输入或输出模拟信号时,若数字 I/O 功能同时开启,则会产生漏电流,可通过端口数模控制寄存器关闭端口的数字 I/O 功能(内部上/下拉电阻及其控制位不受影响)。

*晟矽微电* 31/79





#### 端口数模控制寄存器

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| P0ADCR | P07DC  | P06DC  | P05DC  | P04DC  | P03DC  | P02DC  | P01DC  | P00DC  |
| R/W    |
| 初始值    | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

BIT[7:0]

P0nDC – P0n 端口数字功能控制位(n=7-0)

0: 使能端口的数字 I/O 功能;1: 关闭端口的数字 I/O 功能;

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| P1ADCR | P17DC  | P16DC  | P15DC  | P14DC  | P13DC  | -      | P11DC  | P10DC  |
| R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |        | R/W    | R/W    |
| 初始值    | 0      | 0      | 0      | 0      | 0      |        | 0      | 0      |

BIT[7:3,1:0] P1nDC - P1n 端口数字功能控制位(n=7-3,1-0)

0: 使能端口的数字 I/O 功能;1: 关闭端口的数字 I/O 功能;

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| P2ADCR | -      | -      |        |        | -      | -      | P21DC  | P20DC  |
| R/W    | -      | - ^    | -      | -      | -      | -      | R/W    | R/W    |
| 初始值    | -      |        | -      | -      | -      | -      | 0      | 0      |

BIT[1:0] P2nDC - P2n 端口数字功能控制位(n=1-0)

0: 使能端口的数字 I/O 功能;

1: 关闭端口的数字 I/O 功能;

*晟矽微电* 32/79



## 7 定时器 TIMER

#### 7.1 看门狗定时器 WDT

看门狗定时器 WDT 的时钟源为内部低频 RC 振荡器 LIRC,WDT 溢出将复位芯片或唤醒 CPU。

可通过配置字 WDTM 设置 WDT 工作模式:选择始终开启,则 WDT 一直工作,高速/低速模式下 WDT 溢出将复位芯片,休眠/HOLD 模式下 WDT 溢出将唤醒 CPU;选择低功耗模式下关闭,则 WDT 在休眠/HOLD 模式下自动关闭、在其他方式唤醒 CPU 后恢复工作。

执行 CLRWDT 指令或 STOP 指令将清零 WDT 计数器。

WDT 溢出时间可配置为 16ms/64ms/256ms/1024ms。

注: WDT 溢出时间为典型值,而实际值偏差较大,必须保证清 WDT 的间隔时间小于 WDT 溢出时间的 1/4。

#### 7.2 定时器 T0

定时器 T0 为 8 位定时/计数器,包含 1 个 8 位递减计数器、可编程预分频器、控制寄存器、8 位重载寄存器。

- ◇ 可通过预分频器设置时钟频率,可通过重载寄存器控制计数周期;
- ◇ 支持溢出中断和溢出唤醒功能;



定时器 T0,可通过寄存器位 T0CKS 选择时钟源,通过 T0PRS 选择时钟预分频比,所选时钟源通过预分频器后产生 T0 计数器 T0CNT 的计数时钟(上升沿计数)。写 T0CNT 将清零预分频计数器,而预分频比保持不变。

T0EN=0 时,T0CNT 保持不变,写重载寄存器 T0LOAD 将立即载入 T0CNT;T0EN=1 时,T0CNT 递减计数,计数到 0 的时钟结束后产生溢出信号并触发中断,中断标志 T0IF 将被置 1,同时 T0 自动将当前 T0LOAD 值载入 T0CNT 并重新开始计数。

如图所示,定时器 T0 可实现 BUZ 功能(BUZ0)。当 BUZ0OE=1 时,端口将输出频率为 T0 溢出频率 2 分频的蜂鸣器驱动信号。

定时器 T0 控制寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| T0CR | T0EN   | -      | BUZ00E | T0CKS1 | T0CKS0 | T0PRS2 | T0PRS1 | T0PRS0 |
| R/W  | R/W    | -      | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值  | 0      | -      | 0      | 0      | 0      | 0      | 0      | 0      |



BIT[7] TOEN - 定时器 TO 使能位

0: 关闭定时器 T0;

1: 开启定时器 TO;

BIT[5] BUZ0OE - BUZ0 端口输出使能位

0: 禁止端口输出蜂鸣器驱动波形;1: 允许端口输出蜂鸣器驱动波形;

BIT[4:3] TOCKS[1:0] - TO 时钟源选择位

| T0CKS[1:0] | TO 时钟源  |
|------------|---------|
| 00         | Fcpu    |
| 01         | Fhosc   |
| 10         | FLOSC   |
| 11         | TC0 上升沿 |

BIT[2:0] TOPRS[2:0] - TO 时钟预分频比选择位

| T0PRS[2:0] | T0 时钟预分频比 |
|------------|-----------|
| 000        | 1:1       |
| 001        | 1:2       |
| 010        | 1:4       |
| 011        | 1:8       |
| 100        | 1:16      |
| 101        | 1:32      |
| 110        | 1:64      |
| 111        | 1:128     |

#### 定时器 T0 计数器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| TOCNT | T0CNT7 | T0CNT6 | T0CNT5 | T0CNT4 | T0CNT3 | T0CNT2 | T0CNT1 | T0CNT0 |
| R/W   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值   | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

BIT[7:0] T0CNT[7:0] - T0 计数器,为可读写的递减计数器

#### 定时器 T0 重载寄存器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| T0LOAD | T0LOAD7 | T0LOAD6 | T0LOAD5 | T0LOAD4 | T0LOAD3 | T0LOAD2 | T0LOAD1 | T0LOAD0 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| 初始值    | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

BIT[7:0] TOLOAD[7:0] - TO 重载寄存器,用于设置 TO 的计数周期

*晟矽微电* 34/79





注:定时器重载寄存器的值禁止为 0,否则定时器将无法正常工作。

#### 7.3 定时器 T1

定时器 T1 为 16 位定时/计数器,包含 1 个 16 位递减计数器、可编程预分频器、控制寄存器、16 位重载寄存器。

- ◇ 可通过预分频器设置时钟频率,可通过重载寄存器控制计数周期;
- ◇ 支持内/外部信号的上升/下降沿输入捕捉功能,支持 T1 捕捉中断功能;
- ◇ 支持溢出中断和溢出唤醒功能;



定时器 T1,可通过寄存器位 T1CKS 选择时钟源,通过 T1PRS 选择时钟预分频比,所选时钟源通过预分频器后产生 T1 计数器 T1CNT 的计数时钟(上升沿计数)。写 T1CNT 将清零预分频计数器,而预分频比保持不变。

16 位 T1CNT 的高字节 T1CNTH 配有缓冲器,读写 T1CNTH 实际为读写缓冲器中内容,T1CNTH 实际内容仅在读写 T1CNTL 时才自动与缓冲器交互,因此写 T1CNT 需先写 T1CNTH 再写 T1CNTL (硬件同时自动将缓存器内容载入 T1CNTH),而读 T1CNT 则需先读 T1CNTL(硬件同时自动将 T1CNTH 内容载入缓冲器中)再读 T1CNTH。

T1EN=0 时,T1CNT 保持不变,写重载寄存器 T1LOAD 将立即载入 T1CNT;T1EN=1 时,T1CNT 递减计数,计数到 0 的时钟结束后产生溢出信号并触发中断,中断标志 T1IF 将被置 1,同时 T1 自动将当前 T1LOAD 值载入 T1CNT 并重新开始计数。

16 位 T1LOAD 的高字节 T1LOADH 配有缓冲器(T1LDHbuf),写 T1LOADL 时会同时将 T1LOADH 内容载入该缓冲器中,因此调整 T1LOAD 值时需先写 T1LOADH 再写 T1LOADL。此时若 T1EN=0,则会同时再将[缓冲器:T1LOADL]载入 T1CNT;若 T1EN=1,则会在 T1 溢出后才将[缓冲器:T1LOADL]载入 T1CNT。

如图所示,定时器 T1 可实现 BUZ 功能(BUZ1)。当 BUZ1OE=1 时,端口将输出频率为 T1 溢出频率 2 分频的蜂鸣器驱动信号。

如图所示,定时器 T1 可实现内/外部信号上升沿或下降沿的输入捕捉功能。通过寄存器位 T1MOD 选择输入捕捉模式,当 T1CEOC 为 1 时写 0 启动 T1 捕捉功能,若 T1CINS 选定的输入信号产生起始沿(T1CSTR 选择),则 T1 开始计数(若计数溢出则自动重载),当输入信号产生终止沿(T1CSTP 选择)时,T1 停止计数且 T1CNT 保持当前值,T1CEOC 自动置 1,同时中断标志 T1CIF 置 1 触发 T1 捕捉中断。通过 T1CNT 前后计数的差值,即可获得输入信号起始沿与终止沿之间的时间宽度。T1 捕捉功能还可通过 T1CCT 选择捕捉沿的个数,以获得 1 个高/低电平脉冲信号的时间宽度(起始沿和终止沿方向相反)或 1/4/8/16 个周期信号的时间宽度(起始沿和终止沿方向相同)。

*晟矽微电* 35/79





输入捕捉模式中,在捕捉完成后 T1CEOC 自动置 1,需再次写 0 才能重新启动捕捉功能。在终止沿捕捉完成停止计 数到起始沿再次触发恢复计数的期间,T1CNT将一直保持原值,若要调整则需重新写 T1LOAD 或 T1CNT。

#### T1 输入捕捉示意



定时器 T1 控制寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| T1CR0 | T1EN   | T1MOD  | BUZ10E | T1CKS1 | T1CKS0 | T1PRS2 | T1PRS1 | T1PRS0 |
| R/W   | 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**[7] T1EN - 定时器 T1 使能位

0: 关闭定时器 T1;

1: 开启定时器 T1;

BIT[6] T1MOD - T1 工作模式选择位

0: 定时/计数/BUZ 模式;

1: 输入捕捉模式;

BUZ1OE - BUZ1 端口输出使能位 BIT[5]

0: 禁止端口输出蜂鸣器驱动波形;

1: 允许端口输出蜂鸣器驱动波形;

BIT[4:3] T1CKS[1:0] - T1 时钟源选择位

| T1CKS[1:0] | T1 时钟源  |
|------------|---------|
| 00         | Fcpu    |
| 01         | Fhosc   |
| 10         | FLOSC   |
| 11         | TC1 上升沿 |

BIT[2:0] T1PRS[2:0] - T1 时钟预分频比选择位

晟矽微电

36/79



| T1PRS[2:0] | T1 时钟预分频比 |
|------------|-----------|
| 000        | 1:1       |
| 001        | 1:2       |
| 010        | 1:4       |
| 011        | 1:8       |
| 100        | 1:16      |
| 101        | 1:32      |
| 110        | 1:64      |
| 111        | 1:128     |

|       | Bit[7] | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|---------|---------|---------|--------|--------|--------|--------|
| T1CR1 | T1CEOC | T1CINS2 | T1CINS1 | T1CINS0 | T1CSTR | T1CSTP | T1CCT1 | T1CCT0 |
| R/W   | 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[7] T1CEOC - T1 输入捕捉控制位

0: 输入捕捉等待起始沿触发或正在计数中,终止沿捕捉完成后自动置1;

1: 输入捕捉未启动或已完成,写 0 启动输入捕捉;

BIT[6:4] T1CINS[2:0] - T1 输入捕捉信号源选择位

| T1CINS[2:0] | T1 输入捕捉信号源 |
|-------------|------------|
| 000         | INT0       |
| 001         | INT1       |
| 010         | TC0        |
| 011         | TC1        |
| 100         | CMP_OUT    |
| 101         | -          |
| 110         | FLIRC      |
| 111         | -          |

BIT[3] T1CSTR-T1输入捕捉起始沿选择位

0: 上升沿触发捕捉计数;

1: 下降沿触发捕捉计数;

BIT[2] T1CSTP - T1 输入捕捉终止沿选择位

0: 上升沿终止捕捉计数;

1: 下降沿终止捕捉计数;

BIT[1:0] T1CCT[1:0] - T1 捕捉沿个数选择位

| T1CCT[1:0] | T1 捕捉沿个数 |
|------------|----------|
| 00         | 1 个      |
| 01         | 4个       |

*晟矽微电* 37/79



| 10 | 8个  |
|----|-----|
| 11 | 16个 |

#### 定时器 T1 计数器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1] | Bit[0] |
|--------|---------|---------|---------|---------|---------|---------|--------|--------|
| T1CNTH | T1CNT15 | T1CNT14 | T1CNT13 | T1CNT12 | T1CNT11 | T1CNT10 | T1CNT9 | T1CNT8 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W    | R/W    |
| 初始值    | 1       | 1       | 1       | 1       | 1       | 1       | 1      | 1      |

BIT[7:0] T1CNT[15:8] - T1 计数器高 8 位,为可读写的递减计数器

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| T1CNTL | T1CNT7 | T1CNT6 | T1CNT5 | T1CNT4 | T1CNT3 | T1CNT2 | T1CNT1 | T1CNT0 |
| R/W    |
| 初始值    | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

BIT[7:0] T1CNT[7:0] - T1 计数器低 8 位,为可读写的递减计数器

#### 定时器 T1 重载寄存器

|         | Bit[7]   | Bit[6]   | Bit[5]   | Bit[4]   | Bit[3]   | Bit[2]   | Bit[1]  | Bit[0]  |
|---------|----------|----------|----------|----------|----------|----------|---------|---------|
| T1LOADH | T1LOAD15 | T1LOAD14 | T1LOAD13 | T1LOAD12 | T1LOAD11 | T1LOAD10 | T1LOAD9 | T1LOAD8 |
| R/W     | R/W      | R/W      | R/W      | R/W      | R/W      | R/W      | R/W     | R/W     |
| 初始值     | 1        | 1        | 1        | 1        | 1        | 1        | 1       | 1       |

BIT[7:0] T1LOAD[15:8] - T1 重载寄存器高 8 位,用于设置 T1 的计数周期

|         | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| T1LOADL | T1LOAD7 | T1LOAD6 | T1LOAD5 | T1LOAD4 | T1LOAD3 | T1LOAD2 | T1LOAD1 | T1LOAD0 |
| R/W     |
| 初始值     | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

BIT[7:0] T1LOAD[7:0] - T1 重载寄存器低 8 位,用于设置 T1 的计数周期

注:定时器重载寄存器的值禁止为0,否则定时器将无法正常工作。

## 7.4 定时器 T2

定时器 T2 为 8 位定时器,包含 1 个 8 位递减计数器、可编程预分频器、控制寄存器、8 位重载寄存器和 8 位比较寄存器。

- ◇ 可通过预分频器设置时钟频率,可通过重载寄存器控制计数周期;
- ◇ 支持溢出中断和溢出唤醒功能;

晟矽微电 38/79

定时器 TIMER



#### 8位定时器T2示意图



定时器 T2,可通过寄存器位 T2CKS 选择时钟源,通过 T2PRS 选择时钟预分频比,所选时钟源通过预分频器后产生 T2 计数器 T2CNT 的计数时钟(上升沿计数)。写 T2CNT 将清零预分频计数器,而预分频比保持不变。

T2EN=0 时,T2CNT 保持不变,写重载寄存器 T2LOAD 将立即载入 T2CNT;T2EN=1 时,T2CNT 递减计数,计数到 0 的时钟结束后产生溢出信号并触发中断,中断标志 T2IF 将被置 1,同时 T2 自动将当前 T2LOAD 值载入 T2CNT 并重新开始计数。

如图所示,定时器 T2 可实现 PWM 功能,可通过寄存器位使能或关闭 PWM 功能,并控制端口是否输出 PWM 波形。 PWM2 关闭时 T2PWM 信号为低电平。PWM2 使能后 T2CNT 从重载值开始递减计数直到计数溢出为一个 PWM 周期:当计数到与比较寄存器 T2DATA 相等时,T2PWM 变为高电平;当计数溢出时,T2PWM 变为低电平。

T2DATA 配有 1 个 8 位比较缓冲器(T2DT\_buf)用于与 T2CNT 比较,PWM2 关闭时写 T2DATA 将立即载入缓冲器中,而 PWM2 使能后写 T2DATA 则将在 T2 溢出时才载入缓冲器中。若要首个 PWM 周期和占空比准确,需先写重载寄存器和比较寄存器,再使能 PWM,最后开启定时器。

T2PWM 信号的占空比计算如下:

- ◆ 高电平时间 = (T2DATA) × T2CNT 计数时钟周期
- ◆ 周期(T2溢出时间) = (T2LOAD + 1) × T2CNT 计数时钟周期
- ♦ 占空比(高电平时间/周期) = (T2DATA) / (T2LOAD + 1)

## 定时器 T2 控制寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| T2CR | T2EN   | PWM2EN |        | T2CKS1 | T2CKS0 | T2PRS2 | T2PRS1 | T2PRS0 |
| R/W  | 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[7] T2EN - 定时器 T2 使能位

0: 关闭定时器 T2;

1: 开启定时器 T2;

BIT[6] PWM2EN - PWM2 使能位

0: 关闭 PWM2 功能;

1: 使能 PWM2 功能;

BIT[4:3] T2CKS[1:0] - T2 时钟源选择位

| T2CKS[1:0] T2 时钟源 |
|-------------------|
|-------------------|

*晟矽微电* 39/79



| 00 | Fcpu  |
|----|-------|
| 01 | Fhosc |
| 10 | FLOSC |
| 11 | -     |

BIT[2:0] T2PRS[2:0] - T2 时钟预分频比选择位

| T2PRS[2:0] | T2 时钟预分频比 |
|------------|-----------|
| 000        | 1:1       |
| 001        | 1:2       |
| 010        | 1:4       |
| 011        | 1:8       |
| 100        | 1:16      |
| 101        | 1:32      |
| 110        | 1:64      |
| 111        | 1:128     |

## 定时器 T2 计数器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| T2CNT | T2CNT7 | T2CNT6 | T2CNT5 | T2CNT4 | T2CNT3 | T2CNT2 | T2CNT1 | T2CNT0 |
| R/W   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值   | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

## 定时器 T2 重载寄存器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| T2LOAD | T2LOAD7 | T2LOAD6 | T2LOAD5 | T2LOAD4 | T2LOAD3 | T2LOAD2 | T2LOAD1 | T2LOAD0 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| 初始值    | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

BIT[7:0] T2LOAD[7:0] – T2 重载寄存器,用于设置 T2 的计数周期

注: 定时器重载寄存器的值禁止为 0,否则定时器将无法正常工作。

## 定时器 T2 比较寄存器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| T2DATA | T2DATA7 | T2DATA6 | T2DATA5 | T2DATA4 | T2DATA3 | T2DATA2 | T2DATA1 | T2DATA0 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| 初始值    | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

晟矽微电 40/79

MC32F7062B 定时器 TIMER



BIT[7:0] T2DATA[7:0] - T2 比较寄存器,用于设置 PWM2 的占空比

#### PWM2 控制寄存器

|         | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
| PWM2CR0 | 1      | -      | 1      | -      |        |        | PWM2NV | PWM2OE |
| R/W     | -      | -      | -      | -      |        |        | R/W    | R/W    |
| 初始值     | -      | -      | -      | -      |        |        | 0      | 0      |

BIT[1] PWM2NV - PWM2 端口输出取反控制位

0: 端口输出正向波形;

1: 端口对电平取反后输出;

BIT[0] PWM2OE - PWM2 端口输出使能位

0: 禁止端口输出脉宽调制波形;

1: 允许端口输出脉宽调制波形;

## 7.5 定时器 T3

定时器 T3 为 8 位定时器,包含 1 个 8 位递减计数器、可编程预分频器、控制寄存器、8 位重载寄存器和 3 个 8 位比较寄存器。

- ◆ 可通过预分频器设置时钟频率,可通过重载寄存器控制计数周期;
- ◆ 支持 3 路 8 位共周期 PWM 输出,可通过对应的比较寄存器分别设置每路 PWM 占空比;
- ◇ 支持溢出中断和溢出唤醒功能;



定时器 T3,可通过寄存器位 T3CKS 选择时钟源,通过 T3PRS 选择时钟预分频比,所选时钟源通过预分频器后产生 T3 计数器 T3CNT 的计数时钟(上升沿计数)。写 T3CNT 将清零预分频计数器,而预分频比保持不变。

T3EN=0 时,T3CNT 保持不变,写重载寄存器 T3LOAD 将立即载入 T3CNT;T3EN=1 时,T3CNT 递减计数,计数到 0 的时钟结束后产生溢出信号并触发中断,中断标志 T3IF 将被置 1,同时 T3 自动将当前 T3LOAD 值载入 T3CNT 并重新开始计数。

*晟矽微电* 41/79



定时器 TIMER



如图所示,定时器 T3 可实现 3 路共周期的 PWM 功能(PWM3x,x=A,B,C,下同),可分别设置每路 PWM 占空比,可通过寄存器位使能或关闭 PWM 功能,并控制端口是否输出 PWM 波形。PWM3x 关闭时 T3PWMx 信号为低电平。PWM3x 使能后 T3CNT 从重载值开始递减计数直到计数溢出为一个 PWM 周期: 当计数到与比较寄存器 T3DATx 相等时,T3PWMx 变为高电平;当计数溢出时,T3PWMx 变为低电平。

T3DATx 均配有 1 个 8 位比较缓冲器(T3Dx\_buf)用于与 T3CNT 比较,PWM3x 关闭时写 T3DATx 将立即载入缓冲器中,而 PWM3x 使能后写 T3DATx 则将在 T3 溢出时才载入缓冲器中。若要首个 PWM 周期和占空比准确,需先写重载寄存器和比较寄存器,再使能 PWM,最后开启定时器。

T3PWMx 信号(x=A,B,C,下同)的占空比计算如下:

- ◆ 高电平时间 = (T3DATx) × T3CNT 计数时钟周期
- ◆ 周期(T3 溢出时间) = (T3LOAD + 1) × T3CNT 计数时钟周期
- ♦ 占空比(高电平时间/周期) = (T3DATx) / (T3LOAD + 1)

#### 定时器 T3 控制寄存器

|      | Bit[7] | Bit[6]  | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|---------|--------|--------|--------|--------|--------|--------|
| T3CR | T3EN   | PWM3AEN |        | T3CKS1 | T3CKS0 | T3PRS2 | T3PRS1 | T3PRS0 |
| R/W  | R/W    | R/W     |        | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值  | 0      | 0       |        | 0      | 0      | 0      | 0      | 0      |

BIT[7] T3EN - 定时器 T3 使能位

0: 关闭定时器 T3;

1: 开启定时器 T3;

BIT[6] PWM3AEN - PWM3A 使能位

0: 关闭 PWM3A 功能;

1: 使能 PWM3A 功能;

BIT[4:3] T3CKS[1:0] - T3 时钟源选择位

| T3CKS[1:0] | T3 时钟源 |
|------------|--------|
| 00         | Fcpu   |
| 01         | Fhosc  |
| 10         | FLOSC  |
| 11         | -      |

BIT[2:0] T3PRS[2:0] - T3 时钟预分频比选择位

| T3PRS[2:0] | T3 时钟预分频比 |
|------------|-----------|
| 000        | 1:1       |
| 001        | 1:2       |
| 010        | 1:4       |
| 011        | 1:8       |
| 100        | 1:16      |
| 101        | 1:32      |

*晟矽微电* 42/79



| 110 | 1:64  |
|-----|-------|
| 111 | 1:128 |

## 定时器 T3 计数器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| T3CNT | T3CNT7 | T3CNT6 | T3CNT5 | T3CNT4 | T3CNT3 | T3CNT2 | T3CNT1 | T3CNT0 |
| R/W   | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值   | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

BIT[7:0] T3CNT[7:0] - T3 计数器,为可读写的递减计数器

#### 定时器 T3 重载寄存器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| T3LOAD | T3LOAD7 | T3LOAD6 | T3LOAD5 | T3LOAD4 | T3LOAD3 | T3LOAD2 | T3LOAD1 | T3LOAD0 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| 初始值    | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

BIT[7:0]

T3LOAD[7:0] - T3 重载寄存器,用于设置 T3 的计数周期

注: 定时器重载寄存器的值禁止为 0,否则定时器将无法正常工作。

## 定时器 T3 比较寄存器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| T3DATA | T3DATA7 | T3DATA6 | T3DATA5 | T3DATA4 | T3DATA3 | T3DATA2 | T3DATA1 | T3DATA0 |
| R/W    | 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[7:0] T3DATA[7:0] – T3 比较寄存器 A,用于设置 PWM3A 的占空比

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| T3DATB | T3DATB7 | T3DATB6 | T3DATB5 | T3DATB4 | T3DATB3 | T3DATB2 | T3DATB1 | T3DATB0 |
| R/W    | 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[7:0]

T3DATB[7:0] - T3 比较寄存器 B,用于设置 PWM3B 的占空比

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| T3DATC | T3DATC7 | T3DATC6 | T3DATC5 | T3DATC4 | T3DATC3 | T3DATC2 | T3DATC1 | T3DATC0 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| 初始值    | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

晟矽微电 43/79





#### BIT[7:0] T3DATC[7:0] - T3 比较寄存器 C,用于设置 PWM3C 的占空比

#### PWM3 控制寄存器

|         | Bit[7]  | Bit[6]  | Bit[5] | Bit[4] | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0] |
|---------|---------|---------|--------|--------|---------|---------|---------|--------|
| PWM3CR0 | PWM3CEN | PWM3BEN |        |        | PWM3CNV | PWM3BNV | PWM3ANV |        |
| R/W     | R/W     | R/W     |        |        | R/W     | R/W     | R/W     |        |
| 初始值     | 0       | 0       |        |        | 0       | 0       | 0       |        |

BIT[7] PWM3CEN - PWM3C 使能位

0: 关闭 PWM3C 功能;

1: 使能 PWM3C 功能;

BIT[6] PWM3BEN – PWM3B 使能位

0: 关闭 PWM3B 功能;

1: 使能 PWM3B 功能;

BIT[3] PWM3CNV - T3PWMC 信号取反控制位

0: 脉宽调制信号电平不取反;

1: 脉宽调制信号电平取反;

BIT[2] PWM3BNV - T3PWMB 信号取反控制位

0: 脉宽调制信号电平不取反;

1: 脉宽调制信号电平取反;

BIT[1] PWM3ANV - T3PWMA 信号取反控制位

0: 脉宽调制信号电平不取反;

1: 脉宽调制信号电平取反;

注:控制位 PWM3ANV 对从 P01,P05 输出的 T3PWMA 信号都有效。

|         | Bit[7] | Bit[6] | Bit[5]  | Bit[4] | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0] |
|---------|--------|--------|---------|--------|---------|---------|---------|--------|
| PWM3CR1 |        | -      | PWM3A1E |        | PWM3COE | PWM3BOE | PWM3A0E |        |
| R/W     | -      | -      | R/W     |        | R/W     | R/W     | R/W     |        |
| 初始值     | -      | -      | 0       |        | 0       | 0       | 0       |        |

BIT[5] PWM3A1E - PWM3A (P05) 端口输出使能位

0: 禁止端口输出脉宽调制波形;

1: 允许端口输出脉宽调制波形;

BIT[3] PWM3COE - PWM3C (P03) 端口输出使能位

0: 禁止端口输出脉宽调制波形;

1: 允许端口输出脉宽调制波形;

BIT[2] PWM3BOE - PWM3B (P02) 端口输出使能位

0: 禁止端口输出脉宽调制波形;

1: 允许端口输出脉宽调制波形;

BIT[1] PWM3A0E - PWM3A (P01) 端口输出使能位

*晟矽微电* 



定时器 TIMER



0: 禁止端口输出脉宽调制波形;

1: 允许端口输出脉宽调制波形;



## 8 模数转换器 ADC

## 8.1 ADC 概述

芯片内置 1 个 12 位高精度逐次逼近型的模数转换器 ADC。

- → 14 路外部通道: AN0~AN13; 2 路内部通道: GND、VDD;
- ◆ 参考电压可选: VDD、内部参考电压 VIR (2V);
- ◆ ADC 时钟: FCPU 的 2/4/8/16 分频;
- ◆ 支持 1/1、3/4、1/2、1/4 内部增益;
- ◇ 支持零点校准;

ADC 模块可通过寄存器位 ADEN 开启,通过 ADCKS 选择转换时钟,通过 ADCHS 选择转换的模拟通道,通过 ADEOC 启动并标识 AD 转换状态。当 ADEOC 为 1 时写 0 将启动模数转换,转换完成后结果存入 ADRH/ADRL 中,ADEOC 自动 置 1,同时中断标志 ADIF 置 1 触发 ADC 中断。

MC32F7062B

ADC 的采样(SAMPLE)时间可选择 2/4/8/15 个 ADCLK(即 ADC 时钟周期),转换(CONVERT)时间固定为 12 个 ADCLK,一次 ADC 转换的时间为 14/16/20/27 个 ADCLK。

ADC 转换时序如下图所示:



注:

- 1、 AD 转换过程中或 ADEN 未使能时,ADRH/ADRL 中的数据未知,应在 AD 转换完成且 ADEN 使能的情况下读取 AD 转换结果数据;
- 2、 若选择内部参考电压 VIR,则需保证 VDD> (VIR+0.5V),否则 VIR 实际电压将降为 (VDD-0.5V);
- 3、 使能 ADC 模块,需延时(时间>40µs)以待电路稳定后才可启动 AD 转换;ADC 使能并保证延时稳定后,切换 参考电压操作,可以不需延时,直接启动 AD 转换;
- 4、 AD 转换精度受参考电压精度的影响,且内部参考电压下的转换精度,比外部参考电压下略低 2 个 LSB 左右;
- 5、 转换时钟越慢、采样时间越长,则越能过滤外部输入的波动,越能保证 AD 转换的精度;

## 8.2 ADC 相关寄存器

#### ADC 控制寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| ADCR0 | ADEN   | ADEOC  | ADCKS1 | ADCKS0 | ADCHS3 | ADCHS2 | ADCHS1 | ADCHS0 |

*晟矽微电* 46/79



| R/W |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 初始值 | 0   | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

BIT[7] ADEN - ADC 使能位

0: 关闭 ADC;

1: 开启 ADC;

BIT[6] ADEOC - AD 转换控制位

0: AD 转换中,完成后自动置 1;

1: 转换未开始或已完成,写 0 开始 AD 转换;

BIT[5:4] ADCKS[1:0] - ADC 转换时钟选择位

| ADCKS[1:0] | ADC 转换时钟 FADC |
|------------|---------------|
| 00         | Fcpu/2        |
| 01         | Fcpu/4        |
| 10         | Fcpu/8        |
| 11         | Fcpu/16       |

注:当参考电压选择 VDD 时,ADC 转换时钟不能大于 2MHz;当参考电压选择内部参考时,ADC 转换时钟不能大于 1MHz。

BIT[3:0] ADCHS[3:0] - ADC 模拟输入通道选择位

| ADCHS[3:0] | ADC 模拟输入通道 | ADCHS[3:0] | ADC 模拟输入通道       |
|------------|------------|------------|------------------|
| 0000       | AN0        | 1000       | AN8              |
| 0001       | AN1        | 1001       | AN9              |
| 0010       | AN2        | 1010       | AN10             |
| 0011       | AN3        | 1011       | AN11             |
| 0100       | AN4        | 1100       | AN12             |
| 0101       | AN5        | 1101       | AN13             |
| 0110       | AN6        | 1110       | VDD <sup>注</sup> |
| 0111       | AN7        | 1111       | GND              |

注:选择 VDD 通道,内部硬件固定打开 1/4 增益。

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| ADCR1 | ADRSEL |        | ADVRS1 | ADVRS0 | -      | -      | ADSPS1 | ADSPS0 |
| R/W   | R/W    |        | R/W    | R/W    | -      | -      | R/W    | R/W    |
| 初始值   | 0      |        | 0      | 0      | -      | -      | 0      | 0      |

BIT[7] ADRSEL - ADC 转换结果数据格式选择位

0: ADC 转换结果为 12 位数据, 高 8 位存入 ADRH[7:0]、低 4 位存入 ADRL[3:0];

1: ADC 转换结果为 12 位数据,高 4 位存入 ADRH[3:0]、低 8 位存入 ADRL[7:0];

*晟矽微电* 47/79



## BIT[5:4] ADVRS[1:0] - ADC 参考电压选择位

| ADVRS[1:0] | ADC 参考电压 |
|------------|----------|
| 00         | VDD      |
| 01         | 保留,禁止使用  |
| 10         | 保留,禁止使用  |
| 11         | 内部 2.0V  |

## BIT[1:0] ADSPS[1:0] - ADC 采样时间选择位

| ADSPS[1:0] | ADC 采样时间   |
|------------|------------|
| 00         | 15 个 ADCLK |
| 01         | 8 个 ADCLK  |
| 10         | 4个ADCLK    |
| 11         | 2个ADCLK    |

## 辅助功能控制寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2]  | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|---------|--------|--------|
| AFCR |        |        |        |        |        | CMPNDIV | ADCGS1 | ADCGS0 |
| R/W  |        |        |        |        |        | R/W     | R/W    | R/W    |
| 初始值  |        |        |        |        |        | 0       | 0      | 0      |

## BIT[1:0] ADCGS[1:0] - ADC 内部增益选择位

| ADCGS[1:0] | ADC 内部增益 |
|------------|----------|
| 00         | × 1      |
| 01         | × 0.75   |
| 10         | × 0.5    |
| 11         | × 0.25   |

注: 当通道选择 VDD(ADCHS[3:0]=1110b)时,硬件控制增益固定为 0.25 (1/4),此控制位无效。

## ADC 转换结果寄存器

## ADRSEL=0:

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| ADRH | ADR11  | ADR10  | ADR9   | ADR8   | ADR7   | ADR6   | ADR5   | ADR4   |
| R/W  | R      | R      | R      | R      | R      | R      | R      | R      |
| 初始值  | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      |

BIT[7:0] ADR[11:4] - 12 位 ADC 转换结果高 8 位

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| ADRL | -      | -      | -      | -      | ADR3   | ADR2   | ADR1   | ADR0   |

*晟矽微电* 48/79







| R/W | - | - | - | - | R | R | R | R |
|-----|---|---|---|---|---|---|---|---|
| 初始值 | - | - | - | - | Χ | Χ | Χ | Χ |

BIT[3:0]

ADR[3:0] - 12 位 ADC 转换结果低 4 位

#### ADRSEL=1:

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| ADRH | -      | -      | -      | -      | ADR11  | ADR10  | ADR9   | ADR8   |
| R/W  | -      | -      | -      | -      | R      | R      | R      | R      |
| 初始值  | -      | -      | -      | -      | Х      | Х      | X      | Х      |

BIT[3:0]

ADR[11:8] - 12 位 ADC 转换结果高 4 位

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| ADRL | ADR7   | ADR6   | ADR5   | ADR4   | ADR3   | ADR2   | ADR1   | ADR0   |
| R/W  | R      | R      | R      | R      | R      | R      | R      | R      |
| 初始值  | Х      | Х      | Х      | Х      | Х      | X      | Х      | Х      |

BIT[7:0]

ADR[7:0] - 12 位 ADC 转换结果低 8 位

## ADC 零点偏移修调控制寄存器

|         | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| OSADJCR | OSADJEN | OSADJTD | OSADJT5 | OSADJT4 | OSADJT3 | OSADJT2 | OSADJT1 | OSADJT0 |
| R/W     |
| 初始值     | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

BIT[7] OSADJEN - ADC 零点偏移修调使能位

0: ADC 零点偏移修调无效;

1: ADC 零点偏移修调有效;

OSADJTD - ADC 零点偏移修调方向选择位 BIT[6]

0: 负向修调,即根据修调电压减小转换值(转换结果大于理论值时应选择负向修调);

1: 正向修调,即根据修调电压增加转换值(转换结果小于理论值时应选择正向修调);

BIT[5:0] OSADJT[5:0] - ADC 零点偏移修调电压选择位

| OSADJT[5:0] | 修调电压(典型值)    |
|-------------|--------------|
| 00 0000     | 0            |
| 00 0001     | 1×Vref/4096  |
| 00 0010     | 2×Vref/4096  |
|             |              |
| 00 1111     | 15×VREF/4096 |
| 01 0000     | 16×VREF/4096 |

晟矽微电 49/79



| 11 1110 | 62×VREF/4096 |
|---------|--------------|
| 11 1111 | 63×VREF/4096 |

## 8.3 ADC 操作步骤

#### 模数转换操作步骤:

- (1) 设置相应端口为输入端口,关闭端口的内部上/下拉电阻;
- (2) 通过端口数模控制寄存器,关闭相应端口的数字 I/O 功能;
- (3) 若转换时钟可选,则设置 ADCKS,选择适当的转换时钟;
- (4) 若采样时间可选,则设置 ADSPS,选择适当的采样时间;
- (5) 若参考电压可选,则设置 ADVRS,选择适当的参考电压;
- (6) 若输入电压增益可选,则设置 ADCGS,选择适当的增益系数;
- (7) 若数据格式可选,则设置 ADRSEL,选择 ADC 转换结果的数据格式;
- (8) ADEN 置 1, 使能 ADC 模块;
- (9) 设置 ADCHS,选择 ADC 转换通道;
- (10) 延时等待电路稳定后, ADEOC 写 0, 启动 AD 转换;
- (11) 等待 ADEOC 硬件置 1 (或利用 ADC 中断);
- (12) 读取 ADC 转换结果 (ADRH/ADRL);
- (13) 重复执行(8)~(11),对不同的通道进行转换或对同一通道进行多次转换;

## 8.4 ADC 零点偏移修调流程

- (1) 设置 ADC 输入通道为 GND,设置 ADC 时钟、采样时间等参数,设置 OSADJEN=1;
- (2) 设置 OSADJTD=0、OSADJT=00H, 进行 ADC 转换:
  - ◇ 若转换结果为 0,则执行(4);
  - → 若转换结果非 0,则执行(3);
- (3) OSADJT 自加 1 后进行 ADC 转换:
  - ◇ 若转换结果为 0,则跳至 (6);
  - → 若转换结果非 0,则循环执行(3),直到结果为 0 或 OSADJT=3FH 后,跳至(6);
- (4) 设置 OSADJTD=1、OSADJT=3FH, 进行 ADC 转换:
  - ◇ 若转换结果为 0,则跳至 (6);
  - ◇ 若转换结果非 0,则执行(5);
- (5) OSADJT 自减 1 后进行 ADC 转换:
  - ◇ 若转换结果为 0,则跳至(6);
  - ◆ 若转换结果非 0,则循环执行(5),直到结果为 0 或 OSADJT=00H 后,跳至(6);
- (6) OSADJTD 及 OSADJT[5:0]的值即为零点偏移最佳修调结果,修调流程结束,后续 ADC 工作时直接应用,无需再次修调。

*晟矽微电* 50/79



## 9 模拟比较器 CMP

## 9.1 CMP 概述

芯片内置 1 个模拟比较器 CMP,共模输入范围为  $0^{\sim}$ (VDD-1.4V),输入端失调电压可通过自消除寄存器进行调校,精度为 $\pm 2$ mV,输出无回滞且支持去抖处理。

CMP 的正端输入可通过 CMPPS 选择外部输入电压、GND、或 VDD 内部分压电压;负端输入可通过 CMPNS 选择多路外部输入电压,并支持分压选择,通过 CMPNDIV 控制。

CMP 的输出端电平可通过 CMPDB 选择去抖处理,去抖后的输出信号 CMP\_OUT 可从端口输出且支持输出取反,并可选择上升沿或下降沿触发 CMP 中断。



## 9.2 CMP 相关寄存器

## 比较器控制寄存器

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| CMPCR0 | CMPEN  | CMPDB2 | CMPDB1 | CMPDB0 | CMPNV  | СМРОЕ  | CMPIM  | CMPOF  |
| R/W    | R      |
| 初始值    | 0      | 0      | 0      | 0      | 0      | 0      | 0      | Х      |

BIT[7] CMPEN - 比较器 CMP 使能位

0: 关闭 CMP;

1: 开启 CMP;

BIT[6:4] CMPDB[2:0] - CMP 输出去抖时间选择位

| CMPDB[2:0] | CMP 输出去抖时间    |
|------------|---------------|
| 000        | 0(不去抖)        |
| 001        | 1个 Fcpu 时钟周期  |
| 010        | 2个 Fcpu 时钟周期  |
| 011        | 4个 Fcpu 时钟周期  |
| 100        | 8 个 Fcpu 时钟周期 |

*晟矽微电* 51/79



| 101 | 12 个 Fcpu 时钟周期 |
|-----|----------------|
| 110 | 16 个 Fcpu 时钟周期 |
| 111 | 32 个 Fcpu 时钟周期 |

BIT[3] CMPNV - CMPO 端口输出取反控制位

0: 端口输出 CMP 比较结果的正向电平;

1: 端口对 CMP 比较结果取反后输出;

BIT[2] CMPOE - CMPO 端口输出使能位

0: 禁止端口输出 CMP 比较结果;

1: 允许端口输出 CMP 比较结果;

BIT[1] CMPIM - CMP 中断触发方式选择位

0: CMP 输出信号 CMP\_OUT 的上升沿触发中断;

1: CMP 输出信号 CMP\_OUT 的下降沿触发中断;

BIT[0] CMPOF - CMP 比较结果状态标志位

0: CMP 比较结果为低,即比较器正端输入电压低于负端输入电压;或 CMP 关闭;

1: CMP 比较结果为高,即比较器正端输入电压高于负端输入电压;

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| CMPCR1 | -      | 1      | CMPPS3 | CMPPS2 | CMPPS1 | CMPPS0 | CMPNS1 | CMPNS0 |
| R/W    | -      | -      | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| 初始值    | -      | -      | 0      | 0      | 0      | 0      | 0      | 0      |

## BIT[5:2] CMPPS[3:0] - CMP 正端输入选择位

| CMPPS[3:0] | CMP 正端输入 | CMPPS[3:0] | CMP 正端输入   |
|------------|----------|------------|------------|
| 0000       | GND      | 1000       | 0.40×VDD   |
| 0001       | 0.05×VDD | 1001       | 0.45×VDD   |
| 0010       | 0.10×VDD | 1010       | 0.50×VDD   |
| 0011       | 0.15×VDD | 1011       | 0.55×VDD   |
| 0100       | 0.20×VDD | 1100       | 0.60×VDD   |
| 0101       | 0.25×VDD | 1101       | 0.65×VDD   |
| 0110       | 0.30×VDD | 1110       | 0.70×VDD   |
| 0111       | 0.35×VDD | 1111       | 外部 CMPP 输入 |

## BIT[1:0] CMPNS[1:0] - CMP 负端输入选择位

| CMPNS[1:0] | CMP 负端输入    |
|------------|-------------|
| 00         | 外部 CMPN0 输入 |
| 01         | 外部 CMPN1 输入 |
| 10         | 外部 CMPN2 输入 |
| 11         | 外部 CMPN3 输入 |

*晟矽微电* 52/79



#### 辅助功能控制寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2]  | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|---------|--------|--------|
| AFCR |        |        |        |        |        | CMPNDIV | ADCGS1 | ADCGS0 |
| R/W  |        |        |        |        |        | R/W     | R/W    | R/W    |
| 初始值  |        |        |        |        |        | 0       | 0      | 0      |

BIT[2] CN

CMPNDIV - CMPN 输入分压控制

0: 不分压; 1: 1/2 分压;

#### 比较器自消除寄存器

|        | Bit[7]  | Bit[6]  | Bit[5]  | Bit[4]  | Bit[3]  | Bit[2]  | Bit[1]  | Bit[0]  |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| CMPCLR | CMPCLRE | CMPCLRS | CMPCLR5 | CMPCLR4 | CMPCLR3 | CMPCLR2 | CMPCLR1 | CMPCLR0 |
| R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| 初始值    | 0       | 0       | 1       | 0       | 0       | 0       | 0       | 0       |

BIT[7] CMPCLRE - CMP 自消除模式使能位

0: 关闭 CMP 自消除模式;

1: 使能 CMP 自消除模式;

BIT[6] CMPCLRS - CMP 自消除参考源选择位

0: CMP 自消除参考源为其负端输入;

1: CMP 自消除参考源为其正端输入;

注: 自消除参考源应选择电压较为稳定的一路输入端,且参考源输入端的正、负极性不影响调校效果。

## 9.3 CMP 失调电压调校流程

- (1) 设置 CMPCLRE=1, 使能失调电压自消除模式;
- (2) 设置 CMPCLRS,选择比较器自消除参考源;
- (3) 设置 CMPCLR[5:0]=00H,等待至少 100μs 后读取标志位 CMPOF;
- (4) CMPCLR[5:0]自加 1,等待至少 100μs 后重新读取 CMPOF:
  - → 若 CMPOF 发生翻转,则表示已调校到位;
  - ◆ 若 CMPCLR[5:0]=3FH 而 CMPOF 仍未翻转,则表示共模输入超出范围,调校失败;
- (5) 循环执行(4),直到调校到位或调校失败;
- (6) 判断当前调校输出方向:
  - → 若 CMPCLR[5]=1,则 CMPCLR[4:0]保持当前值不变;
  - → 若 CMPCLR[5]=0,则 CMPCLR[4:0]减1作为校准值;
- (7) 设置 CMPCLRE=0,关闭自消除模式;

*晟矽微电* 53/79





## 10 低电压检测 LVD

芯片内置低电压检测模块 LVD,可通过寄存器位 LVDEN 开启,通过 LVDVS 选择电压检测阀值。当 VDD 电压降至电压检测阀值以下时检测状态标志位 LVDF 将被置 1,同时中断标志 LVDIF 置 1 触发 LVD 中断; 因 LVD 电路的回滞特性(回滞电压典型值为 6%),VDD 电压需恢复至电压检测阀值+6%后 LVDF 才被清 0(但中断标志不会自动清 0)。

MC32F7062B

注: 开启 LVD 或切换电压检测阀值等操作,需待电路稳定(时间>2ms)后 LVD 输出才有效。

#### LVD 控制寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| LVDCR | LVDEN  | -      | LVDVS2 | LVDVS1 | LVDVS0 | -      | -      | LVDF   |
| R/W   | R/W    | -      | R/W    | R/W    | R/W    | -      |        | R      |
| 初始值   | 0      | -      | 0      | 0      | 0      |        | -      | Х      |

BIT[7] LVDEN - 低电压检测 LVD 使能位

关闭 LVD;
 开启 LVD;

BIT[5:3] LVDVS[2:0] - LVD 电压检测阀值选择位

| LVDVS[2:0] | LVD 电压检测阀值 |
|------------|------------|
| 000        | 2.0V       |
| 001        | 2.2V       |
| 010        | 2.4V       |
| 011        | 2.6V       |
| 100        | 2.8V       |
| 101        | 3.2V       |
| 110        | 3.6V       |
| 111        | 4.0V       |

BIT[0] LVDF - LVD 检测状态标志位

0: VDD 电压高于电压检测阀值,或 LVD 关闭;

1: VDD 电压低于电压检测阀值;

*晟矽微电* 54/79



## 11 EEPROM 存储器

## 11.1 EEPROM 概述

芯片内置 128 字节的 EEPROM 型数据存储器,支持用户程序在带电运行中实时地读写数据。对 EEPROM 中数据的读写操作需通过控制寄存器 EECR、保护寄存器 EEPR、地址寄存器 EEAR 和数据寄存器 EEDR 进行。

写操作控制位 EEWRITE 置 1 将启动 EEPROM 写操作,EEDR 中的数据将被写入 EEAR 指向的 EEPROM 地址中,完成后 EEWRITE 自动清 0。为防止误触发 EEPROM 写操作,需先对 EEPR 写 5 SAH 再立即写 A5H,EEWRITE 才能置 1,中间不能插入其他操作(包括 NOP 操作),否则 EEWRITE 将无法置 1。在写 EEPR 前需先屏蔽中断,否则可能会因系统响应中断而导致 EEWRITE 无法置 1。

读操作控制位 EEREAD 置 1 将启动 EEPROM 读操作,EEAR 所指 EEPROM 地址中的数据将被读出并缓存于 EEDR,完成后 EEREAD 自动清 0。读操作需 2 个指令周期,且在 EEWRITE 为 1 时无效。

#### 注:

- 1、 EEPROM 读/写操作时,CPU 将暂停工作;
- 2、 EEPROM 操作的时钟为系统高频时钟 FHOSC, 因此在操作时需确保系统高频时钟源工作;
- 3、对 EECR、EEPR、EEAR 和 EEDR 的写操作,仅能通过 MOVRA 指令进行,其他指令的执行结果不确定;

## 11.2 EEPROM 相关寄存器

#### EEPROM 控制寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0]  |
|------|--------|--------|--------|--------|--------|--------|--------|---------|
| EECR | -      | -      | -      | -      | -      | -      | EEREAD | EEWRITE |
| R/W  | -      | -      | -      | -      | -      | -      | R/W    | R/W     |
| 初始值  | -      | -      |        | -      | -      | -      | 0      | 0       |

BIT[1] EEREAD – EEPROM 读操作控制位

0: 操作未开始或已完成,写 1 开始 EEPROM 读操作;

1: EEPROM 读操作中,完成后自动清 0;

BIT[0] EEWRITE - EEPROM 写操作控制位

0: 操作未开始或已完成,写1开始 EEPROM 写操作;

1: EEPROM 写操作中,完成后自动清 0;

注:应用程序中,在写 EECR 指令和下一条真正执行的指令之间,需增加至少 2 个 NOP 指令,以防止时序错误。

#### EEPROM 保护寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| EEPR | EEP7   | EEP6   | EEP5   | EEP4   | EEP3   | EEP2   | EEP1   | EEP0   |
| R/W  | W      | W      | W      | W      | W      | W      | W      | W      |
| 初始值  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

*晟矽微电* 55/79



BIT[7:0] EEP[7:0] - EEPROM 写操作保护控制位,需先写 5AH 再立即写 A5H, EEWRITE 才能置 1

#### EEPROM 地址寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| EEAR |        | EEA6   | EEA5   | EEA4   | EEA3   | EEA2   | EEA1   | EEA0   |
| R/W  |        | R/W    |
| 初始值  |        | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

BIT[7:0] EEA[6:0] - EEPROM 读写操作的 7 位地址

#### EEPROM 数据寄存器

|      | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|------|--------|--------|--------|--------|--------|--------|--------|--------|
| EEDR | EED7   | EED6   | EED5   | EED4   | EED3   | EED2   | EED1   | EED0   |
| R/W  | 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[7:0] EED[7:0] - EEPROM 读写操作的 8 位数据

## 11.3 EEPROM 操作示例

例如,先将数据 55H 写入 EEPROM 存储器 10H 中,再读取 EEPROM 存储器 11H 地址中内容:

MOVAI 10H

MOVRA EEAR ;将 10H 写入 EEAR

MOVAI 55H

MOVRA EEDR ;将 55H 写入 EEDR

BCLR GIE ;屏蔽中断

MOVAI 5AH

MOVRA EEPR ;使能 EE 操作,第 1 步:EEPR 写 5AH

MOVAI A5H

MOVRA EEPR ; 使能 EE 操作,第 2 步: EEPR 写 A5H

MOVAI 01H

MOVRA EECR ; 启动 EE 写操作,将数据 55H 写入 EEPROM 地址 10H 中

NOP ; 为防止时序错误,CPU 必须先执行 2-4 个 NOP 指令

NOP

BSET GIE ;允许中断

JBCLR EECR,0 ; 检查 EE 写操作是否完成

GOTO \$-1

MOVAI 11H

MOVRA EEAR ;将11H写入EEAR

MOVAI 02H

*晟矽微电* 56/79



MC32F7062B EEPROM 存储器

> MOVRA **EECR** ;启动 EE 读操作,读取 EEPROM 地址 11H 中内容

;为防止时序错误,CPU 必须先执行 2-4 个 NOP 指令 NOP

NOP

MOVAR EEDR ;从 EEDR 中读取数据





## 12 FLASH 烧录编程

## 12.1 FLASH 在板编程

芯片支持编程工具对芯片中程序存储器的在板不带电烧录编程,即在未上电的系统电路板上,借助编程工具,通过芯片的串行编程接口将用户程序代码烧录进芯片的程序存储器中。在板编程功能,可让用户先采用未编程的空芯片制造电路板而仅在产品交付前才将程序代码烧录进芯片,也方便用户直接在电路板上升级 FLASH 存储器中的程序代码。

芯片也支持对 EEPROM 型数据存储器的在板编程。

芯片的在板编程通过引脚 VDD、GND、PCK、PDT 实现,这些编程引脚的外围电路需进行针对性设计,以保证外围电路不会影响在板编程时端口上的电压/电流/时序等特性。下图是典型的在板编程连接示意图:



芯片也支持在板带电烧录编程,即可在系统电路板不掉电(芯片已正常工作)的状态下对存储器编程。当配置字 DBGPIN0/DBGPIN1 允许寄存器位控制后,再通过寄存器位 DBG0EN/DBG1EN 将对应的端口设为编程端口,则端口的通用功能被屏蔽,芯片可通过该组端口进入编程/仿真模式。

#### 注:

- 1、 不支持空芯片的在板带电烧录编程;
- 2、 在板带电烧录,编程器 VCC 不接入电路板,芯片由系统电路板通过 VDD 引脚供电;
- 3、 在板带电烧录,编程器 GND/CLK/DATA 接入电路板前,需注意连接端口之间电压特性是否匹配,尤其需注意编程器与系统电路板的共 GND 是否会发生浮地与市电地短路的问题;
- 4、 在板带电烧录,编程器在烧录完成后,会将芯片重新复位;

## DEBUG 控制寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| DBGCR | -      | -      | 1      | 1      | -      | -      | DBG1EN | DBG0EN |
| R/W   | -      | -      | -      | -      | -      | -      | R/W    | R/W    |
| 初始值   | -      | -      | -      | -      | -      | -      | 1      | 1      |

BIT[1] DBG1EN - PCK1/PDT1 端口编程功能使能位

- 0: 端口用作通用端口,端口的编程功能被屏蔽;
- 1: 使能端口的编程功能,端口用作 PCK1/PDT1,端口的通用功能被屏蔽;

*晟矽微电* 58/79





BIT[0] DBG0EN - PCK0/PDT0 端口编程功能使能位

0: 端口用作通用端口,端口的编程功能被屏蔽;

1: 使能端口的编程功能,端口用作 PCKO/PDTO,端口的通用功能被屏蔽;

注:仅在配置字将端口配置为"可通过寄存器位将端口切换为编程端口或通用端口"时,才可通过对应的寄存器控制位使能端口的编程功能。

#### DEBUG 保护寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| DBGPR | DBGP7  | DBGP6  | DBGP5  | DBGP4  | DBGP3  | DBGP2  | DBGP1  | DBGP0  |
| R/W   | W      | W      | W      | W      | W      | W      | W      | W      |
| 初始值   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

BIT[7:0] DBGP[7:0] - DBGCR 写操作保护控制位

为防止误触发对 DBGCR 的写操作,需先对寄存器 DBGPR 写 3CH 再立即写 C3H,DBG1EN 或 DBG0EN 才能置 1,中间不能插入其他操作(包括 NOP 操作),否则对 DBGCR 的写操作将无效。在写 DBGPR 前需先屏蔽中断,否则可能会因系统响应中断而导致 DBGCR 写操作无效。

例如,在配置字 DBGPIN0 将 PCK0/PDT0 配置为"可通过寄存器位将端口切换为编程端口或通用端口"后,芯片带电工作中若 DBG0EN=0,则 PCK0/PDT0 仍用作数字或模拟等通用功能的输入/输出端口,编程器无法通过这两个引脚进行带电烧录编程,用户程序可按如下例程将 DBG0EN 置 1,以使编程器可通过该组编程接口进行带电烧录编程:

BCLR GIE ; 屏蔽中断

CLRWDT ; 清 WDT

MOVAI 3CH

MOVRA DBGPR ; 使能 DBGCR 写操作,第 1 步: DBGPR 写 3CH

MOVAI C3H

MOVRA DBGPR ; 使能 DBGCR 写操作,第 2 步: DBGPR 写 C3H

MOVAI 01H

MOVRA DBGCR ; DBG0EN 置 1,端口用作编程接口

NOP ;

CLRWDT ; 清 WDT

GOTO \$-2 ; 死循环,等待编程器连接芯片进行带电烧录编程

*晟矽微电* 59/79



## 13 中断

芯片的中断源包括外部中断(INTO~INT1)、定时器中断(TO~T3)、T1 捕捉中断、ADC 中断、CMP 中断、LVD 中断和键盘中断等。可通过中断总使能位 GIE 屏蔽所有中断。

### CPU 响应中断的过程如下:

- ◆ CPU 响应中断源触发的中断请求时,自动将当前指令之后将要执行的下一条指令的地址压栈保存,自动清 0 中断总使能位 GIE 以暂停响应后续中断。与复位不同,硬件中断不停止当前指令的执行,而是暂时挂起中 断继续执行当前指令,完成后再处理中断。
- ◇ CPU 响应中断后,程序跳至中断入口地址(0008H)开始执行中断服务程序,中断服务程序应先保存累加器 A 和状态寄存器 PFLAG,然后处理被触发的中断。
- ◆ 中断服务程序处理完中断后,应先恢复累加器 A 和状态寄存器 PFLAG,再执行 RETIE 指令以返回主程序。 系统将自动恢复 GIE 为 1,然后从堆栈取出此前保存的 PC 值,CPU 从响应中断时正在执行指令的下一条指 令的地址处开始继续运行。

注: 应用外部中断功能或键盘中断功能,需将相应端口设为输入状态。

## 13.1 外部中断

芯片具有 2 路外部中断源 INTO/INT1,可选择上升沿、下降沿或电平变化等触发方式。外部中断触发时,中断标志 INTnIF(n=0-1)将被置 1,若 GIE 为 1 且相应的外部中断使能位 INTnIE(n=0-1)为 1,则产生外部中断。

## 13.2 定时器中断

定时器 Tn(n=0-3)在计数溢出时将触发定时器中断,中断标志 TnIF(n=0-3)将被置 1,若 GIE 为 1 且相应的定时器中断使能位 TnIE(n=0-3)为 1,则产生定时器中断。

#### 13.3 T1 捕捉中断

定时器 T1 的输入捕捉模式,捕捉完成时将触发 T1 捕捉中断,中断标志 T1CIF 将被置 1,若 GIE 为 1 且 T1 捕捉中断 使能位 T1CIE 为 1,则产生 T1 捕捉中断。

## 13.4 键盘中断

芯片具有最多 18 路键盘中断源,均可单独使能或关闭端口的键盘中断功能。任意一路使能键盘中断功能的端口,其输入电平发生变化时均将触发键盘中断,中断标志 KBIF 将被置 1,若 GIE 为 1 且键盘中断使能位 KBIE 为 1,则产生键盘中断。

### 键盘中断控制寄存器

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| P0KBCR | P07KE  | P06KE  | P05KE  | P04KE  | P03KE  | P02KE  | P01KE  | P00KE  |

*晟矽微电* 60/79

MC32F7062B 中断

| R/W |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 初始值 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

BIT[7:0]

P0nKE – P0n 端口键盘中断功能使能位(n=7-0)

0: 关闭端口的键盘中断功能;1: 使能端口的键盘中断功能;

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| P1KBCR | P17KE  | P16KE  | P15KE  | P14KE  | P13KE  | P12KE  | P11KE  | P10KE  |
| R/W    |
| 初始值    | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

BIT[7:0]

P1nKE - P1n 端口键盘中断功能使能位(n=7-0)

0: 关闭端口的键盘中断功能;1: 使能端口的键盘中断功能;

|        | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| P2KBCR | -      | -      | -      | _      | -      | -      | P21KE  | P20KE  |
| R/W    | -      | -      | -      |        | -      | -      | R/W    | R/W    |
| 初始值    | -      | -      | -      | -      | )-     | -      | 0      | 0      |

BIT[7:0]

P2nKE - P2n 端口键盘中断功能使能位(n=7-0)

0: 关闭端口的键盘中断功能;

1: 使能端口的键盘中断功能;

## 13.5 ADC 中断

AD 转换完成时将触发 ADC 中断,中断标志 ADIF 将被置 1,若 GIE 为 1 且 ADC 中断使能位 ADIE 为 1,则产生 ADC 中断。

## 13.6 CMP 中断

比较器 CMP 的输出可选择上升沿或下降沿等方式触发比较器中断,中断标志 CMPIF 将被置 1 ,若 GIE 为 1 且 CMP中断使能位 CMPIE 为 1 ,则产生 CMP 中断。

## 13.7 LVD 中断

当 VDD 电压降至电压检测阀值以下时,将触发 LVD 中断,中断标志 LVDIF 将被置 1,若 GIE 为 1 且 LVD 中断使能位 LVDIE 为 1,则产生 LVD 中断。

*晟矽微电* 61/79



## 13.8 中断相关寄存器

#### 中断使能寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| INTE0 | LVDIE  | ADIE   | T2IE   | KBIE   | INT1IE | INT0IE | T1IE   | TOIE   |
| R/W   | 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[7] LVDIE – LVD 中断使能位

0: 屏蔽 LVD 中断;

1: 使能 LVD 中断;

BIT[6] ADIE – ADC 中断使能位

0: 屏蔽 ADC 中断;

1: 使能 ADC 中断;

BIT[5] T2IE - 定时器 T2 中断使能位

0: 屏蔽定时器 T2 中断;

1: 使能定时器 T2 中断;

BIT[4] KBIE - 键盘中断使能位

0: 屏蔽键盘中断;

1: 使能键盘中断;

BIT[3] INT1IE - INT1 中断使能位

0: 屏蔽 INT1 中断;

1: 使能 INT1 中断;

BIT[2] INTOIE - INTO 中断使能位

0: 屏蔽 INTO 中断;

1: 使能 INT0 中断;

BIT[1] T1IE - 定时器 T1 中断使能位

0: 屏蔽定时器 T1 中断;

1: 使能定时器 T1 中断;

BIT[0] TOIE - 定时器 TO 中断使能位

0: 屏蔽定时器 T0 中断;

1: 使能定时器 T0 中断;

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| INTE1 | -      | -      | -      | -      | T1CIE  | T3IE   |        | CMPIE  |
| R/W   | -      | -      | -      | -      | R/W    | R/W    |        | R/W    |
| 初始值   | -      | -      | -      | -      | 0      | 0      |        | 0      |

BIT[3] T1CIE - T1 捕捉中断使能位

0: 屏蔽 T1 捕捉中断;1: 使能 T1 捕捉中断;

*晟矽微电* 62/79



BIT[2] T3IE - 定时器 T3 中断使能位

0: 屏蔽定时器 T3 中断;

1: 使能定时器 T3 中断;

BIT[0] CMPIE - 比较器 CMP 中断使能位

0: 屏蔽 CMP 中断;1: 使能 CMP 中断;

#### 中断标志寄存器

|       | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| INTF0 | LVDIF  | ADIF   | T2IF   | KBIF   | INT1IF | INT0IF | T1IF   | T0IF   |
| R/W   | 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[7] LVDIF – LVD 中断标志位

0: 未触发 LVD 中断;

1: 已触发 LVD 中断,需软件清 0;

BIT[6] ADIF - ADC 中断标志位

0: 未触发 ADC 中断;

1: 已触发 ADC 中断,需软件清 0;

BIT[5] T2IF - 定时器 T2 中断标志位

0: 未触发定时器 T2 中断;

1: 已触发定时器 T2 中断,需软件清 0;

BIT[4] KBIF - 键盘中断标志位

0: 未触发键盘中断;

1: 已触发键盘中断,需软件清 0;

BIT[3] INT1IF - INT1 中断标志位

0: 未触发 INT1 中断;

1: 已触发 INT1 中断, 需软件清 0;

BIT[2] INT0IF - INT0 中断标志位

0: 未触发 INT0 中断;

1: 已触发 INTO 中断,需软件清 0;

BIT[1] T1IF - 定时器 T1 中断标志位

0: 未触发定时器 T1 中断;

1: 已触发定时器 T1 中断,需软件清 0;

BIT[0] TOIF - 定时器 TO 中断标志位

0: 未触发定时器 T0 中断;

1: 已触发定时器 T0 中断,需软件清 0;

|  |  | Bit[7] | Bit[6] | Bit[5] | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|--|--|--------|--------|--------|--------|--------|--------|--------|--------|
|--|--|--------|--------|--------|--------|--------|--------|--------|--------|

*晟矽微电* 63/79

MC32F7062B 中断

| INTF1 | - | - | - | - | T1CIF | T3IF | CMPIF |
|-------|---|---|---|---|-------|------|-------|
| R/W   | - | - | - | - | R/W   | R/W  | R/W   |
| 初始值   | - | - | - | - | 0     | 0    | 0     |

BIT[3] T1CIF - T1 捕捉中断标志位

0: 未触发 T1 捕捉中断;

1: 已触发 T1 捕捉中断,需软件清 0;

BIT[2] T3IF - 定时器 T3 中断标志位

0: 未触发定时器 T3 中断;

1: 已触发定时器 T3 中断,需软件清 0;

BIT[0] CMPIF - 比较器 CMP 中断标志位

0: 未触发 CMP 中断;

1: 已触发 CMP 中断,需软件清 0;







## 14 特性曲线

注:

- 1、 特性曲线图中数据均源自抽样实测,仅作为应用参考,部分数据因生产工艺偏差,可能与实际芯片不符;为保证 芯片能正常工作,请确保其工作条件符合电气特性参数说明;
- 2、 图文中若无特别说明,则电压特性曲线的温度条件为 T=25℃,温度特性曲线的电压条件为 VDD=5V;

## 14.1 I/O 特性

输入 SMT 阈值电压 VS 电源电压

端口施密特阈值: 0.2VDD/0.8VDD



端口施密特阈值: 0.8V/2.0V



上/下拉电阻值 VS 电源电压

*晟矽微电* 65/79





## I/O 输出电流 VS 端口电压(VDD=5V)







## 14.2 功耗特性

## 运行模式 功耗 VS 电源电压



*晟矽微电* 67/79













## HOLD 模式 功耗 VS 电源电压



休眠模式 功耗 VS 电源电压/温度

*晟矽微电* 69/79



Ta=25°C





## 14.3 模拟电路特性

HIRC 频率 VS 电源电压/温度

*晟矽微电* 70/79



Ta=25°C





LIRC 频率 VS 电源电压/温度

*晟矽微电* 71/79



Ta=25°C





LVR 阈值电压 VS 温度

*晟矽微电* 72/79





VIR 电压 VS 电源电压/温度



Ta=25°C





EEPROM 单字节写入时间 VS 电源电压/温度

*晟矽微电* 74/79







# 15 封装尺寸

15.1 SOP20





| MBOL I            | и L                            |                                   |                              |  |  |
|-------------------|--------------------------------|-----------------------------------|------------------------------|--|--|
| MIDOL             | MIN                            | NOM                               | MAX                          |  |  |
| A                 | _                              |                                   | 2.65                         |  |  |
| A1                | 0.10                           | _                                 | 0.30                         |  |  |
| A2                | 2.25                           | 2.30                              | 2.35                         |  |  |
| A3                | 0.97                           | 1.02                              | 1.07                         |  |  |
| b                 | 0.35                           | _                                 | 0.43                         |  |  |
| bl                | 0.34                           | 0.37                              | 0.40                         |  |  |
| С                 | 0.25                           | _                                 | 0.29                         |  |  |
| cl                | 0.24                           | 0.25                              | 0.26                         |  |  |
| D                 | 12.70                          | 12.80                             | 12.90                        |  |  |
| Е                 | 10.10                          | 10.30                             | 10.50                        |  |  |
| E1                | 7.40                           | 7.50                              | 7.60                         |  |  |
| e                 |                                | 1.27BSC                           |                              |  |  |
| L                 | 0.70                           | _                                 | 1.00                         |  |  |
| L1                |                                | 1.40REF                           |                              |  |  |
| θ                 | 0                              |                                   | 8°                           |  |  |
| Cl D E E1 E1 L L1 | 0.24<br>12.70<br>10.10<br>7.40 | 12.80<br>10.30<br>7.50<br>1.27BSC | 0.26<br>12.9<br>10.5<br>7.60 |  |  |

MILLIMETER





15.2 DIP20









| M         | ILLIME                                                        | TER                                               |  |
|-----------|---------------------------------------------------------------|---------------------------------------------------|--|
| MIN       | NOM                                                           | MAX                                               |  |
| 3.60      | 3.80                                                          | 4.00                                              |  |
| 0.51      | _                                                             | _                                                 |  |
| 3.20      | 3.30                                                          | 3.40                                              |  |
| 1.47      | 1.52                                                          | 1.57                                              |  |
| 0.44      | _                                                             | 0.52                                              |  |
| 0.43      | 0.46                                                          | 0.49                                              |  |
|           |                                                               |                                                   |  |
| 0.25      | 0.29                                                          |                                                   |  |
| 0.24      | 0.25                                                          | 0.26                                              |  |
| 25.80     | 25.90                                                         | 26.00                                             |  |
| 6.45      | 6.55                                                          | 6.65                                              |  |
|           | 2.54BSC                                                       | 2                                                 |  |
| 7.62REF   |                                                               |                                                   |  |
| 7.62 _ 9. |                                                               |                                                   |  |
| Ó         |                                                               | 0.84                                              |  |
| 3.00      | _                                                             | _                                                 |  |
|           | MIN 3.60 0.51 3.20 1.47 0.44 0.43 0.25 0.24 25.80 6.45 7.62 0 | 3.60 3.80 0.51 3.20 3.30 1.47 1.52 0.44 0.43 0.46 |  |



# 15.3 TSSOP20









| SYMBOL | MILLIMETER |       |      |  |
|--------|------------|-------|------|--|
| STMBOL | MIN        | NOM   | MAX  |  |
| Α      | · -        | _     | 1.20 |  |
| A1     | 0.05       | _     | 0.15 |  |
| A2     | 0.80       | 1.00  | 1.05 |  |
| A3     | 0.39       | 0, 44 | 0.49 |  |
| ь      | 0.20       |       | 0.29 |  |
| 61     | 0.19       | 0.22  | 0.25 |  |
| C      | 0.13       | _     | 0.18 |  |
| c1     | .0.12      | 0.13  | 0.14 |  |
| D      | 6.40       | 6.50  | 6.60 |  |
| El     | 4.30       | 4.40  | 4.50 |  |
| E      | 6.20       | 6.40  | 6.60 |  |
| c      | 0.65BSC    |       |      |  |
| L      | 0.45       | 0.60  | 0.75 |  |
| Ll     | 1.00BSC    |       |      |  |
| θ      | 0          | -     | 8"   |  |

## 15.4 SOP16







| SYMBOL | MILLIMETER |      |       |
|--------|------------|------|-------|
|        | MIN        | NOM  | MAX   |
| A      | -          | ·    | 1.75  |
| A1     | 0.10       | _    | 0.225 |
| A2     | 1.30       | 1.40 | 1.50  |
| A3     | 0.60       | 0.65 | 0.70  |
| Ъ      | 0.39       |      | 0.47  |
| bI     | 0.38       | 0.41 | 0.44  |
| c      | 0.20       |      | 0.24  |
| c1     | 0.19       | 0.20 | 0.21  |
| D      | 9.80       | 9.90 | 10.00 |
| E      | 5.80       | 6.00 | 6.20  |
| E1     | 3.80       | 3.90 | 4.00  |
| e      | 1.27BSC    |      |       |
| h      | 0.25       | -    | 0.50  |
| L      | 0.50       | _    | 0.80  |
| Ll     | 1.05REF    |      |       |
| е      | 0          |      | 8"    |



## 15.5 SOP8









| SYMBOL         | MILLIMETER |         |      |  |
|----------------|------------|---------|------|--|
|                | MIN        | TYP     | MAX  |  |
| Ä              | -          | -       | 1.77 |  |
| A1             | 0.08       | 0.18    | 0.28 |  |
| A2             | 1.20       | 1.40    | 1.60 |  |
| A3             | 0.55       | 0.65    | 0.75 |  |
| b <sub>i</sub> | 0.39       | - `     | 0.48 |  |
| (b1            | 0.38       | 0.41    | 0.43 |  |
| c              | 0.21       | -       | 0.26 |  |
| c1:            | 0.19       | 0.20    | 0.21 |  |
| Ď              | 4.70       | 4.90    | 5.10 |  |
| Ē              | 5.80       | 6.00    | 6.20 |  |
| , E1,          | 3.70       | 3.90    | 4.10 |  |
| ë              | 1.27BSC    |         |      |  |
| Ŀ              | 0.50       | 0.65    | 0.80 |  |
| L1             |            | 1.05BSC |      |  |
| θ              | 0          | -       | .8°  |  |





# 16 修订记录

| 版本                | 日期                        | 修订内容                                                 |  |
|-------------------|---------------------------|------------------------------------------------------|--|
| V1.0.0 2024-06-12 | 发布初版                      |                                                      |  |
|                   | 封装类型: B0M/B0E/B0Y/B0K/B0H |                                                      |  |
|                   | 1、 电气特性章节                 |                                                      |  |
|                   | 增加 SMT 的 2V/0.8V 描述;      |                                                      |  |
| V1.0.1            | V1.0.1 2024-07-02         | ADC 最大转换时钟修改,2MHz(MAX.)@参考电压=VDD;1MHz(MAX.) @参考电压=内参 |  |
|                   | ADC 增加外部输入阻抗计算公式及表格;      |                                                      |  |
|                   |                           | 2、 ADC 章节,修改使能 ADC 及切换参考的延时描述;                       |  |
| V1.0.2            | 2024-09-12                | 1、 增加封装类型: SOP16-B2K                                 |  |

