

### USING THE S32V234 EVB DEVELOPMENT PLATFORM

#### FTF-AUT-N1808

STEVE MCASLAN PRINCIPAL ENGINEER FTF-AUT-N1808 MAY,18 2016



PUBLIC USE



### AGENDA

- Introduction to the S32V234 vision processor development platform
- Peripheral and real-time processing
- Application processor cluster
- Vision processing elements
- The Image Signal Processor
- Vision SDK



#### S32V234

- Vision processing MPU
  - multiple ARM® Cortex®-A53 CPUs and one Cortex-M4 CPU
  - -many dedicated modules and processors for acceleration of vision processing tasks
  - Developed according to ISO 26262 with an integrated safety concept
- Automotive applications include front view, surround view and Data Fusion systems
  - -Scalable
- Includes leading edge camera vision modules like APEX2, ISP, and GPU



#### S32V234 Development Environment and This Session

- The NXP development environment consists of hardware platforms and software tools, libraries and operating systems
- This session uses the full-featured EVB for convenience however the examples are also suitable for low cost boards under development
- There are 6 examples to follow which illustrate the features of the board, tools and software
  - Illustrate the low-level boot behaviour of the device
  - Higher level OS and SDK capability
  - Opportunity to modify software functions and run these on the hardware



#### **Workshop Flow**

Software Complexity



# **INTRODUCTION TO HE S32V234** DEVELOPMENT PLATEORM









#### **Example 1: Hello World**

This example is here to make sure the system is functional and you are familiar with the EVB features





## PERIPHERAL AND REAL-TIME PROCESSING



#### S32V234 Detailed Block Diagram





#### **Peripheral and Real-time Processing**

- This portion of the processor is effectively an embedded real-time processor with optimised connection to the device peripherals
  - cf Kinetis family
- It has its own dedicated memory (TCM)
- Boot sources are close by
  - -SD/eMMC and QuadSPI
- · It is always the boot processor





#### **Example 2: Peripheral Use**

This example allows you to take control of the UART and use it to interact with the real-time part of the system





## APPLICATION PROCESSOR CLUSTER



#### Core3 Care1 Core2 DOOMHE 1000MH 1000MH 1000MHz Cortes-A53 Cortex-A53 Cortex-A53 Cortex-A53 NEON/FPU NEON/FPU **NEON/FPU NEON/FPU** 32KB 32KB 256KB 32KB 32KB 32KB 32KB 32KB -Cache D-Cache L2-I-Cache D-Cache I-Cache -Cache -Cache -Cache 12-ECC/ EDC ECC/ EDC ECC/ EDC ECC/ EDC EOC/ EDC ECC/ EDC EOC/ EDC Cache ECC ECC/ EDC Cache ECC SCI 128-bits 3 128-bits OCI-400 ind, EDC 128-bits 1 SRAM - all others 64-bits AHB Hierarchical NIC 301 AXI Bus System incl. EDC AXBS Bus System ind, EDC 32-bits XRDC 64-bits 64-bits 64-bits 64-bits AHB DRAM - SRAM -all others all others QoS 301 ind, EDC 64-bits 64-bits XRDC QuadSPI NOR Flash Ctrl Ctrl Bridae 2x4-bits 32-bits 32-bits 32-bits DRAM-ECC 4/2x4/8-bits QSPI Flash 96KB 32-bit MMDC\_( 32-bit MMDC ROM LPDDR2 DOR3(L) LPDDR2 DOR3(L) (boot) External NOR Flash MC DOR-PHY DOR-PHY Off-Chip GM, RG PCÚ, ME 533MHz 533MHz \* \* \* \* \* \* \* \* \* \* \* \* 1066MHz 1066MHz DDR DDR \* \* \* \* \* \* \* \* \* \* \*\* \*\*\*\*\*\*

#### **Applications Processing Cluster**

- This processor clust OS tasks
- We can boot directly

#### **Example 3: Application Cluster Use**

- This example allows you to use the system DRAM and launch the Cortex M4 and further Cortex A53 cores under the control of the boot core
- This shows the effect that multiple cores can have on throughput





### VISION PROCESSING ELEMENTS



#### **Vision Processing Elements**

- This part of the processor captures incoming RAW video from the cameras and performs basic processing on it before storing it into DRAM
- We will use the 2D-ACE to see the effect that the processing steps have on the video





#### **Example 4: Camera Input**

- This example captures the video from the camera and uses the 2D-ACE to display it in real time on the display panel
- Using some simple software settings we will adjust the appearance of the video





### THE IMAGE SIGNAL PROCESSOR



#### **Vision Processing Elements**

- This part of the processor captures incoming RAW video from the cameras and performs basic processing on it before storing it into DRAM
- We will use the 2D-ACE to see the effect that the processing steps have on the video





#### **Example 5: ISP Use**

- This example uses the Cortex A53 to manipulate the parameters of the ISP processing steps
- This is our first use of the S32V234
  Vision SDK
- We will run examples from the file system on the laptops





### **VISION SDK**



#### **Vision SDK**

- The full vision SDK includes support for the APEX engines, the ISP, the cameras and the 2D-ACE
- This allows us to extract information from the incoming video and identify items of interest





#### **Example 6: Vision SDK Use**

We will examine various Vision SDK example projects to review the range of features supported





#### Summary

- In this session we have seen how the S32V234 vision processor boots from external memory and how the code in that memory is structured
- We can choose the initial target processor and have it launch the other processing elements in the system
- Real-time and peripheral management has a dedicated zone on chip and example support on board
- Capturing and displaying video is optimised by the architecture of the S32V234 and the EVB
- We can create an optimised development environment for our vision processing using the software tools running under a Linux environment with a remote file system





#### SECURE CONNECTIONS FOR A SMARTER WORLD

#### ATTRIBUTION STATEMENT

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, CoolFlux, EMBRACE, GREENCHIP, HITAG, I2C BUS, ICODE, JCOP, LIFE VIBES, MIFARE, MIFARE, MIFARE Classic, MIFARE DESFire, MIFARE Plus, MIFARE FleX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TrenchMOS, UCODE, Freescale, the Freescale logo, AltiVec, C 5, CodeTEST, CodeWarrior, ColdFire, ColdFire+, C Ware, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorIQ, QorIQ Qonverge, Ready Play, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, SMARTMOS, Tower, TurboLink, and UMEMS are trademarks of NXP B.V. All other product or service names are the property of their respective owners. ARM, AMBA, ARM Powered, Artisan, Cortex, Jazelle, Keil, SecurCore, Thumb, TrustZone, and µVision are registered trademarks of ARM Limited (or its subsidiaries) in the EU and/or elsewhere. ARM7, ARM9, ARM11, big.LITTLE, CoreLink, CoreSight, DesignStart, Mali, mbed, NEON, POP, Sensinode, Socrates, ULINK and Versatile are trademarks of ARM Limited (or its subsidiaries) in the EU and/or elsewhere. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org. © 2015–2016 NXP B.V.