rt-thread-official/bsp/lpc55sxx/lpc55s69_nxp_evk
Kevin Peng cd95e4cd59 LPC55S69: Add Protected Storage demo
This demo shows how protected storage works in RTT. It tests by write
and read data over PSA APIs, then check the integrity. The test will
run repeatedly, each time with different data.

The TFM package does not support LPC55S69 board officially yet.

Change-Id: Ib1cd4fc8166b21e3f774f092c95d2811d51123fe
Signed-off-by: Kevin Peng <kevin.peng@arm.com>
Signed-off-by: Karl Zhang <karl.zhang@arm.com>
2020-01-15 08:43:02 +08:00
..
applications LPC55S69: Add Protected Storage demo 2020-01-15 08:43:02 +08:00
board Merge pull request #3314 from karl-zh/RT_USING_TFM 2020-01-14 12:00:22 +08:00
figures added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
.config [BSP] fix the lpc55 issue under Linux/GCC 2020-01-02 08:17:32 +08:00
Kconfig [BSP] fix the lpc55 issue under Linux/GCC 2020-01-02 08:17:32 +08:00
README.md added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
SConscript added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
SConstruct added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
flashdebug.ini added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
project.ewd added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
project.ewp added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
project.eww added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
project.uvoptx added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
project.uvprojx added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
project_ns.uvoptx LPC55S69: Add Protected Storage demo 2020-01-15 08:43:02 +08:00
project_ns.uvprojx LPC55S69: Add Protected Storage demo 2020-01-15 08:43:02 +08:00
rtconfig.h [BSP] fix the lpc55 issue under Linux/GCC 2020-01-02 08:17:32 +08:00
rtconfig.py [BSP] fix the lpc55 issue under Linux/GCC 2020-01-02 08:17:32 +08:00
template.ewp added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
template.eww added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
template.uvoptx added LPC55S6x BSP 2019-10-24 17:56:09 +08:00
template.uvprojx added LPC55S6x BSP 2019-10-24 17:56:09 +08:00

README.md

LPC55S69-EVK 板级支持包

1. 简介(Introduction)

LPC55S69 是由恩智浦NXP半导体推出的基于Cortex-M33内核的高性能单片机 包括如下硬件特性:

硬件 描述
芯片型号 LPC556x/LPC55S6x 全系列
CPU Cortex-M33 Dual Core, with FPU
主频 150MHz
基本外设 8个Flexcomm(任意配置为USART/SPI/I2C/I2S) / 1个50MHz SPI / 双USB(1高1全支持主从)
特色 PowerQuad DSP协处理器 / 安全外设:PRINCE/PUF/CASPER/AES-256/HASH

2. 硬件开发环境(Hardware development system)

开发板EVK

开发板示意图

3. 编译说明

环境 说明
PC操作系统 Linux/MacOS/Windows
编译器 arm-none-eabi-gcc version 6.3.1 20170620 (release)/armcc/iar
构建工具 scons/mdk5/iar
依赖软件环境 Env工具/(MDK或IAR或arm-none-eabi-gcc)/git/调试器驱动
  1. 下载源码
    git clone https://github.com/RT-Thread/rt-thread.git
  1. 配置工程并准备env

Linux/Mac

    cd rt-thread/bsp/lpc55s69_evk
    scons --menuconfig
    source ~/.env/env.sh
    pkgs --upgrade

Windows

RT-Thread官网下载ENV工具包

  1. 配置芯片型号

Linux/Mac

    scons --menuconfig

Windows(ENV环境中)

    menuconfig

在menuconfig页面配置并选择对应的芯片型号若开发环境为MDK/IAR则需要生成工程

  1. 生成工程(Mac/Linux下请跳过此步骤)

Windows IAR

    SET RTT_CC=iar
    scons --target=iar -s

Windows MDK5*

    scons --target=mdk5 -s

*该板级支持包不支持生成mdk4的工程

MDK 与 IAR 在生成完成工程之后一定要在工程中手动选择一次芯片信号,否则会产生严重编译错误

  1. 编译

使用MDK或IAR请参见对应教程

Windows arm-none-eabi-gcc 使用以下指令设置gcc路径

    SET RTT_EXEC_PATH=[GCC路径]

Linux/Mac arm-none-eabi-gcc 使用以下指令设置gcc路径

    export RTT_EXEC_PATH=[GCC路径]

编译WindowsLinux/Mac arm-none-eabi-gcc

    scons -j4

出现下列信息即为编译成功

    LINK rtthread-lpc55s69.elf
    arm-none-eabi-objcopy -O binary rtthread-lpc55s6x.elf rtthread.bin
    arm-none-eabi-size rtthread-lpc55s69.elf
    text    data     bss     dec     hex filename
    41596     356    1456   43408    a990 rtthread-lpc55s6x.elf
    scons: done building targets.

如果编译正确无误会产生rtthread-lpc55s6x.elf、rtthread.bin文件。其中rtthread.bin为二进制固件

3. 烧写及执行

烧写可以使用仿真器 ISP等多种方式 此处不再赘述

3.1 运行结果

如果编译 & 烧写无误会在Flexcomm0串口*上看到RT-Thread的启动logo信息

 \ | /
- RT -     Thread Operating System
 / | \     4.0.1 build Jul 30 2019
 2006 - 2019 Copyright by rt-thread team
uising armclang, version: 6120001
msh />

*默认串口

4. 驱动支持情况及计划

驱动 支持情况 备注
UART 支持 UART0/2
GPIO 支持 自动根据芯片型号选择引脚布局
SPI 支持 支持High Speed SPI
USB Device 不支持 暂不支持
USB Host 不支持 暂不支持
Windowed WatchDog 不支持 支持
ADC 不支持 暂不支持
I2C 支持 可配合MMA8562
I2C Sensor 支持 获取板上MMA8562加速度传感器数据
RTC 支持 RTC时钟自动配置
SDIO 支持 操作SD卡
I2S 不支持 暂不支持

4.1 IO在板级支持包中的映射情况

PIO号 板级包中的定义
PIO0_29 Flexcomm0 USART RXD
PIO0_30 Flexcomm0 USART TXD
PIO0_7 SDIO SD0_CLK
PIO0_8 SDIO SD0_CMD
PIO0_9 SDIO SD0_POW_EN
PIO0_15 SDIO SD0_WR_PRT
PIO0_17 SDIO SD0_CARD_INT
PIO0_24 SDIO SD0_D(0)
PIO0_25 SDIO SD0_D(1)
PIO0_31 SDIO SD0_D(2)
PIO1_0 SDIO SD0_D(3)
PIO0_26 High Speed SPI MOSI
PIO1_2 High Speed SPI SCK
PIO1_3 High Speed SPI MISO
PIO1_4 GPIO1_4 output LED BLUE
PIO1_6 GPIO1_6 output LED RED
PIO1_7 GPIO1_7 output LED GREEN
PIO0_27 Flexcomm2 USART TXD mikro BUS
PIO1_24 Flexcomm2 USART RXD mikro BUS
PIO1_20 Flexcomm4 I2C SCL
PIO1_21 Flexcomm4 I2C SDA

5. menuconfig Bsp菜单详解

选项 解释
Device type 选择芯片型号修改此处需修改MDK/IAR工程为相同芯片型号

*部分选项需要在RT-Thread组件菜单中开启对应的设备框架才能显示。

6. 联系人信息

维护人: Magicoe < magicoe@163.com >