
STM32MP1系列微处理器(ARM dual Cortex-A7 650Mhz + Cortex-M4)![]() ![]() 开发软件安装,STM32CubeMX5 a9 s9 y7 P; I7 y6 V2 w STM32CubeMX 是 ST 意法半导体近几年来大力推荐的 STM32 芯片图形化配置工具, 允许用户使用图形化向导生成 C 初始化代码,可以大大减轻开发工作,时间和费用。stm32mp1中使用协处理器M4需要安装stm32cubemx:7 \4 A& @9 r+ G, j4 }) \ stm32cubemx运行环境搭建,包含两个部分,首先是安装java运行环境(版本必须为v1.7以上),然后是安装stm32cubemx开发软件。 简单使用:% W9 s; `0 o' w 新建工程第一步,选择mcu型号' ^% Y2 Z: s( Q1 N) r+ F! P ![]() 由于pangu开发板选用的是stm32mp157AAA3芯片,故选择stm32mp157AAAX ![]() 接下来配置时钟源,如果选择使用外部高速时钟(HSE),则需要在System Core中配置RCC; " C4 l4 L0 O0 n* |6 ? 5 R! i6 e/ I8 ]1 W5 M 如果使用默认内部时钟(HSI),这一步可以略过;这里使用外部时钟,HSE,LSE pangu开发板上的外部时钟0 `) P* Y2 Q( S% i& W: E ![]() 下拉框中选择crystal/Ceramic Resonator晶体/陶瓷晶振5 i5 h1 b1 X( i! P* E! O6 ^ ![]() 设置开发板上D17灯对应的PH6引脚为输出; G$ g- v8 G. [4 K5 f: h ![]() 生成工程设置* |% U( V+ i# a+ D2 Y ![]() 然后点击Generate code就可生成MDK工程代码。 时钟树配置,配置主要是外部晶振大小,分频系数,倍频系统以及选择器。' V% v1 r* G; E; p+ ]% J0 ` ![]() 最后用MDK打开生成的MDK-ARM工程文件,build编译。0error。( C5 p; |2 ~3 e$ t% m ![]() 之前使用的STM32F407开发板用的是标准外设库(STD库), HAL库是硬件抽象层,更加标准化了。所有的函数名和函数体进行了重新定义,重新编写。更加通用。方便移植。近两年新出的STM32芯片,ST只提供HAL库,可用STM32Cube程序生成开发工具+HAL库" }1 c# |0 o: A+ p stm32cube目前几乎支持STM32全系列,我们需要到ST官网下载对应的STM32Cube包 ![]() 包中大致有(1)Drivers文件夹,Drivers 文件夹包含BSP, CMSIS 和 STM32MP1xx_HAL_Driver 三个子文件夹。BSP是板级支持包,提供直接与硬件打交道的API。 CMSIS 文件夹是符合 CMSIS 标准的软件抽象层组件相关文件。主要包括 DSP库(DSP_LIB 文件夹), Cortex-M 内核及其设备文件(Include 文件夹), 微控制器专用头文件/启动代码/专用系统文件等(Device 文件夹)。 STM32MP1xx_HAL_Driver文件夹中包含所有的 STM32MP1xx系列 HAL 库头文件和源文件,也就是所有底层硬件抽象层 API 声明和定义。 它的作用是屏蔽了复杂的硬件寄存器操作,统一了外设的接口函数。 该文件夹包含 Src 和 Inc 两个子文件夹,其中 Src 子文件夹存放的是.c 源文件, Inc 子文件夹存放的是与之对应的.h 头文件。每个.c 源文件对应一个.h 头文件。 Middlewares文件夹下有Third_Party文件夹(是第三方中间件)里面有FreeRTOS实时系统支持包和OpenAMP(?)0 D$ s9 _7 T2 A2 [' B8 P; I1 {/ ^ Projects文件夹存放的是一些可以直接编译的实例工程,每个文件夹对应一个ST官方的Demo板,暂时只有SW4STM32的工程,没有MDK的。9 o u2 o! ]5 b7 v9 W( `5 o 一般来说,stm32mp1处理器可以在M4上做电机控制,A7上做人机交互界面。 - |) ?! I+ b- U0 \ $ D/ i& n$ Q% ]1 [9 Y! {4 ` 应用开发环境搭建; S9 Z( h# p& N; H$ r- M4 a; ` linux开发需要在ubuntu下进行,主要是交叉编译器的安装。 linux进行C语言开发用的是GCC编译器进行代码编译,但ubuntu自带的GCC编译器是针对X86架构的。我们现在要编译的是ARM架构的代码,需要一个在X86架构的PC机上运行,可以编译ARM架构代码的GCC编译器,这个编译器就叫做交叉编译器。(就是在一个架构上编译另外一个架构的代码)& u2 L( T! _0 w% s X. }! \' t9 T! L) [8 `: ~8 P 8 S; W0 a/ a2 G' P$ w k C pangu开发板的开发环境基于Ubuntu16.04 64bit,在虚拟机上安装ubuntu16.04操作系统# v- Z5 n3 c) ] / e, V& O, b4 O3 @! P PanGu开发板的应用开发,需要先安装应用开发工具包(SDK)。PanGu开发板提供了两种SDK工具包:i2som-image-qt-openstlinux-eglfs-pangu-x86_64-toolchain-2.6-snapshot.sh和i2som-image-weston-openstlinux-weston-pangu-x86_64-toolchain-2.6-snapshot.sh。 由于板载的flash预装的是weston系统,在此我选择在ubuntu系统中安装weston系统镜像的应用开发工具链。 下面开始安装i2som-image-weston-openstlinux-weston-pangu-x86_64-toolchain-2.6-snapshot.sh工具包! c) M5 y9 B b! J; k # y' m0 V3 R6 `! `. B5 A; r( | ' e1 q2 u: ]9 l, Q6 r 首先运行chmod a+x命令,给所有人加上可执行权限,用ls –lh命令查询文件的大小、权限等详细信息,权限都为rwx(读取、写入、执行)2 e8 U/ m$ |# G( Q ![]() 接着在路径下运行安装命令:./i2som-image-weston-openstlinux-weston-pangu-x86_64-toolchain-2.6-snapshot.sh5 j+ _9 z M2 m5 a" w8 z1 V7 s0 p* L ![]() 安装路径输入 /opt/st/pangu-i2som-image-weston/2.6-snapshot ![]() 接着会让你输入管理员密码,之后就等待安装了。 当出现SDK has been successfully时证明安装完成了。 % q* G5 i- L# N' P5 {2 p) q; Y 然后运行如下命令:. H% \6 M; M: B . /opt/st/pangu-i2som-image-weston/2.6-snapshot/environment-setup-cortexa7t2hf-neon-vfpv4-openstlinux_weston-linux-gnueabi ![]() 通过$CC –version验证开发工具是否正确安装,如图显示了版本信息表示工具链安装完成。 Z$ _1 i, @* h) B 编写测试文件test.c内容如下 ![]() 编译test应用 ![]() 然后将输出的 复制到pangu开发板后直接运行 9 p7 y' Q; q/ x+ H 2 W- S3 `% G7 w# C. W 通过MobaXtern配置ssh登录pangu开发板,可通过sftp服务进行文件的复制拷贝。* K' q$ S; y. X8 i6 K* I ![]() 上图是pangu开发板的home目录 现在将编译输出的test从虚拟机的ubuntu系统复制到home目录下& O5 t0 j% L; i" B ![]() 可以看到此时多了个test文件。 % T7 J3 z$ \' O- F6 C3 L 直接运行发现permission denied 通过chmod a+x命令修改下权限,紧接着再输入./test ![]() 输出是hello,I am wangrongyao! K" H% S; {0 |2 S; B % V; J4 b9 b& O. k0 n ]4 n # F9 t* o Q% j" k* Z pangu开发板的Micro usb接口可以作为从设备,默认是作为usb以太网设备,可以实现将开发板的usb otg接口作为从设备模式,模拟成为一个网口,通过PC的usb接口连接到开发板。使用Micro USB线连接开发板J5和PC USB Host接口。PanGu开发板上usb0为网络设备,默认IP地址为192.168.7.23 f5 d. y& e7 k8 E* F: F ![]() PC通过usb连接开发板后,PC上会出现一个usb虚拟的网络设备,自行手动配置ip地址为192.168.7.10,之后就可以通过ssh登录pangu开发板了。 ![]() |
基于STM32MP1和STM32MP2在嵌入式Linux平台上部署有效的安全保护机制
利用STM32MP1和STM32MP2为嵌入式Linux提供有效的安全措施:供当今决策者参考的3条宝贵经验
STM32MP1 WiFi连接
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【STM32MPU 安全启动】 TF-A BL2 TrustedBoot原理学习
《STM32MPU安全启动》学**结
《STM32MPU安全启动》学习笔记之optee 如何加载CORTEX-M核和使能校验
《STM32MPU安全启动》学习笔记之TF-A BL2校验optee和uboot的流程以及如何使能
《STM32MPU 安全启动》课程学习心得+开启一扇通往嵌入式系统安全领域深处的大门。
《STM32MPU安全启动》 课程学习心得