# 杰理 AD18N 芯片手册 V1.0

# 珠海市杰理科技股份有限公司 Zhuhai Jieli Technologyco.,LTD

版权所有, 未经许可, 禁止外传

2023年8月31日



### 目录

| 第1章 引言                  | 4  |
|-------------------------|----|
| 1.1. 编写目的               | 4  |
| 1.2. 文档修改日志             | 4  |
| 第2章 CPU 介绍              | 5  |
| 2.1. 说明                 | 5  |
| 2.2. 中断说明               | 5  |
| 2.2.1. 中断源              |    |
| 2.2.2. 中断控制寄存器 ICFGx    |    |
| 2.2.3. 中断入口(中断列表,中断优先级) |    |
| 2.3. MEMORY             |    |
| 第3章 时钟系统                | 9  |
| 3.1. 时钟源                | 9  |
| 第4章 循环冗余校验(CRC16)       | 10 |
| 4.1. 模块说明               | 10 |
| 4.2. 寄存器 SFR 列表         |    |
| 第5章 看门狗                 | 11 |
| 5.1. 模块说明               | 11 |
| 5.2. 寄存器 SFR 列表         |    |
| 第6章 IIC 模块              |    |
| 6.1. 模块说明               | 13 |
| 1. IIC 接口主要支持特性         |    |
| 2. 主机                   | 13 |
| 3. 从机                   | 13 |
| 4. 特殊注意点                |    |
| 6.2. 寄存器 SFR 列表         |    |
| 6.3. 基本事务操作             |    |
| 第7章 SPI 模块              | 20 |
| 7.1. 模块说明               |    |
| 7.2. 寄存器 SFR 列表         |    |
| 第8章 数模转换器(ADC)          | 25 |
| 8.1. 模块说明               | 25 |
| 8.2. 寄存器 SFR 列表         | 26 |
| 第9章 时钟脉冲计数器(GPCNT)      |    |
| 9.1 模块说明                | 29 |



| 9.2. 寄存器 SFR 列表           | 30 |
|---------------------------|----|
| 第 10 章 定时器(TIMER)         | 31 |
| 10.1. 模块说明                | 31 |
| 10.2. 定时器 IO 通道           | 31 |
| 10.3. 寄存器 SFR 说明          | 32 |
| 第 11 章 红外滤波模块(IRFLT)      | 34 |
| 11.1. 模块说明                | 34 |
| 11.2. 寄存器 SFR 列表          | 34 |
| 11.3. 时基选择                | 35 |
| 第 12 章 MCPWM              |    |
| 12.1. 模块说明                | 36 |
| 12.1.1. 定时器 MCTIMER       |    |
| 12.1.2. MCPWM 模块引脚        | 37 |
| 12.1.3. MCPWM 模块特性        |    |
| 12.2. 寄存器 SFR 列表          | 37 |
| 第 13 章 UART               | 42 |
| 13.1. UART 模块说明           | 42 |
| 13.2. 特殊注意点               | 42 |
| 13.3. UART 寄存器 SFR 列表     | 42 |
| 第 14 章 IO_MAPPING_CONTROL | 47 |
| 14.1. 模块说明                | 47 |
| 14.2. IO MAPPING          |    |
| 14.3. IO 唤醒               | 50 |
| 14.4. 寄存器 SFR 列表          | 50 |
| 第 15 章 RAND64             | 56 |
| 15.1. 模块说明                | 56 |
| 第 16 章 PULSE COUNTER      | 57 |
| 16.1. 模块说明                | 57 |
| 16.2. 寄存器说明               |    |
|                           |    |
| 第 17 章 PAP                |    |
| 17.1. 模块说明                |    |
| 17.2. 模块说明                |    |
| 17.3. 传输波形                |    |



## 第1章 引言

## 1.1. 编写目的

此说明书主要对杰理 AD18N 芯片介绍。

AD18N 是一颗具备较强运算能力的 CPU,内部支持 64M 字节 FLASH 的 cache 寻址; 内部有 40K 普通 Ram + 16K Cache Ram 的内存空间。

## 1.2. 文档修改日志

| 版本  | 日期            | 描述        |  |
|-----|---------------|-----------|--|
|     |               |           |  |
| 1.0 | 2023 / 8 / 25 | 首版 CPU 文档 |  |
| 更新: | •             |           |  |



## 第 2 章 CPU 介绍

## 2.1. 说明

CPU 是一颗具备较强运算能力的 32 位处理器。CPU 有 32 个中断; 有 8 级中断优先级。

## 2.2. 中断说明

#### 2.2.1. 中断源

CPU 中断源可分为系统中断源和外设中断源。

| 中断号  | 中断类型  | 说明                        |
|------|-------|---------------------------|
| 63-4 | 外设中断源 | 优先级可配,外设中断入口,可扩展到250个     |
| 3    | 系统中断源 | 内核定时器 tick_timer          |
| 2    | 系统中断源 | 内核调度入口,不受 IE, IP 和 GIE 控制 |
| 1    | 系统中断源 | 内核异常入口,不受 IE, IP 和 GIE 控制 |
| 0    | 系统中断源 | 仿真调试入口,不受 IE, IP 和 GIE 控制 |

#### 2.2.2. 中断控制寄存器 ICFGx

优先级 IP 有 3bit, 共 8 级, 0 代表最低, 7 代表最高。进入中断后, 硬件会自动屏蔽比其优先级低的中断入口, 例如当优先级为 1 的中断产生后, 将被屏蔽优先级小于 1 或等于 1 的中断, 直到中断退出。中断使能 IE, 只要将相应 IE 的控制位打开即可

### 2.2.3. 中断入口(中断列表,中断优先级)

中断入口从中断 BASE 地址,每 4 个 byte 对应一个中断,存放相应服务程序的地址。 中断发生时,CPU 会从相应中断入口取中断服务程序的入口地址,跳到该中断服务程序。

中断只会压 PC 入 RETI,中断返回时硬件从 RETI 取出返回地址。

| 中断号 | {IP[2:0], IE} | 中断入口地址        | 中断源   |
|-----|---------------|---------------|-------|
| 63  | ICFG7[31:28]  | BASE + 中断号 x4 | Soft3 |
| 62  | ICFG7[27:24]  | BASE + 中断号 x4 | Soft2 |
| 61  | ICFG7[23:20]  | BASE + 中断号 x4 | Soft1 |
| 60  | ICFG7[19:16]  | BASE + 中断号 x4 | Soft0 |



| 59                                                             | ICFG7[15:12]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| 58                                                             | ICFG7[11:08]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 57                                                             | ICFG7[07:04]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 56                                                             | ICFG7[03:00]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 55                                                             | ICFG6[31:28]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 54                                                             | ICFG6[27:24]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 53                                                             | ICFG6[23:20]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 52                                                             | ICFG6[19:16]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 51                                                             | ICFG6[15:12]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 50                                                             | ICFG6[11:08]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 49                                                             | ICFG6[07:04]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 49                                                             | ICFG6[07:04]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
|                                                                |                                                                                                                                                             |                                                                                                                                                                                                     |                                                                             |
| 47                                                             | ICFG5[31:28]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 46                                                             | ICFG5[27:24]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 45                                                             | ICFG5[23:20]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 44                                                             | ICFG5[19:16]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 43                                                             | ICFG5[15:12]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 42                                                             | ICFG5[11:08]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 41                                                             | ICFG5[07:04]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 40                                                             | ICFG5[03:00]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 39                                                             | ICFG4[31:28]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 38                                                             | ICFG4[27:24]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | HADC                                                                        |
| 37                                                             | ICFG4[23:20]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | APA                                                                         |
| 36                                                             | ICFG4[19:16]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | AUDIO                                                                       |
| 35                                                             | ICFG4[15:12]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | UDMA_CH1                                                                    |
| 34                                                             | ICFG4[11:08]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | UDMA_CHO                                                                    |
| 33                                                             | ICFG4[07:04]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | DMA_GEN_CH1                                                                 |
| 32                                                             | ICFG4[03:00]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | DMA_GEN_CHO                                                                 |
| 31                                                             | ICFG3[31:28]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 30                                                             | ICFG3[27:24]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 29                                                             | ICFG3[23:20]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       |                                                                             |
| 28                                                             | ICFG3[19:16]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | Spi2                                                                        |
| 27                                                             | ICFG3[15:12]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | mcpwm_chx                                                                   |
| 26                                                             | ICFG3[11:08]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | lcd                                                                         |
| 25                                                             | ICFG3[07:04]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | pap                                                                         |
| 24                                                             | ICFG3[03:00]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | qdec                                                                        |
| 23                                                             | ICFG2[31:28]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | Pmu tmr1                                                                    |
| 22                                                             | ICFG2[31:28]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | Pmu_tmr0                                                                    |
| 21                                                             | ICFG2[27:24] ICFG2[23:20]                                                                                                                                   |                                                                                                                                                                                                     | _                                                                           |
|                                                                |                                                                                                                                                             | BASE + 中断号 v1                                                                                                                                                                                       | Pmu soft                                                                    |
| 20                                                             |                                                                                                                                                             | BASE + 中断号 x4                                                                                                                                                                                       | Pmu_soft                                                                    |
| 20                                                             | ICFG2[19:16]                                                                                                                                                | BASE + 中断号 x4                                                                                                                                                                                       | mcpwm_tmr                                                                   |
| 19                                                             | ICFG2[19:16]<br>ICFG2[15:12]                                                                                                                                | BASE + 中断号 x4<br>BASE + 中断号 x4                                                                                                                                                                      | mcpwm_tmr<br>timer3                                                         |
| 19<br>18                                                       | ICFG2[19:16]<br>ICFG2[15:12]<br>ICFG2[11:08]                                                                                                                | BASE + 中断号 x4<br>BASE + 中断号 x4<br>BASE + 中断号 x4                                                                                                                                                     | mcpwm_tmr<br>timer3<br>Usb_sie                                              |
| 19<br>18<br>17                                                 | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04]                                                                                                         | BASE + 中断号 x4 BASE + 中断号 x4 BASE + 中断号 x4 BASE + 中断号 x4                                                                                                                                             | mcpwm_tmr timer3 Usb_sie Usb_sof                                            |
| 19<br>18<br>17<br>16                                           | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00]                                                                                            | BASE + 中断号 x4                                                                                                                               | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt                                      |
| 19<br>18<br>17<br>16<br>15                                     | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28]                                                                               | BASE + 中断号 x4                                                                                                                 | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc                                |
| 19<br>18<br>17<br>16<br>15                                     | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28] ICFG1[27:24]                                                                  | BASE + 中断号 x4                                                                                     | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc port                           |
| 19<br>18<br>17<br>16<br>15<br>14<br>13                         | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28] ICFG1[27:24] ICFG1[23:20]                                                     | BASE + 中断号 x4                                                                       | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc port iicl                      |
| 19<br>18<br>17<br>16<br>15<br>14<br>13                         | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28] ICFG1[27:24] ICFG1[23:20] ICFG1[19:16]                                        | BASE + 中断号 x4                                                         | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc port iicl iic0                 |
| 19<br>18<br>17<br>16<br>15<br>14<br>13<br>12                   | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28] ICFG1[27:24] ICFG1[23:20] ICFG1[19:16] ICFG1[15:12]                           | BASE + 中断号 x4                                           | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc port iicl iic0 Spi1            |
| 19<br>18<br>17<br>16<br>15<br>14<br>13<br>12<br>11             | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28] ICFG1[27:24] ICFG1[23:20] ICFG1[19:16] ICFG1[15:12] ICFG1[11:08]              | BASE + 中断号 x4                             | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc port iic1 iic0 Spi1 Spi0       |
| 19<br>18<br>17<br>16<br>15<br>14<br>13<br>12<br>11<br>10<br>09 | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28] ICFG1[27:24] ICFG1[23:20] ICFG1[19:16] ICFG1[15:12] ICFG1[11:08] ICFG1[07:04] | BASE + 中断号 x4 | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc port iicl iic0 Spil Spi0 Uart2 |
| 19<br>18<br>17<br>16<br>15<br>14<br>13<br>12<br>11             | ICFG2[19:16] ICFG2[15:12] ICFG2[11:08] ICFG2[07:04] ICFG2[03:00] ICFG1[31:28] ICFG1[27:24] ICFG1[23:20] ICFG1[19:16] ICFG1[15:12] ICFG1[11:08]              | BASE + 中断号 x4                             | mcpwm_tmr timer3 Usb_sie Usb_sof gpcnt gpadc port iic1 iic0 Spi1 Spi0       |



| 06 | ICFG0[27:24] | BASE + 中断号 x4 | timer2                       |
|----|--------------|---------------|------------------------------|
| 05 | ICFG0[23:20] | BASE + 中断号 x4 | timerl                       |
| 04 | ICFG0[19:16] | BASE + 中断号 x4 | timer0                       |
| 03 | ICFG0[15:12] | BASE + 中断号 x4 | tick_tmr                     |
| 02 | ICFG0[11:08] | BASE + 中断号 x4 |                              |
| 01 | ICFG0[07:04] | BASE + 中断号 x4 | exception(misalign/watchdog) |
| 00 | ICFG0[03:00] | BASE + 中断号 x4 |                              |



## **2.3.** MEMORY

Memory 主要有对 FLASH 的管理和内部 RAM 的管理:

从 0x4000000 开始映射内置 FLASH,一共有 64M 字节的地址空间;从 0x3f000000 ~ 0x3f0a000 是系统主要 RAM 的区域。

| 0x8000000 | FLASH 64M Byte |
|-----------|----------------|
| 0x4000000 |                |
| 0x3F44000 | Reserved       |
| 0x3F40000 | ROM            |
| 0x3F30000 | Cache RAM 16K  |
| 0x3F0A000 | Reserved       |
| 0x3F00000 | RAMO 40K       |
| 0x0       | Reserved       |

AD18N

图 2.2 AD18N CPU MAPPING



## 第3章 时钟系统

### 3.1. 时钟源

- 1. AD18N 具备如下 3 个原生时钟源:
  - a) rc 250k: 内置 RC 振荡器,用于复位系统和 watch dog 功能时钟。
  - b) rc 16m: 内置 RC 振荡器,用于系统启动的初始时钟。
  - c) lrc 200k: 内置低温度电压漂移 RC 振荡器, 用于低功耗计数和 PLL 参考时钟。
  - d) xosc\_32k: 外挂 32.768kHz 晶振, 用于 RTC 走时和 LRC trimming, 不支持 PLL。
- 2. AD18N 衍生时钟源:
  - a) 来自片内 SYS\_PLL 的输出,SYSPLL 工作范围覆盖 137.14MHz~480MHz,输出 PLL\_D1P0,PLL\_D1P5,PLL\_D2P0,PLL\_D2P5,PLL\_D3P5 的时钟,如果 SYSPLL 配置为 480MHz,则能输出 480MHz,320MHz,240MHz,192MHz,137.14MHz 的时钟,每个时钟都有独立的使能端。在不使用该时钟时,软件应关闭其使能端以防止额外电源消耗。

AD18N 最大系统时钟 HSB 不超过 160MHz, LSB 时钟不超过 80MHz。





## 第4章 循环冗余校验(CRC16)

## 4.1. 模块说明

CRC16(Cyclic Redundancy Check,循环冗余校验)主要用于数据的校验,每次运算8bits,

多项式为: 
$$X^{16} + X^{12} + X^5 + X^1$$

## 4.2. 寄存器 SFR 列表

1. JL\_CRC->REG: CRC register

| Bit   | Name    | RW | Description          |
|-------|---------|----|----------------------|
| 31:16 | -       | r  | 预留                   |
| 15:0  | CRC_REG | rw | 写入初始值,CRC 计算完毕,读取校验码 |

#### 2. JL\_CRC->FIFO: CRC FIFO register

| Bit  | Name     | RW | Description            |
|------|----------|----|------------------------|
| 31:8 | -        | r  | 预留                     |
| 7:0  | CRC_FIFO | w  | 运算数据输入,HSB 先运算,LSB 后运算 |



## 第5章 看门狗

## 5.1. 模块说明

WDT(watch dog timer)看门狗定时器用于防止系统软件进入死循环等不正确的状态。它设定了一个时间间隔,软件必须每在此时间间隔内进行进行一次"清看门狗"的操作,否则看门狗将溢出,并导致系统复位(或引发中断,主要用于程序的调试)。

每次系统复位之后,看门狗默认处于关闭的状态。软件可以随时将其打开。当发生系统复位时看门狗也会被关闭。

WDT 设计在 P33 系统里,读写 WDT\_CON 需要用 P33 接口,写 CON 前无需再写 CRC REG 打 key,并且支持低功耗模式下运行。

低功耗模式下, WDT 支持:

- 1. 直接复位芯片
- 2. 唤醒芯片,进入异常
- 3. 唤醒芯片,进入 RTC 中断 (需关闭看门狗异常使能)

### 5.2. 寄存器 SFR 列表

#### 1. P3 WDT CON: Watchdog control register

| Bit | Name    | RW | Description                                                                                  |
|-----|---------|----|----------------------------------------------------------------------------------------------|
| 7   | PND     | r  | wdt 中断请求标志,当 WDRMD 设置为 1 时,WDT 溢出硬件会将此位置 1,Reset 值为 0<br>0:without pending<br>1:with pending |
| 6   | CPND    | W  | 写 1 清除中断标记位                                                                                  |
| 5   | WDRMD   | rw | 看门狗模式选择: 0: 看门狗溢出将导致系统复位,这是看门狗的主要工作模式 1: 看门狗溢出将 WINT 置 1,可产生中断或异常,这种模式主要用于调试                 |
| 4   | WDTEN   | rw | 看门狗定时器使能。<br>0:看门狗定时器关闭<br>1:看门狗定时器打开                                                        |
| 3:0 | TSEL3-0 | rw | 看门狗溢出时间选择                                                                                    |



看门狗

| 有117列 |                                 |
|-------|---------------------------------|
|       | 0000: 1mS                       |
|       | 0001: 2mS                       |
|       | 0010: 4mS                       |
|       | 0011: 8mS                       |
|       | 0100: 16mS                      |
|       | 0101: 32mS                      |
|       | 0110: 64mS                      |
|       | 0111: 128mS                     |
|       | 1000: 256mS                     |
|       | 1001: 512mS                     |
|       | 1010: 1S                        |
|       | 1011: 2S                        |
|       | 1100: 4S                        |
|       | 1101: 8S                        |
|       | 1110: 16S                       |
|       | 1111: 32S                       |
|       | Note:上述溢出时间只是参考值。实际上,wdt由不准确的   |
|       | 片内 RC 振荡器驱动, 其实际溢出时间可能会有高达 100% |
|       | 的偏差,且不同芯片之间也无法保证一致性。所以在选择       |
|       | 溢出时间时必须留有足够余量                   |
|       |                                 |

### 2. P3\_VLD\_KEEP: wdt exception register

| Bit | Name        | RW | Description                         |  |
|-----|-------------|----|-------------------------------------|--|
| 7   | -           | -  | Reserved                            |  |
| 6   | WDT EXPT EN | rw | 看门狗异常使能<br>0: 看门狗异常关闭<br>1: 看门狗异常打开 |  |
| 5:0 | -           | -  | Reserved                            |  |



## 第6章 IIC 模块

### 6.1. 模块说明

IIC接口是一个可兼容大部分 IIC 总线标准的串行通讯接口。在上面传输的数据以 Byte 为最小单位,且永远是 MSB 在前。

### 1. IIC 接口主要支持特性

- (1) 主模式和从模式,不支持多机功能;
- (2) 支持标准速度模式(Standard-mode, Sm, 高达 100kHz), 快速模式(Fast-mode, Fm, 高达 400kHz), 快速增强模式(Fast-mode Plus, Fm+, 高达 1MHz);
  - (3) 7bit 主从机寻址模式,可配置从机地址应答,广播大致响应;
  - (4) 总线时钟延展功能可配置;
  - (5) 总线数据建立时间和保持时间可配置;
  - (6) 基于便捷的事务操作驱动总线;
  - (7) 数据接收发送各独立具有1字节缓冲;
  - (8) 可配置总线信号数字滤波器;

### 2. 主机

- (1) IIC接口SCL时钟由本机产生,提供给片外IIC设备使用;
- (2) IIC 接口 SCL 时钟可配置, SCL 时钟周期为:

 $T_{IIC\_BUS\_SCL} = T_{IIC\_CLK}/(2*BUAD\_CNT) + T$  电阻上拉

#### 3. 从机

- (1) IIC 接口 SCL 时钟由片外 IIC 设备产生,经内部 IIC clk 滤波采样后给本机使用;
- (2) IIC 总线上每一个 start/restart 位后接从机地址,此时当外部 IIC 设备所发的地址与我们匹配时(开启广播地址响应,在接收到广播地址时也会响应),可配置硬件自动回应(ack

位为"0");

#### 4. 特殊注意点

时钟要求:作为主机时,BAUD、TSU、THD 值设置应当满足一下关系

BAUD\_CNT>(SETUP\_CNT + HOLD\_CNT + FLT\_SEL + 5)

作为从机时,SCL 时钟低电平时间与 TSU、THD、FLT\_SEL 值设置应当满足以下关系

 $T_{SCL\_L}$ >(SETUP\_CNT + HOLD\_CNT + FLT\_SEL + 5) \*  $T_{12C\_CLK}$ 

IO 设置: 在选择 IO 作为 IIC 接口的 SCL、SDA 输入输出时,必须配置该两个 IO 的 SPL 寄存器位为 1;

事务寄存器:写入事务后需等待硬件将写入的事务加载后(tx\_task\_load/rx\_task\_load 置位即表示对应事务被硬件加载,task\_done\_pnd 置位即表示事务已被硬件加载且执行完成)才可写入新的事务;

【注意】: IIC 的通信频率不仅与所配置的波特率有关,还会收到 IIC 总线上拉时间的影响,请尽可能符合 IIC 总线硬件电气要求。

### 6.2. 寄存器 SFR 列表

1. IIC CON0: iic control register0

| Bit   | Name          | RW | Default | RV | Description                                                                                                                              |
|-------|---------------|----|---------|----|------------------------------------------------------------------------------------------------------------------------------------------|
| 31-11 | RESERVED      | -  | -       | -  | 预留                                                                                                                                       |
| 10    | BADDR_RESP_EN | rw | 0       | -  | 广播地址响应使能: 1:响应总线上的广播地址; 0:不响应总线上的广播地址;                                                                                                   |
| 9     | AUTO_SLV_TX   | rw | 0       | -  | 从机自动发送数据事务使能(主机模式下无效): 0: 不使能 1: 使能 从机接收匹配的地址且为从机接收数据时,接下来 硬件会自动填充 SEND_DATA 事务操作,使得硬件 能不间断的发送数据; (作为从机与不支持时钟延展的主机通信时必填 使能,其他工作场景依据需求使能) |
| 8     | AUTO_SLV_RX   | rw | 0       | -  | 从机自动接收数据事务使能(主机模式下无效):                                                                                                                   |



| IIC 模块 | •             |    |   |   |                                                                                                                                                                                      |
|--------|---------------|----|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |               |    |   |   | 0:不使能 1:使能 从机接收匹配的地址且为从机接收数据时,接下来 硬件会自动填充 RECV_DATA 事务操作,使得在软 件读取数据时,硬件接口能继续不间断接收数据; (作为从机与不支持时钟延展的主机通信时必填 使能,其他工作场景依据需求使能)                                                          |
| 7      | AUTO_ADR_RESP | rw | 0 | - | 从机接收地址硬件自动响应使能:<br>作为从机时,在接收到地址数据后(接收的第一字节数据)<br>0:不自动进行响应,即不对接收到的地址数据进行 NACK/ACK 事务;<br>1:自动进行响应,接收到匹配的地址(含广播地址)自动响应 ACK;接收到不匹配的地址,自动响应 NACK<br>(从机与不支持时钟延展的主机通信时必须使能,其他工作场景依据需求使能) |
| 6      | IGNORE_NACK   | rw | 0 | _ | NACK 调试模式使能<br>0: 在发送数据中遇到 NACK 后会停止接收发送<br>1: 在发送数据中遇到 NACK 后不会中断接收发送<br>事务(仅用于调试)                                                                                                  |
| 5      | NO_STRETCH    | rw | 0 |   | IIC 主从时钟延展功能选择<br>0: 支持时钟延展<br>1: 不支持时钟延展                                                                                                                                            |
| 4-3    | FLT_SEL       | r  | 0 | - | IIC 接口数字滤波器选择<br>11: 滤除 3*T <sub>iic_baud_clk</sub> 以下尖峰脉宽;<br>10: 滤除 2*T <sub>iic_baud_clk</sub> 以下尖峰脉宽;<br>01: 滤除 T <sub>iic_baud_clk</sub> 以下尖峰脉宽;<br>00: 关闭数字滤波器;                |
| 2      | SLAVE_MODE    | w  | 0 |   | IIC 接口主从机模式:<br>0: 主机模式<br>1: 从机模式                                                                                                                                                   |
| 1      | I2C_RST       | rw | 0 | - | IIC 接口复位(使能后再释放复位)<br>0: IIC 接口复位<br>1: IIC 接口释放                                                                                                                                     |
| 0      | EN            | rw | 0 |   | IIC 接口使能<br>0: 关闭 IIC 接口<br>1: 打开 IIC 接口                                                                                                                                             |

### 2. IIC\_TASK: IIC task register

| Bit | Name | RW Default RV   | Description |
|-----|------|-----------------|-------------|
|     | Name | K W DCIAUIL K V | Describiion |



| 川し、疾・ | <u></u>       |   | _   |   |                                                                                                                                                                                                                          |
|-------|---------------|---|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1  | 3 RESERVED    | - | -   | - | 预留                                                                                                                                                                                                                       |
| 12    | SLAVE_CALL    | r | -   | - | 从机地址匹配:(仅 debug,用户正常流程不可使<br>用)                                                                                                                                                                                          |
| 11    | BC_CALL       | r | -   | - | 广播地址匹配: (仅 debug,用户正常流程不可使用)                                                                                                                                                                                             |
| 10    | SLAVE_RW      | r | -   | - | 从机读写匹配: (仅 debug,用户正常流程不可使<br>用)                                                                                                                                                                                         |
| 9-6   | RUNNING_TASK  | r | -   | - | 正在运行匹配:(仅 debug,用户正常流程不可使<br>用)                                                                                                                                                                                          |
| 5     | TASK_RUN_RDY  | r | -   | - | 事务运行状态: (仅 debug,用户正常流程不可使用)                                                                                                                                                                                             |
| 4     | TASK_LOAD_RDY | r | -   | - | 事务加载状态: (仅 debug,用户正常流程不可使<br>用)                                                                                                                                                                                         |
| 3-0   | RUN_TASK      | W | 0x0 | - | 事务操作:以下 9 种事务操作涵盖了主从机接收发送时的总线行为序列(具体解析见下节) 0x0: SEND_RESET 0x1: SEND_ADDR 0x2: SEND_DATA 0x3: SEND_ACK 0x4: SEND_NACK 0x5: SEND_STOP 0x6: SEND_NACK_STOP 0x7: RECV_DATA 0x8: RECV_DATA_WITH_ACK 0x8: RECV_DATA_WITH_NACK |

### 3. IIC\_PND: IIC pending register

| Bit   | Name            | RW | Default | RV | Description                                         |
|-------|-----------------|----|---------|----|-----------------------------------------------------|
| 31-29 | RESERVED        | -  | -       | -  | 预留                                                  |
| 28    | RXTASK_LOAD_PND | r  | 0       | -  | 硬件将当前的接收相关的 task 事务加载完成                             |
| 27    | TXTASK_LOAD_PND | r  | 0       | -  | 硬件将当前的发送相关的 task 事务加载完成                             |
| 26    | RXBYTE_DONE_PND | r  | 0       | -  | 接收 1byte 的数据                                        |
| 25    | ADR_MATCH_PND   | r  | 0       | _  | 作为从机接收到与 ADDR 相符的地址(开始广播<br>地址响应使能后,匹配广播地址也会起该 PND) |
| 24    | RXNACK_PND      | r  | 0       | -  | 发送地址/数据后接收到 NACK                                    |
| 23    | RXACK_PND       | r  | 0       | -  | 发送地址/数据后接收到 ACK                                     |
| 22    | STOP_PND        | r  | 0       | -  | 接收到总线 STOP 信号序列                                     |
| 21    | RESTART_PND     | r  | 0       | -  | 接收到总线 RESTART 信号序列                                  |
| 20    | TASK_PND        | r  | 0       | -  | 事务执行完成 PND                                          |



| 10 疾药 |                 |    |   |   |               |
|-------|-----------------|----|---|---|---------------|
| 19    | RESERVED        | -  | - | - | 预留            |
| 18    | RXTASK_LOAD_CLR | w  | - | - | 写"1"清除对应的 PND |
| 17    | TXTASK_LOAD_CLR | w  | - |   | 写"1"清除对应的 PND |
| 16    | RXDATA_DONE_CLK | w  | - |   | 写"1"清除对应的 PND |
| 15    | ADR_MATCH_CLR   | w  | - |   | 写"1"清除对应的 PND |
| 14    | RXNACK_CLR      | w  | - |   | 写"1"清除对应的 PND |
| 13    | RXACK_CLR       | w  | - |   | 写"1"清除对应的 PND |
| 12    | STOP_CLR        | W  | - |   | 写"1"清除对应的 PND |
| 11    | RESTART_CLR     | w  | - |   | 写"1"清除对应的 PND |
| 10    | TASK_CLR        | w  | - |   | 写"1"清除对应的 PND |
| 9     | RESERVED        | -  | - | - | 预留            |
| 8     | RXTASK_LOAD_IE  | rw | 0 |   | 对应 PND 的中断使能  |
| 7     | TXTASK_LOAD_IE  | rw | 0 |   | 对应 PND 的中断使能  |
| 6     | RXTASK_DONE_IE  | rw | 0 |   | 对应 PND 的中断使能  |
| 5     | ADR_MATCH_IE    | rw | 0 |   | 对应 PND 的中断使能  |
| 4     | RXNACK_IE       | rw | 0 |   | 对应 PND 的中断使能  |
| 3     | RXACK_IE        | rw | 0 | - | 对应 PND 的中断使能  |
| 2     | STOP_IE         | rw | 0 | - | 对应 PND 的中断使能  |
| 1     | RESTART_IE      | rw | 0 | - | 对应 PND 的中断使能  |
| 0     | TASK_IE         | rw | 0 | - | 对应 PND 的中断使能  |

### 4. IIC\_TXBUF: IIC tx buff register

| Bit  | Name     | RW | Default | RV | Description |
|------|----------|----|---------|----|-------------|
| 31-8 | RESERVED | -  | -       | -  | 预留          |
| 7-0  | TX_BUFF  | rw | -       | -  | 待发送数据       |

### 5. IIC\_RXBUF: IIC rx buff register

| Bit  | Name     | RW | Default | RV | Description |
|------|----------|----|---------|----|-------------|
| 31-8 | RESERVED | -  | -       | -  | 预留          |
| 7-0  | RX_BUFF  | r  | -       | -  | 已接收数据       |

### 6. IIC\_ADDR: IIC device address register

| Bit  | Name            | RW | Default | RV | Description                |
|------|-----------------|----|---------|----|----------------------------|
| 31-8 | RESERVED        | -  | -       | -  | 预留                         |
| 7-1  | IIC DEVICE ADDR | rw | 0x00    | -  | IIC 设备地址(仅支持 7bit 模式)      |
| 0    | W/R OPTION      | rw | 0x0     | -  | 作为主机发送地址时的读写标志: 0:发送数据的从机; |



| 1: 读取从机的数据; |  |
|-------------|--|
|-------------|--|

#### 7. IIC BAUD: IIC baud clk register

| Bit   | Name     | RW | Default | RV | Description                                                         |
|-------|----------|----|---------|----|---------------------------------------------------------------------|
| 31-12 | RESERVED | -  | -       | -  | 预留                                                                  |
| 11-0  | BAUD_CNT | rw | -       | -  | IIC 总线传输时钟 SCL 速率配置: FIIC_BUS_SCL = FIIC_CLK / BUAD_CNT 注意: 不可设置为 0 |

#### 8. IIC\_TSU: IIC setup time register

| Bit  | Name      | RW | Default | RV | Description                                                                                             |
|------|-----------|----|---------|----|---------------------------------------------------------------------------------------------------------|
| 31-7 | RESERVED  | -  | -       | -  | 预留                                                                                                      |
| 6-0  | SETUP_CNT | rw | -       | -  | IIC 总线 SDA 信号更新后到 SCL 时钟上升的最少时间配置:  T <sub>setup</sub> = T <sub>IIC_CLK</sub> * SETUP_CNT 无特殊情况软件配置为 2; |

#### 9. IIC\_THD: IIC hold time register

| Bit  | Name     | RW | Default | RV | Description                                                                    |
|------|----------|----|---------|----|--------------------------------------------------------------------------------|
| 31-8 | RESERVED | -  | -       | -  | 预留                                                                             |
| 7-0  | TX_BUFF  | rw | -       | -  | IIC 总线 SCL 时钟下降到 SDA 信号更新去前的最少时间配置:  Thold = TIIC_CLK * HOLD_CNT 无特殊情况软件配置为 2; |

#### 10. IIC\_DBG: IIC debug register

| Bit   | Name    | RW | Default RV |   | Description |
|-------|---------|----|------------|---|-------------|
| 31-16 | SDA_DBG | r  | -          | - | SDA 相关调试信号  |
| 15-0  | SCL_DBG | r  | -          | - | SCL 相关调试信号  |

## 6.3. 基本事务操作

IIC\_TASK 事务寄存器允许写入以下 9 种事务操作值来驱动 IIC 接口做出相应总线行为序列:

1.0x0: SEND\_RESET

工作在主机模式下,向 IIC 总线发送 START 和 STOP;



#### 2.0x1: SEND ADDR

工作在主机模式下,向 IIC 总线发送 START 和 ADDR 的数据,并接收从机回复的 ACK/NACK;

#### 3.0x2: SEND DATA

工作在主机模式下,向 IIC 总线发送 TX BUFF 的数据,并接收从机回复的 ACK/NACK;

#### 4.0x3: SEND ACK

工作在主机/从机模式下,向 IIC 总线发送 ACK;

#### 5.0x4: SEND NACK

工作在主机/从机模式下,向 IIC 总线发送 NACK;

#### 6.0x5: SEND STOP

工作在主机/从机模式下,向 IIC 总线发送 STOP;

#### 7.0x6: SEND NACK STOP

工作在主机/从机模式下,向 IIC 总线发送 NACK 和 STOP;

#### 8.0x7: RECV DATA

工作在主机/从机模式下,从 IIC 总线上接收一个字节数据,但不进行 ACK/NACK (持续拉低 SCL 线,总线上的设备需支持时钟延展),知道 SEND\_ACK/SEND\_NACK 的事务被填充 SCL 才会撤销拉低;

#### 9.0x8: RECV DATA WITH ACK

工作在主机/从机模式下,从IIC总线上接收一个字节数据,且随后向IIC总线发送ACK; 10.0x9: RECV DATA WITH NACK

工作在主机/从机模式下,从 IIC 总线上接收一个字节数据,且随后向 IIC 总线发送 NACK:



### 第7章 SPI 模块

### 7.1. 模块说明

SPI 接口是一个标准的遵守 SPI 协议的串行通讯接口,在上面传输的数据以 Byte (8bit)为最小单位,且永远是 MSB 在前。

SPI 接口支持主机和从机两种模式:

主机: SPI 接口时钟由本机产生,提供给片外 SPI 设备使用。

从机: SPI 接口时钟由片外 SPI 设备产生,提供给本机使用。

工作于主机模式时,SPI 接口的驱动时钟可配置,范围为 系统时钟~系统时钟/256。工作于从机模式时,SPI 接口的驱动时钟频率无特殊要求,但数据速率需要进行限制,否则易出现接收缓冲覆盖错误。

SPI 接口可独立地选择在 SPI 时钟的上升沿或下降沿更新数据,在 SPI 时钟的上升沿或下降沿采样数据。该芯片有 2 个 SPI: SPI0、SPI1

SPI 接口支持主机和从机两种模式:

主机: SPI 接口时钟由本机产生,提供给片外 SPI 设备使用。

从机: SPI 接口时钟由片外 SPI 设备产生,提供给本机使用。

工作于主机模式时,SPI接口的驱动时钟可配置,范围为系统时钟~系统时钟/256。工作于从机模式时,SPI接口的驱动时钟频率无特殊要求,但数据速率需要进行限制,否则易出现接收缓冲覆盖错误。

SPI 接口支持单向(Unidirection)和双向(Bidirection)模式。

单向模式:使用 SPICK 和 SPIDAT 两组连线,其中 SPIDAT 为双向信号线,同一时刻数据只能单方向传输。

双向模式:使用 SPICK,SPIDI 和 SPIDO 三组连线,同一时刻数据双向传输。但 DMA 不支持双向数据传输,当在本模式下使能 DMA 时,也只有一个方向的数据能通过 DMA 和系统进行传输。

SPI 单向模式支持 1bit data、2bit data 和 4bit data 模式,即:

1bit data 模式: 串行数据通过一根 DAT 线传输,一个字节数据需 8 个 SPI 时钟。

2bit data 模式: 串行数据通过两根 DAT 线传输,一个字节数据需 4 个 SPI 时钟。

4bit data 模式: 串行数据通过四根 DAT 线传输,一个字节数据需 2 个 SPI 时钟。

SPI 双向模式只支持 1bit data 模式,即:

1bit data 模式: 串行数据通过一根 DAT 线传输, 一个字节数据需 8 个 SPI 时钟。

SPI接口在发送方向上为单缓冲,在上一次传输未完成之前,不可开始下一次传输。在接收方向上为双缓冲,如果在下一次传输完成时 CPU 还未取走本次的接收数据,那么本次的接收数据将会丢失。

SPI 接口的发送寄存器和接收寄存器在物理上是分开的,但在逻辑上它们一起称为

SPI 模块

SPIBUF 寄存器,使用相同的 SFR 地址。当写这个 SFR 地址时,写入至发送寄存器。当读这个 SFR 地址时,从接收寄存器读出。

SPI 传输支持由 CPU 直接驱动,写 SPIBUF 的动作将启动一次 Byte 传输。

SPI 传输也支持 DMA 操作,但 DMA 操作永远是单方向的,即一次 DMA 要么是发送一包数据,要么是接收一包数据,不能同时发送并且接收一包数据,即使在双向模式下也是这样。每次 DMA 操作支持的数据量为 1-65535Byte。写 SPI\_CNT 的动作将启动一次 DMA 传输。

## 7.2. 寄存器 SFR 列表

1. SPIx\_CON: SPIx control register 0

| Bit   | Name       | RW | Default | RV  | Description                                                                                                       |
|-------|------------|----|---------|-----|-------------------------------------------------------------------------------------------------------------------|
| 31-22 | RESERVED   | -  | -       | -   | 预留                                                                                                                |
| 21    | OF_PND     | r  | 0       | -   | dma fifo overflow,当 spi 做从机 dma 接收时,fifo 满<br>且 dma 响应慢,而新接收的数据到来时导致 fifo 发生<br>溢出就会产生 of_pnd<br>【注意】:仅做 debug 使用 |
| 20    | OF_PND_CLR | w  | 0       | -   | 清除 of_pnd 写 1 清零                                                                                                  |
| 19    | OF_IE      | rw | 0       | -   | of_pnd 使能位                                                                                                        |
| 18    | UF_PND     | r  | 0       | 1   | dma fifo overflow,当 spi 做从机 dma 接收时,fifo 空<br>且 dma 响应慢,而新接收的数据到来时导致 fifo 发生<br>溢出就会产生 of_pnd<br>【注意】:仅做 debug 使用 |
| 17    | UF_PND_CLR | w  | 0       | -   | 清除 uf_pnd 写 1 清零                                                                                                  |
| 16    | UF_IE      | rw | 0       | 1   | uf_pnd 使能位                                                                                                        |
| 15    | PND        | r  | 0       | 0   | 预留                                                                                                                |
| 14    | CPND       | w  | 0       | 1   | 软件在此位写入'1'将清除 PND 中断请求标志                                                                                          |
| 13    | ΙE         | rw | 0       |     | SPI 中断使能<br>0:禁止 SPI 中断<br>1:允许 SPI 中断                                                                            |
| 12    | DIR        | rw | 0       |     | 在单向模式或 DMA 操作时设置传输的方向<br>0: 发送数据<br>1: 接收数据                                                                       |
| 11-10 | DATW       | r  | 0x0     | 0x0 | SPI 数据宽度设置<br>00: 1bit 数据宽度<br>01: 2bit 数据宽度<br>10: 4bit 数据宽度<br>11: NA,不可设置为此项                                   |



SPI 模块

| SPI 模块<br>9-8 | RESERVED | _  | _ | _ | 预留                                                                                                                                                          |
|---------------|----------|----|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7             | CSID     | rw | 0 | 0 | SPICS 信号极性选择<br>0: SPICS 空闲时为 0 电平<br>1: SPICS 空闲时为 1 电平                                                                                                    |
| 6             | CKID     | rw | 0 | 0 | SPICK 信号极性选择<br>0: SPICS 空闲时为 0 电平<br>1: SPICS 空闲时为 1 电平                                                                                                    |
| 5             | UE       | rw | 0 | 0 | 更新数据边沿选择<br>0:在 SPICK 的上升沿更新数据<br>1:在 SPICK 的下降沿更新数据                                                                                                        |
| 4             | SE       | rw | 0 | 0 | 采样数据边沿选择<br>0:在 SPICK 的上升沿采样数据<br>1:在 SPICK 的下降沿采样数据                                                                                                        |
| 3             | BDIR     | rw | 0 | 0 | 单向/双向模式选择 0: 单向模式,数据单向传输,同一时刻只能发送或者接收数据。数据传输方向因收发而改变,所以由硬件控制,不受写 IO 口 DIR 影响。 1: 双向模式,数据双向传输,同时收发数据,但 DMA只支持一个方向的数据传输。数据传输方向设置后不改变,所以由软件控制,通过写 IO 口 DIR 控制。 |
| 2             | CSE      | rw | 0 | 1 | SPICS 信号使能,always set 为 1                                                                                                                                   |
| 1             | SLAVE    | rw | 0 | 0 | 从机模式                                                                                                                                                        |
| 0             | SPIEN    | rw | 0 | 0 | SPI 接口使能<br>0: 关闭 SPI 接口<br>1: 打开 SPI 接口                                                                                                                    |

### 2. SPI x \_BAUD: SPI baud rate setting register

| Bit | Name     | RW | Default | RV    | Description                                       |
|-----|----------|----|---------|-------|---------------------------------------------------|
| 7-0 | SPI_BAUD | rw | 0x0     | ()y() | SPI 主机时钟设置寄存器<br>SPICK=system clock/(SPIBAUD + 1) |

### 3. SPIx\_BUF: SPI buffer register

| Bit | Name    | RW | Default | RV  | Description                                  |
|-----|---------|----|---------|-----|----------------------------------------------|
| 7-0 | SPI_BUF | rw | 0x0     | 0x0 | 发送寄存器和接收寄存器共用此 SFR 地址。写入至<br>发送寄存器,从接收寄存器读出。 |

### 4. SPIx\_ADR: SPI DMA start address register

| Bit | Name    | RW | Default | RV  | Descrip          | otion |         |
|-----|---------|----|---------|-----|------------------|-------|---------|
| 7-0 | SPI_ADR | rw | 0x0     | 0x0 | SPI DMA 起始地址寄存器, | 只写,   | 读出为不确定值 |



#### 5. SPIx\_CNT: SPI DMA counter register

| Bit  | Name    | RW | Default | RV  | Description                                                                                                              |
|------|---------|----|---------|-----|--------------------------------------------------------------------------------------------------------------------------|
| 31-0 | SPI_CNT | rw | 0x0     | 0x0 | SPI DMA 计数寄存器,读出为当下剩余读写数量,此寄存器用于设置 DMA 操作的数目(按 Byte 计)并启动 DMA 传输<br>如,需启动一次 512Byte 的 DMA 传输,写入 0x0200,<br>此写入动作将启动本次传输。 |

#### 6. SPIx\_CON1:SPIx control register

| Bit | Name         | RW | Default | RV | Description                                                                                                                                |  |  |
|-----|--------------|----|---------|----|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7-0 | SPI_BAUD     | -  | -       |    | SPI 主机时钟设置寄存器<br>SPICK=system clock/(SPIBAUD + 1)                                                                                          |  |  |
| 2   | MIX_MODE     | rw | 0       | -  | 3wire 模式混合接线                                                                                                                               |  |  |
| 1-0 | SPI_BIT_MODE | rw | 0       | 0  | 设置 spi 输入输出位流模式,默认 0 为标准格式 0: [7, 6, 5, 4, 3, 2, 1, 0] 1: [0, 1, 2, 3, 4, 5, 6, 7] 2: [3, 2, 1, 0, 7, 6, 5, 4] 3: [4, 5, 6, 7, 0, 1, 2, 3] |  |  |

SPI DMA 计数寄存器,只写,读出为不确定值。此寄存器用于设置 DMA 操作的数目 (按 Byte 计)并启动 DMA 传输。如:需启动一次 512Byte 的 DMA 传输,写入 0x0200,此写入动作将启动本次传输。

#### 传输波形图:





SPI 模块





## 第8章 数模转换器(ADC)

## 8.1. 模块说明

12Bit ADC(A/D 转换器),支持 6bit/8bit/10bit/12bit 数据位宽采样,其时钟最大不可超过12MHz。可通过 CPU 访问,逐次读取各个通道电压值;也可通过配置固定的采样率和通道数,使用 DMA 模式自动读取通道电压值;使用 DMA 模式的同时 CPU 也可以同时操作读取不同通道电压值,但需要做好采样时间分配。



图 8.1 SARADC 通道选择结构图

数模转换器(ADC)

# 8.2. 寄存器 SFR 列表

1. ADC CON: ADC control register

|       | ADC_CON: ADC co | onuoi . |         |    |                                                                                              |
|-------|-----------------|---------|---------|----|----------------------------------------------------------------------------------------------|
| Bit   | Name            | RW      | Default | RV | Description                                                                                  |
| 31    | ADC_CTL_EN      | rw      | 0x0     | 1  | ADC 控制逻辑使能,正常工作需要设置为<br>1                                                                    |
| 30    | RESERVED        | -       | -       | -  | 预留                                                                                           |
| 29    | TRI_PND         | r       | 0       | -  | 触发标识                                                                                         |
| 28    | TRI_CLR_PND     | w       | 0       | -  | 清除触发标志,写"1"清除                                                                                |
| 27    | TRI_IE          | rw      | 0       | -  | UDMA 触发使能位,用于 udma 联动场景                                                                      |
| 26    | RD_PRIORITY     | rw      | 0       | 0  | 读取优先权,用于调整 CPU 和 DMA 读ADC 的优先权,当 CPU 和 DMA 同时访问ADC 时生效 0: DMA 优先级高于 CPU 1: CPU 优先级高于 DMA     |
| 25    | ADC_AEN         | rw      | 0       | 0  | ADC 模拟使能,置 1 保持模拟功能常开                                                                        |
| 24-23 | BIT_SEL         | rw      | 0       | -  | ADC 采样数据位宽选择<br>0: 6bit<br>1: 8bit<br>2: 10bit<br>3: 12bit                                   |
| 22-16 | BAUD            | rw      | x       | -  | ADC 时钟波特率设置<br>BAUD = 0: ADC_CLK = LSB_CLK<br>BAUD != 0: ADC_CLK =<br>LSB_CLK/(ADC_BAUD * 2) |
| 15    | CPND            | r       | 0       | -  | CPU 采样中断标识                                                                                   |
| 14    | CLR_PND         | rw      | 0       | -  | 清除 CPU 采样中断标识,写"1"清除                                                                         |
| 13    | IE              | rw      | 0       | -  | CPU 采样模式中断使能                                                                                 |
| 12-10 | ANA_SEL         | rw      | 0       | -  | CPU 选择内部信号通道                                                                                 |
| 9     | IO_SEL[0]       | rw      | 0       | -  | CPU 选择 IO 测试信号通道最低位                                                                          |
| 8     | IO_SEL[1]       | rw      | 0       | -  | CPU 选择 IO 测试信号通道次低位                                                                          |
| 7     | IO_SEL[2]       | rw      | 0       | -  | CPU 选择 IO 测试信号通道次高位                                                                          |
| 6     | IO_SEL[3]       | rw      | 0       | -  | CPU 选择 IO 测试信号通道最高位                                                                          |
| 5     | DIFF_EN         | rw      | 0       | -  | CPU 访问模式下选择差分测试信号通路                                                                          |
| 4     | DMUX_EN         | rw      | 0       | -  | CPU 访问模式下选择 IO 测试信号                                                                          |
| 3     | AMUX_EN         | rw      | 0       | -  | CPU 访问模式下选择内部测试信号                                                                            |
| 2     | CAL_KST         | w       | 0       | 1  | ADC 模拟校准 kick_start,写 1 执行一次<br>ADC 模拟内部校准,默认初始化进行校                                          |



#### 数模转换器(ADC)

|   |          |    |   |   | 准,需先打开 ADC_CTL_EN                                               |
|---|----------|----|---|---|-----------------------------------------------------------------|
| 1 | ADC_ARST | rw | 1 |   | ADC 模拟复位 1: ADC 模拟复位使能,硬件根据需要自动关闭复位 0: ADC 模拟复位常关,关闭复位,硬件无法自动复位 |
| 0 | ADC_AEN  | rw | 0 | 0 | 1: ADC 模拟使能常开<br>0: ADC 模拟使能有硬件根据需要自动开<br>关<br>通常设置 0           |

### 2. ADC\_RES: ADC result register

| Bit   | Name     | RW | Default | RV | Description                                                                                                                |
|-------|----------|----|---------|----|----------------------------------------------------------------------------------------------------------------------------|
| 31-12 | RESERVED | -  | -       | -  | 预留                                                                                                                         |
| 11-0  | RES      | r  | 0       | -  | CPU 访问 ADC 结果,有效位如下6bit 模式: 高 6 位数据有效,低 6 位数据无效8bit 模式: 高 8 位数据有效,低 4 位数据无效10bit 模式: 高 10 位数据有效,低 2 位数据无效12bit 模式: 12 数据有效 |

### 3. ANA\_CON: analog control register

| Bit   | Name         | RW | Default | RV | Description                                                           |
|-------|--------------|----|---------|----|-----------------------------------------------------------------------|
| 31-23 | RESERVED     | -  | -       | -  | 预留                                                                    |
| 22-21 | PWER_SEL     | rw | 0       | 0  | 参考电压、电源切换控制位,高电平有效                                                    |
| 20-19 | DYPWR_SEL    | rw | 0       | 3  | 动态功耗控制位,低电平标识高功耗状态                                                    |
| 18-17 | CMP_IS       | rw | 0       | 2  | 比较器前级放大电流档位                                                           |
| 16-15 | DAC_IS       | rw | 0       | 2  | DAC 校准电流档位                                                            |
| 14    | PMU_DET_     | rw | 0       | 0  | PMU voltage detect to ADC output enable                               |
| 13    | SENSE_VCM_EN | rw | 0       | 0  | 差分放大器 VCM 使能位                                                         |
| 12-11 | SENSE_GAIN   | rw | 0       | 1  | 差分放大器增益档位                                                             |
| 10-9  | SENSE_IS     | rw | 0       | 2  | 差分放大器校准电流位                                                            |
| 8     | SENSE_EN     | rw | 0       | -  | 差分放大器使能,使用差分/VB 通道采样时,需将位置 1                                          |
| 7     | CPU_VN_EN    | rw | 0       | -  | CPU VB 通道采样,N 通道使能<br>注:该位不能与 CPU_SP/SN_EN 同时使<br>能,须与 CPU_VP_EN 同时使能 |



#### 数模转换器(ADC)

| 6   | CPU_VP_EN  | rw | 0 | - | CPU VB 通道采样,P 通道使能<br>注:该位不能与 CPU_SP/SN_EN 同时使<br>能,须与 CPU_VN_EN 同时使能 |
|-----|------------|----|---|---|-----------------------------------------------------------------------|
| 5-4 | CPU_SN_SEL | rw | 0 | - | N 通道输入信号选择<br>注:不能和 CPU_SN_SEL 同时选择同一<br>通道                           |
| 3-2 | CPU_SP_SEL | rw | 0 | - | P 通道输入信号选择<br>注:不能和 CPU_SN_SEL 同时选择同一<br>通道                           |
| 1   | CPU_SN_EN  | rw | 0 | - | CPU 差分通道采样,N 通道使能                                                     |
| 0   | CPU_SP_EN  | rw | 0 | - | CPU 差分通道采样,P 通道使能                                                     |



## 第9章 时钟脉冲计数器(GPCNT)

## 9.1. 模块说明

GPCNT 为时钟脉冲计数器,用于计算两个时钟周期的比例,即用一个已知时钟(主时钟)计算另一个时钟(次时钟)的周期。



图 1 GPCNT 时钟计算示意图



图 2 GPCNT 时钟源选择示意图

第 9-29 页 共 62 页

时钟脉冲计数器(GPCNT)

# 9.2. 寄存器 SFR 列表

#### 1. JL GPCNT->CON: GPCNT configuration register

| Bit   | Name     | RW    | Default | RV   | Description                                                |
|-------|----------|-------|---------|------|------------------------------------------------------------|
| DIL   | Ivallic  | IX VV | Delault | IX V | •                                                          |
|       |          |       |         |      | 中断请求标志(当 JL_GPCNT->CON[0]置<br>1 后,主时钟达到 JL GPCNT->[11:8]设定 |
| 31    | PND      | r     | 0       | -    | 的周期数后,PENDING置1,并请求中断):                                    |
|       |          |       |         |      | 0: 无 PENDING                                               |
|       |          |       |         |      | 1:有 PENDING                                                |
|       |          |       |         |      | 清除中断请求标志位                                                  |
| 30    | CLR_PND  | W     | X       | -    | 0: 无效                                                      |
|       |          |       |         |      | 1: 清 PENDING                                               |
| 29-20 | RESERVED | -     | -       | -    | 预留                                                         |
|       |          |       |         |      | 主时钟周期数选择:                                                  |
| 19-16 | GTS      | rw    | 0       | -    | 主时钟周期数 = 32*2^n                                            |
|       |          |       |         |      | (其中 n=GTS)                                                 |
| 15-13 | RESERVED | -     | -       | -    | 预留                                                         |
| 12-8  | GSS      | rw    | 0x0     | -    | 主时钟选择(计数时钟): 见图 2                                          |
| 7-6   | RESERVED | -     | -       | -    | 预留                                                         |
| 5-1   | CSS      | r     | 1       | -    | 次时钟选择(被计数时钟): 见图 1-2                                       |
| 0     | ENABLE   | rw    | 0       | -    | GPCNT 模块使能位                                                |

(注:需配置好其他位,才将 ENABLE 置 1。)

### 2. JL\_GPCNT->NUM: The number of GPCNT clock cycle register

| Bit | Name | RW | Default | RV | Description                                                  |
|-----|------|----|---------|----|--------------------------------------------------------------|
| 31  | NUM  | r  | 0       | -  | 在 JL_GPCNT->CON[0]置 1 到 PENDING<br>置 1(中断到来)之间,次时钟跑的周期<br>数。 |



## 第 10 章 定时器(Timer)

## 10.1. 模块说明

Timer 是一个集合了定时/计数/捕获功能于一体的多动能 16 位定时器。它的驱动源可以选择片内时钟或片外信号。它带有一个可配置的最高达 64 的异步预分频器,用于扩展定时时间或片外信号的最高频率。它具有上升沿/下降沿捕获功能,可以方便的对片外信号的高电平/低电平宽度进行测量。



图 1 TIMER 时钟源选择示意图

### 10.2. 定时器 IO 通道

| JL_TIMERx | 固定 IO | Crossbar |
|-----------|-------|----------|
| JL_TIMER0 | PD8   | 任意 IO    |
| JL_TIMER1 | PD9   | 任意 IO    |
| JL_TIMER2 | PD10  | 任意 IO    |
| JL_TIMER3 | PD11  | 任意 IO    |

定时器(Timer)

# 10.3. 寄存器 SFR 说明

#### 1. JL TIMERx->CON: timer x configuration register

|       | . JL_TIMERx->CON: timer x configuration register |    |         |    |                                                                                                                                                                                                                                                     |  |  |  |
|-------|--------------------------------------------------|----|---------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit   | Name                                             | RW | Default | RV | Description                                                                                                                                                                                                                                         |  |  |  |
| 31-17 | RESERVED                                         | -  | -       | -  | 预留                                                                                                                                                                                                                                                  |  |  |  |
| 16    | DUAL_EDGE_E<br>N                                 | rw | 0       | -  | DUAL_EDGE_EN:双边沿捕获模式,当 MODE=2或3时,使能该位即变成双边沿捕获模式,在上沿和下沿会将TxCNT的值写入TxPR                                                                                                                                                                               |  |  |  |
| 15    | PND                                              | r- | 0       | -  | PND: 中断请求标志, 当 timer 溢出或产生 捕获动作时会被硬件置 1, 需要由软件清 0                                                                                                                                                                                                   |  |  |  |
| 14    | PCLR                                             | w  | X       | -  | PCLR:软件在此位写入'1'将清除 PND 中断请求标志                                                                                                                                                                                                                       |  |  |  |
| 13-10 | SSEL                                             | rw | 0x0     | -  | timer 驱动源选择见图 1<br>【注意】:选择的时钟需要要使用 PSET<br>分频到(lsb_clk/2)以下!                                                                                                                                                                                        |  |  |  |
| 9     | PWM_INV                                          | rw | 0       | -  | PWM_INV: PWM 信号输出反向                                                                                                                                                                                                                                 |  |  |  |
| 8     | PWM_EN                                           | rw | 0       | -  | PWM_EN: PWM 信号输出使能。此位置 1后,相应 IO 口的功能将会被 PWM 信号输出替代。                                                                                                                                                                                                 |  |  |  |
| 7-4   | PSET                                             | rW | 0x0     | -  | PSET: 预分频选择位 0000: 预分频 1 0001: 预分频 4 0010: 预分频 16 0011: 预分频 64 0100: 预分频 1*2 0101: 预分频 4*2 0110: 预分频 16*2 0111: 预分频 64*2 1000: 预分频 1*256 1001: 预分频 16*256 1010: 预分频 16*256 1110: 预分频 12*256 1110: 预分频 1*2*256 1110: 预分频 16*2*256 1111: 预分频 64*2*256 |  |  |  |
| 3-2   | CSEL                                             | rw | 0x0     | -  | 捕获模式端口选择:<br>0: IO mux in (crossbar) / fix io (timer0)<br>1: IRFLT_OUT                                                                                                                                                                              |  |  |  |



定时器(Timer)

| 1-0 | MODE | rw | 0x0 | MODE1-0:工作模式选择 00: timer 关闭; 01: 定时/计数模式; 10: IO 口上升沿捕获模式(当 IO 上升沿到来时,把 JL_TIMERx_CNT 的值捕捉到JL_TIMERx_PRD 中) 11: IO 口下降沿捕获模式(当 IO 下降沿到来时,把 JL_TIMERx_CNT 的值捕捉到JL_TIMERx_PRD 中) |
|-----|------|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-----|------|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 2. JL TIMERx->CNT: timer x counter register

| Bit   | Name     | RW | Default | RV | Description  |
|-------|----------|----|---------|----|--------------|
| 31-16 | RESERVED | -  | -       | -  | 预留           |
| 15-0  | Tx_CNT   | rw | X       | -  | Timer 的计数寄存器 |

#### 3. JL TIMERx->PRD: timer x period register

| Bit  | Name       | RW | Default | RV | Description  |
|------|------------|----|---------|----|--------------|
| 31-1 | 6 RESERVED | -  | -       | -  | 预留           |
| 15-0 | Tx_PR      | rw | X       | -  | Timer 的周期寄存器 |

在定时/计数模式下,当 JL\_TIMERx\_CNT == JL\_TIMERx\_PRD 时,JL\_TIMERx\_CNT 会被清 0。

在上升沿/下降沿捕获模式下,JL\_TIMERx\_PRD 是作为捕获寄存器使用的,当捕获发生时,JL\_TIMERx\_CNT 的值会被复制到 JL\_TIMERx\_PRD 中。而此时 JL\_TIMERx\_CNT 自由的由 0-65535-0 计数,不会和 TIMERx PRD 进行比较清 0

#### 4. JL TIMERx->PWM: timer x PWM register

| Bi   | Name       | RW | Default | RV | Description       |
|------|------------|----|---------|----|-------------------|
| 31-1 | 6 RESERVED | -  | -       | -  | 预留                |
| 15-  | 0 Tx_CNT   | rw | X       | -  | Timer16 的 PWM 寄存器 |

在 PWM 模式下,此寄存器的值决定 PWM 输出的占空比。占空比 N 的计算公式如下: N=(Tx PWM/Tx PR)\*100%

此寄存器带有缓冲,写此寄存器的动作不会导致不同步状态产生的 PWM 波形占空比瞬间过大或过小的问题。



## 第11章 红外滤波模块(IRFLT)

## 11.1. 模块说明

IRFLT 是一个专用的硬件模块,用于去除掉红外接收头信号上的窄脉冲信号,提升红外接收解码的质量。

IRFLT 使用一个固定的时基对红外信号进行采样,必须连续 4 次采样均为'1'时,输出信号才会变为'1',必须连续 4 次采样均为'0'时,输出信号才会变为'0'。换言之,脉宽小于 3 倍时基的窄脉冲将被滤除。改变该时基的产生可兼容不同的系统工作状态,也可在一定范围内调整对红外信号的过滤效果。

通过对 IOMC 寄存器的配置,可以将 IRFLT 插入到系统 4 个 timer 中某一个的捕获引脚之前。例如通过 IOMC 寄存器选择了 IRFLT 对 timer1 有效,并且 IRFLT\_EN 被使能之后,则 IO 口的信号会先经过 IRFLT 进行滤波,然后再送至 timer1 中进行边沿捕获。

## 11.2. 寄存器 SFR 列表

1. JL IRFLT->CON: irda filter configuration register

| Bit | Name | RW | Description                                                                                                                                                                                                                                                            |
|-----|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | PSEL | rw | 时基发生器分频选择 0000: 分频倍数为 1 0001: 分频倍数为 2 0010: 分频倍数为 4 0011: 分频倍数为 8 0100: 分频倍数为 16 0101: 分频倍数为 32 0110: 分频倍数为 64 0111: 分频倍数为 128 1000: 分频倍数为 256 1001: 分频倍数为 512 1010: 分频倍数为 1024 1011: 分频倍数为 2048 1100: 分频倍数为 4096 1101: 分频倍数为 8192 1110: 分频倍数为 16384 1111: 分频倍数为 32768 |



#### 红外滤波模块(IRFLT)

| 3:2 | TSRC     | rw | 时基发生器驱动源选择,见图 1                        |
|-----|----------|----|----------------------------------------|
| 1   | -        | r  | 预留                                     |
| 0   | IRFLT_EN |    | IRFLT 使能<br>0: 关闭 IRFLT<br>1: 打开 IRFLT |

### 11.3. 时基选择

PSEL 选定的分频倍数 N 和 TSRC 选定的驱动时钟的周期 Tc 共同决定了 IRFLT 用于采样红外接收信号的时基 Ts

$$Ts = Tc * N$$

例如,当选择 24MHz 的系统时钟,并且分频倍数为 512 时,Ts=21.3uS。根据 IRFLT 的工作规则,所有小于(21.3\*3=63.9uS)的窄脉冲信号,均会被滤除。



图 1 irflt clk 时钟结构



# 第 12 章 MCPWM

## 12.1. 模块说明

MCPWM 功能块包括:

6个 timer 时基模块, 6对独立的 PWM 通道, 6路故障保护输入。框图如下:



图 1 PWM 模块示意图

| Mcpwmx_h / l | 固定 IO                | Crossbar |
|--------------|----------------------|----------|
| Mcpwm0_h     | 无                    | 任意 IO    |
| Mcpwm0_1     | 无                    | 任意 IO    |
| Mcpwm1_h     | 无                    | 任意 IO    |
| Mcpwm1_1     | 无                    | 任意 IO    |
| Mcpwm2_h     | 无                    | 任意 IO    |
| Mcpwm2_1     | 无                    | 任意 IO    |
| Mcpwm3_h     | PD2(IO_Mapping 章节查阅) | 无        |
| Mcpwm3_1     | PD3(IO_Mapping 章节查阅) | 无        |
| Mcpwm4_h     | PD4(IO_Mapping 章节查阅) | 无        |
| Mcpwm4_l     | PD5(IO_Mapping 章节查阅) | 无        |
| Mcpwm5_h     | PD6(IO_Mapping 章节查阅) | 无        |
| Mcpwm5_1     | PD7(IO_Mapping 章节查阅) | 无        |



### 12.1.1. 定时器 MCTIMER

mctimer 是 16 位定时器,可作为 pwmx 的时基控制特性:

- (1) 16 位定时功能
- (2) 带缓冲的周期寄存器
- (3) 支持多种工作模式: 递增、递增-递减、外部引脚控制递增递减
- (4) 多种中断模式:上溢出中断、下溢出中断、上下溢出中断

### 12.1.2. MCPWM 模块引脚

PWM0: PWMCHXH、PWMCHXL

PWM1: PWMCHXH、PWMCH1L

PWM2: PWMCHXH、PWMCH2L

.....

PWM5: PWMCH5H、PWMCH5L

故障输入引脚: FPIN

### 12.1.3. MCPWM 模块特性

- 1.边沿对齐和中心对齐输出模式
- 2.可运行过程中更改 PWM 频率、占空比
- 3.多种更新频率/占空比模式:上溢出重载、下溢出重载
- 4.灵活配置每对通道的有效电平状态
- 5.可编程死区控制
- 6.硬件故障输入引脚

## 12.2. 寄存器 SFR 列表



## 1. TMRx\_CON: Timer contrl register

| Bit   | Name     | RW | Default | RV | Description                                               |
|-------|----------|----|---------|----|-----------------------------------------------------------|
| 31-16 | RESERVED | -  | -       | -  | 预留                                                        |
| 15    | INCF     | rw | 0       | -  | 递增递减标志位<br>0: 递减<br>1: 递增                                 |
| 14    | RESERVED | -  | -       | -  | 预留                                                        |
| 13    | UFPND    | w  | X       | -  | 递减借位标志<br>0: 没溢出<br>1: 已发生溢出                              |
| 12    | OFPN     | rw | 0x0     | -  | 计数溢出(TMRXCNT==TMRXPR)标志<br>0: 没溢出<br>1: 已发生溢出             |
| 11    | UFCLR    | w  | -       | 1  | 清除 UFPND 标志位<br>0:无效<br>1:消除 UFPND                        |
| 10    | OFCLR    | w  | -       | 1  | 清除 OFPND 标志位<br>0:无效<br>1:消除 OFPND                        |
| 9     | UFIE     | rw | 0       | 1  | 定时递减借位中断使能<br>0: 禁止<br>1: 允许                              |
| 8     | OFIE     | rw | 0       | 1  | 计数溢出中断使能<br>0: 禁止<br>1: 允许                                |
| 7     | CKSRC    | rw | 0       | -  | 定时器时钟源<br>0: 内部时钟<br>1: 外部引脚时钟                            |
| 6-3   | CKPS     | rw | 0       | -  | 时钟预分频设置,TCK/(2^TCKPS)                                     |
| 2     | RESERVED | -  | -       | -  | 预留                                                        |
| 1-0   | MODE     | rw | 0       | -  | 定时器工作模式<br>00:保持计数值<br>01:递增模式<br>10:递增-递减循环模式<br>11:递减模式 |

## 2. TMRx\_CNT: counter initial value register

| Bit  | Name    | RW | Default | RV | Description |
|------|---------|----|---------|----|-------------|
| 15-0 | TMR_CNT | rw | X       | -  | 计数/定时初值     |



## 3. TMRx\_PR: counter target value register

| Bit  | Name   | RW | Default | RV | Description |
|------|--------|----|---------|----|-------------|
| 15-0 | TMR_PR | rw | X       | -  | 计数/定时目标值    |

### 4. CHx\_CON0: pwm control register0

| Bit   | Name   | RW | Default | RV | Description                                                                                                            |
|-------|--------|----|---------|----|------------------------------------------------------------------------------------------------------------------------|
| 15-12 | DTCKPS | rw | 0       | -  | 死区时钟预分频,Tsys/(2^DTCKPS)                                                                                                |
| 11-7  | DTPR   | rw | 0       | -  | 死区时间控制<br>死区时间: Tsys/(2^DTCKPS)×(DTPR+1)                                                                               |
| 6     | DTEN   | rw | 0       | -  | 死区允许控制,对应 PWMCHxH、PWMCHxL<br>0: 禁止<br>1: 允许                                                                            |
| 5     | L_INV  | rw | 0       | -  | 对应 PWMCHxL 输出反向控制<br>0: 反向禁止<br>1: 反向允许                                                                                |
| 4     | H_INV  | rw | 0       | -  | 对应 PWMCHxH 输出反向控制<br>0: 反向禁止<br>1: 反向允许                                                                                |
| 3     | L_EN   | rw | 0       | -  | 对应 PWMCHxL 输出允许控制(仅走固定 IO<br>时有效)<br>0: 禁止 PWMCHxH<br>1: 允许 PWMCHxH                                                    |
| 2     | H_EN   | rw | 0       | -  | 对应 PWMCHxH 输出允许控制(仅走固定 IO<br>时有效)<br>0:禁止 PWMCHxH<br>1:允许 PWMCHxH                                                      |
| 1-0   | CMP_LD | rw | 0       | -  | CHx_CMP 重新载入控制 00: 时基 TMRX_CNT 等于"0"载入 01: 时基 TMRX_CNT 等于"0"或者等于 TMRX_PR 的时候载入 10: 时基 TMRX_CNT 等于 TMRX_PR 时载入 11: 立即载入 |

### 5. CHx\_CON1: pwm control register1

| Bit | Name | RW | Default | RV | Description                                            |
|-----|------|----|---------|----|--------------------------------------------------------|
| 15  | FPND | r  | 0       | -  | 故障保护输入标志,只读,写无效 读 0: 未发生保护 读 1: 已发生保护,模块的 PWM 引脚会变成高阻态 |
| 14  | FCLR | w  | -       | -  | 清除 FPND 标志位,只写,读为"0"<br>写 0: 无效                        |



| IVICI VV | MCPWM    |    |   |   |                                                                         |  |  |  |  |
|----------|----------|----|---|---|-------------------------------------------------------------------------|--|--|--|--|
|          |          |    |   |   | 写 1:清除 FPND                                                             |  |  |  |  |
| 13-12    | RESERVD  | -  | - | - | 预留                                                                      |  |  |  |  |
| 11       | INTEN    | rw | 0 |   | FPND 中断允许<br>0:禁止<br>1:允许                                               |  |  |  |  |
| 10-8     | TMRSEL   | rw | 0 | - | 选择 TMR0-7 作为 PWM 时基<br>0-7:选择时基                                         |  |  |  |  |
| 7-5      | RESERVED | -  | - | - | 预留                                                                      |  |  |  |  |
| 4        | FPINEN   | rw | 0 | 1 | 故障保护输入允许控制<br>0:禁止保护<br>1:允许保护                                          |  |  |  |  |
| 3        | FPINAUTO | rw | 0 | 1 | 故障自动保护控制 0: 禁止自动保护 1: 允许自动保护 当检测到故障引脚有效信号时,自动把 PWM 引脚设成高阻态,直到软件清除 FPND。 |  |  |  |  |
| 2-0      | FPINSEL  | rw | 0 | - | 故障保护输入引脚选择<br>0-7: 选择 FPIN 作为保障输入 (0-5 为 io 输入,<br>6-7 固定为 0)           |  |  |  |  |

## 6. CHx\_CMPH: pwm high port compare register

| Bit  | Name     | RW | Default | RV | Description                           |
|------|----------|----|---------|----|---------------------------------------|
| 15-0 | MMRX_PRH | rw | -       | -  | 带缓冲的 16 位比较寄存器,对应 PWMCHxH<br>引脚的占空比控制 |

### 7. CHx\_CMPL: pwm low port compare register

| Bit  | Name     | RW | Default | RV | Description                        |
|------|----------|----|---------|----|------------------------------------|
| 15-0 | TMRX_PRL | rw | -       | -  | 带缓冲的 16 位比较寄存器,对应 PWMCHxL 引脚的占空比控制 |

### 8. FPIN\_CON: input filter control register

| Bit   | Name   | RW | Default | RV | Description                     |
|-------|--------|----|---------|----|---------------------------------|
| 23-16 | EDGE   | rw | 0       | -  | FPINx 边沿选择<br>0: 下降沿<br>1: 上升沿  |
| 15-8  | FLT_EN | rw | 0       | -  | FLT_EN: FPINx 滤波使能开关<br>0: 滤波关闭 |



|     |          |    |   |   | 1: 滤波开启                                  |
|-----|----------|----|---|---|------------------------------------------|
| 7-6 | RESERVED | -  | - | - | 预留                                       |
| 5-0 | FLT_PR   | rw | 0 | _ | FLT_PR: 滤波宽度选择<br>滤波宽度=16×FLT_PR×lsb_clk |

### 9. MCPWM\_CON: mcpwm control register

| Bit  | Name   | RW | Default | RV | Description                                   |
|------|--------|----|---------|----|-----------------------------------------------|
| 15-8 | TMR_EN | rw | 0       | -  | 定时器计数开关控制(tmr7-0)<br>0: 定时器计数关闭<br>1: 定时器计数打开 |
| 7-0  | PWM_EN | rw | 0       | -  | 模块开关控制(pwm7-0)<br>0: 模块关闭<br>1: 模块开启          |



## 第13章 UART

## 13.1. UART 模块说明

支持接收带循环 Buffer 的 DMA 模式和普通模式。

UART 在 DMA 接收的时候有一个循环 Buffer,UTx\_RXSADR 表示它的起始,UTx\_RXEADR 表示它的结束。同时,在接收过程中,会有一个超时计数器(UTx\_OTCNT),如果在指定的时间里没有收到任何数据,则超时中断就会产生。超时计数器是在收到数据的同时自动清空。

## 13.2. 特殊注意点

#### 【注意】:

- 1. OT PND 触发流程,满足一下 (1-4) 顺序,则可产生 OT PND:
  - (1) 写 UTx OTCNT,数值不为 0 启动 OT 功能;
  - (2) 收到 n 个 byte 数据;
- (3) 从最后一个下降沿开始,等待 OT 超时(每来一个下降沿都会重新计时,时钟与接收 baud clk 一致);
  - (4) 当 OTCNT 与超时时间相等, OT PND 置 1 (只能通过 CLR OTPND 清零)。
- 2. 读接收的数据量时,先将 RDC 该 bit 写 1,接着 asm("csync")清空流水线,然后软件查询 RDC\_OVER 置 1,置 1 后即可读取 HRXCNT 数值,RDC\_OVER 只在 RDC 写 1 之后生效,平常为无效状态(不管 0 或 1);

## 13.3. UART 寄存器 SFR 列表

1. JL\_UARTx->CON0: uart x control register 0

| Bit   | Name      | RW | Default | RV | Description                                               |
|-------|-----------|----|---------|----|-----------------------------------------------------------|
| 31-16 | RESERVED  | -  | 0       | -  | 预留                                                        |
| 15    | TPND      | r  | 1       | -  | TPND: TX Pending                                          |
| 14    | RPND      | r  | 0       | _  | RPND: RX Pending & Dma_Wr_Buf_Empty, 数据接收不完 Pending 不会为 1 |
| 13    | CLRTPND   | r  | 0       | -  | CLRTPND: 清空 TX Pending                                    |
| 12    | CLRRPND   | r  | 0       | -  | CLRRPND: 清空 RX Pending                                    |
| 11    | OTPND     | r  | 0       | -  | OTPND: Over Time Pending                                  |
| 10    | CLR_OTPND | w  | 0       | -  | CLR_OTPND: 清空 OTPND                                       |



| Ο. | AKI |          |    |   |   |                                                            |
|----|-----|----------|----|---|---|------------------------------------------------------------|
|    |     |          |    |   |   |                                                            |
|    | 9   | RESERVED | W  | 0 | - | 预留                                                         |
|    | 8   | RDC_OVER | r  | 0 | - | 用于判断写RDC后数据是否已存入内存标志,<br>RDC写1时会清零,当数据存入内存后置1。             |
|    | 7   | RDC      | W  | 0 | - | RDC:写1时,将已经收到的数目写到<br>UTx_HRXCNT,已收到的数目清零写0无效。             |
|    | 6   | RX_MODE  | rw | 0 | - | RXMODE (*):读模式选择<br>0:普通模式,不用 DMA;<br>1: DMA 模式;           |
|    | 5   | OT_IE    | rw | 0 | 1 | OTIE: OT 中断允许<br>0: 不允许;<br>1: 允许;                         |
|    | 4   | DIVS     | rw | 0 | - | DIVS: 前 3 分频选择:<br>0: 4 分频;<br>1: 3 分频;                    |
|    | 3   | RXIE     | rw | 0 | 1 | RXIE: RX 中断允许<br>当 RX Pending 为 1,而且 RX 中断允许为 1,<br>则会产生中断 |
|    | 2   | TXIE     | rw | 0 | 1 | TXIE: TX 中断允许<br>当 TX Pending 为 1,而且 TX 中断允许为 1,<br>则会产生中断 |
|    | 1   | UTRXEN   | rw | 0 | 1 | UTRXEN:UART 模块接收使能                                         |
|    | 0   | UTTXEN   | rw | 0 | 1 | UTTXEN:UART 模块发送使能                                         |

## 2. JL\_UARTx->CON1: uart x control register 1

| Bit   | Name       | RW | Default | RV | Description                        |
|-------|------------|----|---------|----|------------------------------------|
| 15    | CTSPND     | r  | 0       | 0  | CTSPND: CTS 中断 pending             |
| 14    | RTSPND     | r  | 0       | 0  | RTSPND: RST 中断 pending             |
| 13    | CLR_CTSPND | w  | 0       | -  | CLR_CTSPND:清除 CTS pending          |
| 12    | CLR_RTSPND | w  | 0       | -  | CLRRTS:清除 RTS<br>0:N/A<br>1:清空 RTS |
| 11-10 | 预留         | -  | 0       | -  | 预留                                 |
| 9     | TX_INV     | rw | 0       | 0  | Tx 发送数据电平取反<br>0: 不取反<br>1: 取反     |
| 8     | RX_INV     | rw | 0       | 0  | Rx 发送数据电平取反<br>0:不取反<br>1:取反       |



| U. | AKI |            |    |   |   |                                                    |
|----|-----|------------|----|---|---|----------------------------------------------------|
|    | 7   | CTS_INV    | rw | 0 | - | CTS 流控有效电平选择(对方允许我方发送数据) 0: 高电平有效 1: 低电平有效         |
|    | 6   | RTS_INV    | rw | 0 | - | RTS 流控有效电平选择(允许对方发送数据)<br>0: 高电平有效<br>1: 低电平有效     |
|    | 5   | RX_BYPASS  | rw | 1 | 1 | Rx 接收数据通路直通使能<br>0: 滤波输入<br>1: 直通输入                |
|    | 4   | RX_DISABLE | r  | 1 | 0 | 关闭数据接收<br>0: 开启输入(正常模式)<br>1: 关闭输入(输入固定为 1)        |
|    | 3   | CTSIE      | rw | 0 | - | CTSIE: CTS 中断使能<br>0: 禁止中断;<br>1: 允许中断;            |
|    | 2   | CTSE       | rw | 0 | - | CTSE: CTS 使能<br>0:禁止 CTS 硬件流控制;<br>1:允许 CTS 硬件流控制; |
|    | 1   | RESERVED   | -  | 0 | - | 预留                                                 |
|    | 0   | RTSE       | rw | 0 | - | RTSE: RTS 使能<br>0:禁止 RTS 硬件流控制<br>1:允许 RTS 硬件流控制   |

## 3. JL\_UARTx->CON2: uart x control register 2

| Bit  | Name           | RW | Default | RV | Description                                     |
|------|----------------|----|---------|----|-------------------------------------------------|
| 15-9 | RESERVED       | -  | 0       | -  | 预留                                              |
| 8    | CHK_PND        | r  | 0       | -  | 校验中断标志                                          |
| 7    | CLR_CHKPND     | w  | 0       | -  | 校验中断 CHK_PND 清除,置 1 清除                          |
| 6    | CHK_IE         | rw | 0       | 1  | 校验中断使能,置1使能                                     |
| 5-4  | CHECK_MOD<br>E | rw | 0       |    | 校验模式选择:<br>0: 常 0<br>1: 常 1<br>2: 偶校验<br>3: 奇校验 |
| 3    | CHECK_EN       | rw | 0       | 0  | 校验功能使能位,置1使能                                    |
| 2    | RB8            | r  | 0       | 0  | RB8: 9bit 模式时,RX 模式接收的第 9 位                     |
| 1    | RESERVED       | -  | -       | -  | 预留                                              |
| 0    | M9EN           | rw | 0       | 0  | 9bit 模式使能                                       |



### 4. JL UARTx->BAUD: uart x baudrate register

| Bit  | Name     | RW | Default | RV  | Description |
|------|----------|----|---------|-----|-------------|
| 15-0 | UTx_BAUD | w  | 0x0     | 0x0 | 注释如下所示      |

uart 的 UTx DIV 的整数部分

串口频率分频器因子(UTx DIV)的整数部分

当 DIVS=0 时,

Baudrate = Freq sys / ((UARTx\_BAUD + 1) \* 4 + BAUD FRAC)

当 DIVS=1 时,

Baudrate = Freq syst / ((UARTx\_BAUD + 1) \* 3 + BAUD FRAC)

(其中, Freq sys 与 apb clk, 指慢速设备总线的时钟, 非系统时钟)

### 5. JL UARTx->BUF: uart x data buffer register

| Bit  | Name     | RW | Default | RV | Description                                                 |
|------|----------|----|---------|----|-------------------------------------------------------------|
| 31-8 | RESERVED | -  | 0       | -  | 预留                                                          |
| 7-0  | UT_BUF   | rw | 0x0     | -  | Uart 的收发数据寄存器<br>写 UTx_BUF 可启动一次发送;<br>读 UTx_BUF 可获得已接收到的数据 |

#### 6. JL UARTx->TXADR: uart x TX DMA buffer register

| Bi   |       | Name    | RW | Default | RV  | Description   |
|------|-------|---------|----|---------|-----|---------------|
| 31-2 | 25 RI | ESERVED | -  | 0       | -   | 预留            |
| 24-  | 0 UT  | x_TXADR | w  | 0x0     | 0x0 | DMA 发送数据的起始地址 |

### 7. JL UARTx->TXCNT: uart x TX DMA counter register

| Bit  | Name      | RW | Default | RV  | Description                                                                                         |
|------|-----------|----|---------|-----|-----------------------------------------------------------------------------------------------------|
| 31-0 | UTx_TXCNT | W  | 0x0     | 0x0 | 写 UTx_TXCNT,控制器产生一次 DMA 的操作,同时清空中断,当 uart 需要发送的数据达到 UTx_TXCNT 的值,控制器会停止发送数据的操作,同时产生中断(UTx_CON[15])。 |

#### 8. JL UARTx->RXCNT: uart x RX DMA counter register

| Bit  | Name      | RW | Default | RV  | Description                                                                                         |
|------|-----------|----|---------|-----|-----------------------------------------------------------------------------------------------------|
| 31-0 | UTx_RXCNT | W  | 0x0     | 0.0 | 写 UTx_TXCNT,控制器产生一次 DMA 的操作,同时清空中断,当 uart 需要接收的数据达到 UTx_TXCNT 的值,控制器会停止发送数据的操作,同时产生中断(UTx_CON[14])。 |



## 9. JL\_UARTx->BUF: uart x data buffer register

| Bit   | Name       | RW | Default | RV  | Description                              |
|-------|------------|----|---------|-----|------------------------------------------|
| 31-25 | RESERVED   | -  | 0       | -   | 预留                                       |
| 24-0  | UTx_RXSADR | W  | 0x0     | UXU | DMA 接收数据时,循环 buffer 的开始地址,需 4 byte 地址对齐。 |

### 10. JL\_UARTx->RXEADR: uart x RX DMA end address register

| Bit   | Name       | RW | Default | RV  | Description                                                                                             |
|-------|------------|----|---------|-----|---------------------------------------------------------------------------------------------------------|
| 31-25 | RESERVED   | -  | 0       | -   | 预留                                                                                                      |
| 24-0  | UTx_RXEADR | W  | 0x0     | 0x0 | DMA 接收数据时,循环 buffer 的结束地址。<br>需 4 byte 地址对齐。<br>【注意】: UTx_RXSADR = UTx_RXEADR 时<br>没有循环 buffer,接收地址会递增。 |

## 11. JL\_UARTx->HRXCNT: uart x have RX DMA counter register

| Bit  | Name       | RW | Default | RV  | Description                                                                      |
|------|------------|----|---------|-----|----------------------------------------------------------------------------------|
| 31-0 | UTx_HRXCNT | r  | 0x0     | 0x0 | 当设这 RDC (UTx_CON[7] = 1)时, 串口设备会<br>将 当 前 总 共 收 到 的 字 节 数 记 录 到<br>UTx_HRXCNT 里。 |

### 12. JL\_UARTx->OTCNT: uart x Over Timer counter register

| Bit  | Name            | RW | Default | RV | Description                                                                                                                                             |
|------|-----------------|----|---------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | UTx_ERR_CN<br>T | r  | 0x0     | -  | 设置串口设备在等待 RX 下降沿的时间,在设置的时间内没收到 RX 下降沿,则产生OT_PND Time(ot) = Time(rx_baud_clk) * UTx_OTCNT;例如:接收波特率时间(rx_baud_clk)为 100ns,UTx_OTCNT = 10,则 OT 时间为 1000ns。 |

### 13. JL\_UARTx->ERR\_CNT: uart x error byte counter register

| Bit  | Name            | RW | Default | RV | Description                                                                                |
|------|-----------------|----|---------|----|--------------------------------------------------------------------------------------------|
| 31-0 | UTx_ERR_CN<br>T | r  | 0x0     | -  | 校验错误数量计数,当打开 CHECK_EN 后,当第一次校验出错时,该寄存器会记录当前byte 对应的数量。<br>【注意:只记录第一次出错的数量,清除CHK_PND 会重新记录】 |



# 第14章 IO\_Mapping\_Control

# 14.1. 模块说明

IOMC(IO remapping control)控制寄存器主要用于控制 IO 除 crossbar 之外的一些拓展功能的配置。

# 14.2. IO Mapping

| TO 1                 | TO 26 Til |              |             |     | 固定 I0i | mapping |       |     |
|----------------------|-----------|--------------|-------------|-----|--------|---------|-------|-----|
| IO pad               | 10 类型     | Analog       | Reset       | SFC | SPI0   | TMR     | MCPWM | EMI |
| PAO<br>(上拉)<br>(注 2) | SDR       | ADCO         | 长按复位<br>(7) |     |        |         |       |     |
| PA1                  | SDR       | ADC1         |             |     |        |         |       |     |
| PA2                  | SDR       | ADC2/VSENO   |             |     |        |         |       |     |
| PA3                  | SDR       | ADC3/VSEN1   |             |     |        |         |       |     |
| PA4                  | SDR       | ADC4/VSEN2   |             |     |        |         |       |     |
| PA5                  | SDR       | ADC5/VSEN3   |             |     |        |         |       |     |
| PA6<br>(注1)          | SDR       | ADC6         |             |     |        |         |       |     |
| PA7                  | SDR       | ADC7/OSC32KI | MCLR        |     |        |         |       |     |
| PA8                  | SDR       | ADC8/OSC32KO |             |     |        | TMROCK  |       |     |
| PA9                  | SDR       | ADC9         |             |     |        |         |       |     |
| PA10                 | SDR       | ADC10        |             |     |        |         |       |     |
| PA11                 | SDR       | ADC11/LED_EX |             |     |        |         |       |     |
| PA12                 | SDR       | ADC12/LEDEX  |             |     |        |         |       |     |
| PD15<br>(注 6)        | SDR       | VLCD         |             |     |        |         |       |     |
| PC0                  | SDR       | COMO         |             |     |        |         |       |     |
| PC1                  | SDR       | COM1         |             |     |        |         |       |     |
| PC2                  | SDR       | COM2         |             |     |        |         |       |     |
| PC3                  | SDR       | COM3         |             |     |        |         |       |     |
| PC4                  | SDR       | COM4/SEGOO   |             |     |        |         |       |     |
| PC5                  | SDR       | COM5/SEG01   |             |     |        |         |       |     |
| PC6                  | SDR       | SEG02        |             |     |        |         |       |     |
| PC7                  | SDR       | SEG03        |             |     |        |         |       |     |



| IO-no-l       | 10 米刑 | Analog      | 固定 IOmapping |            |             |            |         |        |  |  |  |
|---------------|-------|-------------|--------------|------------|-------------|------------|---------|--------|--|--|--|
| IO pad        | 10 类型 | Analog      | Reset        | SFC        | SPI0        | TMR        | MCPWM   | EMI    |  |  |  |
| PC8           | SDR   | SEG04       |              |            |             |            |         | EMIO   |  |  |  |
| PC9           | SDR   | SEG05       |              |            |             |            |         | EMI1   |  |  |  |
| PC10          | SDR   | SEG06       |              |            |             |            |         | EMI2   |  |  |  |
| PC11          | SDR   | SEG07       |              |            |             |            |         | EMI3   |  |  |  |
| PC12          | SDR   | SEG08       |              |            |             |            |         | EMI4   |  |  |  |
| PC13          | SDR   | SEG09       |              |            |             |            |         | EMI5   |  |  |  |
| PC14          | SDR   | SEG010      |              |            |             |            |         | EMI6   |  |  |  |
| PC15          | SDR   | SEG011      |              |            |             |            |         | EMI7   |  |  |  |
| PD0           | SDR   | SEG012      |              |            |             |            |         | EMI_WR |  |  |  |
| PD1           | SDR   | SEG013      |              |            |             |            |         | EMI_RD |  |  |  |
| PD2           | SDR   | SEG014      |              |            |             |            | мсрум3н |        |  |  |  |
| PD3           | SDR   | SEG015      |              |            |             |            | MCPWM3L |        |  |  |  |
| PD4           | SDR   | SEG016      |              |            |             |            | MCPWM4H |        |  |  |  |
| PD5           | SDR   | SEG017      |              |            |             |            | MCPWM4L |        |  |  |  |
| PD6           | SDR   | SEG018      |              |            |             |            | МСРWМ5Н |        |  |  |  |
| PD7           | SDR   | SEG019      |              |            |             |            | MCPWM5L |        |  |  |  |
| PD8           | SDR   | SEG20       |              |            |             | TIMERO_PWM |         |        |  |  |  |
| PD9           | SDR   | SEG21       |              |            |             | TIMER1_PWM |         |        |  |  |  |
| PD10          | SDR   | SEG22       |              |            |             | TIMER2_PWM |         |        |  |  |  |
| PD11          | SDR   | SEG23       |              |            |             | TIMER3_PWM |         |        |  |  |  |
| PD12          | SDR   | SEG24       |              |            |             |            |         |        |  |  |  |
| PD13          | SDR   | SEG25       |              |            |             |            |         |        |  |  |  |
| PD14          | SDR   | SEG26       |              |            |             |            |         |        |  |  |  |
| PF0           | SDR   |             |              | SFC_CSA    | spiO_CSA    |            |         |        |  |  |  |
| (注3)          | SDIK  |             |              | SPC_CSA    | Spro_coa    |            |         |        |  |  |  |
| PF1           | SDR   |             |              | SFC_DIA(1) | spiO_DIA(1) |            |         |        |  |  |  |
| PF2           | SDR   |             |              | SFC_CLKA   | spiO_CLKA   |            |         |        |  |  |  |
| PF3           | SDR   |             |              | SFC_DOA(0) | spi0_DOA(0) |            |         |        |  |  |  |
| FSPG          |       |             |              |            |             |            |         |        |  |  |  |
| (ROM 驱动)      | SDR   | Flash_Power |              |            |             |            |         |        |  |  |  |
| (注5)          |       |             |              |            |             |            |         |        |  |  |  |
| USBDP         | CDD   | ADC19       |              |            |             |            |         |        |  |  |  |
| (下拉)<br>(注 4) | SDR   | ADC13       |              |            |             |            |         |        |  |  |  |
| USBDM         |       |             |              |            |             |            |         |        |  |  |  |
| USDDM<br>(下拉) | SDR   | ADC14       |              |            |             |            |         |        |  |  |  |
| (注4)          |       |             |              |            |             |            |         |        |  |  |  |



注 1: 上拉和 MCLR 一起,可以通过 1 bit efuse 控制可以默认关闭

注 2: 上拉和长按复位一起,可以通过 1 bit efuse 控制可以默认关闭

注 3: PFn 不支持 crossbar, 不支持 PMU IO 功能

注:4: maskrom 里面软关机唤醒时软件通过 soft flag 恢复 IO 状态

注5: 在 rom 中配置 FSPG 输出 1, 同事将 flash 的 vdd 和 cs 点位拉高

注 6: 该 IO 不能有下冲负电压,也就是不能有强驱的 1 到 0 的变化边沿

允许举例:按键接到 IOVDD, IO 配置成下拉;

注7: default 值, 支持 pmu io mux (任意量产封装 IO)

升级: PP0 为串口升级 IO

#### 1. IO 类型驱动能力说明

| VDDIO   | 驱动<br>HD==00 | 驱动<br>HD==01 | 驱动<br>HD==10 | 驱动<br>HD==11           | Input<br>VH | Input<br>VL |
|---------|--------------|--------------|--------------|------------------------|-------------|-------------|
| SDR     | 1.8mA        | 6mA          | 20mA         | 输出 1:45mA<br>输出 0:24mA | 1. 71v      | 1. 31v      |
| HVT_SEG |              | 81           | mA           |                        | 1.71v       | 1.31v       |
| USB_DP  |              |              |              |                        |             |             |
| USB_DM  |              |              |              |                        |             |             |
| FSPG    |              |              |              |                        |             |             |

#### 2. 各 IO 类型上/下拉电阻说明

| VDDIO   | 上拉 PU1 PU0 == 0 | 上拉 PU1 PU0 == 01 | 上拉 PU1 PU0 == 10 | 上拉 PU1 PU0 == 11 |
|---------|-----------------|------------------|------------------|------------------|
| SDR     | 0               | 10k              | 100k             | 1 M              |
| HVT_SEG | 0               | 10k              | 100k             | 1M               |
| USB_DP  |                 | 1.5k             |                  | 1. 5k            |
| USB_DM  |                 | 180k             |                  | 180k             |
| VDDIO   | 下拉 PD1 PD0 == 0 | 下拉 PD1 PD0 == 01 | 下拉 PD1 PD0 == 10 | 下拉 PD1 PD0 == 11 |
| SDR     | 0               | 10k              | 100k             | 1 M              |
| HVT_SEG | 0               | 10k              | 100k             | 1M               |
| USB_DP  |                 | 15k              |                  | 15k              |
| USB_DM  |                 | 15k              |                  | 15k              |



## 14.3. 10 唤醒

Wakeup 是一个异步事件唤醒模块。它可以将处于 sleep 状态下的系统唤醒,进入正常工作模式。当系统处于正常模式时,则 Wakeup 源作为中断源,Wakeup 模块有 8 个唤醒事件来源,可通过 input channel 选择对应 IO。

|          | input channel |        |             |             |  |  |  |  |  |  |
|----------|---------------|--------|-------------|-------------|--|--|--|--|--|--|
| ICHO_SEL | WAKEUPO       | Timer0 | PLL_EXT_CLK | ICH_QDEC[0] |  |  |  |  |  |  |
| ICH1_SEL | WAKEUP1       | CAPO   |             |             |  |  |  |  |  |  |
| ICH2_SEL | WAKEUP2       | Timer1 | IRFLT       |             |  |  |  |  |  |  |
| ICH3_SEL | WAKEUP3       | CAP1   |             | 3           |  |  |  |  |  |  |
| ICH4_SEL | WAKEUP4       | Timer2 | CLK_MUX     | ICH_QDEC[1] |  |  |  |  |  |  |
| ICH5_SEL | WAKEUP5       | CAP2   |             |             |  |  |  |  |  |  |
| ICH6_SEL | WAKEUP6       | Timer3 | TOUCH_CAP   |             |  |  |  |  |  |  |
| ICH7_SEL | WAKEUP7       | CAP3   | 9868        |             |  |  |  |  |  |  |

图 1 IO 唤醒源

# 14.4. 寄存器 SFR 列表

3. JL\_IOMC->IOMC0:IO Mapping Control register0

| Bit   | Name             | RW | Default | RV | Description                                                                          |
|-------|------------------|----|---------|----|--------------------------------------------------------------------------------------|
| 31-24 | RESERVED         | -  | -       | -  | 预留                                                                                   |
| 27    | TMR3_IO_EN       | rw | 0       | -  | TMR3_PWM 固定 IO 输出使能                                                                  |
| 26    | TMR2_IO_EN       | rw | 0       | -  | TMR2_PWM 固定 IO 输出使能                                                                  |
| 25    | TMR1_IO_EN       | rw | 0       | -  | TMR1_PWM 固定 IO 输出使能                                                                  |
| 24    | TMR0_IO_EN       | rw | 0       | -  | TMR0_PWM 固定 IO 输出使能                                                                  |
| 23    | APA_OCH1_R<br>EG | rw | 0       | -  | APA_OCH1 寄存器输出                                                                       |
| 22    | APA_OCH0_R<br>EG | rw | 0       | -  | APA_OCH0 寄存器输出                                                                       |
| 21-18 | APA_OCH1_S<br>EL | rw | 0       | -  | APA1 通用输出通道选择 0: tmr_pwm1 1: tmr_pwm2 2: uart0_tx 3: uart1_tx 4: uart2_tx 5: gp_ich0 |



| IC | O_Mapping_Control |                  |    |   |   |                                                                                             |  |  |
|----|-------------------|------------------|----|---|---|---------------------------------------------------------------------------------------------|--|--|
|    |                   |                  |    |   |   | 6: gp_ich1 7: clk_out0 8: clk_out1 9: clk_out2 10: mc_pwm0_h 11: mc_pwm0_l 12: apa_och1_reg |  |  |
|    | 17-14             | APA_OCH0_S<br>EL | rw | 0 | - | APA0 通用输出通道选择<br>0-11 与 APA_OCH1 一致<br>12: apa_och0_reg                                     |  |  |
|    | 13                | PAP_DEN          | rw | 0 | - | 允许 PAPDx 占用 IO<br>0:无论 PAP 有无使能,其 PAPDx 不占用相应<br>IO;<br>1:当 PAP 使能时,其 PAPDx 占用相应 IO;        |  |  |
|    | 12                | PAP_REN          | rw | 0 | - | 允许 PAP_RD 占用 IO<br>0:无论 PAP 有无使能,其 PAP_RD 不占用相<br>应 IO;<br>1:当 PAP 使能时,其 PAP_RD 占用相应 IO;    |  |  |
|    | 11                | PAP_WEN          | rw | 0 | - | 允许 PAP_WR 占用 IO<br>0:无论 PAP 有无使能,其 PAP_WR 不占用相<br>应 IO;<br>1:当 PAP 使能时,其 PAP_WR 占用相应 IO;    |  |  |
|    | 10-8              | SPI_ICK_SEL      | rw | 0 | - | SPII 输入时钟延迟级数选择                                                                             |  |  |
|    | 7                 | SPI_DUPLEX       | rw | 0 | - | Spi1 从机输入时钟选择<br>0:spi1_clki<br>1:spi0_clko                                                 |  |  |
|    | 6-5               | SDTAP_IOS        | rw | 0 | - | SDTAP IO 选择<br>0:A组 IO<br>1:B组 IO<br>2:C组 IO<br>3:D组 IO                                     |  |  |
|    | 4                 | RESERVED         | rw | 0 | - | 预留                                                                                          |  |  |
|    | 3                 | CAP_MUX_ED<br>GE | rw | 0 | - | CAP0_ICH 输出极性选择<br>0:不变<br>1:取反                                                             |  |  |
|    | 2-0               | CLKOUT_EN        | rw | 0 | - | 时钟输出使能,每 1bit 对应每一通道输出,<br>CLKOUT 输出使能选择请参考 clock_system                                    |  |  |



## 4. JL\_IOMC->OCH\_CON0:output channel Control register0

| Bit   | Name     | RW | Default | RV | Description                                                                                                              |
|-------|----------|----|---------|----|--------------------------------------------------------------------------------------------------------------------------|
| 29-25 | OCH5_SEL | rw | 0       | 5  | 通用输出通道选择  0: comp_out0  1: comp_out1  2: comp_out2  3: comp_out3  4: comp_out4  5: comp_out5  6: comp_out6  7: comp_out7 |
| 24-20 | OCH5_SEL | rw | 0       | 4  | 同 OCH5_SEL                                                                                                               |
| 19-15 | OCH5_SEL | rw | 0       | 3  | 同 OCH5_SEL                                                                                                               |
| 14-10 | OCH5_SEL | rw | 0       | 2  | 同 OCH5_SEL                                                                                                               |
| 9-5   | OCH5_SEL | rw | 0       | 1  | 同 OCH5_SEL                                                                                                               |
| 4-0   | OCH5_SEL | rw | 0       | 0  | 同 OCH5_SEL                                                                                                               |

## 5. JL\_IOMC->OCH\_CON1:output channel Control register1

| Bit   | Name      | RW | Default | RV | Description                                                                                              |
|-------|-----------|----|---------|----|----------------------------------------------------------------------------------------------------------|
| 31-30 | RESERVED  | -  | -       | -  | 预留                                                                                                       |
| 30-28 | COMP6_SEL | rw | 0       | -  | 复合通道 6 输出通道选择  0: tmr0_pwm  1: tmr1_pwm  2: tmr2_pwm  3: tmr3_pwm  4: input channel 0                    |
| 27-25 | COMP5_SEL | rw | 0       | -  | 复合通道 5 输出通道选择  0: tmr0_pwm  1: tmr1_pwm  2: tmr2_pwm  3: tmr3_pwm  4: mc_pwm2_h  5: mc_pwm2_l  6: EMI_RD |
| 24-22 | COMP4_SEL | rw | 0       | -  | 复合通道 4 输出通道选择  0: tmr0_pwm  1: tmr1_pwm  2: tmr2_pwm  3: tmr3_pwm  4: mc_pwm2_h                          |



| 10_ | Mapping | g_Control |    |   |   |                                                                                                                         |
|-----|---------|-----------|----|---|---|-------------------------------------------------------------------------------------------------------------------------|
|     |         |           |    |   |   | 5: mc_pwm2_l<br>6: EMI_WR                                                                                               |
|     | 21-19   | COMP3_SEL | rw | 0 |   | 复合通道 3 输出通道选择 0: mc_pwm0_h 1: mc_pwm0_l 2: mc_pwm1_h 3: mc_pwm1_l 4: clk_out0 5: clk_out1                               |
|     | 18-16   | COMP2_SEL | rw | 0 |   | 复合通道 2 输出通道选择 0: mc_pwm0_h 1: mc_pwm0_l 2: mc_pwm1_h 3: mc_pwm1_l 4: clk_out0 5: clk_out2                               |
|     | 15-13   | COMP1_SEL | rw | 0 | - | 复合通道 1 输出通道选择 0: mc_pwm0_h 1: mc_pwm0_l 2: mc_pwm1_h 3: mc_pwm1_l 4: EMI_RD 5: clk_out0 6: clk_out1 7: clk_out2         |
|     | 12-10   | COMP0_SEL | rw | 0 | - | 复合通道 0 输出通道选择  0: mc_pwm0_h  1: mc_pwm0_l  2: mc_pwm1_h  3: mc_pwm1_l  4: EMI_WR  5: clk_out0  6: clk_out1  7: clk_out2 |
|     | 9-5     | OCH7_SEL  | rw | 0 | 7 | 同 OCH5_SEL                                                                                                              |
|     | 4-0     | OCH6_SEL  | rw | 0 | 6 | 同 OCH5_SEL                                                                                                              |

## 6. JL\_IOMC->OCH\_CON2:output channel Control register2

| Bit  | Name      | RW | Default | RV | Description |
|------|-----------|----|---------|----|-------------|
| 31-3 | RESSERVED | -  | -       | -  | 预留          |



| 27-24 |           | P\$\$/ | 0v0 |   | 复合通道 0 输出通道选择<br>0: tmr0_pwm<br>1: tmr1_pwm |
|-------|-----------|--------|-----|---|---------------------------------------------|
| 27-24 | COMP7_SEL | rw     | 0x0 | - | 2: tmr2_pwm<br>3: tmr3_pwm                  |
|       |           |        |     |   | 4: input channel 1                          |

### 7. JL\_IOMC->ICH\_CON0:input channel Control register0

| Bit   | Name     | RW | Default | RV | Description                                                                                                         |
|-------|----------|----|---------|----|---------------------------------------------------------------------------------------------------------------------|
| 31-28 | ICH7_SEL | rw | 0x0     | -  | 功能输入通道选择 0-7: GP_ICH0 - GP_ICH7 8: tmr2_pwm 9: tmr3_pwm 10: usb_dp_in 11: usb_dm_in 12: hadc_opa_cmp 13: dac_pa_cmp |
| 27-24 | ICH6_SEL | rw | 0x0     | -  | 同 ICH7 选项                                                                                                           |
| 23-20 | ICH5_SEL | rw | 0x0     | -  | 同 ICH7 选项                                                                                                           |
| 19-16 | ICH4_SEL | rw | 0x0     | -  | 同 ICH7 选项                                                                                                           |
| 15-12 | ICH3_SEL | rw | 0x0     | -  | 同 ICH7 选项                                                                                                           |
| 11-8  | ICH2_SEL | rw | 0x0     | -  | 同 ICH7 选项                                                                                                           |
| 7-4   | ICH1_SEL | rw | 0x0     | -  | 同 ICH7 选项                                                                                                           |
| 3-0   | ICH0_SEL | rw | 0x0     | -  | 同 ICH7 选项                                                                                                           |

### 8. JL\_IOMC->WKUP\_CON0: wakeup enable control register

| Bit   | Name     | RW | Default | RV | Description                       |
|-------|----------|----|---------|----|-----------------------------------|
| 31-17 | RESERVED | -  | 0x0     | -  | 预留                                |
| 16-0  | WKUP_EN  | rw | 0x0     | -  | 对应唤醒源使能<br>0: 关闭唤醒功能<br>1: 打开唤醒功能 |

### 9. JL\_IOMC->WKUP\_CON1: wakeup edge control register

| Bit  | Name      | RW | Default | RV | Description |
|------|-----------|----|---------|----|-------------|
| 31-8 | RESERVED  | -  | 0x0     | -  | 预留          |
| 7-0  | WKUP_EDGE | rw | 0x0     | -  | 对应唤醒源边沿选择   |



|  |  |  | 0: 上升沿唤醒<br>1: 下降沿唤醒 |
|--|--|--|----------------------|
|  |  |  |                      |

## 10. JL\_IOMC->WKUP\_CON2: wakeup clear pending control register

| Bit   | Name      | RW | Default | RV | Description   |
|-------|-----------|----|---------|----|---------------|
| 31-17 | RESERVED  | -  | 0x0     | -  | 预留            |
| 16-0  | WKUP_CPND | w  | 0x0     | -  | 对应唤醒中断清除,写1清零 |

### 11. JL\_IOMC->WKUP\_CON3: wakeup pending control register

| Bit   | Name     | RW | Default | RV | Description |
|-------|----------|----|---------|----|-------------|
| 31-17 | RESERVED | -  | 0x0     | -  | 预留          |
| 16-0  | WKUP_PND | r  | 0x0     | -  | 对应唤醒源中断标记   |



## 第15章 RAND64

# 15.1. 模块说明

RAND64 是一个产生 64 位伪随机序列的模块,它由片内 RC 振荡器驱动, RC 振荡器频率的不稳定性进一步确保了生成序列的随机性。

由于片内 RC 振荡器的振荡频率大约为 250KHz,即每个周期 4us,因此 RAND64 生成的序列约每 4us 自动更新一次。若软件有读取 RAND64 寄存器(RAND64H 或 RAND64L)的动作,则生成序列将立即更新,以确保每次读取均能获得不同的序列。

| 寄存器列表   | 宽度    | 读写 | 复位值 |
|---------|-------|----|-----|
| RAND64H | 32bit | r  | 不确定 |
| RAND64L | 32bit | r  | 不确定 |

PULSE COUNTER

# 第16章 PULSE COUNTER

# 16.1. 模块说明

PULSE COUNTER 触摸键的寄存器说明及使用方法。

# 16.2. 寄存器说明

### 1. JL\_PCNT->CON

| Bit  | Name      | RW | Default | RV | Description                                                                                                                                                             |
|------|-----------|----|---------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | RESSERVED | -  | -       | -  | 预留                                                                                                                                                                      |
| 3-2  | CLK_SEL   | rw | 0x0     | -  | Pulse counter 时钟选择 00: 选择 std_48m 作为计数时钟; 01: 选择 clk_mux_in 作为计数时钟; 10: 选择 pll_d1p5 作为计数时钟; 11: 选择 pll_d1p0 作为计数时钟; 备注: 时钟选择频率越大,JL_PCNT->VAL 计数值会越大,分辨率会越高,即触摸按键灵敏度越高。 |
| 1    | EN        | rw | 0       | -  | 触 摸 按 键 使 能 , 当 该 BIT 为 1 时 ,<br>JL_PCNT->VAL 累加计数,计满后归 0 重新累<br>加<br>0: 触摸键禁止<br>1: 触摸键使能                                                                              |
| 0    | TEST_EN   | rw | 0       | 0  | 触摸按键测试使能(此为专用于测试)<br>0:测试模式未使能<br>1:测试模式使能                                                                                                                              |

#### 2. JL PCNT->VAL

| Bit  | Name  | RW | Default | RV | Description |
|------|-------|----|---------|----|-------------|
| 31-0 | VALUE | r  | -       | -  |             |



# 第17章 PAP

## 17.1. 模块说明

PAP 接口(Parallel Active Port)是一个并行主动数据接口,它工作于主动模式,支持8bit 或 16bit 数据宽度,具有读、写使能信号,并可支持 DMA 方式发送/接收数据。

PAP 传输支持由 CPU 直接驱动,写 PAPBUF 的动作将启动一次传输; PAP 传输也支持 DMA 操作,每次 DMA 操作支持的数据量为 1 - 65535 byte,写 PAPCNT 的动作将启动一次 传输。

PAP 在 DMA 发送数据(写)时支持普通模式和数据扩展模式。普通模式是指: PAP 接口直接将原始数据发送出去。数据扩展模式是指: PAP 接口可预设两个 16 位的数值 DAT0 和DAT1,在发送过程中,硬件依次检查原始数据(1 byte)的每一 bit(从 LSB 到 MSB,或从MSB 到 LSB),若该 bit 为 1,则发送预设值 DAT1,否则发送预设值 DAT0。此状态下,若设置为 16 bit 数据宽度,则 DAT0 / DAT1 先后分两次写出。

【注意】: PAP 在接收数据(读)时只支持普通模式,请勿在读状态下使能数据扩展模式,否则会导致不可预计的错误。

# 17.2. 模块说明

1. JL PAP->CON: PAP contrl register 0

| Bit   | Name     | RW | Default | RV | Description                                                          |
|-------|----------|----|---------|----|----------------------------------------------------------------------|
| 31-19 | RESERVED | r  | -       | -  | 预留                                                                   |
| 18    | PAPIE    | rw |         |    | 中断使能<br>0: 关闭,不允许 PAP 引发 CPU 中断<br>1: 打开,允许 PAP 引发 CPU 中断            |
| 17    | EXTMSB   | rw |         |    | 数据扩展模式下,数据扩展顺序设置<br>0:从 LSB 到 MSB 逐位检查原始数据<br>1:从 MSB 到 LSB 逐位检查原始数据 |
| 16    | EXTE     | rw |         |    | 数据扩展模式使能<br>0: 普通模式<br>1: 数据扩展模式,此模式只支持数据发送                          |



| PAP   | AP       |      |  |  |                            |  |  |  |  |
|-------|----------|------|--|--|----------------------------|--|--|--|--|
|       |          |      |  |  | (写),勿在数据接收(读)时设置此位         |  |  |  |  |
|       |          |      |  |  | 数据建立时间设置                   |  |  |  |  |
|       |          |      |  |  | 0x0: 数据建立时间为 0             |  |  |  |  |
| 15-14 | TS[1:0]  | rw   |  |  | 0x1:数据建立时间为 1 个系统时钟的宽度     |  |  |  |  |
|       |          |      |  |  | 0x2:数据建立时间为 2 个系统时钟的宽度     |  |  |  |  |
|       |          |      |  |  | 0x3:数据建立时间为3个系统时钟的宽度       |  |  |  |  |
|       |          |      |  |  | 数据保持时间设置                   |  |  |  |  |
|       |          |      |  |  | 0x0:数据建立时间不小于 0            |  |  |  |  |
|       |          |      |  |  | 0x1:数据建立时间不小于 1 个系统时钟的宽    |  |  |  |  |
| 13-12 | TH[1:0]  | rw   |  |  | 度                          |  |  |  |  |
| 13 12 | 111[1.0] | 1 ** |  |  | 0x2:数据建立时间不小于 2 个系统时钟的宽    |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x3:数据建立时间不小于 3 个系统时钟的宽    |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 读/写使能信号宽度设置                |  |  |  |  |
|       |          |      |  |  | 0x0: 读/写使能信号宽度为 16 个系统时钟的宽 |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x1: 读/写使能信号宽度为 1 个系统时钟的宽  |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x2: 读/写使能信号宽度为 2 个系统时钟的宽  |  |  |  |  |
|       |          |      |  |  | 度 2 法定供给房里穿穿出了人名格叶特的穿      |  |  |  |  |
|       |          |      |  |  | 0x3: 读/写使能信号宽度为 3 个系统时钟的宽度 |  |  |  |  |
|       |          |      |  |  | 0x4: 读/写使能信号宽度为 4 个系统时钟的宽  |  |  |  |  |
|       |          | rw   |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x5:读/写使能信号宽度为 5 个系统时钟的宽   |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x6: 读/写使能信号宽度为 6 个系统时钟的宽  |  |  |  |  |
| 11-8  | TW[3:0]  |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x7: 读/写使能信号宽度为7个系统时钟的宽    |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x8: 读/写使能信号宽度为 8 个系统时钟的宽  |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0x9: 读/写使能信号宽度为 9 个系统时钟的宽  |  |  |  |  |
|       |          |      |  |  | 度                          |  |  |  |  |
|       |          |      |  |  | 0xA: 读/写使能信号宽度为 10 个系统时钟的  |  |  |  |  |
|       |          |      |  |  | 宽度                         |  |  |  |  |
|       |          |      |  |  | 0xB: 读/写使能信号宽度为 11 个系统时钟的  |  |  |  |  |
|       |          |      |  |  | 宽度                         |  |  |  |  |
|       |          |      |  |  | 0xC: 读/写使能信号宽度为 12 个系统时钟的  |  |  |  |  |
|       |          |      |  |  | 宽度                         |  |  |  |  |
|       |          |      |  |  | 0xD: 读/写使能信号宽度为 13 个系统时钟的  |  |  |  |  |

| PAP |        |    |                                                                                                                               |
|-----|--------|----|-------------------------------------------------------------------------------------------------------------------------------|
|     |        |    | 宽度 0xE:读/写使能信号宽度为 14 个系统时钟的宽度 0xF:读/写使能信号宽度为 5 个系统时钟的宽度                                                                       |
| 7   | PND    | r  | 中断请求标志,当一次传输完成或 dma 传输完成时会被硬件置 1.<br>有 3 种方法清除此标志<br>1: 向 PCLR 写入'1'<br>2: 写 PAPBUFL 寄存器来启动下一次传输<br>3: 写 PAPCNT 寄存器来启动下一次 dma |
| 6   | PCLR   | w  | 软件在此位写入'1'将清除 PND 中断请求标志,写入'0'无效                                                                                              |
| 5   | DW16ED | rw | 数据大小端选择 0:16 bit 模式下,低地址数据至端口低位 8 bit 模式下,数据至端口低位 1:16 bit 模式下,低地址数据至端口高位 8 bit 模式下,数据至端口低位                                   |
| 4   | DW16EN | rw | 8 bit / 16 bit 模式选择<br>0:8 bit 模式<br>1:16 bit 模式                                                                              |
| 3   | PRE    | rw | 读使能信号极性选择<br>0:读使能信号空闲时为0电平,有效时为1<br>电平<br>1:读使能信号空闲时为1电平,有效时为0<br>电平                                                         |
| 2   | PWE    | rw | 写使能信号极性选择<br>0:写使能信号空闲时为0电平,有效时为1<br>电平<br>1:写使能信号空闲时为1电平,有效时为0<br>电平                                                         |
| 1   | DIR    | rw | 传输方向设置<br>0: 发送数据<br>1: 接收数据                                                                                                  |
| 0   | PAPE   | rw | PAP 接口使能<br>0: 关闭 PAP 接口<br>1: 打开 PAP 接口                                                                                      |



## 2. JL\_PAP->BUF: PAP buffer register

| Bit   | Name     | RW | Default | RV | Description                                                |
|-------|----------|----|---------|----|------------------------------------------------------------|
| 31-16 | RESERVED | r  | -       | -  | 预留                                                         |
| 15-0  | PAP_BUF  | rw |         |    | 发送寄存器和接收寄存器共用此 SFR 地址。写入至发送寄存器,从接收寄存器读出。写此寄存器将启动一次发送或接收操作。 |

### 3. JL\_PAP->DTA0: PAP buffer register

| Bit   | Name     | RW | Default | RV | Description  |
|-------|----------|----|---------|----|--------------|
| 31-16 | RESERVED | r  | -       | -  | 预留           |
| 15-0  | PAP_DAT0 | w  |         |    | 数据扩展模式的 DTA0 |

### 4. JL\_PAP->DTA1: PAP buffer register

| Bit   | Name     | RW | Default | RV | Description  |
|-------|----------|----|---------|----|--------------|
| 31-16 | RESERVED | r  | -       | -  | 预留           |
| 15-0  | PAP_DAT1 | w  |         |    | 数据扩展模式的 DTA1 |

### 5. JL\_PAP->ADR: PAP buffer register

| Bit   | Name     | RW | Default | RV | Description             |
|-------|----------|----|---------|----|-------------------------|
| 31-16 | RESERVED | r  | -       | -  | 预留                      |
| 15-0  | PAP_ADR  | w  |         |    | DMA 起始地址(需满足 4 byte 对齐) |

#### 6. JL\_PAP->CNT: PAP buffer register

| Bit   | Name     | RW | Default | RV | Description                                         |
|-------|----------|----|---------|----|-----------------------------------------------------|
| 31-16 | RESERVED | r  | -       | -  | 预留                                                  |
| 15-0  | PAP_DAT0 | w  |         |    | DMA 计数寄存器(按 Byte 计),<br>兼有 DMA 传输启动(kick_start)的功能。 |



# 17.3. 传输波形



图 1 波形图 1



图 2 波形图 2