Rockchip Developer Guide MCU

Rockchip-Developer-Guide-linux4.4-MCU

Rockchip-Developer-Guide-linux4.4-MCU

Rockchip-Developer-Guide-MCU

Rockchip-Developer-Guide-MCU

Rockchip-Developer-Guide-linux4.4-MCU

User Manual:

Open the PDF directly: View PDF PDF.
Page Count: 8

DownloadRockchip-Developer-Guide-MCU
Open PDF In BrowserView PDF
MCU 开发指南
发布版本:1.1
作者邮箱:frank.wang@rock-chips.com
日期:2017.12
文件密级:公开资料

前言
概述
本文档主要介绍Rockchip MCU开发的基本方法。
产品版本
芯片名称

内核版本

RK3399

4.4

读者对象
本文档(本指南)主要适用于以下工程师:
技术支持工程师
软件开发工程师
修订记录
日期

版本

作者

修改说明

2017-09-20

V1.0

王明成

初始版本

2017-12-27

V1.1

王明成

修订文档格式

MCU 开发指南
1 Rockchip MCU简介
2 开发基础
2.1 运行前配置
2.1.1 启动地址
2.1.2 地址映射
2.1.3 时钟配置
2.1.4 复位撤销
2.2 其它配置
2.2.1 JTAG使能配置

2.3 MCU与主控通信
2.3.1 Mailbox
2.3.2 共享内存
3 Demo程序
3.1 代码获取
3.2 代码简介
3.2.1 目录结构
3.2.2 编译方法
3.2.3 中断编程
4 MCU调试
4.1 JTAG调试
4.2 串口打印
4.3 读写寄存器
参考文档

1 Rockchip MCU简介
ARM® Cortex®-M处理器系列具有灵活性、易用性、高性能、低功耗等特点。同时,Cortex-M处理器能够帮助开
发者以更低的成本提供更多的功能,其在代码重用和提高开发效率方面有显著优势,所以在嵌入式设备领域的应用
非常广泛。如下为Cortex-M0和Cortex-M3的基本简介。
Cortex-M0采用ARMv6-M结构,基于一个高集成度、低功耗的32位处理器内核;它采用冯·诺伊曼结构,基于
16位的Thumb指令集,并包含Thumb-2技术。
Cortex-M3采用ARMv7-M结构,为32位处理器内核。它采用哈佛结构,拥有独立的指令总线和数据总线,可
以让取指与数据访问并行不悖。
基于以上ARM® Cortex®-M优点,目前,Rockchip SoC上集成的MCU说明如下:
RK3399 集成2个Cortex-M0,其一PMU M0为ATF所用,其二Perilp M0开放给客户使用。

2 开发基础
2.1 运行前配置
本章节主要以RK3399 Perilp M0为例介绍Rockchip MCU开发的基础方法。

2.1.1 启动地址
以常见miniloader + ATF + u-boot的启动方式为例。
采用这种启动方式,通常将MCU代码编译生成的BIN和ATF的BIN一起打包为trust.img,因此,需要在u-boot添加
如下打包配置。

1

tools/rk_tools/RKTRUST/RK3399TRUST.ini

2

...

3

[BL30_OPTION]

4

SEC=1

5

PATH=tools/rk_tools/bin/rk33/rk3399bl30_v1.00.bin

6

ADDR=0x00080000

7

...

其中,PATH为MCU BIN文件存放路径,ADDR为MCU在DDR中被加载的地址(MCU的0地址)。当然这个地址需
要是在u-boot中reserve出来的一段安全地址。这个地址会传递给miniloader,其会负责将MCU的代码从ROM中加
载到DDR的这个地址处。
当然,如果使用u-boot或其它loader作为一级boot loader,也可参考上面的方法对M0的固件进行打包和加载。
MCU BIN编译方法参阅3.2.2章节。

2.1.2 地址映射
Coretex-M0/Coretex-M3拥有固定的Memory Map,这样方便软件在不同系统之间的轻松移植,其地址空间被分
为许多不同的段,可参阅Cortex-M0 Devices Generic User Guide Chapter 2.2章节Memory model和RK3399
TRM Chapter 7.4.2章节。通常,我们只需要配置MCU的0x00000000-0x1FFFFFFF地址映射。
注意,RK3399 M0的地址映射需要通过SGRF配置,所以务必在能访问SGRF的模块进行配置(通常放在miniloader
或ATF中进行),以2.1.1章节中的加载地址为例,具体内存映射配置方式如下:
启动地址配置
1

sgrf_perilp_m0_con7 = 0xf << (4 + 16) | (0x080000 >> 28) & 0x0f

2

sgrf_perilp_m0_con15 = 0xffff << 16 | (0x80000 >> 12) & 0xffff

外设地址配置
Rockchip MCU已默认配置了外设的映射地址(0x40000000-0x5FFFFFFF),即:
ADDR_MCU = ADDR_CA72 – 0xB8000000
这里的外设就是RK3399 TRM Chapter 2 System Overview中所列出的外设。

2.1.3 时钟配置
Rockchip MCU 时钟源可选择CPLL或GPLL,可参考RK3399 TRM Chapter 3 CRU章节。在其章节中指出clk配置寄
存器为CRU_CLKSEL_CON24(0x0160),其中:
bit[15] : 时钟源选择,1’b0: CPLL;1’b1: GPLL bit[12:8] : 分频设置,用于配置MCU的运行频率。
u-boot 参考代码

1

arch/arm/cpu/armv8/rk33xx/clock‐rk3399.c

2

#ifdef CONFIG_PERILP_MCU

3

/* peril m0 clk = 300MHz, select gpll as the source clock */

4

clk_parent_hz = RKCLK_GPLL_FREQ_HZ;

5

clk_child_hz = 300000000; /* HZ */

6

div = rkclk_calc_clkdiv(clk_parent_hz, clk_child_hz, 1);

7
8

div = div ? (div ‐ 1) : 0;

9

cru_writel((1 << 31) | (0x1F << 24) | (1 << 15) | (div << 8),

10
11

CRU_CLKSELS_CON(24));
#endif

2.1.4 复位撤销
MCU运行起来的最后一步就是进行复位撤销。其寄存器信息阅RK3399 TRM Chapter 3 CRU章节。RK3399 Perilp
M0的复位撤销寄存器为:
PMUCRU_SOFTRST_CON0(0x0110) 需要设置PMUCRU_SOFTRST_CON0[5:0] = 4b’0000.
u-boot 参考代码
1

arch/arm/cpu/armv8/rk33xx/clock‐rk3399.c

2

#ifdef CONFIG_PERILP_MCU

3
4
5

/* perilp m0 dereset */
cru_writel(0x00160000, CRU_SOFTRSTS_CON(11));
#endif

提示:时钟和复位的配置可放在最后期望MCU跑起来的地方,目前Rockchip SDK是放在u-boot当中。

2.2 其它配置
2.2.1 JTAG使能配置
MCU开发过程中,常常需要借助于JTAG来跟踪、调试和解决问题。Rockchip MCU JTAG接口采用SWD(2线)模
式,需要配置JTAG iomux后才能连接上。
RK3399 Perilp M0的iomux配置信息详见RK3399 TRM Chapter 7.3章节,包括如下两个寄存器。
1

GRF_GPIO4B_IOMUX[9:8] = 2’b10

2

GRF_GPIO4B_IOMUX[9:8] = 2’b10

2.3 MCU与主控通信
2.3.1 Mailbox
Rockchip SoC上集成的mailbox拥有4个通道,通过中断触发,数据通过共享内存传递。Rockchip MCU可通过
mailbox外设与主控通信。RK3399 Mailbox编程可参阅RK3399 TRM Chapter 21 Mailbox章节;RK3368 Mailbox
参考RK3368 TRM Chapter 11 Mailbox章节。
目前Linux 4.4 Kernel中,Mailbox Driver框架上层使用ARM SCPI协议,因此需要在Kernel开启
CONFIG_RK3368_MBOX和CONFIG_RK3368_SCPI_PROTOCOL两个配置。同时,MCU这边代码也需要编写
mailbox驱动和scpi协议支持。

Kernel DTS可参考下面代码进行配置。
1

mailbox: mailbox@ff6b0000 {

2

compatible = "rockchip,rk3368‐mbox‐legacy";

3

reg = <0x0 0xff6b0000 0x0 0x1000>,

4

<0x0 0xff8cf000 0x0 0x1000>; /* the end 4k of sram */

5

interrupts = ,

6

,

7

,

8

;

9

clocks = <&cru PCLK_MAILBOX>;

10

clock‐names = "pclk_mailbox";

11

#mbox‐cells = <1>;

12

status = "disabled";

13

};

14
15

mailbox_scpi: mailbox‐scpi {

16

compatible = "rockchip,rk3368‐scpi‐legacy";

17

mboxes = <&mailbox 0>, <&mailbox 1>, <&mailbox 2>;

18

chan‐nums = <3>;

19
20

status = "disabled";
};

2.3.2 共享内存
Rockchip MCU亦可通过共享内存方式与主控通信,比如在INTMEM (SRAM)中划分一块空间,将其配置成对主控和
MCU均可访问,即可实现共享内存方式通信。
Rockchip MCU还可以通过UART或其它方式与主控通信。

3 Demo程序
3.1 代码获取
Git仓库路径:
ssh://git@10.10.10.29/rk/mcu或https://github.com/frawang/rk-mcu.git
29代码可参考rk3399-pmu-m0 branch;github可参考rk3399-box-m0 branch。

3.2 代码简介
3.2.1 目录结构
1

rk‐mcu>ls ‐R

2

.:

3

build

include

Makefile

4
5

./build:

6

arm‐gcc‐link.ld

RK3399M0

7
8

./build/RK3399M0:

src

9

bin

obj

10
11

./build/RK3399M0/bin:

12

RK3399M0.bin

RK3399M0.dump

RK3399M0.elf

RK3399M0.map

13
14

./build/RK3399M0/obj:

15

main.o

startup.o

16
17

./include:

18

mcu.h

remotectl_pwm.h

rk3399.h

19
20

./src:

21

main.c

main.c.bk

remotectl_pwm.c

startup.c

build:用于存放编译生成的obj文件和bin文件。
include:代码头文件。
src:代码C文件。
startup.c文件为M0入口程序,主要包括M0中断向量表和中断执行函数。 main.c文件为M0程序的main函
数。

3.2.2 编译方法
交叉编译工具链使用gcc-arm-none-eabi- v4.8版本或以上。 编译方法如下:
1

rk‐mcu>make help

2

usage: make PLAT= 

3
4

PLAT is used to specify which platform you wish to build.

5

If no platform is specified in first time, PLAT defaults to:

6
7

Supported Targets:

8

all

9

clean Clean the current platform project

10

Build all the project

distclean Clean the current project and delete .config

11
12
13

example: build the targets for the RK3399M0 project:
make PLAT=RK3399M0

编译后会生成build/RK3399M0/bin/RK3399M0.bin文件,将RK3399M0.bin拷贝到u-boot目录中
tools/rk_tools/bin/rk33/目录,重命名为rk3399bl30_v1.00.bin;然后按照2.1.1章节配置,重新编译u-boot,即可
将M0的bin打包到trust.img。

3.2.3 中断编程
M0中断向量表可参阅Cortex-M0 Devices Generic User Guide Chapter 2.3 Exception model章节。对应到Demo
程序,即src/startup.c中有如下参考代码:
1

/**

2

* The minimal vector table for a Cortex M3.

3

* must be placed on this to ensure that it ends up at physical address

Note that the proper constructs

4

* 0x00000000.

5

*/

6

__attribute__ ((used,section(".isr_vector")))

7

void (* const g_pfnVectors[])(void) =

8

{

9

/* core Exceptions */

10

(void *)&pstack[STACK_SIZE], /* the initial stack pointer */

11

reset_handler,

12

nmi_handler,

13

hardware_fault_handler,

14

0,0,0,0,0,0,0,

15

svc_handler,

16

0,0,

17

pend_sv_handler,

18

systick_handler,

19
20

/* external exceptions */

21

0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,

22

0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

23

};

Coretex-M0内部有16个异常,从g_pfnVectors[0]到g_pfnVectors[15],可根据实际应用需要注册并实现对应的异
常处理函数。
Cortex-M0可处理32个外部中断,对应g_pfnVectors[16]到g_pfnVectors[47]。
RK3399 Perilp M0引入了中断仲裁器,将32个外部中断扩展到256个,可参阅RK3399 TRM Chapter 7.4.6
Interrupt Source Arbiter for PERILPM0章节。当然,使用仲裁器,需要配置对应的mask bit,而M0收到中断后,
需要根据对应的mask bit来判断具体的中断源。
Arbiter的接口可参考include/rk3399.h中
M0_INT_ARB_SET_MASK() // 设置中断mask M0_INT_ARB_GET_FLAG() // 获取中断bit
RK3399 Perilp M0支持的外部中断请参阅RK3399 TRM 2.4 System Interrupt Connection for Cortex-M0 章节。

4 MCU调试
4.1 JTAG调试
GRF中设置JTAG相关iomux、tck、tms,请阅2.2.1章节。
开发板JTAG拨码开关或tck/tms开关拨至MCU处;
DS-5或ICE连接m3/m0进行调试。

4.2 串口打印
M0可直接访问UART寄存器进行打印调试。
如果MCU使用跟主控相同的UART,建议正常运行时关闭M0打印,防止UART访问异常导致系统异常。

4.3 读写寄存器
可将系统停留到u-boot或Kernel命令行,通过io读取MCU状态寄存器查看MCU状态。

也可将MCU关键点的运行状态写入空闲GRF寄存器,然后在u-boot或kernel命令行读取其值判断MCU的当前
运行状态。

参考文档
Cortex-M0 Devices Generic User Guide
Cortex-M0 Technical Reference Manual
ARM Cortex-M3 Processor Technical Reference Manual
Cortex-M3 Devices Generic User Guide
Rockchip RK3399 TRM V0.4
Rockchip RK3368 TRM V2.0



Source Exif Data:
File Type                       : PDF
File Type Extension             : pdf
MIME Type                       : application/pdf
PDF Version                     : 1.4
Linearized                      : No
Creator                         : Typora
Producer                        : Typora
Create Date                     : 2018:01:24 09:47:53
Modify Date                     : 2018:01:24 09:47:53
Page Count                      : 8
Page Mode                       : UseOutlines
Warning                         : [Minor] Ignored duplicate Info dictionary
EXIF Metadata provided by EXIF.tools

Navigation menu