# Renesas RA Family # Building a Vision Al Application using the RA8P1 MCU with Ethos-U55 NPU ### Introduction This application project is designed to provide guidelines for implementing Vision AI applications using Renesas RA8P1 MCUs with Ethos-U NPU support. Key guidelines and demonstrations covered in this application project include: - Compiling a pre-trained TensorFlow Lite model to enable inference execution on the Ethos-U NPU by the RUHMI Framework. - Compiling a pre-trained TensorFlow Lite model to enable inference execution on the CPU by the RUHMI Framework. - Integrating the RUHMI compilation results in an embedded project to perform runtime inference using real-time camera input from the OV5640 camera sensor via the MIPI CSI interface. - Displaying the inference result and real-time camera feed on the parallel graphics LCD included with the EK-RA8P1 kit. - Demonstrating a dual-core solution with low-power mode features The contents of this application project can be used as a reference for developing other vision Al applications. # **Required Resources** #### **Target Devices** RA8P1 ### Software and development tools - e<sup>2</sup> studio IDE v2025-04.1 with LLVM 18.3 support - Renesas Flexible Software Package (FSP) v6.0.0 - Renesas RUHMI (Robust Unified Heterogeneous Model Integration) Framework (installed as an add-on for e<sup>2</sup> studio) The links to download the FSP and e<sup>2</sup> studio IDE are available at https://github.com/renesas/fsp. #### **Hardware** - EK-RA8P1 with included Camera Module and Parallel graphics LCD panel - Evaluation Kit for RA8P1 MCU Group (<u>renesas.com/ra/ek-ra8p1</u>) - Workstation running Windows® 10 and the Tera Term console or a similar application. - One USB Type-C device cable ### **Prerequisites and Intended Audience** This application project assumes that the audience understands Al/ML design concepts and has good experience using the Renesas e<sup>2</sup> studio IDE and the Renesas RA Smart Configurator. Basic instructions on how to import and compile an application are not provided. Refer to the "Importing an Existing Project into e<sup>2</sup> studio" section in the Flexible Software Package (FSP) User's Manual for guidance. The intended audience is all users who are or will be developing Al applications using Renesas RA MCUs, specifically those with Ethos-U NPU support and pre-quantized int8 models. Model training and quantization are outside the scope of this application project. # Contents | 1. | RA8P1 MCUs with Ethos-U NPU | 4 | |-------|--------------------------------------------------------------------------------|----| | 1.1 | Dual Core | 4 | | 1.1.1 | Inter-Processor Communication (IPC) | 5 | | 1.1.2 | Shared Memory | 5 | | 1.2 | Memory Sub-Systems | 5 | | 1.3 | Neural Processing Unit | 6 | | 1.4 | Human Interface Features | 6 | | 1.4.1 | 2D Drawing Engine (DRW) | 6 | | 1.4.2 | Graphic LCD Controller (GLCDC) | 6 | | 1.4.3 | MIPI CSI and Video Input Module (VIN) Interface | 6 | | 1.4.4 | Camera Engine Unit (CEU) | 7 | | 1.4.5 | MIPI DSI | 7 | | 1.5 | Communication Interfaces | 7 | | 1.5.1 | Serial Communication Interface (SCI) | 7 | | 1.5.2 | I2C Bus Interface (IIC) | 7 | | 1.6 | Timers | 7 | | 1.6.1 | General PWM Timer (GPT) | 7 | | 1.6.2 | Lower Power Asynchronous General Purpose Timer (AGT) | 7 | | 2. | Deploy an Open-Source Al Model using the Renesas RUHMI Framework | 8 | | | | | | | The Image Classification AI Application | | | 3.1 | System Architecture | | | 3.2 | FSP Driver Usage | | | 3.3 | Dual Core Architecture and Low Power Feature | | | 3.4 | Memory Allocation | | | 3.5 | Hardware Configurations | | | 3.5.1 | MIPI-CSI and Camera Connections | | | 3.5.2 | · | | | 3.5.3 | | | | 3.5.4 | | | | 3.6 | The Image Classification Model | | | 3.7 | OV5640 Camera Module Usage | | | 3.8 | MIPI-CSI and VIN Interface | | | 3.9 | Al Inference Pre-Processing and Post-Processing | | | 3.10 | Displaying the Camera Image and Inference Results on the Parallel Graphics LCD | 16 | | 4. | Running the Image Classification Project | 17 | | 4.1 | Setting Up the Hardware and the IDE | 17 | | | | | | 4.2. | Observe the System Performance using the LCD Output | 22 | |-------|-------------------------------------------------------------------------------------|----| | 4.3 | Compile and Run the Single-Core Ethos-U and CPU Inference on Cortex-M85 | 22 | | 4.3. | Compile and Run the Single-Core Ethos-U Inference Project | 22 | | 4.3.2 | 2 Compile and Run the Single-Core CPU Inference Project | 22 | | 4.4 | Observe the System Statistics using the J-Link Virtual Console | 23 | | 4.5 | Summarize the Ethos-U Inference Performance Uplifting | 24 | | 4.6 | Low Power Feature Summary | 24 | | 5. | Appendix: Compile the MobileNet V1 0.25 Model for Embedded Al Inference | 26 | | 5.1 | Quantize the MobileNet V1 0.25 Float Model | 26 | | 5.2 | Use the Renesas RUHMI Framework to Compile the Model for Ethos-U and CPU Deployment | 26 | | 6. | References | 27 | | 7. | Website and Support | 28 | | Rev | ision History | 29 | | | | | # 1. RA8P1 MCUs with Ethos-U NPU This section briefly introduces the RA8P1 MCU features and how these features contribute to improved inference speed and enhanced user visual experience. Other RA8 MCUs may have a selection of these features. Additionally, brief information regarding how the e² studio IDE and FSP support these features is provided. In this example application, the e² studio IDE and the LLVM Embedded Toolchain for Arm are used. The tools reference information, and screenshots are presented based on the e² studio IDE and the LLVM Embedded Toolchain for Arm. ### 1.1 Dual Core The RA8P1 is based on the Arm® Cortex-M85 Processor and Arm® Cortex®-M33 Processor. The following table captures some of the core features available for Al applications. Please refer to the Hardware User's Manual for any additional information. **Table 1. RA8P1 Dual Core Features** | Cortex-M85 Features | Cortex-M33 Features | Comments | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ARMv8.1-M architecture profile | ARMv8-M architecture profile | Refer to R01AN7881 for developing a dual-core application. | | running up to 1 GHz | Running up to 250 MHz | | | Floating Point Unit (FPU) compliant with the ANSI/IEEE Std 754-2008 Scalar half, single, and double-precision floating-point operation. Interrupt notification when an FPU exception occurs. | Floating Point Unit (FPU) compliant with the ANSI/IEEE Std 754-2008 Single-precision floating-point operation. Interrupt notification when an FPU exception occurs. | Improves AI application performance when using a float model. Needs more model storage spaces and runs slower than a quantized model. See <b>Note 1*</b> for how to enable the FPU. | | M-profile Vector Extension (MVE) Integer, half-precision, and single-precision floating-point MVE (MVE-F) | Armv8-DSP Extension | Refer to R11AN0756 to<br>understand how to use the<br>Helium technology and<br>CMSIS with quantized AI<br>models. | | Cache – Instruction cache: 16 KB with ECC – Data cache: 16 KB with ECC | Cache – Code-bus Cache (C-Cache): 16 KB with ECC – System-bus Cache (S-Cache): 16 KB with ECC | Refer to the FSP UM section titled "Cortex-M85 Caches" to understand the general guidelines. | | | | Refer to R11AN0538 to understand the Cortex-M33 usage of the C-Cache and S-Cache | | Tightly Coupled Memory (TCM) – ITCM: 128 KB (16 blocks × 8 KB) with ECC | Tightly Coupled Memory (TCM) – CTCM: 64 KB with ECC – STCM: 64 KB with ECC | See Note 2* | | – DTCM: 128 KB (16 blocks × 8 KB) with ECC | | | | Low power modes | Low power modes | Refer to the Hardware User's | | - Sleep mode | – Sleep mode | Manual on the enter and exit of the CPU low power mode. | | – Deep Sleep mode | - Deep Sleep mode | In this application, the deep sleep mode is used for power saving on CM85 when the image classification is not actively running. | | 96 Interrupts | 96 Interrupts | The interrupts are used to progress system states and trigger subsequent data sensing and data processing. | |---------------|---------------|------------------------------------------------------------------------------------------------------------| Note 1\*: For both cores, navigate to the project properties: **Properties -> C/C++ Build->Settings->Tools Settings->CPU->** and set **Float ABI** to **FP Instruction (hard)**. Note 2\*: The RA8P1 Cortex-M85 integrates 256 KB of TCM RAM with 128 KB of Instruction TCM with ECC and 128 KB of Data TCM with ECC. TCM RAM, being part of the CPU subsystem, provides a consistent response time with optimized access. The TCM memory areas are not cached. By default, the FSP BSP has both ICTM and DTCM enabled with regions defined in the linker script. Application code can allocate selected code and data to these regions. When designing an AI application, the ITCM can be used to store real-time interrupt routines or interrupt callback routines. For models or sensor data that fit the DTCM, this can be used to improve access speed and determinism. As the camera image buffers are larger than the DTCM, the DTCM is not used in this example. ### 1.1.1 Inter-Processor Communication (IPC) Inter-processor communication (IPC) supports hardware sharing and communication between two processors. There are three IPC mechanisms between the CM85 and CM33 cores. - IPC can generate Maskable and Non-maskable interrupt events to support communication between the processors. In this application project, the Non-maskable Interrupt issued by CM33 is used to wake the CM85 core from Deep Sleep mode. - IPC semaphore mechanisms can support applications to achieve mutually exclusive access between processors. - IPC data communication message FIFOs can be used for simple data communication between the two cores. Refer to application project R01AN7881 for more examples of IPC usage in a ducal core system. #### 1.1.2 Shared Memory Shared Memory allocation for the dual-core system needs to be carried out manually. Please refer to the application note R01AN7881 for the use cases and examples of implementation of a Shared Memory region. ### 1.2 Memory Sub-Systems There is an abundance of memory available on the EK-RA8P1 to support the various needs of an AI application. **Table 2. Memory Sub-Systems** | Types | Total Size | Typical Usage in an Al Application | Usage in this<br>Application Project | |--------------------------------|-------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------| | User SRAM | 1664 KB | Input data for the AI model, Tensor Arena,<br>Sensor Data | Tensor Arena, image<br>buffer as input to Al<br>inference | | Code MRAM<br>(Note 1*) | 1 MB | Al model, Static Image, application code | Text Image, application code | | External<br>SDRAM (Note<br>2*) | 64 MB<br>organized<br>as 16M x 32<br>bits | Sensor Data, GLCDC framebuffer, AI model,<br>Tensor Arena | VIN output buffer,<br>Graphics background,<br>and foreground<br>framebuffer | | External OSPI<br>(Note 2*) | 64 MB | Al model, Static Image | not used | Note 1\*: Renesas RA8P1 features 1 MB of Code MRAM with fast read/write access, low power consumption, and high endurance. There is also a 1 MB Prefetch buffer, which accelerates CPU instruction fetches from the code MRAM. Note 2\*: The RA8P1 has external address space, which is divided into 8 CS areas, an SDRAM area (SDCS), and OSPI areas (CS0 and CS1). On the EK-RA8P1, an SDRAM with a 32-bit data bus is available for good performance throughput. Additionally, an OSPI flash of 64MB is provided on board, which can facilitate AI application development. Refer to Application Note R01AN7880 for details on the RA8P1 Memory Topologies. # 1.3 Neural Processing Unit The RA8P1 provides the Arm® EthosTM-U55 NPU. This NPU offers improvement of AI inference performance and contributes significantly to the image classification performance we observed with this implementation. For the Ethos-U55 hardware features, tools, and FSP support for using Ethos-U55, please refer to Application Note R01AN7712. The FSP UM includes a section describing the APIs; please review it to understand the API details. ### 1.4 Human-Machine Interface Features There is a group of Human Machine Interface (HMI) peripherals that support data sensing and rendering of the application results. For details on the specification of these peripherals, please refer to the Hardware User's Manual of the RA8P1. For details on how to use these modules with FSP support, please refer to the FSP User's Manual. This section highlights the key features and how they are used in this image classification application. ### 1.4.1 2D Drawing Engine (DRW) The RA8P1 MCU incorporates a 2D drawing engine (DRW) capable of performing vector drawing and image rasterization, the BitBLT function (fill, copy, stretch, etc.), and supports various types of color formats. FSP supports this hardware feature through the r drw stack. In this application, the DRW is used to stream the camera image, display the AI model information, and print the inference result on the parallel graphics LCD. FSP driver r\_drw is used to access the DRW engine in this application. # 1.4.2 Graphic LCD Controller (GLCDC) The GLCDC on the RA8P1 MCU supports a single-color background and two graphics planes. A variety of pixel formats are supported. The GLCDC peripheral works with several sub-peripherals to form a pixel data processing pipeline. The GLCDC controller can interface with a parallel graphics LCD or a MIPI DSI interface. In this application project, the parallel graphics LCD interface is used. The input for the GLCDC is RGB565, and the output is RGB888. The parallel graphics LCD includes a touch controller. The touch IRQ is used in this application project by the Cortex-M33 to wake up the CM85 from deep sleep mode to resume image classification functionality. # 1.4.3 MIPI CSI and Video Input Module (VIN) Interface The MIPI CSI-2 is a MIPI Camera Serial Interface 2 receiver module. This module supports MIPI CSI-2 V3.0 and MIPI D-PHY V2.5 (80 Mbps to 720 Mbps/lane and up to 2 lanes). The image signal received by the MIPI-CSI2 is transferred to the VIN module inside the MCU. The video input module (hereinafter abbreviated as VIN) is a video capture module that stores YCbCr-422 data and RGB data in external memory through the MIPI CSI-2 interface. The module has one video channel that can control the capture of data into a capture area of up to 4096 × 4096 pixels when scaling is off (2048 × 2048 pixels when scaling is on). It can also provide vertical and horizontal scaling of the data up to three and two times, respectively. This application project uses the MIPI-CSI and the VIN module to stream the images from the camera. Note that the EK-RA8P1 hardware configuration allows usage of either MIPI-DSI or MIPI-CSI, but not both at the same time. ### 1.4.4 Camera Engine Unit (CEU) The CEU peripheral supports interfacing with external cameras by accepting timing and data signals to capture incoming data. A callback is invoked for each V-Sync event, frame of data accepted, or when certain errors occur. The CEU peripheral supports interfacing with external cameras using an 8 or 16-bit data bus with uncompressed image data (e.g., RGB565 or YUV422) or compressed image data (e.g., JPEG) with images of sizes up to 5 megapixels. The hardware interface to the external camera includes vertical sync, horizontal sync, pixel clock, and data line. This module is not used in this application project. Refer to R11AN0756 for an example usage of the CEU with MIPI-DSI for camera image streaming. #### 1.4.5 MIPI DSI The MIPI PHY on the RA8P1 is MIPI D-PHY that supports the MIPI Alliance Specification Version 2.1 for the D-PHY Specification. This D-PHY supports two lanes with a maximum rate of 720 Mbps per lane. The MIPI DSI on the RA8D1 is the MIPI DSI-2 Host model, which supports the MIPI Alliance Specification for Display Serial Interface 2 (DSI-2) Specification. The MIPI DSI interface accesses the MCU bus system through the GLCDC interface, so when MIPI DSI is used, the GLCDC module also needs to be incorporated into the system. When a parallel graphics LCD interface is used, the GLCDC can be used without adding the MIPI DSI stack. This module is not used in this example project. Refer to R11AN0756 for an example usage of the CEU with MIPI-DSI for camera image streaming. The MIPI LCD panel in EK-RA8D1 can be used with the EK-RA8P1. ### 1.5 Communication Interfaces # 1.5.1 Serial Communication Interface (SCI) SCI comprises 6 channels for asynchronous and synchronous serial interfaces that can be configured for many standard serial communication interfaces, for example, UART, Smart Card Interface, and simple SPI, etc. In AI applications, these interfaces can be used for data collection as well as external module configuration and control. In this image classification application, Channel 8 is configured as a UART to communicate with the J-Link OB Virtual COM port for status display on the Windows terminal (Tera Term). ### 1.5.2 I2C Bus Interface (IIC) The I2C bus interface (IIC) comprises two channels. The IIC module conforms to and offers a subset of the NXP I2C (Inter-Integrated Circuit) bus interface functions. This module can be utilized for sensor communication and data collection in an AI application. In this image classification application, channel 1 is for the following two functionalities: - In master mode, communicate with the I2C slave interface on the OV5640 control block. - In master mode, configure the LCD touch controller. # 1.6 Timers ### 1.6.1 General PWM Timer (GPT) The General PWM Timer (GPT) is a 32-bit timer with GPT32 × 14 channels on RA8P1. The clock sources can be independently selected for each channel. Each channel has two input/output pins, which can be used for input capture and output comparison. Generally, this peripheral can be used in an AI application to provide sensor clocks or time tracking. In this image classification application, two channels are used: - Channel 0 is used as a periodic timer to track the various execution times of the system. - Channel 12 is used to generate the input clock for the OV5640 using the output pin P501. # 1.6.2 Lower Power Asynchronous General Purpose Timer (AGT) The Low Power Asynchronous General Purpose Timer (AGT) is a 16-bit timer with 2 channels that can be used for pulse output, external pulse width or period measurement, and counting external events. This timer consists of a reload register and a down counter. In this application project, the AGT channel 1 is used by the Cortex-M33 core as a periodic timer to define the operational period of the Cortex-M85. When the operating period expires, Cortex-M33 sends an IPC message-FIFO to request the Cortex-M85 to enter Deep Sleep Mode. # 2. Deploy an Open-Source Al Model using the Renesas RUHMI Framework Renesas RUHMI Framework is an AI GUI Tool integrating an embedded AI compiler with e² studio. It is powered by EdgeCortix® MERA™ 2.0. This AI tool can compile highly optimized models in minutes to run efficiently on Renesas embedded processors. For more details on the usage of RUHMI, please refer to the RUHMI Framework Quick Start Guide R11QS0065. RUHMI Framework offers the following major functionalities: - Translates and optimizes the AI model to perform inference using Ethos-U or RA MCU CPU. - Supports multiple ML frameworks like Tensor Flow, PyTorch, and ONNX. - Supports quantization of float models. # 3. The Image Classification Al Application This section describes how the application project architects the operation of the various hardware units, data processing, communication among them, the Al inference, and the graphics operations. The following are some of the key design considerations that are implemented in this application: - Decouple the AI inference operation path and display operation path. - Utilize the Dual Core features to optimize the power performance. - Utilize SRAM access performance advantage over SDRAM for key operations in the system - Configure the Graphics system for optimal camera data capture and camera image streaming effect. # 3.1 System Architecture Figure 1. System Architecture The Cortex-M85 performs the following major functions: - Initialize the hardware components and FSP drivers: SDRAM, GLCDC, DRW, MIPI-CSI, VIN, Ethos-U55 NPU, OV5640, IPC, and LPM - 2. Stream the camera image data in 640x480 RGB565 format and display the image on the parallel graphics LCD - 3. Preprocess the camera image to 224x224 RGB888 format and feed it to the AI inference engine for runtime image classification. - 4. Use the Ethos-U or the CPU to perform the runtime inference operation. - 5. Enter Deep Sleep Mode after receiving the IPC Message ('1') from Cortex-M33 - 6. Exit the Deep Sleep Mode after receiving IPC NMI from Cortex-M33 and resume normal camera image streaming and AI inference. The Cortex-M33 performs the following major functions: - 1. Initialize the hardware components: AGT, IPC, LCD touch, and touch IRQ. - 2. Monitor the AGT timer overflow event. - 3. Send an IPC message to trigger the Cortex-M85 to enter Deep Sleep Mode when an AGT timer expires. - 4. When the user touches the LCD, send an IPC NMI to wake up the Cortex-M85 ### 3.2 FSP Driver Usage The following FSP v6.0.0 drivers are used in the software development of the application. Figure 2. FSP Drivers and Third-Party Libraries Used ### 3.3 Dual Core Architecture and Low Power Feature The following timeline graph describes the dual core communication states. Figure 3. Dual Core Communication and Low Power Feature # 3.4 Memory Allocation The following tables detail the memory usage of the system when using FSP v6.0.0. The BSP Stack, Heap, Thread Stack, and Thread Heap are allocated in the e<sup>2</sup> studio Stack view, while other usages are allocated by the compiler based on the application code. The RA8P1 on the EK-RA8P1 features a 1MB code MRAM. For both Ethos-U inference and CPU inference, the AI model and application code are stored in the code MRAM. The application code for CPU inference is larger than that for Ethos-U inference, as more CMSIS-NN kernels are used, which consume more memory than Ethos-U inference. Table 3. Code MRAM Usage | Category | Description | Ethos-U Inference<br>(KB) | CPU Inference (KB) | |---------------------------------------------------------------|----------------|---------------------------|--------------------| | Al Model | Stored in MRAM | 510 | 460 | | Application code (including FSP package and user application) | Stored in MRAM | 220 | 274 | The following table outlines major SRAM usage. For models with a large Tensor Arena, it may be allocated in SDRAM. However, inference performance is typically lower than when the Tensor Arena resides in SRAM. If the application is updated with additional functionality, the stack and heap usage need to be adjusted. Table 4.1. SRAM Memory Usage | Category | Description | | Ethos-U Inference<br>(KB) | CPU<br>Inference<br>(KB) | |------------------|-------------------------------------------------------------|---------------------|--------------------------------------|--------------------------| | Stack and | BSP Main Stack | | 4 | 4 | | Неар | BSP Heap | | 12 | 12 | | | Display Thread Stack | | 8 | 5 | | | Camera Thread Stack Al Inference Thread Stack Thread Heap | | 6 | 7 | | | | | 8 | 18 | | | | | 16 | 14 | | Al-specific | tensor Arena | | 402 | 607 | | usage | Model input image | model_buffer_int8[] | 150 | 150 | | | Copy of model input model_input[] image | | Allocated from the tensor Arena area | 150 | | Application Code | | 11 | 11 | | The GLCDC fb\_foreground and the VIN output buffers are stored in SDRAM. The VIN buffers are used as the first layer of the LCD display. Table 4.2. SRAM Memory Usage | Category | Description | Ethos-U Inference/CPU Inference | | |----------|--------------------------|---------------------------------|---------| | SDRAM | Camera Output/VIN Output | vin_image_buffer_1, | 1800 KB | | | | vin_image_buffer_2, | | | | | vin_image_buffer_3 | | | | GLCDC framebuffer | fb_foreground | 350 KB | # 3.5 Hardware Configurations ### 3.5.1 MIPI-CSI and Camera Connections Table 5.SEQ Table \\* ARABIC is the MIPI-CSI and Camera Pin connection used in the Application Project. This connection is established by the ribbon cable. Table 5. MIPI-CSI and Camera Module Pin Configurations | MCU pin number | Signal Name | Comment | | |-------------------------|-------------------------|--------------------------------------------------------------------------|--| | P108 | MIPI_IF_EN | Initial State High, Transition to Low to enable MIPI-CSI Interface | | | MIPI_CLN,<br>MIPI_CLP | MIPI_CLN,<br>MIPI_CLP | Differential MIPI Clock Signal Pair | | | MIPI_DL0N,<br>MIPI_DL0P | MIPI_DL0N,<br>MIPI_DL0P | Differential MIPI Data Lane 0 | | | MIPI_DL1N,<br>MIPI_DL1P | MIPI_DL1N,<br>MIPI_DL1P | Differential MIPI Data Lane 1 | | | P709 | CAM_RST | Camera Reset: Initial Low, Transition to High to enable Camera | | | P501 | CAM_XCLK | Output from GPT Channel 12 for Camera Input Clock | | | P511 | SDA1 | IIC Channel 1 Data Line for Camera and Parallel LCD Touch Configuration | | | P512 | SDA1 | IIC Channel 1 Clock Line for Camera and Parallel LCD Touch Configuration | | # 3.5.2 Parallel Graphics LCD Connections Table 6. is the parallel graphics LCD control pin connection used in this application project. The clock, vertical and horizontal sync lines, and the data lines are not listed. Please refer to the stack configuration to understand all the data lines. **Table 6. Parallel Graphics LCD Pin Description** | MCU pin number | Signal Name | Comment | |----------------|-------------|---------------------------------------------------------------------------------------------------| | P111 | Touch_INT | LCD panel touch IRQ (IRQ19). Note that this line is only used in the Dual Core Cortex-M33 project | | P606 | DISP_RESET | Initialized to Low -> Transition to High to release the LCD | | P514 | DISP_BLEN | Initialized to Low -> Transition to High to enable the LCD Backlight | | P108 | MIPI_IF_EN | Initialized to Low -> Transition to Low to enable MIPI Interface | ### 3.5.3 SDRAM Connections To use the SDRAM for camera image buffer and LCD framebuffer, the SDRAM can be enabled using the BSP stack configuration. After that is done, the SDRAM address and signal lines will be automatically enabled. There is no additional control or update to the PIN configuration required. Figure 4. Enable SDRAM Usage from BSP Stack The VIN output buffers are allocated to the .sdram\_noinit section. Figure 5. Allocate the VIN Output to SDRAM The LCD framebuffers are also allocated to the SDRAM region. Note that although the fb\_background framebuffer is used in the initialization stage based on the current GLCDC driver requirement, the VIN output buffers are directly displayed in layer 1 afterwards to reduce access frequencies to the SDRAM area. Figure 6. Allocate the LCD Framebuffers to the SDRAM Region ### 3.5.4 J-Link Virtual Console Table 7SEQ Table \\* ARABIC is the J-Link Virtual Console pin connection used in the Application Project. Table 7. J-Link Virtual Console Pin Description | MCU pin number | Signal Name | Comment | |----------------|-------------|---------------| | PD03 | RXD8 | Reception pin | | PD02 | TXD8 | Transmit pin | ### 3.6 The Image Classification Model The image classification model used in this application project is a quantized MobileNet V1 0.25 model. Refer to the Appendix section to understand how to access the float model and quantize the model for the RUHMI Framework. The dataset used for training this model is the imagenet dataset. Refer to the following page to understand this dataset. Refer to the following page to learn about this dataset. ### https://www.image-net.org/download.php Reference the Renesas RUHMI Framework Quick Start Guide and the RUHMI Github landing page to understand how to use the RUHMI framework to compile the generated integer mode. The compilation results are included in the \ai application\image classification\mera folder. # 3.7 OV5640 Camera Module Usage This application project utilizes the OV5640 camera included in the EK-RA8P1 kit to gather camera data via the MIPI-CSI interface. On the EK-RA8P1 board, the image sensor input clock is provided by the GPT timer channel 12 from the MCU. This clock is used by OV5640 to enable image sensing. ### **Color Format and Framerate Configuration** The OV5640 has an active array size of 2592x1944. The supported output formats are YUV (422/420) and YCbCr422, RGB565/555/444, and 8-bit compression data. This application project uses YUV422 output from the camera and converts to RGB565 by the MCU VIN module to achieve reasonable throughput on the SDRAM traffic. The output format of the OV5640 is configured through a set of registers via the I2C interface. For more details on the OV5640 specification and the descriptions of the control registers, please contact the manufacturer. Only the usage related to this example project is described. Renesas is not responsible for any issues generated when referencing the register descriptions provided in this write-up. The maximum frame rate of the OV5640 depends on the resolution of the image data collected. This application project uses the default register setting, which has auto-exposure enabled. This application project uses the default register setting, which does not scale the camera image prior to feeding it to the MCU through the MIPI-CSI interface. ### **Output Size Configuration** The following group of parameters controls the final camera output image size. This size should be no larger than the scaling output size. In this image classification application, the same size is used for both the Ethos-U Inference and the CPU Inference projects. Table 8. Configure the Camera Output (IMAGE\_WIDTH = 640; IMAGE\_HEIGHT = 480) | Register<br>number | Description | Default setting (QXGA) | Application Setting (VGA) | |--------------------|-----------------------------------|------------------------|-----------------------------| | 0x3808 | DVP output horizontal width[11:8] | 0x0A | (uint8_t)(IMAGE_WIDTH>>8)) | | 0x3809 | DVP output horizontal width[7:0] | 0x20 | (uint8_t)IMAGE_WIDTH) | | 0x380a | DVP output vertical height[10:8] | 0x07 | (uint8_t)(IMAGE_HEIGHT>>8)) | | 0x380b | DVP output vertical height[7:0] | 0x00 | (uint8_t)IMAGE_HEIGHT) | Users can reference \src\camera\_layer\camera\_control.c to understand the details of the camera configuration. ### 3.8 MIPI-CSI and VIN Interface The MIPI-CSI and VIN Interface is configured through the FSP stack. Its configuration should match the camera output (Table 8SEQ Table \\* ARABIC) in terms of the image format and size. In this example project, the camera is used to fetch RGB565 images with 640x480 resolution. An interrupt is triggered when a complete camera image frame is captured. The following are the key stack configurations for this example usage. Refer to the section VIN in the FSP User's Manual to understand the other VIN configurations. By default, the VIN stack uses a triple-output buffer configuration. This setting is used in this application project. #### **Data Storage of the Camera Image** With the SRAM primarily allocated for the Al tensorArena, the thread stack and heap usage, the camera image output buffers are allocated in the SDRAM. Figure 7. Video Input Module Configurations # 3.9 Al Inference Pre-Processing and Post-Processing The following diagram captures the Pre-Processing and Post-Processing of the AI Inference. For performance consideration, the processed AI inference image is stored in SRAM. Note that as only the middle 480x480 of the original VGA image is sent to the AI inference engine, the image classification will be effective in the middle 480x480 of the active window. Figure 8. Pre and Post-Processing for Al Inference The following routine is used for image processing. Note that this routine is targeted to process 16bpp images to 24bpp images; it should be updated if other input and output formats are used. Figure 9. Software API to process camera image data for inference # 3.10 Displaying the Camera Image and Inference Results on the Parallel Graphics LCD The camera output saved by the VIN module at 640x480 RGB565 is directly displayed on the LCD without any scaling or cropping. The project includes a text printing service capable of printing English alphabet characters from 'a' to 'z' in both lowercase and uppercase, as well as numeric digits from '0' to '9'. The service is also able to print several special characters, such as %, -. The text image buffers are generated using the open-source GIMP tool and are allocated to array ascii\_table\_flash in the code flash (refer to \src\graphics\bg\_font\_18\_full.c). The display thread accesses the Al model inference result and displays the result on the parallel graphics LCD using this text printing service. The following API prints a string to the parallel graphics LCD using DRW: Figure 10. Print Text to Parallel Graphics LCD There are several asynchronous interrupt service routine callbacks in the system. Some critical system synchronizations are handled in these interrupt routines. - VIN ISR Callback: An interrupt is triggered when a complete camera image frame is captured. The system switches to the next buffer in a triple-buffer system to collect a new image. - GLCDC ISR Callback: An interrupt is triggered when a Vertical Sync display signal arrives. The system signals the display thread to render a new camera image. - MIPI Command Transfer ISR Callback: This interrupt facilitates the MIPI-CSI data collection from the OV5640. There is no significant system handling in this application project in this ISR. Additional error handling and debugging information can be added to this ISR in case the system runs into any issues with the MIPI-CSI communication. # 4. Running the Image Classification Project This section describes how to run and evaluate the image classification application. # 4.1 Setting Up the Hardware and the IDE The EK-RA8P1 package includes all the hardware components needed to run this image classification application. - EK-RA8P1 board - USB Type-C cable. This is used to connect with the Debug USB port on the EK-RA8P1 and the PC's USB port. We recommend using a USB Type-C to Type-C cable for a reliable power supply to the system. - Camera module and ribbon cable - Parallel Graphics LCD Expansion Board - Display mounting hardware (spacers and fixing screws). Prior to running this image classification application, the default jumper and switch settings must be utilized. Refer to the EK-RA8P1 user's manual for the default jumper and switch settings. ### Connect the OV5640 Camera Module with EK-RA8P1 To connect the camera module with the EK-RA8P1 kit, follow the steps: - Connect one end of the ribbon cable included to the bottom of the EK-RA8P1 kit: Camera Expansion Port J35. - 2. Connect the other end of the ribbon cable to the camera module. - 3. It is highly recommended to use the Nylon stub included in the EK-RA8P1 kit to secure the camera from movement. Be careful not to apply excessive force to the ribbon cable, and make sure to protect the camera lens. ### Connect the Parallel Graphics LCD with the EK-RA8P1 The parallel graphics display board features a 1024 x 600 TFT LCD with a capacitive touchscreen connected to the RA MCU using the Parallel Graphics Expansion Port (J1). It is highly recommended to secure the LCD Graphic Expansion board using the Nylon stands and screws if they are available. Reference Figure 11 for the orientation of the LCD. Once the camera and parallel graphics LCD are assembled, connect J10 to the development PC to provide power, debug communication, and J-link console communication with the PC. Figure 11. Assemble the Hardware System ### Set up the IDE Set up the development environment following the section **Software and development tools** on the first page. Note that prior to running the dual-core project, the MCU needs to be initialized. This can be achieved by using the Renesas Device Partition Manager, which is a built-in tool of the e<sup>2</sup> studio IDE. Launch e<sup>2</sup> studio, select Run -> Renesas Debug Tools -> Renesas Device Partition Manager. Use the following settings to initialize the MCU. Ensure the operation is successful. In case the dual core projects are already imported, or you have other dual core projects in the workspace, the RDPM should be launched by highlighting a Cortex-M85 or a Cortex-M33 project rather than the dual core solution project; otherwise, the RDPM might not launch. Figure 12. Initialize the MCU # 4.2 Compile and Run the Dual-Core Ethos-U Inference Application Projects Follow the "Importing an Existing Project into e² studio" section in the FSP User's Manual to import the image classification Dual Core projects image\_classification\_dualcore.zip into a new workspace. Note: The workspace needs to be established under the \image\_classification\_dualcore folder for a smooth compilation of the projects. There should be three projects imported into the workspace. Figure 13. Image Classification Dual Core Embedded Code The following are some additional details on the application code. Figure 14. Image Classification Application Code for Cortex-M85 Figure 15. Image Classification Application Code for Cortex-M33 Notice that there is a stack error message in the Cortex-M33 project. This error message will be resolved in the future FSP version; it can be ignored. This is not a functioning issue for the system setup. Figure 16. IIC Stack After the projects are imported, select the **dualcore\_solution** project, right click, and select the Build Project option; both the Cortex-M85 and the Cortex-M33 projects will be built. This can take about 5 minutes for the first time. There are warnings from third-party software. Next, open the **Debug Configurations** page and select to debug from the Group Launch. Figure 17. Debug the Dual Core Project After the debug session is launched, the Cortex-M85 will be released from Reset first and start executing the application code. Click Resume twice to run the Cortex-M85 application. Figure 18. Release the Cortex-M85 from Reset\_Handler Once the Reset\_Handler of the Cortex-M33 project is highlighted by the debug session, click Resume to run the Cortex-M33 application. Figure 19. Release the Cortex-M33 from Reset\_Handler ### 4.2.1 Observe the System Performance using the LCD Output Observe the LCD image classification result display and present an object or picture from one of the options in \image\_classification\labels.c to see the image classification in action. Some of the objects that have been tested are fish, fruits, and musical instruments. Note that every object presented in the middle $480 \times 480$ pixels of the camera output/LCD active screen will be classified. For a classification focused on one particular object, use a clean background and present that particular object to the camera. By default, after 30 seconds, the LCD screen will go black as the CM85 enters Deep Sleep mode. The AGT timer period can be updated to adjust this operational period. Meanwhile, the debug connection of both Cortex-M85 and Cortex-M33 will be terminated. Touching the parallel graphics LCD panel will wake up the Cortex-M85 to resume the image classification. ### 4.3 Compile and Run the Single-Core Ethos-U and CPU Inference on Cortex-M85 ### 4.3.1 Compile and Run the Single-Core Ethos-U Inference Project To ensure smooth operation, initialize the MCU as described in the section 4.2. Import project image\_classification\_ethosu\_mobilenet\_v1.zip to a workspace. Open the configuration.xml file and compile the project. Once the project is compiled, right-click on the project image\_classification\_ethosu\_mobilenet\_v1 and select Debug As -> Renesas GDB Hardware Debugging to launch the debug session. Use the same method to evaluate the performance of the CPU inference. Figure 20. Launch the Ethos-U Inference-based Image Classification ### 4.3.2 Compile and Run the Single-Core CPU Inference Project To ensure smooth operation, initialize the MCU as described in section 4.2. Import project image\_classification\_cpu\_mobilenet\_v1.zip to a workspace. Open the configuration.xml file and compile the project. Once the project is compiled, right click on the project image\_classification\_cpu\_mobilenet\_v1 and select Debug As -> Renesas GDB Hardware Debugging to launch the debug session as shown in **Figure 20**. Use the same method to evaluate the performance of the CPU inference. # 4.4 Observe the System Statistics using the J-Link Virtual Console The J-Llink console using UART8 on PD02 and PD03 is used to display the system information configured with a baud rate of 230400. The J-Link console is accessed through the same USB Debug connection from the PC. It can be used concurrently during a debug session or in a standalone session. Tera Term terminal version 4.106 is used during the project evaluation. Launch Tera Term and select the enumerated COM port (J-Link CDC UART Port). Figure 21. Select the JLink Console Connection Once the COM port is open, navigate to the **Setup** tab and select **Serial port**. Figure 22. Open the "Serial port" interface Update the Speed to 230400 and click New setting to commit the update. Figure 23. Configure the Tera Term The time reported here includes the influence of the software design and the SDRAM being accessed by multiple peripherals. This utility is provided to assist with system debugging. ``` Processing time: Camera image capture vsync period: 18 ms, 55 fps AI inference pre processing time: 1 ms, 1000 fps AI inference time: 2 ms, 500 fps LCD display vsync period: 34 ms, 29 fps ``` Figure 24. Typical Statistical Output for Ethos-U Inference ``` Processing time: Camera image capture vsync period: 18 ms, 55 fps AI inference pre processing time: 2 ms, 500 fps AI inference time: 96 ms, 10 fps LCD display vsync period: 34 ms, 29 fps ``` Figure 25. Typical Statistical Output for CPU Inference # 4.5 Summarize the Ethos-U Inference Performance Uplifting The following table captures the system performance with inferencing performed by the Ethos-U55 and the CPU. For details on memory allocation usage, please refer to section 3.4. This information may change when a different model or a different MCU is used in an image classification. The CPU-based inference benefits from data caching due to frequent access to weights and intermediate tensors. In contrast, Ethos-U accesses memory through tightly managed DMA or AXI interfaces, and its performance is more dependent on external memory bandwidth and not directly affected by the CPU's data cache. In all cases, using the Ethos-U NPU brings in a significant performance uplift compared with the CPU inference. | Application | Core<br>Frequenci<br>es<br>(CPU<br>/Ethos-<br>U55) | MRA<br>M<br>(KB) | SDRAM<br>(KB) | SRAM<br>(KB) | MACs/Infere<br>nce (based<br>on output<br>from RUHMI<br>compilation<br>result) | Inference | e time (ms) | Frames<br>/second<br>(Display<br>) | Frames<br>/second<br>(MIPI CSI) | |------------------------------------------------------------|----------------------------------------------------|------------------------|---------------|---------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------|-------------|------------------------------------|---------------------------------| | RA8P1<br>(M85<br>w/Helium,<br>inference on<br>Ethos-U55) | 1GHz<br>/500MHz | Refer<br>ence<br>Table | Referen<br>ce | Referenc<br>e SEQ<br>Table \*<br>ARABI<br>C | 41947984 | 1-2 (regardless of<br>whether the data cache<br>is enabled) | | 29 | 55 | | RA8P1<br>(M85 only<br>w/Helium,<br>inference<br>using CPU) | 1GHz<br>/500MHz | Refer<br>ence<br>Table | Referen<br>ce | Referenc<br>e SEQ<br>Table \*<br>ARABI<br>C | | data<br>cache<br>enabled<br>data<br>cache<br>disable<br>d | 98<br>1885 | 29 | 55 | ### 4.6 Low Power Feature Summary When the Cortex-M85 is in deep sleep mode, the core is halted. The application code also puts the Ethos-U and the MIPI-CSI into stop mode and disables the GLCDC output. When the Cortex-M33 is in sleep mode, the core is halted while the peripherals remain active. This leads to power saving in a real-world application with only the Cortex-M33 monitoring user actions. The EK-RA8P1 board provides precision 5 m $\Omega$ resistors (Yageo, part number PS0612FKE070R005L) for current measurement of the main 3.3 V MCU power and the 3.3 V USB MCU power. Measure the voltage drop across these resistors and use Ohm's Law to calculate the current. Note that these power consumptions are based on this application's project hardware configuration and software implementation with data cache enabled. Other applications may exhibit different power consumption characteristics. **Table 10. Power Consumption in Different States Measured at Office Room Temperature** | | Voltage across R3 Accessible via TP1 and TP3 (matching current value) | |-----------------------------------------------------------|-----------------------------------------------------------------------| | Cortex-M85 in deep sleep mode<br>Cortex-M33 in sleep mode | 290 Micro Volt (58 mA) | | Normal mode | 380 Micro Volt (76 mA) | # 5. Appendix: Compile the MobileNet V1 0.25 Model for Embedded Al Inference ### 5.1 Quantize the MobileNet V1 0.25 Float Model Within this application project, there is a Google Colab notebook file included: Quantize\_MobileNet\_v1\_0\_25\_Model.ipynb. It can be executed in a Colab environment to generate a quantized Mobilenet\_V1\_0.25 int8 model. The following steps to run this Colab Notebook: - 1. Ensure the PC is connected to the Internet. - 2. Open the Colab page: https://colab.research.google.com/ - Choose File -> Open notebook -> Upload -> Browse and upload this notebook to the Colab environment. - 4. Once the notebook is opened, click the array to run the notebook. ``` 1 import tensorflow as tf 2 import keras 3 import numpy as np 4 import os 5 from PIL import Image ``` Figure 26. Run the Colab notebook Code 5. There will be a green tick mark on the left of the array once the execution is successfully executed. ``` 1 import tensorflow as tf 2 import keras 3 import numpy as np 4 import os 5 from PIL import Image ``` Figure 27. Successful Execution 6. Click the folder icon on the left, the generated mobilenet v1.tflite will appear as shown below. Figure 28. Successful Execution # 5.2 Use the Renesas RUHMI Framework to Compile the Model for Ethos-U and CPU Deployment Refer to <a href="https://github.com/renesas/ruhmi-framework-mcu/tree/main">https://github.com/renesas/ruhmi-framework-mcu/tree/main</a> for instructions on how to set up RUHMI and compile the generated mobilenet\_v1.tflite mode for Ethos-U and CPU Inference. The compilation result for Ethos-U NPU Inference is located under this folder using the Dual Core project as reference: \cm85\_image\_classification\_ethosu\src\ai\_application\image\_classification\mera\. The compilation result for CPU Inference is located under this folder:\image\_classification\_cpu\_mobilenet\_v1\src\ai\_application\image\_classification\mera. ### 6. References Renesas RA FSP User's Manual Renesas RA Family RA8P1 User's Manual: Hardware (R01UH1064) Renesas RUHMI Framework Quick Start Guide (R11QS0065) Renesas RUHMI Framework GitHub Using Ethos-U NPU with RA MCUs (R01AN7712) Guidelines for Using the S Cache on the System Bus (R11AN0538) Developing with RA8 Dual Core MCU (R01AN7881) Getting Started with RA8 Memory Architecture, Configurations and Topologies (R01AN7880) Reference System Design for Vision AI on EK-RA8D1 (R11AN0756) # 7. Website and Support Visit the following URLs to learn about the RA family of microcontrollers, download tools and documentation, and get support. EK-RA8P1 Resources RA8P1 Resources RA Product Information Flexible Software Package (FSP) RA Product Support Forum Renesas Support Flexible Software Package (FSP) RA Product Support Forum Renesas Support Frenesas.com/ra/forum renesas.com/support # **Revision History** | | | Description | | |------|-----------|-------------|-----------------| | Rev. | Date | Page | Summary | | 1.00 | Jul.15.25 | _ | Initial release | # General Precautions in the Handling of Microprocessing Unit and Microcontroller Unit Products The following usage notes are applicable to all Microprocessing unit and Microcontroller unit products from Renesas. For detailed usage notes on the products covered by this document, refer to the relevant sections of the document as well as any technical updates that have been issued for the products. 1. Precaution against Electrostatic Discharge (ESD) A strong electrical field, when exposed to a CMOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop the generation of static electricity as much as possible, and quickly dissipate it when it occurs. Environmental control must be adequate. When it is dry, a humidifier should be used. This is recommended to avoid using insulators that can easily build up static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work benches and floors must be grounded. The operator must also be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions must be taken for printed circuit boards with mounted semiconductor devices. 2. Processing at power-on The state of the product is undefined at the time when power is supplied. The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the time when power is supplied. In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the time when power is supplied until the reset process is completed. In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the time when power is supplied until the power reaches the level at which resetting is specified. 3. Input of signal during power-off state Do not input signals or an I/O pull-up power supply while the device is powered off. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements. Follow the guideline for input signal during power-off state as described in your product documentation. 4. Handling of unused pins Handle unused pins in accordance with the directions given under handling of unused pins in the manual. The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of the LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. 5. Clock signals After applying a reset, only release the reset line after the operating clock signal becomes stable. When switching the clock signal during program execution, wait until the target clock signal is stabilized. When the clock signal is generated with an external resonator or from an external oscillator during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Additionally, when switching to a clock signal produced with an external resonator or by an external oscillator while program execution is in progress, wait until the target clock signal is stable. 6. Voltage application waveform at input pin Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between $V_{IL}$ (Max.) and $V_{IH}$ (Min.) due to noise, for example, the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between $V_{IL}$ (Max.) and $V_{IH}$ (Min.). 7. Prohibition of access to reserved addresses Access to reserved addresses is prohibited. The reserved addresses are provided for possible future expansion of functions. Do not access these addresses as the correct operation of the LSI is not quaranteed. 8. Differences between products Before changing from one product to another, for example to a product with a different part number, confirm that the change will not lead to problems. The characteristics of a microprocessing unit or microcontroller unit products in the same group but having a different part number might differ in terms of internal memory capacity, layout pattern, and other factors, which can affect the ranges of electrical characteristics, such as characteristic values, operating margins, immunity to noise, and amount of radiated noise. When changing to a product with a different part number, implement a system-evaluation test for the given product. ### **Notice** - 1. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information. - 2. Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving patents, copyrights, or other intellectual property rights of third parties, by or arising from the use of Renesas Electronics products or technical information described in this document, including but not limited to, the product data, drawings, charts, programs, algorithms, and application examples. - 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others. - 4. You shall be responsible for determining what licenses are required from any third parties, and obtaining such licenses for the lawful import, export, manufacture, sales, utilization, distribution or other disposal of any products incorporating Renesas Electronics products, if required. - 5. You shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering. - 6. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; industrial robots; etc. - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc. Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems; surgical implantations; etc.), or may cause serious property damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document. - 7. No semiconductor product is absolutely secure. Notwithstanding any security measures or features that may be implemented in Renesas Electronics hardware or software products, Renesas Electronics shall have absolutely no liability arising out of any vulnerability or security breach, including but not limited to any unauthorized access to or use of a Renesas Electronics product or a system that uses a Renesas Electronics product. RENESAS ELECTRONICS DOES NOT WARRANT OR GUARANTEE THAT RENESAS ELECTRONICS PRODUCTS, OR ANY SYSTEMS CREATED USING RENESAS ELECTRONICS PRODUCTS WILL BE INVULNERABLE OR FREE FROM CORRUPTION, ATTACK, VIRUSES, INTERFERENCE, HACKING, DATA LOSS OR THEFT, OR OTHER SECURITY INTRUSION ("Vulnerability Issues"). RENESAS ELECTRONICS DISCLAIMS ANY AND ALL RESPONSIBILITY OR LIABILITY ARISING FROM OR RELATED TO ANY VULNERABILITY ISSUES. FURTHERMORE, TO THE EXTENT PERMITTED BY APPLICABLE LAW, RENESAS ELECTRONICS DISCLAIMS ANY AND ALL WARRANTIES, EXPRESS OR IMPLIED, WITH RESPECT TO THIS DOCUMENT AND ANY RELATED OR ACCOMPANYING SOFTWARE OR HARDWARE, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE. - 8. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified ranges. - 9. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury, injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, such as safety design for hardware and software, including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult and impractical, you are responsible for evaluating the safety of the final products or systems manufactured by you. - 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations. - 11. Renesas Electronics products and technologies shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions. - 12. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third party in advance of the contents and conditions set forth in this document. - 13. This document shall not be reprinted, reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics. - 14. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products. - (Note1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries. - (Note2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics. (Rev.5.0-1 October 2020) ### **Corporate Headquarters** TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan www.renesas.com # **Trademarks** Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners. # **Contact information** For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit: <a href="https://www.renesas.com/contact/">www.renesas.com/contact/</a>.