



Welcome to **E-XFL.COM** 

What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded - Microcontrollers</u>"

| Details                    |                                                            |
|----------------------------|------------------------------------------------------------|
| Product Status             | Active                                                     |
| Core Processor             | 508                                                        |
| Core Size                  | 8-Bit                                                      |
| Speed                      | 40MHz                                                      |
| Connectivity               | CANbus, I <sup>2</sup> C, LINbus, SCI, SPI                 |
| Peripherals                | LVD, POR, PWM, WDT                                         |
| Number of I/O              | 39                                                         |
| Program Memory Size        | 48KB (48K x 8)                                             |
| Program Memory Type        | FLASH                                                      |
| EEPROM Size                | 1.5K x 8                                                   |
| RAM Size                   | 3K x 8                                                     |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                |
| Data Converters            | A/D 16x12b                                                 |
| Oscillator Type            | External                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                          |
| Mounting Type              | Surface Mount                                              |
| Package / Case             | 48-LQFP                                                    |
| Supplier Device Package    | 48-LQFP (7x7)                                              |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc9s08dz48clf |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# 章节列表

| 章节号    | 标题                      | 页码  |
|--------|-------------------------|-----|
| 第1章    | 器件概述                    | 19  |
| 第 2 章  | 管脚和连接                   | 25  |
| 第 3 章  | 操作模式                    | 33  |
| 第4章    | 存储器                     | 39  |
| 第 5 章  | 复位、中断和系统总控制             | 65  |
| 第6章    | 并行输入 / 输出控制             | 81  |
| 第7章    | 中央处理器 (S08CPUV3)        | 107 |
| 第8章    | 多功能时钟发生器 (S08MCGV1)     | 127 |
| 第9章    | 模拟比较器 (S08ACMPV3)       | 157 |
| 第 10 章 | 数模转换器 (S08ADC12V1)      | 163 |
| 第 11 章 | IIC 模块 (S08IICV2)       | 189 |
| 第 12 章 | 飞思卡尔控制器局域网 (S08MSCANV1) | 207 |
| 第 13 章 | 串行外围器件接口 (S08SPIV3)     | 257 |
| 第 14 章 | 串行通信接口 (S08SCIV4)       | 271 |
| 第 15 章 | 实时计数器 (S08RTCV1)        | 289 |
| 第 16 章 | 定时器脉冲宽度调节器 (S08TPMV3)   | 299 |
| 第 17 章 | 开发支持                    | 323 |
| 附录 A   | 电气特征                    | 342 |
| 附录 B   | 定时器脉宽调制器 (TPMV2)        | 364 |
| 附录 C   | 订购信息和机械图                | 378 |



VREFH 和 VREFL 在内部分别连接到 VDDA 和 VSSA。

图 2-3.32 管脚 LQFP

# 5.8.1 中断管脚请求状态和控制寄存器 (IRQSC)

该直接页面寄存器包括用来配置 IRQ 功能、报告状态和确认 IRQ 事件的状态和控制位。



图 5-2. 中断请求状态和控制寄存器 (IRQSC)

表 5-2. IRQSC 寄存器字段描述

| 字段          | 描述                                                                                                                                                             |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>IRQPDD | 中断请求 (IRQ) 上拉器件禁止 — IRQ 管脚激活时 (IRQPE = 1) ,这个读 / 写控制位用来禁止内部上拉 / 下拉器件,从而允许使用外部器件。 0 如果 IRQPE = 1, IRQ 上拉器件激活; 1 如果 IRQPE = 1, IRQ 上拉器件禁止。                       |
| 5<br>IRQEDG |                                                                                                                                                                |
| 4<br>IRQPE  | IRQ 管脚使能 — 这个读写控制位使能 IRQ 管脚。当设置了该位时, IRQ 管脚可以用作中断请求。<br>0 IRQ 管脚禁止;<br>1 IRQ 管脚使能。                                                                             |
| 3<br>IRQF   | IRQ 标志 — 该只读状态位显示中断请求事件发生的时间。<br>0 无 IRQ 请求;<br>1 检测到 IRQ 事件。                                                                                                  |
| 2<br>IRQACK | IRQ 确认 — 这个只写位用来确认中断请求事件 (写 1 来清除 IRQF)。写入 0 则没有任何意义或影响。读总是返回 0。如果选择了边沿和电平检测 (IRQMOD = 1),则不能清除 IRQF,并且 IRQ 管脚位于断言级。                                           |
| 1<br>IRQIE  | IRQ 中断使能 — 这个读 / 写控制位决定 IRQ 事件是否生成中断请求。 0 当 IRQF = 1 时不产生中断请求 (使用轮询); 1 当 IRQF = 1 时产生中断请求。                                                                    |
| 0<br>IRQMOD | IRQ 检测模式 — 这个读 / 写控制位选择只边沿检测还是边沿和电平检测。 IRQEDG 控制位决定检测为中断请求事件的边沿和电平极性。如需了解更多信息,请参见 5.5.2.2,"边沿和电平敏感度"。 0 只下降边沿或上升边沿的 IRQ 事件; 1 下降边沿和低电平 IRQ 事件或上升边沿和高电平 IRQ 事件。 |

# 5.8.2 系统复位状态寄存器 (SRS)

该高页寄存器包括只读状态标记,以显示最近复位的源。将 1 写入 SBDFR 寄存器的 BDFR 时,调试主机强制完成复位, SRS 中不设置任何状态位。 COP 使能时,在寄存器地址中写入任意值

# 5.8.3 系统后台调试强制复位寄存器 (SBDFR)

这个高页寄存器只包括一个只写控制位。串行后台命令,如 WRITE\_BYTE 必须用来写入 SBDFR。从用户程序写入寄存器的尝试被忽略。读总是返回 0x00。



<sup>1</sup> 只能通过串行后台调试命令,而非用户程序写入 BDFR。

### 图 5-4. 后台调试强制复位寄存器 (SBDFR)

### 表 5-4. SBDFR 寄存器字段描述

| 字段        | 描述                                                                                         |
|-----------|--------------------------------------------------------------------------------------------|
| 0<br>BDFR | 后台调试强制复位 — 可以使用串行后台命令,如 WRITE_BYTE, 使外部调试主机强制进行目标系统复位。在该位中写入 1 就能强制进行 MCU 复位。该位不能从用户程序中写入。 |

# 5.8.4 系统选项寄存器 1 (SOPT1)

该高页寄存器是 write-once 寄存器,因此只重视复位后的第一次写入。它可以在任何时候读取。任何后续 SOPT1 写入尝试(有意或无意)都将被忽略,以避免对这些敏感器件的意外修改。该寄存器应在用户复位初始化程序期间写入,以设置期望的控制,即便期望的设置与复位设置相同。



图 5-5. 系统选项寄存器 1 (SOPT1)

### 表 5-5. SOPT1 寄存器字段描述

| 字段               | 描述                                                                                             |
|------------------|------------------------------------------------------------------------------------------------|
| 7:6<br>COPT[1:0] | COP 看门狗超时 — 这些单次写入有效的位选择 COP 的超时周期。STOP2 中的 COPT 和 COPCLKS 定义 COP 超时周期。参见表 5-6。                |
| 5<br>STOPE       | 停止模式使能 — 这个单次写入有效的位用来使能停止模式。如果停止模式禁止且用户程序试图实施 STOP 指令,则会强制进行非法操作码复位。<br>0 停止模式禁止。<br>1 停止模式使能。 |

# 6.5.3.1 C 端口数据寄存器 (PTCD)



图 6-19. C 端口数据寄存器 (PTCD)

表 6-17. PTCD 寄存器字段描述

| 字段        | 描述                                                                                                                                                                                                |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PTCD[7:0] | C 端口数据寄存器位 — 对于配置为输入的 C 端口管脚,读数返回管脚上的逻辑电平。对于配置为输出的 C 端口管脚,读数返回写入寄存器的最后一个值。写入值被锁定在本寄存器的所有位中。对于配置为输出的 C 端口管脚,逻辑电平被输出到相应的 MCU 管脚。复位强制 PTCD 都为 0,但是这些 0 未被输出到驱出相应的管脚,因为复位还会将所有端口管脚配置为上拉 / 下拉禁止的高抗阻输入。 |

# 6.5.3.2 C 端口数据方向寄存器 (PTCDD)



图 6-20. C 端口数据方向寄存器 (PTCDD)

表 6-18. PTCDD 寄存器字段描述

| 字段             | 描述                                                                                                               |
|----------------|------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTCDD[7 | C 端口位的数据方向 — 这些读 / 写位控制着 C 端口管脚的方向以及为 PTCD 读数读取的内容。 0 输入 (输出驱动禁止),读数返回管脚值。 1 C 端口位 - 输出驱动使能, PTCD 读数返回 PTCDn 内容。 |

## 6.5.4.8 D 端口中断边沿选择寄存器 (PTDES)



图 6-31. D 端口边沿选择寄存器 (PTDES)

表 6-29. PTDES 寄存器字段描述

| 字段         | 描述                                                                                                                                |  |  |  |  |
|------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| PTDES[7:0] | D端口边沿选择 — 每个 PTDESn 位都具有双重功能,选择活动中断边沿的极性以及选择上拉或下拉器件 (使能的话)。<br>0 上拉器件与相关的管脚相连,检测中断生成的下降边沿/低电平。<br>1 下拉器件与相关的管脚相连,检测中断生成的上升边沿/高电平。 |  |  |  |  |

# 6.5.5 E 端口寄存器

E端口由下列寄存器控制。

## 6.5.5.1 E 端口数据寄存器 (PTED)



图 6-32. E端口数据寄存器 (PTED)

### 表 6-30. PTED 寄存器字段描述

| 字段               | 描述                                                                                                                                                                                                 |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTED[7:0] | E端口数据寄存器位 — 对于配置为输入的 E 端口管脚,读数返回管脚上的逻辑电平。对于配置为输出的 E 端口管脚,读数返回写入寄存器的最后一个值。写入值被锁定在本寄存器的所有位中。对于配置为输出的 E 端口管脚,逻辑电平被输出到驱出相应的 MCU 管脚。复位强制 PTED 都为 0,但是这些 0 未被输出到驱出相应的管脚,因为复位还会将所有端口管脚配置为上拉 / 下拉禁止的高抗阻输入。 |

<sup>1</sup> 读取这个位总是要返回相关管脚的管脚值,与端口数据方向位中保存的值无关。

# 8.5 特性描述

## 8.5.1 运行模式



图 8-8. 时钟切换模式

MCG 的 9 种状态如状态示意图所示,并在下面做了详细地介绍。箭头显示状态间的允许移动方向。

第8章多功能时钟发生器 (S08MCGV1)

# 第 10 章 数模转换器 (S08ADC12V1)

## 10.1 介绍

12 位数模转换器(ADC)是逐次逼近式 ADC,为集成微控制器片上系统设计。

### 注意

MC9S08DZ60 系列器件的工作电压 (2.7 V -5.5 V) 较高,不支持 STOP1 模式。请忽略 STOP1 参考。

# 10.1.1 模拟功率和接地信号名称

本章的 V<sub>DDAD</sub> 和 V<sub>SSAD</sub> 参考分别对应 V<sub>DDA</sub> 和 V<sub>SSA</sub> 信号。

## 10.1.2 信道分配

## 注意

MC9S08DZ60 系列器件的 ADC 通道分配如表 10-1. 所示。保留通道转换结果未知。

本章介绍了所有 S08ADC12V1 通道位。MC9S08DZ60 系列 MCU 并不全部使用所有这些通道。器件上不可用通道对应的所有位都被保留。

第 11 章 IIC 模块 (S08IICV2)

## 11.2.3 结构图

图 11-3 是 ICC 的结构图。



图 11-2. IIC 功能结构图

# 11.3 外部信号描述

本节描述了用户可连接的各个管脚信号。

# 11.3.1 SCL — 串行时钟线

双向 SCL 是 IIC 系统的串行时钟线。

# 11.3.2 SDA — 串行数据线

双向 SDA 是 IIC 系统的串行数据线。

### 表 12-9. CANRFLG 寄存器字段描 ^(continued)

| 字段                    | 描述                                                                                                                                                                                                                                                                   |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2<br>TSTAT[1:0]     | 发送器状态位 — 错误计数器的值控制着 MSCAN 的实际 CAN 总线状态。只要设置了状态变化中断标志(CSCIF),这些位就显示 MSCAN 的与接收器有关的适当 CAN 总线状态。位 TSTAT1、 TSTAT0 的编码是:: 00                                                                                                                                              |
| 1<br>OVRIF            | 溢出中断标志 — 该标志在出现数据溢出情况时设置。如果没有被屏蔽,当设置了该标志时有一个错误中断产生。<br>0 无数据溢出情况<br>1 检测到数据溢出                                                                                                                                                                                        |
| 0<br>RXF <sup>2</sup> | 接收缓冲器已满标志 — 当新报文被转移到接收器 FIFO 中时, RXF 由 MSCAN 进行置位。该标志表示移位缓冲器是否接收了正确的报文(匹配标识符,匹配循环冗余代码 (CRC)和未检测到其他错误)。在 CPU 从接收器 FIFO 中的 RxFG 缓冲器那里读取了该报文后, RXF 标志必须清除,以释放缓冲器。已设置的 RXF 标志禁止下一个 FIFO 条目转移到前景缓冲器 (RxFG)。如果未被屏蔽,当设置了该标志时有一个接收中断产生。 RxFG 中没有新报文 1 接收器 FIFO 非空。 RxFG 中有报文 |

处于 "总线脱离"状态的最重要 CAN 总线状态的冗余报文。只有当 Tx 错误计数器的错误超过 255 个时才会出现这种情况。 总线脱离会影响接收器状态。一旦发送器离开其总线脱离状态,接收器状态也立即跳到 RxOK。也请参见本寄存器中的 TSTAT[1:0] 编码。

# 12.3.5 MSCAN 接收器中断使能寄存器 (CANRIER)

该寄存器包含用于 CANRFLG 寄存器中描述的中断标志的中断使能位。



图 12-9. MSCAN 接收器中断使能寄存器 (CANRIER)

### 注意

当初始化模式处于有效状态时, CANRIER 寄存器保持复位状态 (INITRQ=1 and INITAK=1). 当未处于初始化模式时,该寄存器可以写入 (INITRQ=0, INITAK=0)。

The RSTATE[1:0], TSTATE[1:0] 位不受初始化模式影响。

读取: 任何时间

写入:未处于初始化模式的任何时间。

<sup>&</sup>lt;sup>2</sup> T 为确保数据完整性,当 RXF 标志清除时,不要读取接收缓冲器寄存器。对于那些有双 CPU 的 MCU 来说,当 RXF 标志被清除时读取接收缓冲器寄存器可能会导致 CPU 故障。

第 12 章 飞思卡尔控制器局域网 (S08MSCANV1)

| Register<br>Name |        | Bit 7 | 6    | 5    | 4                  | 3                  | 2    | 1    | Bit0             |
|------------------|--------|-------|------|------|--------------------|--------------------|------|------|------------------|
| IDR0             | R<br>W | ID28  | ID27 | ID26 | ID25               | ID24               | ID23 | ID22 | ID21             |
| IDR1             | R<br>W | ID20  | ID19 | ID18 | SRR <sup>(1)</sup> | IDE <sup>(1)</sup> | ID17 | ID16 | ID15             |
| IDR2             | R<br>W | ID14  | ID13 | ID12 | ID11               | ID10               | ID9  | ID8  | ID7              |
| IDR3             | R<br>W | ID6   | ID5  | ID4  | ID3                | ID2                | ID1  | ID0  | RTR <sup>2</sup> |
| DSR0             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR1             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR2             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR3             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR4             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR5             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR6             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR7             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DLR              | R<br>W |       |      |      |                    | DLC3               | DLC2 | DLC1 | DLC0             |

= Unused, always read 詘 '

图 12-23. 接收 / 发送报文缓冲器 — 扩展标识符映射

<sup>&</sup>lt;sup>1</sup> SRR 和 IDE 都为 1。

<sup>&</sup>lt;sup>2</sup> RTR 的位置在扩展和标准标识符映射间存在差异。

### 第 12 章 飞思卡尔控制器局域网 (S08MSCANV1)

CAN 2.0B 扩展标识符 CAN 2.0A/B 标准标识符



图 12-39. 32 位可屏蔽标识符接收滤波器

CAN 2.0B 扩展标识符 CAN 2.0A/B 标准标识符



图 12-40. 16 位可屏蔽标识符接收滤波器

### 第 13 章 串行外围器件接口 (S08SPIV3)

## 13.1.2.2 SPI 模块结构图

图 13-3 是 SPI 模块的结构图。SPI 的中心元件是 SPI 移位寄存器。数据写入双缓冲发射器(写入 SPID),然后转移到位于数据传输起点的 SPI 移位寄存器。在数据字节中转换后,数据被传输到双缓冲接收器,在这里数据可以被读取(从 SPID 读取)。管脚复用逻辑控制着 MCU 管脚和 SPI 模块间的连接。

当 SPI 配置为主 SPI 时,时钟输出被路由到 SPSCK 管脚,移位器输出被路由到 MOSI,移位器输入从 MISO 管脚路由出来。

当 SPI 配置为从 SPI 时, SPSCK 管脚为时钟输出。 MOSI 为移位输出, MISO 管脚为移位器输入。

在外部 SPI 系统,只需将所有 SPSCK 管脚彼此连接,所有 MISO 管脚连接起来,所有 MOSI 管脚连接起来就可以来。外围器件通常为这些管脚使用略有不同的名称。



MC9S08DZ60 系列,第3版

### 第 14 章 串行通信接口 (S08SCIV4)



图 14-1. MC9S08DZ60 结构图

MC9S08DZ60 系列,第3版

## 14.3.3 接收器功能描述

在本小节,首先把接收器结构图 (图 14-3)作为接收器总体功能描述的指南使用。然后详细描述了用来重建接收器数据的数据采样方法。最后解释了接收器唤醒功能的两个变种。

通过设置 RXINV = 1,接收器输入被反转。通过设置 SCIxC2 中的 RE 位,接收器被使能。字符帧由逻辑 0 的起始位、8个(或 9个)数据位(LSB 先发)和逻辑 1 的停止位组成。如需了解 9 位数据模式的有关信息,参见 14.3.5.1,"8 位和 9 位数据模式"."对于本小节的其余部分,我们假设 SCI 配置用于正常的 8 位数据模式。

在把停止位接收到接收移位器后,如果接收数据寄存器还未满,数据字符就被传输到接收数据寄存器,设置接收数据寄存器已满(RDRF)状态标记。如果已经设置了显示接收数据寄存器(缓冲器)已满的 RDRF,就设置溢出(OR)状态标记,新数据丢失。因为 SCI 接收器是双缓冲的,程序在设置 RDRF 后、读取接收数据缓冲器的数据前,有一个全字符时间,以避免接收器溢出。

当程序检测到接收数据寄存器已满(RDRF = 1)时,它通过读 SCIxD 从接收数据寄存器中获取数据。 RDRF 标记由一个 2 步式顺序自动清除,这个 2 步式顺序通常在处理接收数据的用户程序中满足。如需了解标记清除的更多详细信息,参见 14.3.4, "中断和状态标记"。

## 14.3.3.1 数据采样方法

SCI 接收器使用 16 倍波特率时钟进行采样。接收器通过以 16 倍波特率提取逻辑电平样本,以搜索 RxD 串行数据输入管脚上的下降边沿。下降边沿的定义是 3 个连续逻辑 1 采样后的逻辑 0 样本。 16 倍波特率时钟用来把位时间划分为 16 个段,分别标记为 RT1 到 RT16。当定位了下降边沿时,还要从 RT3、 RT5 和 RT7 中提取三个样本,以确保这是真正的起始位,而不仅仅噪音。如果这三个样本至少有两个样本为 0,接收器假设它与接收器字符同步。

接收器然后在 RT8, RT9 和 RT10 的每个位时间上进行采样,包括起始启位和停止位,以决定该位的逻辑电平。逻辑电平是位时间期间提取的绝大多数样本的逻辑电平。在起始位中,如果 RT3、 RT5 和 RT7 上的样本中至少有 2 个样本为 0,那么就假设该位为 0,即便在 RT8、 RT9 和 RT10 上提取的一个或所有样本均为 1。如果字符帧的任意位时间(包括起始和停止位)中的任意样本不能与该位的逻辑电平保持一致,当收到的字符传输到接收数据缓冲器时,都设置噪音标记(NF)。

下降边沿检测逻辑不断寻找下降边沿,如果检测到边沿,样本时钟重新同步位时间。这样当出现噪音或不匹配波特率时,就可以提高接收器的可靠性。它不能改进最坏情况分析,因为有些字符在字符帧的任何地方都没有额外的下降边沿。

在成帧错误情况下,假设收到的字符不是中止字符,搜索下降边沿的采样逻辑就充满 3 个逻辑 1 样本,这样一个新起始位几乎可以立即检测到。

在成帧错误情况下,接收器禁止接收任何新字符,直到成帧错误标记被清除。如果仍设置 FE,接收移位寄存器继续发挥作用,但整个字符不能传输到接收数据缓冲器。

### 第 15 章 实时计数器 (S08RTCV1)



图 15-1. MC9S08DZ60 结构图

MC9S08DZ60 系列, 第3版

### 第 15 章 实时计数器 (S08RTCV1)

## 15.4.1 操作实例

这一部分显示了计数器达到模数寄存器中的匹配值时 RTC 的运行情况。



图 15-6. RTC 计数器溢出实例

在图 15-6 所示的例子中,所选时钟源为内部时钟源。预分频器 (RTCPS) 设置为 0xA 或 divide-by-4。RTCMOD 寄存器中的模数值设置为 0x55。当计数器 RTCCNT 达到模数值 0x55 时,计数器溢出为 0x00 并继续计数。. 实时中断标记 RTIF 会在计数器值从 0x55 变为 0x00 时设置。如果如果 RTIE = 1, RTIE 被设置时会生成一个实时中断。

## 15.5 初始化/应用信息

本小节提供示例代码,为用户提供如何初始化和配置 RTC 模块方面的一些基本指导。示例软件 采用  $\mathbf{C}$  语言实施。

下面的示例介绍了如何通过使用 1-kHz 时钟源的 RTC 实现时间计时,以实现尽可能低的功耗。由于 1-kHz 时钟源不如晶振准确,我们可以添加软件来进行必要的调整。为了在没有以额外的功耗为代价进行调整的情况下实现精确性,可选择具有适当预分频器和模数值的外部时钟 (ERCLK) 或内部时钟 (IRCLK)。

/\* Initialize the elapsed time counters \*/
Seconds = 0;
Minutes = 0;
Hours = 0;
Days=0;

/\* Configure RTC to interrupt every 1 second from 1-kHz clock source \*/
RTCMOD.byte = 0x00;
RTCSC.byte = 0x1F;



图 A-5. 定时器外部时钟



图 A-6. 定时器输入捕捉脉冲

# A.12.3 MSCAN

表 A-15. MSCAN 唤醒脉冲特性

| 编号 | С | 参数             | 符号               | 最小值 | 典型值值 | 最大值 | 单位 |
|----|---|----------------|------------------|-----|------|-----|----|
| 14 | D | MSCAN 唤醒显性脉冲过滤 | t <sub>WUP</sub> | _   | _    | 2   | ms |
| 15 | D | MSCAN 唤醒显性脉冲通过 | t <sub>WUP</sub> | 5   |      | 1   | ms |

在输入捕获模式中,读取任何一个字节 (无论是 TPMxCnVH 还是 TPMxCnVL)都会使两个字节的内容被锁入到缓冲器中。这些内容一直锁定在这个缓冲器中,直到另一个字节被读取。当 TPMxCnSC 寄存器被写入时,锁存机制可复位 (变为未锁存状态)。

在输出对比或 PWM 模式中,写入任何一个字节 (无论是 TPMxCnVH 还是 TPMxCnVL)都会 使该值被锁入到缓冲器中。两个字节都被写入后,它们会作为连贯的 16 位值传输到定时器通道 值寄存器中。这一锁存机制可以通过写入 TPMxCnSC 寄存器来人工进行复位。

这种锁定机制允许以任何顺序进行连贯的 16 位写入,这对各种编译器实施方案都很友好。

# B.6 功能介绍

所有 TPM 功能都与允许灵活选择时钟源和预分频器的 16 位主计数器相关。此外, 16 位模数寄存器还与 TPM 中的 16 位主计数器相关。每个 TPM 通道可与 MCU 管脚及可屏蔽的中断功能相关。

TPM 具有中央对齐的功能 (由 TPMxSC 中 CPWMS 控制位控制)。当 CPWMS 被设置为 1 时,定时器计数器 TPMxCNT 改变为向上/向下计数器并且相关 TPM 中的所有通道都作为中央对齐的 PWM 通道。当 CPWMS=0 时,每个通道可独立配置,以便以输入捕获、输出对比或缓冲的边缘对齐 PWM 模式运行。

后面各小节介绍 16 位主计数器和计数器的每种运行模式 (输入捕获、输出对比、边缘对齐 PWM 和中央对齐 PWM)。因为管脚运行和中断活动的细节取决于操作模式,这些主题将在相关模式的章节中介绍。

## B.6.1 计数器

所有定时器功能都基于 16 位主计数器 (TPMxCNTH:TPMxCNTL)。本小节讨论时钟源选择、向上计数和向下计数、计数结束溢出和手动计数器复位。

在任何 MCU 复位后, CLKSB:CLKSA = 0:0,所以没有选择时钟源,并且 TPM 是不活动的。正常情况下, CLKSB:CLKSA 将设置为 0:1,使总线时钟驱动定时器计数器。 TPM 的时钟源可以选为关闭、总线时钟(BUSCLK)、固定系统时钟(XCLK)或外部输入。外部时钟方法的最大允许频率为总线速率的 1/4。参见 B.5.1,"定时器状态和控制寄存器 (TPMxSC)"及表 B-2 来了解有关时钟源的更多信息。

当微控制器处于活动后台模式时, TPM 会临时挂起所有计数,直到微控制器返回到正常用户操作模式。在停止模式下,所有 TPM 时钟被停止;因此在时钟恢复前, TPM 一直被有效地关闭。在等待模式期间, TPM 继续正常运行。

16 位主计数器有两种计数模式。选择中央对齐 PWM 时 (CPWMS = 1), 计数器以向上 / 向下计数模式运行。否则, 计数器作为简单的向上计数器运行。用作向上计数器时, 16 位主计数器从 0x0000 开始计数, 直到终端计数, 然后重新从 0x0000 开始。最大计数为 0xFFFF 或 TPMxMODH:TPMxMODL 中的模数值。

当规定了中央对齐 PWM 操作时,计数器从 0x0000 向上计数,直到达到终端计数,然后向下计数到 0x0000,再从这里向上计数。 0x0000 和终端计数值 (TPMxMODH:TPMxMODL 中的值)为正常长度计数 (一个定时器时钟周期长度)。