# **EMBEDDED SYSTEMS**

BASED ON CORTEX-M4 AND THE RENESAS SYNERGY PLATFORM

#### 2020

PROF. DOUGLAS RENAUX, PHD PROF. ROBSON LINHARES, DR. UTFPR / ESYSTECH

RENESAS ELECTRONICS CORPORATION



# 12 WEEK COURSE OUTLINE (1/2)

- 1) Introduction
  - What are embedded systems
  - Characteristics
  - Sample Market Segments
- The IoT Era
- 2) Computer Architecture
  - RISC vs CISC
- 3) ARM Cortex-M Architecture
  - Block Diagram
  - Registers
  - Instruction set
  - Memory access
  - Exception handling

- 4) Memory
  - SRAM
  - DRAM (SDRAM, DDR)
  - ROM/EEPROM/Flash
- 5) Timer and GPIO
  - Timer
  - PWM
  - GPIO
  - Simple drivers (e.g. LED, Relay)
  - Power drivers (motors)
- 6) Interrupt Controller

# 12 WEEK COURSE OUTLINE (2/2)

- 7) Analog Interfacing
  - ADC / DAC
- 8) Serial Communication
  - UART
  - SPI
  - I2C
- 9) CAN
  - Physical interface
  - Stack
- 10) USB
  - Physical interface
  - Stack
- 11) Ethernet
  - Physical interface
  - Stack

- 12) Software Development
  - Software Process
  - UML Class Diagram
  - UML State Machine Diagram
- 13) Concurrent Programming
  - Tasks / Context Switching, Scheduling
  - Semaphores, Signals / Messages
  - Common problems to avoid: deadlock, priority inversion
- 14) RTOS
  - Thread Management
  - Inter-thread communication and synchronization
  - Timing Services
  - Memory Management



#### LIST OF LABS – BASED ON SK-S7G2

- Lab1 Synergy Installation try demo program on the S7G2 board. Requirements: none.
- Lab2 Sample C program means to access hardware peripherals; memory organization of a C program. Requirements: Section 5.
- Lab3 Assembly Programming ATPCS access from C a function written in assembly. Requirements: Section 5.
- Lab4 Peripheral Sample device driver. Requirements: Section 6.
- Lab5 Serial Communication. Requirements: Section 8.
- Lab6 Display and Touch. Requirements: Section 8.
- Lab7 RTOS. Requirements: Section 14.
- Lab8 USB Device. Requirements: Section 14.
- Lab9 IoT. Requirements: Section 14.





- This course material was developed to contribute to the several forms of training in the area of Embedded Systems, but particularly with undergraduate courses such as Electrical Engineering, Computer Engineering and Computer Science.
- Contents can be freely copied and distributed to students both for commercial and non-commercial purposes, as long as:
  - Credit to original work mentioning authors and Renesas as the distributor of this work.
  - The contents can be freely modified to suit the needs of specific courses, all figures made by the authors may be freely used without modification as long as credited; likewise, all figures authored by Renesas may be freely used without modification as long as credited. All figures from other sources, if used in derived work or in other works must request authorization from the original author/copyright holder.



- The authors: Douglas Renaux and Robson Linhares are faculty at UTFPR in the subjects of Embedded Real-Time Systems and Computer Architecture and Organization.
   UTFPR is the Brazilian Federal University of Technology.
- eSysTech Embedded Systems Technologies is a company providing engineering and training services in the area of Embedded Systems. It is a spin-off of the Laboratory of Innovation and Technology in Embedded Systems of UTFPR.
- Renesas is a major player in the semiconductor market. They have been providing significant support for educational material such as this one. Renesas has worldwide non-exclusive distribution rights for this material.

### **OVERVIEW AND PREREQUISITES**

- This Embedded Systems course is organized into theory and practice parts. There are 12 theory sections and 9 labs. The labs solutions can be made available to instructors. All labs are conceived to be developed on the Renesas SK-S7G2 board, based on an ARM Cortex-M4F MCU.
- The course assumes that the students have previous knowledge on:
  - C programming for embedded systems
  - Microcontrollers and assembly programming (on an architecture other than ARM)
  - Digital Systems
  - Digital communications and networks



# **1 – INTRODUCTION**

- 1. What are Embedded Systems
- 2. Characteristics
- 3. Market Segments
- 4. The IoT Era



#### WHAT ARE EMBEDDED SYSTEMS?

An Embedded System (a.k.a. Embedded Computing System) is a computing system that is built-into (i.e. embedded) a larger device, such as an equipment, a system, or a vehicle.

Embedded Systems (ES) are usually application-specific and have real-time constraints; thus, many ES are also real-time systems. Often, ES are used in control loops: reading sensors, processing data, and generating outputs that control the device they are embedded into. Finite State Machines are commonly used to model the behavior of ES.

# **CHARACTERISTICS OF EMBEDDED SYSTEMS (1/4)**

Typical characteristics of an Embedded System are:

1. Microcontroller based system consisting of a processor,

non-volatile memory (Flash), volatile memory (RAM), and a large number of inputs and output interfaces as well as communication channels.

- 2. Cost effective implementations as many device architectures are cost-driven.
- 3. Energy efficient solutions as many devices are battery powered. Current trend is to develop battery-less devices that harvest energy from the environment.

### **CHARACTERISTICS OF EMBEDDED SYSTEMS (2/4)**

- 4. Heterogeneous. While desktop computers are based on standard platforms (Windows PC, Apple IOS, ...) there is a large variety of hardware and software for embedded systems.
- 5. Variety of restrictions to the design solutions, such as:
  - a) Physical: Size, Weight, Temperature Range, Vibration, Dust, Spills, Water;
  - b) Computational resources: processing speed, non-volatile memory, RAM, available I/O;
  - c) Response time.
- 6. Interconnected. Embedded devices and systems are ever more interconnected to each other. Trend is to increase the interconnection rate (IoT).

# **CHARACTERISTICS OF EMBEDDED SYSTEMS (3/4)**

#### 7. Reliability

The ability of a system or component to function under stated conditions for a specified period of time.

#### 8. Availability

The ability of a system or component to function at a specific moment of interval of time.

#### 9. Maintainability

Measures how easily and how fast a system can be restored to operational status after a failure.

#### **10.** Testability

The degree to which a system or component facilitates the establishment of test criteria and the performance of tests to determine whether those criteria have been met.



# **CHARACTERISTICS OF EMBEDDED SYSTEMS (4/4)**

#### **11.** Scalability

The ability of a system to handle increased workload by repeatedly and cost-effectively adding components to extend the system's capacity.

#### 12. Safety

Concerns the requirement: not to harm people, the environment or other assets.

#### **13.** Security

The ability of a system to protect information and system resources with respect to integrity and confidentiality.



### **CHARACTERISTICS OF EMBEDDED SYSTEMS**

Relationship among 22 of the most common ilities:



BIG IDEAS FOR EVERY SPACE **RENESAS** 

to read about this graph: Book Chapter about the Ilities: Chapter 4 from "Engineering Systems: Meeting Human Needs in a <u>Complex Technological World</u>" by de Weck O., Roos D. and Magee C, MIT Press, January 2012 (http://strategic.mit.edu)

### SAMPLE MARKET SEGMENTS

- Consumer Electronics
- Telecommunications
- Home Automation
- Industrial Automation
- Transportation
  - Avionics
  - Navigation
  - Electric Vehicles
- Defense
- Medical Equipment
- ??? (many new areas to come)



Smart House

**Connected Care** 



Smart Factory



**Cool Gadget** 





Robots

source: Renesas DevCon2015



\_\_\_\_\_

# **CONSUMER ELECTRONICS**

- Phones
- Videogame consoles
- Printers
- Digital cameras
- Audio/Video:
  - Television
  - Music Players
  - Home Entertainment Systems
  - BRD players





source: pixabay.com (CC)



### **HOUSEHOLD APPLIANCES**

- Washing Machines
- Dishwasher
- Air Conditioners
- Microwave Oven





source: pixabay.com (CC)

#### **TELECOMMUNICATIONS**

- Routers
- Satellite Phones
- Switches



source: wikimedia.org (CC)



source: pixabay.com (CC)



#### HOME AUTOMATION



source: pixabay.com (CC)

#### **TRANSPORTATION – AVIONICS**

Glass cockpit of the

Airbus A350 XWB





source: flickr (CC)



### **TRANSPORTATION – NAVIGATION**

- Automotive GPS
- Electronic Compass



### **TRANSPORTATION – AUTOMOTIVE**

#### Automotive ECUs Controllers by 2020

- Between 25 and 100 individual ECUs
- With distributed sensors and motor controllers.



© 2020 Renesas Electronics Corporation. All rights reserved.

#### **TRANSPORTATION – AUTOMOTIVE**





source: Renesas



# **MEDICAL EQUIPMENT**

- CT Scanners
- ECG (Electrocardiogram)
- Blood Glucose Monitor
- Blood Pressure Monitor
- Body Composition Analyzer

#### HEALTHCARE SOLUTION USING RENESAS SYNERGY™

Accelerate Medical Device Design with IEC62304 Class C Pre-Certified Renesas Synergy™ Platform Safety Solution

# Certified 100 18

source: Renesas



THE IOT ERA



source: Renesas



Five-year gap from state of the art to MCU technology



#### Technology node = minimum transistor gate length

Source: ITRS, Renesas Electronics - based on product announcement

source: Renesas



© 2020 Renesas Electronics Corporation. All rights reserved.

### **EMBEDDED SYSTEMS ARCHITECTURE – GENERIC MODEL**

- One of the important characteristics of Embedded Systems (ES) is its diversity. Hence, a truly generic model for an ES does not exist.
- The model presented here attempts to represent a large set of the existing ES. Hence, it is adequate to understand Embedded Systems concepts.

suggested reading: (see IEEEXplore.ieee.org)

D. Renaux, F. Pottker, "<u>Applicability of the CMSIS-RTOS Standard to the Internet of Things</u>", 10th Workshop on Software Technologies for Future Embedded and Ubiquitous Systems - SEUS/ISORC 2014, June 2014.





#### **EMBEDDED SYSTEMS ARCHITECTURE GENERIC MODEL**



source: Authors



# **1. HARDWIRED HW**

- This level is composed of hardware devices (MCU, Memory, I/O, connectors) whose connection is determined by the copper traces on a PCB, hence, not changeable after fabrication.
- Currently, a significant portion of the HW functionality of an ES is integrated into a SoC (System on Chip).
   External HW consists of the remaining HW not in the SoC and comprises, among others, sensors, actuators, Human-Machine Interface devices, Storage devices, and a large variety of communication interfaces.



Skywire Renesas Synergy PMOD Kit

# 2. SOFT WIRED HW

- In contrast to Level 1, the soft wired HW level consists of components whose connection is programmable, hence, can be modified at any time.
- Currently, the most common programmable devices are FPGAs, however, a variety of programmable logic devices (PLD) are available: FPGA, CPLD, GAL, PAL, PLA, and even ROM.
- The two hardware layers (1 and 2) compose the physical part of an embedded system. The remaining layers (3 to 9) are software layers.





### **SOFTWARE LAYERS**

The upper layers (3 to 9) are software layers.

Embedded Systems Software have two distinct characteristics:

- 1. Typically the development environment (compiler toolchain) generates a single binary file that integrates all software components: device drivers, libraries (RTOS, Services, ...) and the Application. Hence, avoiding the process of reading an executable file and loading it on memory.
- 2. While on desktops applications are changed and upgraded quite frequently, in embedded systems, typically a single multitasking application is executed along the life of the device. Upgrades may occur but are much less frequent.



### 3. HARDWARE ABSTRACTION LAYER

- The HAL is comprised of a set of functions that directly access the hardware devices. These functions are also called device drivers.
- A well-designed HAL provides to the upper levels a standardized interface, providing an easy interchange of devices. For instance, if all communication devices have the same API then replacing a comm. interface (such as SPI) for another (such as I2C) is straightforward. The Renesas SSP (Synergy Software Package) is an example of such.
- Developing a device driver for the HAL requires expertise in both hardware and software. Such a development is a complex and time-consuming task typically performed in C and sometimes mixing with assembly language.

# **4. ADAPTATION LAYER**

• An Adaptation Layer (or Wrapper) is a means of providing a common interface for different device drivers.

- If a HAL is not carefully designed, or if device drivers from different vendors are integrated in the same solution, then the software interface to the upper level may not be regular, meaning that different devices have access functions with different signatures. Such a scenario poses severe difficulties for portability and changes.
- The adaptation layer is a simple translation layer aiming at converting the non-standard interface to a standardized one.
   Such a translation can often be done at compile time, hence, not imposing any runtime penalty.



- Embedded Operating Systems have significant differences to O.S. used in desktop computers, including a very small memory footprint and a reduced amount of functionality. Most embedded O.S. have to provide support for real-time systems, hence, they are termed RTOS (Real-Time Operating System).
- The implementation of a well designed RTOS has at least two layers, so that different software modules implement the architectural dependent code and the architectural independent code. This approach improves modularity and improves the portability to other architectures.

# 7. RTOS ADAPTATION LAYER

This is a wrapper that translates the API of a given RTOS to a standard API, such as CMSIS-RTOS. Once a standard API is provided to the upper levels, all of the software in the Services and Application layers can be reused in different platforms without rewriting the calls to the RTOS.



- To cope with the large amount of functionality implement by software in current Embedded Systems, code reuse is almost mandatory. Thus, off-the-shelf software components are integrated to form the final solution. Typically, these components come in the form of libraries that are linked at compile time.
- A large variety of software components is available providing functionality for: TCP/IP stacks, USB stacks, communication protocols, georeferencing, navigation, security, storage, among many others.



## 9. APPLICATION LAYER

- The top layer of the model is the Application Layer. This is the software layer that implements the specific functionality of each embedded system.
- In this layer, several concurrent tasks cooperate to provide the required functionality. Concurrent programming is the most common approach to cope with the software complexity of current Embedded Systems.
- The RTOS provides the management of the concurrency, among many other services.

## 2 – COMPUTER ARCHITECTURE – RISC VS CISC

- Computer Generations
- The RISC Paradigm



## **DEFINING "COMPUTER"**

Computer =

a device, or person, who performs a computation, i.e. a sequence of calculations according to an algorithm.

Hence, we consider Generation 0 of computers the generation that precedes the electronic device currently known as computer.

## **COMPUTER GENERATIONS**

| Generation | Description                                                                                             |
|------------|---------------------------------------------------------------------------------------------------------|
| 0          | Mechanical and Electromechanical Devices                                                                |
| 1          | 40's – Vacuum tubes<br>ENIAC, Zuse                                                                      |
| 2          | 50's – Transistors<br>Manchester University, IBM 350                                                    |
| 3          | 60's – SSI Integrated Circuits (logic gates)<br>Apollo Guidance Computer<br>IBM System/360, Digital VAX |
| 4          | 70's – Microprocessor                                                                                   |
| 5          | 2010's? – quantic / organic / optical???<br>Al                                                          |

## **RESEARCH PRECEDING THE RISC PARADIGM SHIFT**

- Careful examination of the execution of actual programs concluded that:
  - Often, complex instructions were not used and the equivalent effect was obtained by a sequence of simpler instructions.
  - The inclusion of a single complex instruction in the instruction set could impact overall performance by imposing a lower clock rate.
  - Since the instructions did not have a regular execution sequence (i.e. each one had its execution determined by its microcode) the implementation of a pipeline was close to impossible.

## **RESEARCH PRECEDING THE RISC PARADIGM SHIFT**

What is the final goal?

- From the user's perspective, the goal is **performance of the application programs**
- RISC thesis: a processor whose instruction set is made of simple instructions with a regular execution, allowing the implementation

of a pipeline, will have a higher performance than a CISC

(Complex Instruction Set Computer)

John L. Hennessy ] David A. Patterson COMPUTER ARCHITECTURE A Quantitative Approach

1 : 1

RENESAS

M<

**BIG IDEAS FOR EVERY SPAC** 

recommended reading: Computer Architecture: A Quantitative Approach 6th Edition by John L. Hennessy, David A. Patterson

## **RISC ARCHITECTURAL FEATURES**

Features that characterize the RISC paradigm are:

- An instruction set with a reduced number of very simple instructions.
- LD/ST architecture, meaning that only two instructions (and their variants) access memory: LD (load) reads data from memory, and ST (store) saves data to memory.
- All other instructions operate on registers. There is a large number of general-purpose registers, avoiding access to memory.
- All instructions follow the same logical execution sequence. Hence, a pipelined architecture can be implemented, significantly improving performance. Typically 1 instruction is executed every clock cycle.





Requirements for the implementation of a Pipeline in a processor:

- The instruction set must be designed so that all instructions have the same execution steps
- Instructions must be regular with respect to:
  - Size
  - Addressing modes
  - Decoding
  - Operands

### PIPELINING

Example of a Pipeline with 5 stages:

1. Fetch

and 5

- 2. Decode and read operands in registers
- 3. Use ALU to execute instruction or to calculate memory address
- 4. Read or Write to memory
- 5. Write result back to Register file





Execute

source: wikimedia.org (CC)

Write

Memory

Instr. Decode

Instruction

Fetch

Adde

Next PC

## **BENEFITS OF PIPELINING**

For the previous example of a 5 stage pipeline, the

execution over time is presented in this diagram.

Note that although each instruction takes 5 clock cycles to execute, due to pipelining, after filling the pipeline, on every clock another instruction finished its execution.

Effectively, the number of instructions executed per second is the same as the clock rate.



| IF              | ID | ΕX | MEM | WB  |     |     |     |    |
|-----------------|----|----|-----|-----|-----|-----|-----|----|
| ļi              | IF | ID | EX  | MEM | WB  |     |     |    |
| $t \rightarrow$ |    | IF | ID  | ΕX  | MEM | WB  |     |    |
|                 |    |    | IF  | ID  | ΕX  | MEM | WB  |    |
|                 |    |    |     | IF  | ID  | ΕX  | MEM | WB |

source: wikimedia.org (CC)

## **LIMITATIONS OF PIPELINING**

• Data Hazard:

if an instruction requires as input a value produced by the previous instruction, this value may not be available at stage 2 (decode and fetch operands) since the previous instruction only saves its results at stage 5.

Solutions: stall the pipeline (instruction must wait for result of previous)

OR use a technique called bypassing to forward the result of the previous instruction at stage 3 of its executionOR reorder instructions to avoid this dependency

• Control Hazard:

a change of control flow (e.g. a branch instruction) causes the pipeline to be flushed, meaning that following instructions that already were fetched and decoded will be discarded.

#### **Consequence:**

the average number of instructions executed per second is lower than the clock rate.



## **COMPARING RISC X CISC**

| RISC                                                                                                                                                      | CISC                                                                                                   |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|--|
| Instruction set has a reduced number of instructions                                                                                                      | Instruction set has a large number of instructions                                                     |  |  |
| Instructions are very simple                                                                                                                              | Instructions are complex, i.e. have a high semantic content                                            |  |  |
| Large number of general purpose register                                                                                                                  | Small number of registers                                                                              |  |  |
| Instruction codes have fixed size                                                                                                                         | Instructions are coded in a variable number of bytes                                                   |  |  |
| Instruction decoding is very simple and typically performed by a table in ROM                                                                             | Instruction decoding is complex                                                                        |  |  |
| Instruction execution is simple, typically requiring a single clock cycle                                                                                 | Instruction execution is complex and typically uses microprogramming, i.e. interpretation by microcode |  |  |
| Regular execution of the instructions                                                                                                                     | Execution steps varies from instruction to instruction                                                 |  |  |
| Execution time is regular, typically a single clock cycle                                                                                                 | Execution time varies significantly among instructions                                                 |  |  |
| Architecture is prone to the use of a pipeline in the implementations, resulting in N times performance improvement (N is the number of pipeline stages). | Architecture is not prone to the use of Pipeline.                                                      |  |  |

## **COMPARING RISC X CISC**

When the same source program is compiled to a RISC processor and to a CISC processor:

- The number of machine instructions of the compiled program is typically larger on the RISC
- The size of the compiled program (measured in bytes) is typically larger on the RISC
- The performance (inverse of the time to execute the program) is typically better on the RISC

## **COMPARING RISC X CISC**

From a HW perspective, the design of a RISC processor is significantly simpler than that of a CISC:

- Shorter design cycle,
- Lower number of transistors to implement,
- Less area on silicon die.

## **ECONOMICS OF INTEGRATED CIRCUITS MANUFACTURING**

The cost of a chip is determined mainly by:

- Cost of the die (cost of manufacturing a wafer divided by the number of good dies per wafer)
- Testing costs (both for die testing and testing after packaging)
- Packaging costs
- Yield (percentage of functional chips).



## **ECONOMICS OF INTEGRATED CIRCUITS MANUFACTURING**

Curve shows how many transistors can be purchased with one dollar for each manufacturing technology over time.

This graph represents the situation in 2018. At the time, the most costeffective technology was 20 nm.

Over time, as the processes mature, transistors cost lowers. Until a given technology enters obsolescence.





## **ECONOMICS OF INTEGRATED CIRCUITS MANUFACTURING**

#### Key design decision:

If currently the "sweet spot" (best value for money) is a given manufacturing technology and a transistor count of T millions transistors, **what is the best use for this asset?** 

- 1. CISC core + little Cache/Memory/Peripherals
- 2. RISC core + large amount of Cache/Memory/Peripherals

Most silicon vendors select the second alternative



## **RISC VS CISC TODAY**

Currently, there is a trend to mix the best features of both paradigms. The convergence of RISC and CISC has not been named yet, but the characteristics of novel processors are:

- Large instruction set
- Regular instructions, prone to pipelining
- Pipelines from 3 to 20 stages
- No microcode

#### **RISC VS CISC TODAY**

Instruction set of Cortex-M

including Cortex-M23 and

Cortex-M33

ARMv8-M

ARMv8-M Baseline



Cortex-M23

## **3 – ARM CORTEX-M ARCHITECTURE**

- History of ARM
- Cortex-M Features
- Cortex-M Instruction Set Architecture
- Instruction Set
- Memory Access
  - Memory-mapped I/O
- Exception Handling



## 3.1 – ARM HISTORY

- Over time, several ARM architecture versions were released. From the seminal ARMv1 to the ARMv8.3-A, released in 2017. The documentation of these standards is available on the arm.com website.
- For each architectural version there are several implementations





© 2020 Renesas Electronics Corporation. All rights reserved.

BIG IDEAS FOR EVERY SPACE RENESAS

## **ARM PROCESSOR FAMILY**



source: ARM ARM Cortex-M for Beginners - Yiu



## **THE CORTEX-M FAMILY**



source: community.arm.com



## THE CORTEX-M FAMILY

In 2016, the Cortex-M33 and Cortex-M23 were added to the Cortex-M family.



source: community.arm.com



Among the distinguishing features of the Cortex-M architecture are:

- 3-stage pipeline (except for Cortex-M7): Fetch, Decode, Execute,
- Harvard architecture (except for Cortex-M0 and M0+),
- Designed for power efficiency (includes an ultra low-power deep sleep),
- Thumb-2 instruction set, combining ARM performance and Thumb code density,
- Interrupt Controller (NVIC) is defined in the architecture; low latency vectored interrupt servicing,
- Interrupt servicing with tail-chaining and late arrival functionalities,
- Bit-banding to provide faster bit operations in memory and memory mapped I/O,
- MPU = Memory Protection Unit,
- Most instructions can be conditional.



- The ARM7TDMI had two instructions sets:
- ARM with 32-bit instructions, higher performance and lower code density,
- Thumb with 16-bit instructions, lower performance and higher code density.
- Cortex-M has a single instruction set: Thumb-2
- It mixes 16-bit and 32-bit instructions. Its code density is similar to Thumb and its performance is similar to ARM.



**BIG IDEAS FOR EVERY SP** 

RENESAS

source: ARM The ARM Architecture - Joe Bungo

| Comparison                   | Cortex-M0  | Cortex-M3   |  |
|------------------------------|------------|-------------|--|
| DMIPS/MHz                    | 0.9        | 1.25        |  |
| Gate count                   | 12k        | 43k         |  |
| Number interrupts            | 1-32 + NMI | 1-240 + NMI |  |
| Interrupt priorities         | 4          | 256         |  |
| Breakpoints, Watchpoints     | 4/2, 2/1   | 8/4, 2/1    |  |
| MPU, integrated trace option | No         | Yes         |  |
| Hardware Divide              | No         | Yes         |  |



source: ARM ARM Cortex-M Processor Family



# **Cortex-M3 Datapath**



source: ARM The ARM Architecture - Joe Bungo

RENESAS





BIG IDEAS FOR EVERY SPACE

#### Memory Protection Unit (MPU)

- Prevents application task from corrupting OS or other task data
  - Improves system reliability
- Configurable regions
  - Address
  - Size
  - Memory attributes
  - Access permissions
- Optional in all processors (except Cortex-M0)



source: ARM How to Choose Your ARM Cortex-M Processor - Tim Menasveta



Cortex-M4 Pipeline



source: ARM The ARM Architecture - Joe Bungo

Cortex-M4 Pipeline – example for optimal execution



F-Fetch D-Decode E-Execute

source: ARM ARM Cortex-M3 Introduction - ARM University Relations

Cortex-M4 Pipeline – pipeline flush due to indirect branch (no forwarding)



source: ARM ARM Cortex-M3 Introduction - ARM University Relations

Cortex-M4 Pipeline – Harvard architecture allows for concurrent access to code and data memory.



source: ARM ARM Cortex-M3 Introduction - ARM University Relations

## **3.3 – CORTEX-M4 INSTRUCTION SET ARCHITECTURE**

The Instruction Set Architecture (ISA) presents the Programmer's View of the processor, including:

- Data types
- Processor Modes
- Processor Registers
- Instruction Set
- Memory Accessing
- Exception Processing



The Cortex-M4 instruction set can operate on the following data types:

• **bit:** stores a single bit of information (0 or 1).

Bit banding instructions can set or clear bits in specific memory regions.

- **byte:** 8-bit. Each byte in memory is individually addressable.
- half-word: 16-bit. The address of a half-word in memory is the address of its least significant byte.
- word: 32-bit. The address of a word in memory is the address of its least significant byte.
- double-word: 64-bit. Requires a register pair to be stored, such as R1:R0 (concatenation of R1 and R0 with R1 being the most significant word). The address of a double-word in memory is the address of its least significant byte.



The Cortex-M4 processor modes are:

- Privileged Thread mainly for OS execution
- Unprivileged Thread mainly for Application code
- Privileged Handler -

for exception handling code

Remark: there are two stacks: Main and

Process.

The usage of these stacks is related to the

processor mode.



source: ARM ARM Cortex-M for Beginners - Yiu

The Cortex-M4 has two stacks:

- Main stack addressed by MSP (Main Stack Pointer) mainly to be used by the Operating System (OS) and exception handlers.
- Process stack addressed by PSP (Process Stack Pointer) mainly to be used by the Application threads.

Only one stack is active at any given time, as selected by the CONTROL register. Register R13 (SP) maps to the active stack pointer, either MSP or PSP.



#### Table B1-1 Mode, privilege and stack relationship

| Mode    | Privilege    | Stack pointer | Typical usage model                                                                                                                                                                                                     |                                                            |
|---------|--------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| Handler | Privileged   | Main          | Exception handling.                                                                                                                                                                                                     |                                                            |
| Thread  | Privileged   | Main          | Execution of a privileged process or thread using a common stack<br>in a system that only supports privileged access.                                                                                                   |                                                            |
|         |              | Process       | Execution of a privileged process or thread using a stack reserved<br>for that process or thread in a system that only supports privileged<br>access, or that supports a mix of privileged and unprivileged<br>threads. |                                                            |
| Thread  | Unprivileged | Main          | Execution of an unprivileged process or thread using a common stack in a system that supports privileged and unprivileged access.                                                                                       |                                                            |
|         |              | Process       | Execution of an unprivileged process or thread using a stack<br>reserved for that process or thread in a system that supports<br>privileged and unprivileged access.                                                    | source: ARM<br>ARMv7-M<br>Architecture<br>Reference Manual |



Available on the Cortex-M4 with FDI I only

#### 3.3 – CORTEX-M4 ISA – REGISTERS

The register set of the Cortex-M4 consists of:

- General Purpose Registers (R0-R15)
- Floating Point Registers (S0-S31)
- Special Registers (xPSR, PRIMASK, FAULTMASK, BASEPRI, CONTROL)

All registers are 32-bit wide. Not all bits of the Special Registers are implemented.

source: ARM

| General register | s (Floatii                  |
|------------------|-----------------------------|
| R0               | S1                          |
|                  | S3                          |
|                  | S5                          |
| R2               | S7                          |
| R3               | S9                          |
| R4               | <u>S11</u><br>S13           |
|                  | S15                         |
|                  | S17                         |
| R6               | S19                         |
| R7               | S21                         |
| R8               | S23                         |
|                  | S25                         |
| R9               | S27                         |
| R10              | S29                         |
| R11              | S31                         |
| R12              | FPSCR                       |
| R13 (MSP)        | Main Stack Pointer (M       |
| R13 (PSP)        | Process Stack Pointer (     |
| R14              | Link Register (LR)          |
| R15              | Program Counter (PC)        |
| Name             | Functions                   |
| xPSR             | Program Status Regist       |
| PRIMASK          |                             |
| FAULTMASK        | Interrupt Mask<br>Registers |
| BASEPRI          |                             |
| CONTROL          | Control Register            |

| Floatir                                             | ng Point Unit |     |  |  |  |
|-----------------------------------------------------|---------------|-----|--|--|--|
| S1                                                  | SO            | D0  |  |  |  |
| S3                                                  | S2            | D1  |  |  |  |
| S5                                                  | S4            | D2  |  |  |  |
| S7                                                  | S6            | D3  |  |  |  |
| S9                                                  | S8            | D4  |  |  |  |
| S11                                                 | S10           | D5  |  |  |  |
| S13                                                 | S12           | D6  |  |  |  |
| S15                                                 | S14           | D7  |  |  |  |
| S17                                                 | S16           | D8  |  |  |  |
| S19                                                 | S18           | D9  |  |  |  |
| S21                                                 | S20           | D10 |  |  |  |
| S23                                                 | S22           | D11 |  |  |  |
| S25                                                 | S24           | D12 |  |  |  |
| S27                                                 | S26           | D13 |  |  |  |
| S29                                                 | S28           | D14 |  |  |  |
| S31                                                 | S30           | D15 |  |  |  |
| FPSCR Floating Point Status<br>and Control Register |               |     |  |  |  |

| P)<br>P)        | Main Stack Pointer (MSP),<br>Process Stack Pointer (PSP) |                      |
|-----------------|----------------------------------------------------------|----------------------|
|                 | Link Register (LR)                                       |                      |
|                 | Program Counter (PC)                                     |                      |
|                 | Functions                                                |                      |
|                 | Program Status Registers                                 |                      |
| SK<br>ASK<br>RI | Interrupt Mask<br>Registers                              | Special<br>Registers |
| OL              | Control Register                                         |                      |

ARM Cortex-M for Beginners - Yiu

General Purpose Registers:

- 32-bit wide
- Low registers: R0 .. R7
- High registers: R8 .. R15
- Special usage:

R13 or SP is the Stack Pointer - points to the top of the stack

R14 or LR is the Link Register - stores the procedure return address

R15 or PC is the Program Counter - stores the address of the next instruction fetch

| b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 | b15 | b14 | b13 | b12 | b11 | b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |

RENESAS

**BIG IDEAS FOR EVERY SP** 

General Purpose Registers:

- the general-purpose registers are accessible by most instructions;
- b0 is the Least Significant Bit (LSb) and b31 is the Most Significant Bit (MSb);
- a register can hold an unsigned integer with values from 0 to 4,294,967,295
   or a signed integer with values from -2,147,483,648 to 2,147,483,647;
- when using hexadecimal notation, a 32-bit register holds 8 hex digits. E.g. 0x1234 5678;
- Cortex-M architecture uses 32-bit memory addresses, hence, a single general-purpose register can hold a memory address.

| b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 | b15 | b14 | b13 | b12 | b11 | b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |

RENESAS

**BIG IDEAS FOR EVERY SPACE** 

Special Purpose Registers - XPSR

• The three registers APSR, IPSR and EPSR can be accessed individually or combined as XPSR.



### 3.3 – CORTEX-M4 ISA – APSR

#### **APSR = Application Program Status Register**

| 31 | 30 | 29 | 28 | 27 | 26   | 20   | 19       16 | 15 |         |    | 0 |
|----|----|----|----|----|------|------|-------------|----|---------|----|---|
| N  | z  | С  | V  | Q  | Rese | rved | GE[3:0]     |    | Reserve | ed |   |

| Flag | bit   | Description                                                                                                                                      |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Ν    | 31    | Negative. For two's complement results this bit is set to indicate that the result is negative.                                                  |
| Z    | 30    | Zero. This bit is set when the result is zero. After a comparison, this bit is set to indicate that the compared values are equal.               |
| С    | 29    | Carry. Set to indicate that the result of an unsigned addition produced overflow. Also set to indicate that un unsigned subtraction underflowed. |
| V    | 28    | Overflow. Set to indicate overflow in a signed arithmetic operation.                                                                             |
| Q    | 27    | Saturation bit. For DSP extension instructions.                                                                                                  |
| GE   | 19:16 | Greater than or Equal. For SIMD instructions.                                                                                                    |
|      |       |                                                                                                                                                  |

#### 3.3 – CORTEX-M4 ISA – IPSR

#### **IPSR = Interrupt Program Status Register**

| IPSR |  | 0 or Exception Number |
|------|--|-----------------------|
|------|--|-----------------------|

| Field               | bit | Description                                                                                                                                                                                                                                                          |
|---------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Exception<br>Number | 8:0 | This field identifies the exception that is currently active (being serviced). The value 0 indicates that no exception is currently active.<br>If this value is non-zero the processor is in Handler mode.<br>If this value is zero the processor is in Thread mode. |

#### 3.3 – CORTEX-M4 ISA – EPSR

#### **EPSR = Execution Program Status Register**

| EPSR | ICI/IT T | ICI/IT |  |
|------|----------|--------|--|
|------|----------|--------|--|

| Field  | bit            | Description                                                                                                                                                                                                                                       |
|--------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Т      | 24             | Thumb. This bit is set to indicate that the instruction set in use is Thumb.<br>On Cortex-M this bit must be set all the time or an exception occurs.<br>On ARM7TDMI, Cortex-R and Cortex-A this bit is 0 when the ARM instruction set is in use. |
| ICI/IT | 26:25<br>15:10 | ICI - used for a interrupted exception-continuable multi-cycle load or store.<br>IT - provide context information for instructions in an IT block.                                                                                                |

#### 3.3 – CORTEX-M4 ISA – XPSR

Mnemonics used to combine the XPSR component registers:

| Mnemonic Registers accesse |                          |
|----------------------------|--------------------------|
| IAPSR                      | IPSR and APSR            |
| EAPSR                      | EPSR and APSR            |
| XPSR                       | All three xPSR registers |
| IEPSR                      | IPSR and EPSR            |



#### 3.3 – CORTEX-M4 ISA – SPECIAL REGISTERS



| Field       | bit          | Description                                                                                                                               |
|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| PM          | PRIMASK[0]   | Set to mask exceptions with configurable priority (priority 0 and lower). Reset to unmask.                                                |
| FM          | FAULTMASK[0] | Set to mask the HardFault exceptions and the configurable priorities (prio -1 and lower).                                                 |
| BASE<br>PRI | BASEPRI[7:0] | Changes the priority level required for exception preemption. Affects only the currently executing code with lower priority than BASEPRI. |

### 3.3 – CORTEX-M4 ISA – CONTROL REGISTER

CONTROL Register



| Field      | bit | Description                                                                                                                                                   |
|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| nPRIV      | 0   | When the processor is in Thread mode. 0 = privileged mode; 1 = unprivileged mode.                                                                             |
| SPSEL      | 1   | Stack selection. 0 = use MSP (Main Stack); 1 = use PSP (Process Stack).<br>In Handler mode this bit is always 0.                                              |
| FPCA       | 2   | Implemented only when floating point is available.<br>0 = do not save floating point registers on exception;<br>1 = save floating point context on exception. |
| Source: AF |     |                                                                                                                                                               |

Floating Point Registers:

- The Cortex-M4 with optional floating-point extension, implements 32 32-bit floating point registers named S0 to S31.
- These can be combined two by two forming 16 double precision (64-bit) floating point registers named D0 to D15. D0 is formed by S1:S0 (the concatenation of the registers S1 and S0 where S1 is the most significant word, i.e. the leftmost word).

Before presenting the instruction set, lets examine:

- Assembly syntax
- 3-operand instructions
- Conditional instructions
- Instructions that affect the flags



The most common instruction formats are: (format)

| label:  | MNEMONIC   | Destination, Operand1, Operand2 | ;comment |
|---------|------------|---------------------------------|----------|
| label:  | MNEMONIC   | Destination, Operand2           | ;comment |
| Example | S:         |                                 |          |
| fmtl: A | ADD R2, R4 | , R5 ; R2 = R4 + R5             |          |

; R2 = R2 + R4



fmt2: ADD R2, R4

Suggested assembly source file layout:

 $\begin{array}{cccc} \text{col 1} & \text{col 5} & \text{col 13} \\ \downarrow & \downarrow & \downarrow \\ \text{fmt1: ADD} & \text{R2, R4, R5} & ; \text{R2} = \text{R4} + \text{R5} \end{array}$ 

By setting the TABs to 4 spaces, these positions can be easily obtainable.

Only labels should begin on column 1.

Only mnemonics are compulsory. Labels, operands and comments are optional, although they are all very frequent.



For an instruction with two operands, the first operand (Op1) is always a register. The second operand (Op2) may be a register, or a register that had its contents shifted or rotated, or an immediate value coded in the instruction.



Examples of Operand 2

| ADD | R2, R4, R5        | ;Operand 2 is a register (R5)                                                                                        |
|-----|-------------------|----------------------------------------------------------------------------------------------------------------------|
| ADD | R2, R4, R5,LSL #2 | ;Operand 2 is a shifted register<br>;R5 is shifted left by 2 bits<br>;this corresponds to multiplying its value by 4 |
| ADD | R2, R4, #0xFF     | ;Operand 2 is an immediate value<br>;the hexadecimal value 0xFF                                                      |



In the Cortex-M4 instruction set, the programmer explicitly controls if the result of an instruction should affect the flags: N,Z,C,V.

Most instructions have a variant with the letter S appended to the mnemonic. The S variant means: "set the flags".

| ADD R2, R4, R5  | ;the result of this addition does |  |
|-----------------|-----------------------------------|--|
|                 | ;not affect the flags.            |  |
| ADDS R2, R4, R5 | ;the result of this addition      |  |
|                 | ;affects the N,Z,C and V flags.   |  |

Many Cortex-M4 instruction can be **conditional**, meaning that the instruction only executes if the flags are in a given state. Except for branch instructions, an instruction must be in an IT block to be conditional. The condition is specified by two letters appended after the mnemonic (see condition table on next slide).

| ADD    | R2,R4,R5 | ;the result of this addition does              |
|--------|----------|------------------------------------------------|
|        |          | ;not affect the flags.                         |
| ADDS   | R2,R4,R5 | ;the result of this addition                   |
|        |          | ;affects the N,Z,C and V flags.                |
| ITT    | ΕQ       | ;start of an IT block with 2 instructions      |
| ADDEQ  | R2,R4,R5 | ;if Z is set, execute the ADD                  |
| ADDSEQ | R2,R4,R5 | ;if Z is set, execute the ADD and change       |
|        |          | ;flags according to result of this instruction |



Condition codes mnemonics suffixes

| - | Suffix   | Flags              | Meaning                                                  |
|---|----------|--------------------|----------------------------------------------------------|
|   | EQ       | Z = 1              | Equal                                                    |
|   | NE       | Z = 0              | Not equal                                                |
|   | CS or HS | C = 1              | Higher or same, unsigned                                 |
|   | CC or LO | C = 0              | Lower, unsigned                                          |
|   | MI       | N = 1              | Negative                                                 |
|   | PL       | N = 0              | Positive or zero                                         |
|   | VS       | V = 1              | Overflow                                                 |
|   | VC       | V = 0              | No overflow                                              |
|   | HI       | C = 1 and Z = 0    | Higher, unsigned                                         |
|   | LS       | C = 0 or Z = 1     | Lower or same, unsigned                                  |
|   | GE       | N = V              | Greater than or equal, signed                            |
|   | LT       | N != V             | Less than, signed                                        |
|   | GT       | Z = 0 and $N = V$  | Greater than, signed                                     |
|   | LE       | Z = 1 and N != V   | Less than or equal, signed                               |
|   | AL       | Can have any value | Always. This is the default when no suffix is specified. |

BIG IDEAS FOR EVERY SPACE RENESAS

Code examples for conditional instructions.

| cmp   | R12,R10    | ;compare the unsigned values in R12 and R10, change flags |
|-------|------------|-----------------------------------------------------------|
| beq   | opl        | ;branch to op1 if the values of R12 and R10 are equal     |
| ite   | hi         | ;two-instruction IT block with HI condition               |
| addhi | R12,R12,#1 | ;if R12 > R10 then increment R12                          |
| addls | R10,R10,#1 | ;else increment R10                                       |
|       |            |                                                           |

op1:

• • •



An immediate value is a constant whose value is encoded in the instruction. Hence, a limited range of values is allowed.

The notation for immediate values is #value.

The notation for negative values is #-15.

The notation for hexadecimal values is #0xFA0.

Example:

ADD  $R_{2}, R_{4}, \#_{5}$ ;  $R_{2} = R_{4} + 5$ 



- Cortex-M4 instruction codes are either 16-bit or 32-bit.
- 16-bit instructions are called narrow and may have a .N suffix.
- 32-bit instructions are called wide and may have a .W suffix.
- Some mnemonics may be coded either in narrow or wide format, for example:

| 0x37a: | 0x1840        | ADDS.N | RO, RO, R1 | //16-bit code |
|--------|---------------|--------|------------|---------------|
| 0x37c: | 0xeb10 0x0001 | ADDS.W | R0, R0, R1 | //32-bit code |

- 16-bit and 32-bit instruction code can be freely intermixed in a program.
- All instructions must be halfword aligned, i.e. must be stored on an even address.



- Hence, PC will never hold an odd address => bit 0 of PC is always 0.
- When writing a 32-bit value to PC, bit 0 is ignored => can be used for other purpose.
- In other ARM processors, use bit 0 for interworking (i.e. change of instruction set).
- On Cortex-M, bit 0 must be a 1. This value is stored to the T flag in XPSR.
- Instructions that can be used for interworking (i.e. write to T flag):
  - BX
  - BLX
  - pop {PC}
- Instructions that have as destination register the PC, cause a branch
  - MOV PC, LR
  - ADD PC, PC,R1
- There are restrictions on which instructions may write to PC.

#### **Arithmetic instructions**

| Instruction              | Description                                                              | Action                                  |
|--------------------------|--------------------------------------------------------------------------|-----------------------------------------|
| ADD Rd, Rn, Op2          | Add a register to Operand2                                               | Rd = Rn + Op2                           |
| ADC Rd, Rn, Op2          | Add a register to Operand2 and to Carry                                  | Rd = Rn + Op2 + CY                      |
| SUB Rd, Rn, Op2          | Subtract from a register the Operand2                                    | Rd = Rn - Op2                           |
| SBC Rd, Rn, Op2          | Subtract from a register the Operand2 and the Borrow (negation of Carry) | Rd = Rn - Op2 - /CY                     |
| RSB Rd, Rn, Op2          | Subtract from Operand2 a register                                        | Rd = Op2 - Rn                           |
| RSC Rd, Rn, Op2          | Subtract from Operand2 a register and the Borrow                         | Rd = Op2 - Rn - /CY                     |
| MOV Rd, Op2              | Move to Rd from Operand2 (put a copy of Operand2 into Rd)                | Rd = Op2                                |
| MVN Rd, Op2              | Move to Rd /Operand2                                                     | Rd = /Op2                               |
| MOVT Rd, <imm16></imm16> | Move to Rd[31:16] from imm16. Lower bits of Rd are unaffected            | Rd[31:16] = imm16<br>Rd[15:0] unchanged |

BIG IDEAS FOR EVERY SPACE RENESAS

#### **Compare and Test**

| Instruction | Description                                                          |  |
|-------------|----------------------------------------------------------------------|--|
| CMP Rn, Op2 | Compare: Subtract from Rn the Operand2, discard result, change flags |  |
| CMN Rn, Op2 | Compare negative: Add Rn to Operand2, discard result, change flags   |  |
| TST Rn, Op2 | Test: Rn AND Operand2, discard result, change flags                  |  |
| TEQ Rn, Op2 | Test equivalence: Rn EOR Operand2, discard result, change flags      |  |
|             |                                                                      |  |
|             |                                                                      |  |
|             |                                                                      |  |
|             |                                                                      |  |
|             |                                                                      |  |

#### Logical

| Instruction     | Description                                              | Action          |
|-----------------|----------------------------------------------------------|-----------------|
| AND Rd, Rn, Op2 | AND: bitwise logical AND a register to Operand2          | Rd = Rn AND Op2 |
| ORR Rd, Rn, Op2 | OR: bitwise logical OR a register to Operand2            | Rd = Rn OR Op2  |
| EOR Rd, Rn, Op2 | Exclusive OR: bitwise logical XOR a register to Operand2 | Rd = Rn XOR Op2 |
| ORN Rd, Rn, Op2 | OR NOT: bitwise logical OR a register to NOT(Operand2)   | Rd = Rn OR /Op2 |
|                 |                                                          |                 |
|                 |                                                          |                 |
|                 |                                                          |                 |
|                 |                                                          |                 |
|                 |                                                          |                 |

#### **Shift Instructions**

| Instruction          | Description                                            | #imm Sh range |
|----------------------|--------------------------------------------------------|---------------|
| ASR Rd, Rn, Sh       | Arithmetic Shift Right (preserves signal)              | 132           |
| LSL Rd, Rn, Sh       | Logical Shift Left                                     | 031           |
| LSR Rd, Rn, Sh       | Logical Shift Right                                    | 132           |
| ROR Rd, Rn, Sh       | Rotate Right                                           | 031           |
| RRX Rd, Rn           | Rotate Right Extended                                  |               |
|                      |                                                        |               |
| Remark: Sh is either | the lower 8 bits of a register (value from 0255)       |               |
|                      | a 5-bit immediate value representing either 132 or 031 |               |
|                      |                                                        |               |

BIG IDEAS FOR EVERY SPACE RENESAS

LSL : Logical Left Shift



RENESAS

BIG IDEAS FOR EVERY SPACE

source: ARM The ARM Architecture

#### Shift Operators to be used in Operand2

| Operator             | Description                                            | #imm Sh range |
|----------------------|--------------------------------------------------------|---------------|
| ASR Sh               | Arithmetic Shift Right (preserves signal)              | 132           |
| LSL Sh               | Logical Shift Left                                     | 031           |
| LSR Sh               | Logical Shift Right                                    | 132           |
| ROR Sh               | Rotate Right                                           | 031           |
| RRX                  | Rotate Right Extended                                  |               |
|                      |                                                        |               |
| Remark: Sh is either | the lower 8 bits of a register (value from 0255)       |               |
|                      | a 5-bit immediate value representing either 132 or 031 |               |
| Usage:               | R4, LSL #3 (Operand2 is R4 << 3)                       |               |

Multiply

| Instruction                                                                                                                 | Description                                  | Action                                     |  |
|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--------------------------------------------|--|
| Instructions that multiply 32-bit by 32-bit resulting 32-bit with wrapping (LSW is preserved and higher bits are discarded) |                                              |                                            |  |
| MUL Rd, Rm, Rs                                                                                                              | Multiply                                     | Rd = Rm * Rs                               |  |
| MLA Rd, Rm, Rs, Rn                                                                                                          | Multiply and accumulate                      | Rd = Rm * Rs + Rn                          |  |
| MLS Rd, Rm, Rs, Rn                                                                                                          | Multiply and subtract                        | Rd = Rm * Rs - Rn                          |  |
| Long multiplication: multiply 32-bit by 32-bit resulting 64-bit                                                             |                                              |                                            |  |
| UMULL RdLo, RdHi, Rm, Rs                                                                                                    | Unsigned long multiply                       | RdHi:RdLo = unsigned(Rm*Rs)                |  |
| UMLAL RdLo, RdHi, Rm, Rs                                                                                                    | Unsigned long multiply and accumulate        | RdHi:RdLo = unsigned(RdHi:RdLo +<br>Rm*Rs) |  |
| UMAAL RdLo, RdHi, Rm, Rs                                                                                                    | Unsigned long multiply and accumulate double | RdHi:RdLo = unsigned(RdHi+RdLo +<br>Rm*Rs) |  |
| SMULL RdLo, RdHi, Rm, Rs                                                                                                    | Signed long multiply                         | RdHi:RdLo = signed(Rm*Rs)                  |  |
| SMLAL RdLo, RdHi, Rm, Rs                                                                                                    | Signed long multiply and accumulate          | RdHi:RdLo = signed(RdHi:RdLo + Rm*Rs)      |  |
| © 2020 Renesas Electronics Corporation. All rights reserved.                                                                | Page 106                                     | BIG IDEAS FOR EVERY SPACE RENESAS          |  |

#### Divide

| Instruction     | Description     | Action       |
|-----------------|-----------------|--------------|
| UDIV Rd, Rn, Rm | Unsigned divide | Rd = Rn / Rm |
| SDIV Rd, Rn, Rm | Signed divide   | Rd = Rn / Rm |

Bit field operations

A bit field is a sequence of bits in a register.

- A bit field is characterized by two values:
- Width: the number of bits in the bit field (1..32);
- Isb: the position of the least significant bit in the bitfield (0..31).

| Instruction                                   | Description                                                | Action                                              |
|-----------------------------------------------|------------------------------------------------------------|-----------------------------------------------------|
| BFC Rd,# <lsb>,#<width></width></lsb>         | Bit field clear                                            | clear Rd[(width+lsb-1)lsb], others unchanged        |
| BFI Rd, Rn,# <lsb>,#<width></width></lsb>     | Bit field insert. Copy the <width> LSb of Rn to Rd</width> | Rd[(width+lsb-1)lsb] = Rn[(width-1)0]               |
| SBFX Rd,<br>Rn,# <lsb>,#<width></width></lsb> | Signed bit field extract.                                  | Copy bitfield from Rn to LSb of Rd and sign extend. |
| UBFX Rd,<br>Rn,# <lsb>,#<width></width></lsb> | Unsigned bit field extract.                                | Copy bitfield from Rn to LSb of Rd and zero extend. |

RENESAS

**BIG IDEAS FOR EVERY SPACE** 

Memory access instructions

| Instruction type | Description                                                                                  |
|------------------|----------------------------------------------------------------------------------------------|
| LDRB             | Load byte. Read a byte from memory and store in the LSB of a register.                       |
| LDRH             | Load half word. Read a half-word from memory and store in the lower half-word of a register. |
| LDR              | Load register. Read a word from memory and store in a register.                              |
| LDRD             | Load double. Read a double word form memory and store in two registers.                      |
| STRB             | Store byte. Store the LSB of a register into memory.                                         |
| STRH             | Store half-word. Store the lower half of a register into memory.                             |
| STR              | Store register. Store a register into memory.                                                |
| STRD             | Store double. Store the two registers into memory.                                           |
| LDM              | Load multiple. Read several (up to 16) registers from memory.                                |
| STM              | Store multiple. Store several (up to 16) registers into memory.                              |



Memory access instructions – addressing

For the purposes of addressing, memory is just a very large vector of bytes. For Cortex-M, it is a vector with 4G entries.

The four data types that can be accesses with LDR/STR instructions are shown here. In a little-endian memory system, when a data type occupies more than 1 byte in memory, its address is the address of the LSB (Least Significant Byte).

shown: byte at 0x0, half-word at 0x2, word at 0x4, and double-word at 0x8



RENESAS

BIG IDEAS FOR EVERY SPACE

|                      | 31          | 24          | 23          | 16          | 15        |         | 8     | 7         |           | 0 |
|----------------------|-------------|-------------|-------------|-------------|-----------|---------|-------|-----------|-----------|---|
| Word at<br>Address A | Byte at add | dress (A+3) | Byte at ado | dress (A+2) | Byte at a | address | (A+1) | Byte at a | address A |   |
|                      |             |             | Halfword at | Address A   | Byte at a | address | (A+1) | Byte at a | address A |   |

#### Figure A3-1 Little-endian byte format

|                      | 31        | 24        | 23          | 16          | 15          | 8           | 7          | 0           |
|----------------------|-----------|-----------|-------------|-------------|-------------|-------------|------------|-------------|
| Word at<br>Address A | Byte at a | address A | Byte at add | dress (A+1) | Byte at add | lress (A+2) | Byte at ad | dress (A+3) |
|                      |           |           | Halfword at | t Address A | Byte at a   | ddress A    | Byte at ad | dress (A+1) |

Figure A3-2 Big-endian byte format

source: DDI0403E.B ARMv7-M Architecture Reference Manual

| MSByte                                      | MSByte-1     | LSByte+1              | LSByte            |
|---------------------------------------------|--------------|-----------------------|-------------------|
|                                             | Word at a    | address A             |                   |
| Halfword at a                               | ddress (A+2) | Halfword at           | address A         |
| Byte at address (A+3) Byte at address (A+2) |              | Byte at address (A+1) | Byte at address A |

Figure A3-3 Little-endian memory system

source: DDI0403E.B ARMv7-M Architecture Reference Manual



Memory access instructions – addressing modes

| Indexing<br>Mode             | Example                 | Action                                                                     | Change in base register |
|------------------------------|-------------------------|----------------------------------------------------------------------------|-------------------------|
| Pre-index with writeback (!) | LDR R0,[R1,#4] !        | R0 = [R1 + 4] (R0 gets the contents of<br>memory location at address R1+4) | R1 = R1 + 4             |
|                              | LDR R0,[R1,R2] !        | R0 = [R1+R2]                                                               | R1 = R1 + R2            |
|                              | LDR R0,[R1,R2,LSL #2] ! | R0 = [R1 + (R2 << 2)]                                                      | R1 = R1 + R2 << 2       |
| Pre-index                    | LDR R0,[R1,#4]          | R0 = [R1 + 4]                                                              | no change               |
|                              | LDR R0,[R1,R2]          | R0 = [R1+R2]                                                               | no change               |
|                              | LDR R0,[R1,R2,LSL #2]   | R0 = [R1 + (R2 << 2)]                                                      | no change               |
| Pre-index                    | LDR R0,[R1],#4          | R0 = [R1]                                                                  | R1 = R1 + 4             |
|                              | LDR R0,[R1],R2          | R0 = [R1]                                                                  | R1 = R1 + R2            |
|                              | LDR R0,[R1],R2,LSL #2   | R0 = [R1]                                                                  | R1 = R1 + R2 << 2       |

BIG IDEAS FOR EVERY SPACE RENESAS

#### **Execution flow control instructions**

| Instruction               | Usage                                                        | Branch Range      |
|---------------------------|--------------------------------------------------------------|-------------------|
| B.N <label></label>       | 16-bit Branch to target address.                             | -256 to 254 bytes |
| B.W <label></label>       | 32-bit Branch to target address.                             | +/-1 MB           |
| CBNZ <label></label>      | Compare and Branch on Nonzero.                               | 0-126 B           |
| CBZ <label></label>       | Compare and Branch on Zero.                                  | 01200             |
| BL <label></label>        | Call a subroutine.                                           | +/–16 MB          |
| BLX <register></register> | Call a subroutine, optionally change instruction set.        | Any               |
| BX <register></register>  | Branch to target address, optionally change instruction set. | Any               |
| TBB                       | TBB: Table Branch, byte offsets.                             | 0-510 B           |
| ТВН                       | TBH: Table Branch, halfword offsets.                         | 0-131070 B        |

BIG IDEAS FOR EVERY SPACE RENESAS

**Miscellaneous instructions** 

| Instruction | Usage                                       |
|-------------|---------------------------------------------|
| CPSID       | Change Processor State, Disable Interrupts. |
| CPSIE       | Change Processor State, Enable Interrupts.  |
| DMB         | Data Memory Barrier.                        |
| DSB         | Data Synchronization Barrier.               |
| ISB         | Instruction Synchronization Barrier.        |
| MRS         | Move to Register from Special Register.     |
| MSR         | Move to Special Register from Register.     |
| NOP         | No Operation.                               |
| SVC         | Supervisor Call.                            |
| WFI         | Wait for Interrupt.                         |

### **3.5 – EXCEPTIONS**

The normal flow of execution of a program is to execute the next instruction in memory, unless a Branch, Subroutine Call or Return is executed. Hence, a human processor could execute the same program in the same order.

An exception if a break in this normal flow of execution. Such a break can be caused by:

- Hardware interrupt,
- Fault (e.g. memory access error, divide by 0, invalid instruction code),
- Software generate exception.

### **3.5 – EXCEPTIONS**

Exceptions occur **asynchronousl**y, this is, at any point of the execution. They may occur many time and on successive executions of the program they usually occur at different places of this program.

When an exception occurs it must be **serviced**. Meaning that a software routine must either respond to the interrupt request or take steps to resolve or mitigate the fault.

This routine is called: exception handler routine, interrupt service routine, or interrupt handler.



# **3.5 – EXCEPTIONS – INTERRUPTS**

Hardware Interrupts are one of the kind of exceptions.

Interrupts are an efficient way for a peripheral to inform the processor that it requires servicing. If interrupts were not available, the processor would have to periodically poll the peripherals (thus termed **polling**) to check if service is required. Polling is an inefficient technique.



# **3.5 – EXCEPTIONS – INTERRUPTS**

Basic concepts of interrupts:

- Peripheral sends an Interrupt Request (IRQ) to an Interrupt Controller
- 2. Interrupt Controller selects the highest priority non-masked interrupt request and informs the core.
- 3. If the priority of the IRQ is sufficiently high, when the instruction currently in execution finishes then the IRQ is serviced.



BIG IDEAS FOR EVERY SPACE

1- An external device, such as a peripheral, requests an interrupt (IRQ) by signaling to the interrupt controller.

The input lines of the interrupt controller (240 in the NVIC of a Cortex-M4) can be either level sensitive of edge sensitive.



2- Upon receiving an IRQi (hardware signal on input i of the interrupt controller - IC) then the IC performs two checks:

- a) if input i is masked or not;
- b) if there is another request (IRQj on input j) already being sent to the processor.

If IRQi is not masked and if its priority is higher than IRQj's priority (or no request is currently being sent to the processor)

then IRQi is forwarded to the processor.

- 3- The processor, upon receiving an IRQ verifies if its priority is sufficiently high:
- a) PRIMASK and FAULTMASK, when set, impose a priority level of 0 or -1 respectively. Hence, when FAULTMASK is set, all exceptions from 3 on are masked.
- b) If an exception is active (being serviced) then only a higher priority exception may preempt its handler.

If both these conditions are met, servicing starts at the end of the current instruction.

source: ARM Cortex™-M4 Devices Generic User Guide

| Exception<br>number <sup>a</sup> | IRQ<br>number <sup>a</sup> | Exception type  | Priority                  | Vector address<br>or offset <sup>b</sup> | Activation                                               |
|----------------------------------|----------------------------|-----------------|---------------------------|------------------------------------------|----------------------------------------------------------|
| 1                                | -                          | Reset           | -3, the highest           | 0x00000004                               | Asynchronous                                             |
| 2                                | -14                        | NMI             | -2                        | 0x0000008                                | Asynchronous                                             |
| 3                                | -13                        | HardFault       | -1                        | 0x0000000C                               | -                                                        |
| 4                                | -12                        | MemManage       | Configurable <sup>c</sup> | 0x00000010                               | Synchronous                                              |
| 5                                | -11                        | BusFault        | Configurable <sup>c</sup> | 0x00000014                               | Synchronous when precise,<br>asynchronous when imprecise |
| 6                                | -10                        | UsageFault      | Configurablec             | 0x00000018                               | Synchronous                                              |
| 7-10                             | -                          | Reserved        | -                         | -                                        | -                                                        |
| 11                               | -5                         | SVCall          | Configurable <sup>c</sup> | 0x0000002C                               | Synchronous                                              |
| 12-13                            | -                          | Reserved        | -                         | -                                        | -                                                        |
| 14                               | -2                         | PendSV          | Configurable <sup>c</sup> | 0x00000038                               | Asynchronous                                             |
| 15                               | -1                         | SysTick         | Configurable <sup>c</sup> | 0x0000003C                               | Asynchronous                                             |
| 16                               | 0                          | Interrupt (IRQ) | Configurabled             | 0x00000040 <sup>e</sup>                  | Asynchronous                                             |



4- Eight registers are pushed onto the StackThe Interrupt changes state toActive.

Since R0-R3 and R12 are stacked,

any C procedure following ATPCS

can be registered as a handler.



Exception frame without floating-point storage

source: ARM Cortex<sup>™</sup>-M4 Devices Generic User Guide

5- Register LR is loaded with one of the EXC\_RETURN values, depending on the current state of the processor.
Note that EXC\_RETURN
represents memory addresses
in a region where code is not allowed.

| EXC_RETURN[31:0] | Description                                                                                                                 |
|------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 0xFFFFFF1        | Return to Handler mode, exception return uses non-floating-point state<br>from the MSP and execution uses MSP after return. |
| 0xFFFFFF9        | Return to Thread mode, exception return uses non-floating-point state from MSP and execution uses MSP after return.         |
| 0xFFFFFFD        | Return to Thread mode, exception return uses non-floating-point state from the PSP and execution uses PSP after return.     |
| 0xFFFFFE1        | Return to Handler mode, exception return uses floating-point-state from MSP and execution uses MSP after return.            |
| 0xFFFFFE9        | Return to Thread mode, exception return uses floating-point state from MSP and execution uses MSP after return.             |
| 0xFFFFFED        | Return to Thread mode, exception return uses floating-point state from PSP and execution uses PSP after return.             |
|                  | SOURCE: ARM                                                                                                                 |

source: ARM Cortex<sup>™</sup>-M4 Devices Generic User Guide

6- The processor reads from the vector tablethe initial address of the handler for theInterrupt. This value is loaded to PC and theexecution of the handler starts.

*Important:* since the handler is Thumb-2 code the addresses in the vector table must have its LSb set to 1.

16+n IRQn n 0x0040+4n . 0x004C IRQ2 2 18 0x0048 17 IRQ1 1 0x0044 IRQ0 16 0 0x0040 15 -1 Systick 0x003C PendSV -2 14 0x0038 13 Reserved 12 Reserved for Debug SVCall 11 -5 0x002C 10 9 Reserved 8 7 -10 Usage fault 6 0x0018 -11 Bus fault 5 0x0014 -12 Memory management fault 4 0x0010 -13 Hard fault 3 0x000C 2 -14 NMI 0x0008 1 Reset 0x0004 Initial SP value 0x0000

Exception number IRQ number Offset

source: ARM Cortex<sup>™</sup>-M4 Devices Generic User Guide

Figure 2-2 Vector table

Vector

### **3.5 – EXCEPTIONS – SERVICING**

#### **Exception Servicing**

The handler must service the interrupt request, in this process at least three actions must be taken:

- 1. The interrupt request signal must be deactivated, otherwise the processor would continuously be servicing this interrupt.
- 2. Any volatile data (such as a byte that arrived on the UART and is available in the Receiving Register) must be saved.
- 3. Apart from the registers saved in Step 4 of the entry process, any other register must be saved by the handler before modifying it and these registers must be restored before returning to the interrupted code.



### 3.5 – EXCEPTIONS – RETURN

#### **Exception Return**

The instruction that causes the return from the handler to the interrupted code is either:

BX LR Or

POP {..., PC} // if this instruction is used the the entry of the handler must be PUSH {..., LR}



### 3.5 – EXCEPTIONS – RETURN

#### **Exception Return**

What happens when a value such as 0xFFFF FFF1 is loaded to the PC?

Being an invalid code address, the processor detects that this is an EXC\_RETURN code and proceeds with the actions

described in the table in the slide Step 5 of the Interrupt Entry.



# **3.5 – EXCEPTION HANDLING**

Tail Chaining: optimization that avoids registers pop followed by registers push when one exception is handled right after another.



An Introduction to the ARM Cortex-M3 Processor - Shyam Sadasivan

**RENESAS** 

**BIG IDEAS FOR EVERY SPACE** 

# **3.5 – EXCEPTION HANDLING**

Late arrival: optimization where a higher priority interrupt is serviced first even if it arrives while a prior lower priority interrupt is already in the stage of pushing registers.





source: ARM An Introduction to the ARM Cortex-M3 Processor - Shyam Sadasivan



- Introduction
- Non-Volatile Memory
- Static RAM
- Dynamic RAM



# **MEMORY – INTRODUCTION**

Semiconductor Memory

- Electronic components that store information.
- Memory is an essential part of a microprocessor-based system.

Types of Memory devices:

- Volatile: memory devices that do not retain information when power is removed.
   Example: PC main memory
- Non-volatile: memory devices that retain information even when not powered.
   Example: flash drive



Types of Volatile Memory:

- Static: retain information as long as the device is powered.
- Dynamic: do not retain information, even when powered. Hence, dynamic memories do need to be constantly "remembered" of the information they store. This process is called refresh. It must occur every few milliseconds in order not to loose information.

# **TYPES OF NON-VOLATILE MEMORY**

Some of the types of non-volatile memory are:

- ROM: (or masked ROM) Read Only Memory,
- EPROM: Erasable Programmable Read Only Memory,
- EEPROM: Electrically Erasable Programmable Read Only Memory,
- NOR Flash,
- NAND Flash,
- FeRAM: Ferro Electric Random Access Memory.



## **TYPES OF VOLATILE MEMORY**

Some of the types of volatile memory are:

- SRAM: Static Random Access Memory
- DRAM: Dynamic Random Access Memory
- DDR: Double Data Rate

### **MEMORY – CONCEPT**

A memory device behaves like an array in C.

The memory device that is pictured here has size 2<sup>20</sup> and every addressable location can store 8 bits. The three control lines indicate when the memory is being addressed, if it is being read or written.

- A address bus. Input. With N address lines it is possible to index 2<sup>N</sup> unique locations.
- D data bus. Bidirectional. Width corresponds to the number of bits stored in each addressable location.
- /CS active low chip select. When active, this device is selected.
- /OE active low output enable. When active, indicates the device is being read.
- /WR active low write. When active, indicates the device is being written to.



**BIG IDEAS FOR EVERY** 

### **MEMORY – CONCEPT**

A memory device behaves like an array in C



### Physical view

2<sup>20</sup> = 1,048,576 = 1 Mega addressable locations

each location holds 8 bits

hence, total storage is 1 Mbyte corresponding to a vector of 1,048,576 8-bit cells



### **MEMORY – CONCEPT**

From an external perspective, e.g. the perspective of the processor. This device is an array of 2<sup>20</sup> locations of 8 bits each.

Hence, the size of the memory is 1 MByte (1,048,576) and the width is 8 bits. Or, 1 M x 8 bits resulting in 8 Mbits of total storage capacity.

Internally the organization is different. Possibly this memory is organized as a matrix of 1024 line and 1024 columns with 8 bits in each position. Resulting in the capacity of  $1024 \times 1024 \times 8 = 8$  Mbits.





0x0

source: Authors



Assume the only memory chip available is 1 M x 8 bits. How to implement 2 M x 32 bits = 8 MBytes of memory to a Cortex-M4 with data bus width of 32-bits?

Memory should be located from address 0x1000 0000 on.



# SAMPLE PROBLEM

The addressing space of a Cortex-M is 4 GBytes, i.e.  $2^{32} = 4,294,967,296$ .

If physical memory is 32-bit wide (4 bytes) then there are 1 G lines (1,073,741,824). Each of these lines is addressable by its LSByte address. Hence, 30 address lines are required to select a single

memory line (as  $2^{30} = 1$  G)

The address lines A31-A2 are used to select on of the

1G lines while address lines A1 and A0 are used to select a byte in the memory line

Memory address lines have their A1-A0 addresses set to 0.

Hence, the first memory line is at address 0x0000 0000, the second at

address 0x0000 0004 and so on.



BIG IDEAS FOR EVERY SPACE

**RENESAS** 

### SAMPLE PROBLEM

Since the capacity of each chips is 1 Mbit and 8 Mbits are required, 8 chips must be used.

Since the processor data bus is 32-bit wide and the memory is 8-bit wide, 4 chips are put side-by-side to complete one 32-bit wide memory line.

The first set of 4 chips have a combined capacity of 8 MWords and are mapped from address 0x1000 0000 to 0x103F FFFF.

The second set of 4 chips are mapped from 0x1040 0000 to 0x107F FFFF.



# SAMPLE PROBLEM

Selecting the address lines for  $A_{31}$  $A_{30}$  $A_{29}$ CS (Chip Select) and for memory line addressing. These are the 32bit addresses from (0x100) the Cortex-M processor:



source: Authors



/CS1 must be active in the range 0x1000 0000 to 0x103F FFFF

/CS2 must be active in the range 0x1040 0000 to 0x107F FFFF

### **NOR FLASH MEMORY**

NOR Flash memory is frequently used in embedded systems to store non-volatile data, particularly code and constants.

Each bit of a NOR Flash memory is implemented by a single floating gate MOS. The floating gate may be charged and, since the floating gate is isolated, the charges are trapped into de gate. Hence, the two possible states are: charges trapped in the floating gate vs no charges trapped in the floating gate.



source: wikimedia.org (CC)



#### **EXAMPLE OF A FLASH MEMORY DEVICE 128K X 16 BITS**



#### **EXAMPLE OF A FLASH MEMORY DEVICE 128K X 16 BITS**

The operation of a NOR Flash memory is straightforward: the processor sets the address to be read, and activates Chip Select (CE#) and Output Enable (OE#) after a delay (TCE of TOE) valid data is presented on the data bus.





#### **R1LV5256E Series**

256Kb Advanced LPSRAM (32k word x 8bit)

| Pin name   |                   |
|------------|-------------------|
| Vcc        | Power supply      |
| Vss (GND)  | Ground            |
| A0 to A14  | Address input     |
| DQ0 to DQ7 | Data input/output |
| CS#        | Chip select       |
| WE#        | Write enable      |
| OE#        | Output enable     |



source: Renesas



#### **INTERNAL ORGANIZATION**



#### **Operation Table**

| CS#                                | WE#   | OE# | DQ0~7  | Operation      |  |  |  |
|------------------------------------|-------|-----|--------|----------------|--|--|--|
| Н                                  | Х     | Х   | High-Z | Stand-by       |  |  |  |
| L                                  | L     | Х   | Din    | Write          |  |  |  |
| L                                  | Н     | L   | Dout   | Read           |  |  |  |
| L                                  | L H H |     | High-Z | Output disable |  |  |  |
| Note 1. H: VIH L:VIL X: VIH or VIL |       |     |        |                |  |  |  |

BIG IDEAS FOR EVERY SPACE RENESAS

#### **READ CYCLE**

Read Cycle timing diagram

#### Read Cycle

| Parameter                          | Symbol           | Min. | Max. |  |
|------------------------------------|------------------|------|------|--|
| Read cycle time                    | t <sub>RC</sub>  | 55   | -    |  |
| Address access time                | taa              | -    | 55   |  |
| Chip select access time            | tacs             | -    | 55   |  |
| Output enable to output valid      | toe              | -    | 30   |  |
| Output hold from address change    | toн              | 10   | -    |  |
| Chip select to output in low-Z     | t <sub>CLZ</sub> | 5    | -    |  |
| Output enable to output in low-Z   | tolz             | 5    | -    |  |
| Chip deselect to output in high-Z  | t <sub>снz</sub> | 0    | 20   |  |
| Output disable to output in high-Z | t <sub>онz</sub> | 0    | 20   |  |

#### Read Cycle



### WRITE CYCLE

Write Cycle timing diagram



#### Write Cycle

| Parameter                          | Symbol           | Min. | Max. |
|------------------------------------|------------------|------|------|
| Write cycle time                   | twc              | 55   | -    |
| Address valid to end of write      | taw              | 50   | -    |
| Chip select to end of write        | tcw              | 50   | -    |
| Write pulse width                  | twe              | 40   | -    |
| Address setup time                 | tas              | 0    | -    |
| Write recovery time                | twr              | 0    | -    |
| Data to write time overlap         | tow              | 25   | -    |
| Data hold from write time          | t <sub>DH</sub>  | 0    | -    |
| Output enable from end of write    | tow              | 5    | -    |
| Output disable to output in high-Z | t <sub>онz</sub> | 0    | 20   |
| Write to output in high-Z          | twнz             | 0    | 20   |

### **DYNAMIC RAM**

In a dynamic RAM, each bit is implemented by a circuit consisting of a capacitor and a transistor.

The capacitor stores de information (charged vs discharged) and the transistor acts as a switch that connects the capacitor to the Bit Line when that particular bit is accessed.

Because the capacitance is very small and because of leakage, the charge of the capacitor only holds reliably for a few milliseconds, hence, this memory bit must be constantly refreshed.

Also, every read of a memory cell is destructive, hence, after a read the value must be rewritten.



source: wikimedia.org (CC)

#### **DDR – DOUBLE DATA RATE**

#### [R1Q4A4436RBG]



# **5 – TIMER AND GPIO**

- 1. Introduction Peripherals
- 2. Timer
- 3. PWM Pulse Width Modulations
- 4. GPIO
- 5. Low-power Drivers (LED, Relay)
- 6. Power Drivers (DC Motor)

#### **5.1 – PERIPHERALS**

A Microprocessor-based system consists of three types of components:

- 1. Microprocessor (the core of the MCU) executes the instructions of a program;
- 2. Memory store code and data;
- **3. Peripherals** perform specific functions particularly related to I/O. Peripherals provide the means for the system to sense, actuate and communicate with the world.

A microprocessor-based system without peripherals would be unable to interact with the rest of the world!





Classes of peripherals in a microprocessor-based system:

- Digital I/O: input/output of digital signals,
- Analog I/O: input/output of analog signals,
- Timing: pulse generation, pulse measurement, PWM, ...
- Storage: non-volatile memory, file system, ...
- Communications: RS-232, SPI, I2C, CAN, USB, Ethernet, ...
- HMI: touch-screen, keyboard, ...
- Imaging: camera interface, ...
- System management: clock generation, watchdog, power management, ...



#### **5.2 – TIMERS/COUNTERS**

Timers/Counters are essential components of a Microcontroller Unit (MCU). They consists of a **digital counter circuit** that counts pulses on their input. **Timers** count clock pulses and Counters count pulses of a signal present on their input pin. **Timers/Counters** are used for:

- Measuring time, particularly time intervals,
- Counting events,
- Keeping track of current date and time (Real-Time Clock RTC),
- Generating digital waveforms (PWM Pulse-Width Modulation),
- Generating periodic interrupts to the MCU (Operating System Clock),
- Generating periodic signals to other peripheral, such as the command to start an Analog-to-Digital Conversion,
- Restart the MCU if software is unable to periodically restart a WATCHDOG timer.



- Timers/Counters vary in their characteristics, such as:
  - edge of the input signal used for counting: positive, negative, or both edges;
  - count direction: up, down, or both;
  - what is being counted: clock pulses (timers) or other input signal (counters);
  - periodic timers vs single-shot;
  - a number of actions can be taken at the end of the timing period: change state of GPIO pin, generate IRQ, stop the timer, reload the timer;
  - number of bits of the counter circuit: typically 32 bits for ARM MCUs;
  - since the frequency of the input signal and number of bits of the counter determine the maximum timing period, a
    prescaler may be used to reduce the input frequency.



#### **TIMING SAMPLE PROBLEM 1**

Consider the problem where an LED, connected to a pin on an MCU, must be on during 0.9 second.

The first solution to be presented is a software-based solution:

- 1. Turn the LED on by activating the MCU pin connected to it;
- 2. Execute a loop N times, where N is chosen so that the execution of the loop takes 0.9 second;
- 3. Turn the LED off by deactivating the MCU pin connected to the LED

#### void hal\_entry(void)

{

}

```
// pins 0,1,2 are output, reset pin 0 to 0 to turn green led ON
R IOPORT6->PCNTR1 = 0x00060007;
```

| asm("    | ldr r4,=7200000          | )0 <mark>-2")</mark> ; |
|----------|--------------------------|------------------------|
| asm("loo | p:                       | ");                    |
| asm("    | <pre>subs r4,r4,#1</pre> | ");                    |
| asm("    | bne loop                 | ");                    |

```
// pins 0,1,2 are output, set pin 0 to 1 to turn green led OFF
R IOPORT6->PCNTR1 = 0x00070007;
```



- This is the Timing Diagram for the execution of the code of the previous slide.
- Due to branch forwarding at the decode stage of the BNE instruction, each loop takes 3 clock cycles.
- At 240 MHz (period of 4.16ns), it takes 12.5 ns for each subs loop; hence, 0.9 second takes 72,000,000 loops.
- Remark: the loop\_count must be reduced by 2 to compensate for GPIO and load instructions.



source: Authors

 Connecting a scope to the LED allows us to verify the timing of the software-based solution.



BIG IDEAS FOR EVERY SPACE

Evaluation of the software-based solution:

- 100% of the MCU processing capability was used for counting so that the exact timing of 0.9 seconds was obtained.
- No other activities where executed by the processor during this time.
- If interrupts where allowed, there would have been an error in timing.
  - This software-based solution is called busy-wait. It should be avoided as it wastes processor cycles and energy.

### **A VERY SIMPLE TIMER**

- To avoid the drawbacks of the software-based solution, a small piece of hardware is added to an MCU: a counter.
- This circuit performs the function of counting clock cycles, freeing the processor to perform other tasks.



# **A VERY SIMPLE TIMER**

Description:

- The counter decrements its value on every positive edge of the CLK.
- The processor can write an initial count value by performing a load followed by a start command.
- When the count reaches 0 the Z output is activated.
- The Z output may command a change to the GPIO pin, generate an Interrupt Request (IRQ), and stop the counter.





#### **A VERY SIMPLE TIMER**

- clk 1 the value 5 is loaded to the counter.
- clk 2 the processor commands the start of the counting.
- clk 3 to 7 count value is decremented on every positive edge of the CLK.
- clk 7 count reaches 0 activating the Z output.



source: Authors

**BIG IDEAS FOR EVERY SPA** 

# SOLVING THE TIMING SAMPLE PROBLEM 1 USING THE SIMPLE TIMER

Solution:

- Load the value 72,000,000 to the timer and start it.
- When the count reaches zero:
  - Option 1: timer commands LED pin to turn LED off;
  - Option 2: generate an IRQ and its service routine turns the LED off.
- Remark: for option 2, the value loaded to the timer should be lower to compensate for the entry into the interrupt service routine.

# SOLVING THE TIMING SAMPLE PROBLEM 1 USING THE SIMPLE TIMER

Evaluation:

- The solution using a timer requires significantly less processing power, just a few cycles to configure the timer and to perform an action when the timing period finishes.
- Processor is free to perform other tasks OR processor can be put into a low energy sleep state.
- If interrupts are serviced during the timing period, this will not affect the timing precision.



- The SYSTICK is a timer available in all Cortex-M processors.
- It is a simple 24-bit counter with auto-reload.
- Its main use is to generate periodic interrupts required by most Embedded Operating Systems.
- Since its structure and operation is defined by ARM, its interface is standard, regardless of MCU supplier.

SysTick auto-reload has a period of SYST\_RVR + 1 clock cycles.

**BIG IDEAS FOR EVERY SPACE** 





**BIG IDEAS FOR EVERY SPACE** 

- Timing diagram for the scenario where SYST\_RVR holds the value 2.
- As the reload occurs on the next positive edge of the clock, the SysTick period is of 3 clock cycles.
   If enabled, every reload generates a SysTick interrupt request (IRQ).







 Pulse Width Modulation (PWM) is a modulation technique that allows the encoding of analog information in a binary digital signal.

This is achieved by encoding the information in width of a pulse while maintaining the pulse frequency constant.

- A low pass filter with cut-off frequency way below the PWM frequency restores the analog information.
- PWM has several applications including: control of power electronics including switched power supplies, motor control, temperature control and light dimmering; audio power-amplifiers; and analog signal generation.
- Often, a low-pass filter is not required as the load itself performs this function.



The effect of 5 different duty cycles after passing a low-pass filter:



source: commons.wikimedia.org (CC)



- If the duty cycle of a PWM signal is varied on every PWM period, an analog signal can be produced (after a low-pass filter).
- The higher the frequency of the PWM signal when compared to the frequency of the analog signal, the better (less noisy) the analog signal will be.



source: commons.wikimedia.org (CC)

# **A PWM TIMER**

#### Operation:

- at start of period set the GPIO pin.
- counts up from 0.
- when counter matches Match Reg then reset GPIO pin.
- when counter matches Limit Reg then:

set GPIO pin;

generate IRQ;

reset counter.

 interrupt service routine may reprogram the match register.



The Renesas S7G2 MCU has 14 timers of the type GPT (General PWM Timer).

Each one is a complex circuit that provides significant flexibility for a variety of applications.

Diagram shows the hardware modules of the S7G2 MCU.

General PWM Timers (GPT) are identified.







BIG IDEAS FOR EVERY SPACE **RENESAS** 

source: Renesas S7 Series Microcontrollers User's Manual

There are 14 timers, grouped into:

- 4x EH enhanced high resolution
- 4x E enhanced
- 6x conventional

| CH13    | CH12    | CH11    | CH10    | CH9    | CH8    | CH7     | CH6     | CH5     | CH4     | CH3      | CH2      | CH1      | CH0      |
|---------|---------|---------|---------|--------|--------|---------|---------|---------|---------|----------|----------|----------|----------|
|         |         |         |         |        |        |         |         |         |         |          |          |          |          |
| GPT3213 | GPT3212 | GPT3211 | GPT3210 | GPT329 | GPT328 | GPT32E7 | GPT32E6 | GPT32E5 | GPT32E4 | GPT32EH3 | GPT32EH2 | GPT32EH1 | GPT32EH0 |
| GPT32   |         |         | GPT32E  |        |        | GPT32EH |         |         |         |          |          |          |          |
|         |         |         |         |        |        |         |         |         |         |          |          |          |          |

source: Renesas S7 Series Microcontrollers User's Manual

BIG IDEAS FOR EVERY SPACE RENESAS



© 2020 Renesas Electronics Corporation. All rights reserved.

#### TIMER CASE STUDY 2 – S7G2 GPT

| GTWP     | : General PWM Timer Write-Protection Register                                           | GTPR      | : General PWM Timer Cycle Setting Register                                         |
|----------|-----------------------------------------------------------------------------------------|-----------|------------------------------------------------------------------------------------|
| GTSTR    | : General PWM Timer Software Start Register                                             | GTPBR     | : General PWM Timer Cycle Setting Buffer Register                                  |
| GTSTP    | : General PWM Timer Software Stop Register                                              | GTPDBR    | : General PWM Timer Cycle Setting Double-Buffer Register                           |
| GTCLR    | : General PWM Timer Software Clear Register                                             | GTADTRA   | : General PWM Timer A/D Converter Start Request Timing Register A                  |
| GTSSR    | : General PWM Timer Start Source Select Register                                        | GTADTBRA  | : General PWM Timer A/D Converter Start Request Timing Buffer Register A           |
| GTPSR    | : General PWM Timer Stop Source Select Register                                         | GTADTDBRA | : General PWM Timer A/D Converter Start Request Timing Double-Buffer<br>Register A |
| GTCSR    | : General PWM Timer Clear Source Select Register                                        | GTADTRB   | : General PWM Timer A/D Converter Start Request Timing Register B                  |
| GTUPSR   | : General PWM Timer Up Count Source Select Register                                     | GTADTBRB  | : General PWM Timer A/D Converter Start Request Timing Buffer Register B           |
| GTDNSR   | : General PWM Timer Down Count Source Select Register                                   | GTADTDBRB | : General PWM Timer A/D Converter Start Request Timing Double-Buffer<br>Register B |
| GTICASR  | : General PWM Timer Input Capture Source Select Register A                              | GTDTCR    | : General PWM Timer Dead Time Control Register                                     |
| GTICBSR  | : General PWM Timer Input Capture Source Select Register B                              | GTDVU     | : General PWM Timer Dead Time Value Register U                                     |
| GTCR     | : General PWM Timer Control Register                                                    | GTDVD     | : General PWM Timer Dead Time Value Register D                                     |
| GTUDDTYC | : General PWM Timer Count Direction and Duty Setting Register                           | GTDBU     | : General PWM Timer Dead Time Buffer Register U                                    |
| GTIOR    | : General PWM Timer I/O Control Register                                                | GTDBD     | : General PWM Timer Dead Time Buffer Register D                                    |
| GTINTAD  | : General PWM Timer Interrupt Output Setting Register                                   | GTSOS     | : General PWM Timer Output Protection Function Status Register                     |
| GTST     | : General PWM Timer Status Register                                                     | GTSOTR    | : General PWM Timer Output Protection Function Temporary Release Register          |
| GTBER    | : General PWM Timer Buffer Enable Register                                              |           |                                                                                    |
| GTITC    | : General PWM Timer Interrupt and A/D Converter Start Request Skipping Setting Register | OPSCR     | : Output Phase Switching Control Register                                          |
| GTCNT    | : General PWM Timer Counter                                                             |           |                                                                                    |
| GTCCRA   | : General PWM Timer Compare Capture Register A                                          |           |                                                                                    |
| GTCCRB   | : General PWM Timer Compare Capture Register B                                          |           |                                                                                    |
| GTCCRC   | : General PWM Timer Compare Capture Register C                                          |           |                                                                                    |
| GTCCRD   | : General PWM Timer Compare Capture Register D                                          |           |                                                                                    |
| GTCCRE   | : General PWM Timer Compare Capture Register E                                          |           |                                                                                    |
| GTCCRF   | : General PWM Timer Compare Capture Register F                                          |           |                                                                                    |
|          |                                                                                         |           |                                                                                    |

source: Renesas S7 Series Microcontrollers User's Manual



## TIMER CASE STUDY 2 – S7G2 GPT

Simplified view of a GPT





# TIMER CASE STUDY 2 – S7G2 GPT

GPT characteristics and operation:

 The counter (GTCNT) can count up (from 0 to GTPR), count down (from GTPR to 0) or up and down (from 0 to GTPR and back to 0).

Hence, the period is either GTPR+1 or 2x GTPR;

- Due to a prescaler, the clock source can be selected from PCLKD to PLCKD/1024;
- A GPT can be used to trigger the start of an AD conversion, registers GTADTR are used to determine the timing to command the start;
- 8 compare registers are available. On match, a number of actions can take place: set, reset, toggle an IO pin, generate an interrupt request, generate an event, ...





General Purpose Input/Output (GPIO) is possibly the simplest form of I/O in a system.

An input pin can be connected to a key, a push-button, or any other digital signal. By reading the pin the program can detect if it is on high or low level and take appropriate action.

Input pins can generate interrupt requests (IRQ) when a required transition or level is detected.

An output pin can be connected to an LED, to a switch (transistor, relay) or any other device to be controlled by.



# **GPIO CASE STUDY – S7G2 I/O PORTS**

The MCU used in the lab experiments (kit SK-S7G2) is the R7FS7G27H3A01CFC. Its packaging is a 176 pins LQFP (Low-profile Quad Flat Package).

Of its 176 pins, 126 are available either for I/O or to be used by the integrated peripherals.

The I/O pins are grouped into 12 ports (P0 to PB) each with up to 16 pins.



| Port | pins | Port | pins |
|------|------|------|------|
| P0   | 13   | P6   | 16   |
| P1   | 16   | P7   | 8    |
| P2   | 10   | P8   | 7    |
| P3   | 16   | P9   | 6    |
| P4   | 16   | PA   | 5    |
| P5   | 11   | PB   | 2    |

# **GPIO CASE STUDY – S7G2 I/O PORTS**

source: Renesas S7 Series Microcontrollers User's Manual

- I/O pins can be configured in several ways:
- inputs may have an internal pull-up;
- outputs may be open-drain;
- output current capacity may be selectable:
  - 2, 4, 16/20 mA;
- some inputs are 5V tolerant.

Remarks:

- total current provided by the MCU is restricted to 80 mA;
- configuration capabilities vary from pin to pin, see table on the right.

| Port   | Port name                  | Input pull-up | Open-drain<br>output | Drive capacity<br>switching | 5-V tolerant |
|--------|----------------------------|---------------|----------------------|-----------------------------|--------------|
| Port 0 | P000 to P007               | -             | -                    | -                           | -            |
|        | P008 to P011, P014, P015   | ✓             | ~                    | -                           | -            |
| Port 1 | P100 to P115               | ✓             | ~                    | Low, middle, high           | -            |
| Port 2 | P200                       | ✓             | -                    | -                           | -            |
|        | P202 to P204, P207         | √             | ~                    | Low, middle, high           | -            |
|        | P205, P206                 | ✓             | ~                    | Low, middle, high           | ✓            |
|        | P201, P212                 | ✓             | ~                    | Low                         | -            |
|        | P213                       | ~             | ~                    | High                        | -            |
| Port 3 | P300 to P315               | ~             | ~                    | Low, middle, high           | -            |
| Port 4 | P400, P401                 | ~             | ~                    | Middle                      | ~            |
|        | P402 to P404               | ✓             | ~                    | Low, middle                 | ✓            |
|        | P405 to P406               | ✓             | ~                    | Low, middle, high           | -            |
|        | P407                       | ✓             | ~                    | Low, middle, high           | ✓            |
|        | P408 to P415               | ✓             | ~                    | Low, middle, high           | ✓            |
| Port 5 | P500 to P510, P513 to P515 | ✓             | ~                    | Low, middle, high           | -            |
|        | P511, P512                 | ✓             | ~                    | Middle                      | ✓            |
| Port 6 | P600 to P615               | ~             | ~                    | Low, middle, high           | -            |
| Port 7 | P700 to P707               | ~             | ~                    | Low, middle, high           | -            |
|        | P708 to P713               | ~             | ~                    | Low, middle, high           | ~            |
| Port 8 | P800 to P813               | ~             | ~                    | Low, middle, high           | -            |
| Port 9 | P900 to P915               | ✓             | ~                    | Low, middle, high           | -            |
| Port A | PA00 to PA15               | ~             | ~                    | Low, middle, high           | -            |
| Port B | PB00, PB02 to PB07         | ~             | ~                    | Low, middle, high           | -            |
|        | PB01                       | ~             | ~                    | Low, middle, high           | ~            |

rem: not all pins listed above are available on the part number R7FS7G27H3A01CFC

Table 20.2

I/O port functions





BIG IDEAS FOR EVERY SPACE

### **GPIO CASE STUDY – S7G2 I/O PORTS**

Block diagram for an I/O pin

| Reg   | Description           | Reg         | Description                      |
|-------|-----------------------|-------------|----------------------------------|
| PCR   | Pull-up control       | PODR        | Port output data                 |
| PDR   | Port direction        | PSEL        | Peripheral sel.                  |
| DSCR  | Drive capabil.        | PIDR        | Port input data                  |
| NCODR | open-drain ctr        | ISEL        | interrupt enable                 |
| EOSR  | evt output set        | ASEL        | analog select                    |
| EORR  | event output<br>reset | PMR         | Port mode:<br>I/O vs periph.     |
| POSR  | port output set       | EIDR        | event input data                 |
| PORR  | port output<br>reset  | EOF/<br>EOR | event on falling/<br>rising edge |

#### source: Renesas S7 Series Microcontrollers User's Manual



Figure 20.1 Connection diagram for I/O port registers



## **5.5 – LOW-POWER DRIVERS**

When a device connected to an output pin has low input current requirements (low typically means below 1 mA) then it can be directly connected to the I/O pin.

Example: the Renesas Development Kit for S7G2 has an audio amplifier and a speaker connector.

This audio amplifier is controlled by an output pin:

 P902 is an I/O pin of the S7G2 microcontroller that controls if the amplifier is enabled or not.



source: Renesas Development Kit S7G2 (DK-S7G2) User's Manual



#### **LOW-POWER DRIVERS**

In the case of a small LED, which typically requires current around 2 to 5 mA to light up, a limited number can still be connected directly to output pins.

The S7G2 MCU has the same source and sink capability, meaning that an output pin configured for middle drive capacity can source 4mA when its output is high and can sink 4mA when its output is low.

This symmetry is not a rule, many digital logic ICs are capable to sink much higher currents than to source them. Hence, quite often, devices such as LEDs are turned on by an output pin sinking current, i.e. with a logic level 0.



P6.0 = 0 (0V) LED is ON P6.0 = 1 (3.3V) LED is OFF

source: Authors



### **5.6 – POWER DRIVERS**

Loads that require higher currents than in the previous examples are controlled by output pins connected to interface circuits, such as:

- Transistor (bipolar, MOS, or BICMOS),
- Relay,
- H-Bridge,
- Other power electronics circuits.

Such interface circuits also allow the use of much higher voltages on the load.

Example 1 - Power LED

Consider a Power LED requiring a forward current of 500mA with a forward voltage of  $3.2V \pm 0.15V$ (varies with ambient temperature and component sample).



source: wikimedia.org (CC)



Example 1 - Power LED

A low-cost solution consists of a transistor,

acting as a power switch, and a series

resistance, to limit the forward current.

When P6.0 is at logic level 1, Q1 is on and LED is on. When P6.0 is at logic level 0, Q1 and LED are off.

#### Drawbacks:

R1 dissipates 1W when LED is on.

LED current, and brightness, vary with LED forward voltage.

#### Advantages:

Load can operate from a power source with different voltage. (in this example, MCU VDD is 3.3V and LED is powered from 5V)



Example 2 - Relay

If galvanic isolation between the MCU and the load is required, a solution is the use of a relay.

When P6.0 is at logic level 1, the transistor is ON, current flows through the relay coil and the contact closes, turning the electric motor ON. When P6.0 is at 0, the motor is off.

Since the relay coil is an inductive load to the transistor, the diode is required to avoid voltage spikes when the transistor switches off.



source: Authors



Example 3 - H-Bridge

An H-Bridge consists of four switches (in this case four n-mos). The load is a DC motor. When Q1 and Q4 are ON, the motor is energized. When Q2 and Q3 are ON the polarity is reversed.

Q1 and Q2 should never be ON at the same time as this would short circuit the power supply. For the same reason, Q3 and Q4 should never be ON at the same time.

Typically, the four switches are driven by PWM signals to control the current and the speed of the motor.



Example 4 -

Power LED driver using a switching power supply.

GPIO can turn LED on or OFF.

Alternatively, PWM can dimmer the LED.

When compared to Example 1, this circuit does not waste energy on a current limiting resistor, hence, it is energy efficient.



source: Authors



GPIO

or

PWM

# **6 – INTERRUPT CONTROLLER**

- NVIC
  - Structure
  - Registers
- CMSIS interface for NVIC operations



The Nested Vectored Interrupt Controller (NVIC) is an integral part of the Cortex-M4 architecture. Hence, all Cortex-M4 have the same interrupt controller.

Exception handling was examined in Section 3 (link)

Functionality of the NVIC:

- Detect interrupt requests (IRQ) at its inputs and combine them into a single interrupt request to the microprocessor core
- Capability to **mask** any given input
- Associate inputs to interrupt priority levels



#### NVIC

The Cortex-M4 NVIC may have up to 240 IRQ inputs.

Each input is an interrupt request coming from an integrated peripheral, an external pin, or even from the core itself to inform of a system exception.

The operation of the NVIC is configured by the core via a set of NVIC registers that provide the functionality of:

- input masking
- IRQ priority assignment
- check status of input (is there a pending IRQ?)



source: Authors

#### **NVIC CHARACTERISTICS**

The Nested Vectored Interrupt Controller provides support for:

- Nested exceptions each exception has an associated priority level. Nesting means that when an exception is being serviced, it can be interrupted by a higher priority exception that was activated. Once the higher priority exception has its service completed, the lower priority service resumes.
- Vectored exceptions the starting addresses of the service routines (handlers) are stored in a table (vector table). When
  IRQi is detected the processor simply reads entry i of the table and starts servicing, avoiding delays to start the handler.
- Interrupt masking each IRQi can be individually masked, i.e. ignored.



By default, its start address is 0x0.

The table has a 31-bit address for each of the possible exceptions (number is implementation dependent).

The 32th bit (the LSb) is used to identify the instruction set (ARM or Thumb) and must be always set in a Cortex-M processor

The first entry in the table is the initial value of the SP.

The next 15 entries are for the system exceptions

(Reset, NMI, ... SysTick).

Then follow up to 240 entries for IRQ0 to IRQ239.



### **VECTOR TABLE FOR THE RENESAS S7G2**

On the S7G2 the interrupt sources are managed by the ICU – Interrupt Control Unit. The ICU sits between the peripherals and the NVIC, preprocessing the interrupt requests before sending them to the NVIC.

| Table 14.3          | Interrupt vector table (1/3) |               |             |                                                      |  |  |  |
|---------------------|------------------------------|---------------|-------------|------------------------------------------------------|--|--|--|
| Exception<br>number | IRQ number                   | Vector offset | Source      | Description                                          |  |  |  |
| 0                   | _                            | 000h          | ARM         | Initial stack pointer                                |  |  |  |
| 1                   | —                            | 004h          | ARM         | Initial program counter (Reset Vector)               |  |  |  |
| 2                   | —                            | 008h          | ARM         | Non-maskable interrupt (NMI)                         |  |  |  |
| 3                   | _                            | 00Ch          | ARM         | Hard fault                                           |  |  |  |
| 4                   | _                            | 010h          | ARM         | MemManage fault                                      |  |  |  |
| 5                   | _                            | 014h          | ARM         | Bus fault                                            |  |  |  |
| 6                   | _                            | 018h          | ARM         | Usage fault                                          |  |  |  |
| 7                   | _                            | 01Ch          | ARM         | Reserved                                             |  |  |  |
| 8                   | —                            | 020h          | ARM         | Reserved                                             |  |  |  |
| 9                   | _                            | 024h          | ARM         | Reserved                                             |  |  |  |
| 10                  | _                            | 028h          | ARM         | Reserved                                             |  |  |  |
| 11                  | _                            | 02Ch          | ARM         | Supervisor call (SVCall)                             |  |  |  |
| 12                  | _                            | 030h          | ARM         | Debug Monitor                                        |  |  |  |
| 13                  | _                            | 034h          | ARM         | Reserved                                             |  |  |  |
| 14                  | —                            | 038h          | ARM         | Pendable request for system service (PendableSrvReq) |  |  |  |
| 15                  | _                            | 03Ch          | ARM         | System tick timer (SysTick)                          |  |  |  |
| 16                  | 0                            | 040h          | ICU.IELSR0  | Event selected in the ICU.IELSR0 register            |  |  |  |
| 17                  | 1                            | 044h          | ICU.IELSR1  | Event selected in the ICU.IELSR1 register            |  |  |  |
| 18                  | 2                            | 048h          | ICU.IELSR2  | Event selected in the ICU.IELSR2 register            |  |  |  |
| 19                  | 3                            | 04Ch          | ICU.IELSR3  | Event selected in the ICU.IELSR3 register            |  |  |  |
|                     | •                            | •             |             | -                                                    |  |  |  |
| 107                 | 91                           | 1ACh          | ICU.IELSR91 | Event selected in the ICU.IELSR91 register           |  |  |  |
| 108                 | 92                           | 1B0h          | ICU.IELSR92 | Event selected in the ICU.IELSR92 register           |  |  |  |
| 109                 | 93                           | 1B4h          | ICU.IELSR93 | Event selected in the ICU.IELSR93 register           |  |  |  |
| 110                 | 94                           | 1B8h          | ICU.IELSR94 | Event selected in the ICU.IELSR94 register           |  |  |  |
| 111                 | 95                           | 1BCh          | ICU.IELSR95 | Event selected in the ICU.IELSR95 register           |  |  |  |

# **EXCEPTION HANDLING STATE MACHINE**



source: Authors



# FUNCTIONAL MODEL OF THE NVIC



BIG IDEAS FOR EVERY SPACE RENESAS

# **NVIC – ARM DOCUMENTATION**

- ARMv7-M Architecture Reference Manual (2014)
   <u>ARM DDI 0403E.b</u>
- ARM® Cortex® -M4 Processor Revision: r0p1 (2015)
   Technical Reference Manual
   <u>ARM 100166\_0001\_00\_en</u>
- Cortex<sup>™</sup>-M4 Devices Generic User Guide (2011)
   <u>ARM DUI 0553A</u>



#### Table 6-1 NVIC registers

BIG IDEAS FOR EVERY SPACE RENESAS

| Address                 | Name                    | Туре | Reset      | Description                              |
|-------------------------|-------------------------|------|------------|------------------------------------------|
| 0×E000E004              | ICTR                    | RO   | -          | Interrupt Controller Type Register, ICTR |
| 0xE000E100 - 0xE000E11C | NVIC_ISER0 - NVIC_ISER7 | RW   | 0x00000000 | Interrupt Set-Enable Registers           |
| 0xE000E180 - 0xE000E19C | NVIC_ICER0 - NVIC_ICER7 | RW   | 0x00000000 | Interrupt Clear-Enable Registers         |
| 0xE000E200 - 0xE000E21C | NVIC_ISPR0 - NVIC_ISPR7 | RW   | 0x00000000 | Interrupt Set-Pending Registers          |
| 0xE000E280- 0xE000E29C  | NVIC_ICPR0 - NVIC_ICPR7 | RW   | 0x00000000 | Interrupt Clear-Pending Registers        |
| 0xE000E300 - 0xE000E31C | NVIC_IABR0 - NVIC_IABR7 | RO   | 0x00000000 | Interrupt Active Bit Register            |
| 0xE000E400- 0xE000E4EC  | NVIC_IPR0 - NVIC_IPR59  | RW   | 0x00000000 | Interrupt Priority Register              |

source: ARM® Cortex® -M4 Technical Reference Manual

### **NVIC REGISTERS – ICTR**

Since the number of input lines (IRQi) to the NVIC is implementation dependent, so is the number of registers to control the NVIC. ICTR informs how many control registers are actually implemented in any given NVIC. For the Renesas S7G2. ICTR.INTLINESNUM holds the value 2. meaning that there are 3 registers of each type (ISER, ICER, ISPR, ICPR, IABR, with indexes 0..2; and 24 registers IPR, with indexes 0..23). The number of input lines IRQi on this processor is limited to 96.



source: ARM® Cortex® -M4 Technical Reference Manual

**BIG IDEAS FOR EVERY SP** 

RENESAS

31

#### **NVIC REGISTERS – ISER – S7G2**



In a Renesas S7G2, each bit of registers ISER[0] to ISER[2] corresponds to one of the 96 IRQi lines.

on write: 1 enables the interrupt line, 0 has no effect

on read: returns the current state of each IRQi line

0 = disabled, 1 = enabled

#### **NVIC REGISTERS – ICER/ISPR/ICPR/IABR – S7G2**

Same bit assignment as for ISER.

ICER: on write: 1 disables the interrupt line, 0 has no effect

on read: report the current state of each IRQi line, 0 = disabled, 1 = enabled

ISPR: on write: 1 sets the interrupt line to **pending**, 0 has no effect

on read: report the current state of each IRQi line, 0 = not-pending, 1 = pending

ICPR: on write: 1 clears the pending state of the interrupt line, 0 has no effect

on read: report the current state of each IRQi line, 0 = not-pending, 1 = pending

IABR: read only: report the current state of each IRQi line, 0 = not-active, 1 = active



## **NVIC PRIORITIES**

On the Cortex-M4, each IRQi line has a register that defines its priority level in relation to the other IRQi lines. This register may have up to 8 bits (implementation defined).

On the S7G2, 4-bit registers are implemented, allowing the definition of up to 16 priority levels. 0 is the highest priority and 15 is the lowest. Since these bits are left aligned, the actual values are 0, 0x10, 0x20, 0x30, ... 0xF0.

A higher priority interrupt preempts a lower priority interrupt whose handler is being executed.



#### **NVIC PRIORITIES**

The bits of the priority register are divided into:

- Priority Group
- Priority Subgroup

The bits in the Priority Group define the number of priority levels for the purpose of preemption.

The bits in the Priority Subgroup define the number of sub-levels for the purpose of selecting which IRQi will be serviced first if two IRQi are simultaneously pending when the core accepts an interrupt.



#### **NVIC PRIORITIES**

The PRIGROUP bits of the AIRCR register are used to configure the division of bits among Priority Group and Subgroup.

AIRCR.PRIGROUP may be written with values in the range of 0..7

On the S7G2, programming PRIGROUP with 0, 1, 2 or 3 has the effect of using the four bits for Priority Group and none for the Subgroup.

For PRIGROUP = 4 the division is 3.1 (3 for Group and 1 for Subgroup)

For PRIGROUP = 5 the division is 2.2, and so on...



These is a partial list of the functions available in CMSIS-CORE that provide access to the NVIC as well as to other interrupt functionality.

Next slides detail these functions

| CMSIS function                                                       | Description                                    |
|----------------------------------------------------------------------|------------------------------------------------|
| <pre>void NVIC_SetPriorityGrouping (uint32_t PriorityGroup)</pre>    | Set priority grouping                          |
| uint32_t NVIC_GetPriorityGrouping (void)                             | Read the priority grouping                     |
| void NVIC_EnableIRQ (IRQn_Type IRQn)                                 | Enable a device-specific interrupt             |
| uint32_t NVIC_GetEnableIRQ (IRQn_Type IRQn)                          | Get a device-specific interrupt enable status. |
| void NVIC_DisableIRQ (IRQn_Type IRQn)                                | Disable a device-specific interrupt            |
| uint32_t NVIC_GetPendingIRQ (IRQn_Type IRQn)                         | Get the pending device-specific interrupt      |
| void NVIC_SetPendingIRQ (IRQn_Type IRQn)                             | Set a device-specific interrupt to pending     |
| void NVIC_ClearPendingIRQ (IRQn_Type IRQn)                           | Clear a device-specific interrupt from pending |
| uint32_t NVIC_GetActive (IRQn_Type IRQn)                             | Get the device-specific interrupt active       |
| <pre>void NVIC_SetPriority (IRQn_Type IRQn, uint32_t priority)</pre> | Set the priority for an interrupt              |
| uint32_t NVIC_GetPriority (IRQn_Type IRQn)                           | Get the priority of an interrupt               |

source: infocenter.arm.com

**BIG IDEAS FOR EVERY SPACE** 

RENESAS

#### typedef enum {

| /*                    | <u>Cortex-M4</u> J | Process | <u>or E</u> | Exceptions Numbers*/                                                              |         |
|-----------------------|--------------------|---------|-------------|-----------------------------------------------------------------------------------|---------|
| Reset_IRQn            | = -15,             | /*!<    | 1           | Reset Vector, invoked on Power up and warm reset                                  | */      |
| NonMaskableInt_IRQn   | = -14,             | /*!<    | 2           | Non <u>maskable Interrupt, cannot be stopped or preempted</u>                     | */      |
| HardFault_IRQn        | = -13,             | /*!<    | 3           | Hard Fault, all classes of Fault                                                  | */      |
| MemoryManagement_IRQn | = -12,             | /*!<    | 4           | Memory Management, MPU mismatch, including Access Violation and No Match          | * /     |
| BusFault_IRQn         | = -11,             | /*!<    | 5           | Bus Fault, Pre-Fetch-, Memory Access Fault, other address/memory<br>related Fault | ?<br>*/ |
| UsageFault IRQn       | = -10,             | /*!<    | 6           | Usage Fault, i.e. <u>Undef Instruction, Illegal State Transition</u>              | */      |
| SVCall_IRQn           | = -5,              | /*!<    | 11          | System Service Call via SVC instruction                                           | */      |
| <br>DebugMonitor_IRQn | = -4,              | /*!<    | 12          | Debug Monitor                                                                     | */      |
| PendSV_IRQn           | = -2,              | /*!<    | 14          | Pendable request for system service                                               | */      |
| SysTick_IRQn          | =    -1,           | /*!<    | 15          | System Tick Timer                                                                 | */      |
| } IRQn_Type;          |                    |         |             |                                                                                   |         |

This is the IRQn\_Type enumeration defined in file S7G2.h



void \_\_enable\_irq(void)

Resets PRIMASK in the core, allowing interrupts from NVIC to be serviced.

```
Example: ___enable_irq( );
```

void \_\_\_disable\_irq(void)

Sets PRIMASK in the core, preventing exceptions with configurable priorities (exceptions 4 and up) to be serviced. Example: disable irq();



void NVIC\_EnableIRQ(IRQn\_Type)
Enables (unmask) a specific IRQi line

Example: NVIC\_Enable (SysTick\_IRQn);

void NVIC\_DisableIRQ(IRQn\_Type)

Disables (mask) a specific IRQi line

Example: NVIC\_Disable (SysTick\_IRQn);

# **CMSIS-CORE INTERRUPT FUNCTIONS**

uint32\_t NVIC\_GetPendingIRQ(IRQn\_Type)
Reads the Pending status (P\_FF) returning 0 (not pending) or 1 (pending)
Example: uint32\_t pend = NVIC\_GetPendingIRQ(SysTick\_IRQn);

void NVIC\_SetPendingIRQ(IRQn\_Type)

Sets the Pending status (P-FF) of a specific IRQi line

Example: NVIC\_SetPendingIRQ(SysTick\_IRQn);

void NVIC\_ClearPendingIRQ(IRQn\_Type)
Clears (resets) the Pending status (P-FF) of a specific IRQi line
Example: NVIC ClearPendingIRQ(SysTick IRQn);

# **CMSIS-CORE INTERRUPT FUNCTIONS**

void NVIC\_SetPriority(IRQn\_Type IRQn, uint32\_t priority)
Sets the priority of a specific IRQi line

```
Example: NVIC_SetPriority(SysTick_IRQn, 4);
```

uint32\_t NVIC\_GetPriority(IRQn\_Type IRQn)

Get the priority level of a specific IRQi line

Example: uint32\_t prio = NVIC\_GetPriority(SysTick\_IRQn);

Rem: The integer value of the priority must be in the range of 0 .. 2N-1, where N is the number of priority bits implemented. For S7G2 the range is 0..15.



# **CMSIS-CORE INTERRUPT FUNCTIONS**

uint32\_t NVIC\_GetActive(IRQn\_Type)

Reads the Active status (ACTIVE\_FF) returning 0 (not active) or 1 (active)

Example: uint32\_t act = NVIC\_ GetActive(SysTick\_IRQn);



# 7 – ANALOG INTERFACING

- ADC Analog to Digital Converter
- DAC Digital to Analog Converter



recommended readings:

- 1- http://www.analog.com/en/analog-dialogue/articles/the-right-adc-architecture.html
- 2- The Data Conversion Handbook, Edited by Walt Kester, Analog Devices Inc.



### **ANALOG VS DIGITAL**

- Real world phenomena, such as audio, images, temperature, forces, pressure, and so, can be represented by waveforms that are continuous both in time and amplitude with an infinite resolution.
- Sensors are able to convert these physical quantities into analog electrical signals that can be processed by analog circuits. This was the most common case a few decades ago: radio, audio amplifiers, television, ...
- Nowadays, these physical quantities are converted to a sequence of numbers, i.e. they were digitized, so that they can be processed by a computer (digital processor).



# **ANALOG VS DIGITAL**

| Analog                                                                                                                                                                                              | Digital                                                                                                                                                            |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Physical quantities are converted to electrical signals that are <b>continuous</b> both in time and amplitude.                                                                                      | Physical quantities are converted into numeric codes after being <b>discretized</b> both in the time ( <b>sampling</b> ) and in amplitude ( <b>quantization</b> ). |  |  |
| Analog signal are prone to <b>noise</b> and<br><b>distortion</b> during processing and<br>transmission. Hence, <b>signal quality</b><br><b>decreases</b> as the signal travels through a<br>system. | Digital signals are much more <b>robust</b> to<br>noise and distortion. They can be<br><b>restored</b> to their original value after a<br>noisy system stage.      |  |  |
| Analog processing is typically done by a hardwired circuit that performs a <b>predefined processing</b> function.                                                                                   | Digital signal processing is typically performed in <b>software</b> , thus, its function can be changed <b>dynamically.</b>                                        |  |  |

# **INTERACTING WITH AN ANALOG WORLD**



To interact with the physical quantities in the real world, sensors and actuators are required.

**Sensors** perceive ("read") a phenomena and translate it to an electrical signal. The output of a sensor can be an analog signal or a digital signal.

Analog sensors require an Analog-to-Digital conversion before the information is digitally processed.

Actuators act upon ("write to") the environment. The input of an actuator may be an analog or digital signal. To connect a digital processor to an analog actuator a Digital-to-Analog conversion is required.

**Page 223** 

**.** 





source: Authors

RENESAS

**BIG IDEAS FOR EVERY SPACE** 

### **EXAMPLE OF A DIGITAL SENSOR - ENCODER**

A rotary optical encoder is an angular position sensor. It consists of a disc with transparent and opaque areas that are detected by a photodetector.

The disc show is of an absolute rotary encoder. Alternatively, an incremental (or relative) rotary encoder generates pulses to represent angular movement of its axis. A set of two pulse stream, shifted by 90 degrees, allows the detection of the

direction of movement in an incremental rotary encoder.





### **EXAMPLE OF AN AUDIO PROCESSING SYSTEM**



In this example, the microphone is an analog sensor;

the speaker is an analog actuator and its driver is the amplifier.



## THE ANALOG-TO-DIGITAL CONVERSION PROCESS

The conversion of an analog signal to digital requires several steps:

- 1. Low-pass filter to guarantee that the input signal spectrum is limited to a given frequency (f<sub>signal</sub>)
- 2. Sampling (time discretization) at periodic intervals take samples of the analog signal. The signal amplitude is still an analog value.
- 3. Quantization (amplitude discretization) mapping of the continuous amplitude range into a set of discrete values.



### SAMPLING

The green curve represents an analog signal S(t).

This signal is sampled periodically, T being the sampling period, resulting in a discrete sequence of samples Si (i = 1, 2, 3, ...).

The amplitude of each sample is an analog value.

Sampling is performed by a **Sample-and-Hold** (S&H) circuit, represented by a switch and a capacitor. The switch closes momentarily, the capacitor is charged with the current value of the input signal, the switch opens and the value remains "memorized" by the capacitor.



**BIG IDEAS FOR EVERY SPACE** 

# QUANTIZATION

To illustrate de quantization performed by an ADC, consider the transfer function on the right. The horizontal axis is the analog input values to the ADC and the vertical axis are the digital codes produced by the ADC. In this example the ADC has 3 bits, hence, it is able to represent 8 binary values, from 0 (000) to 7 (111). The input range for this example is from 0 to 8 volts.

The bold line in the graph is the transfer function. If the input voltage is 3.8 volts, the output code will be 4 (100), representing 4 volts. The difference between the actual input value (3.8) and the output value (4) is the quantization error and it is due to the output assuming only a discrete set of values.



source: Renesas DevCon2015 Mitch Ferguson - ADC Specifications



### **OUTPUT VALUE CALCULATION**

a) Unipolar: the quantization levels are distributed from 0 to Vref.
For an ADC with N-bit resolution, there are 2<sup>N</sup> quantization levels.
Each quantization level corresponds to an input range q, where

$$q = \frac{Vref}{2^N}$$

Hence, q corresponds to the input range of the LSb (Least Significant bit) of the output code.

The output code (n) of an unipolar ADC, for Vin in the range of 0..(Vref-q) is given by:

$$n = int\left(\frac{Vin}{Vref} * (2^N) + \frac{1}{2}\right)$$

Example: N = 10 bits, Vref = 5V, Vin = 2.5V

q is 4.88 mV and the output code is 512 (10 0000 0000b)

int(x) results in the integer part of x by truncation. Hence, for  $x \ge 0$ , int(x) = floor(x) and for x < 0, int(x) = ceiling(x)



### **OUTPUT VALUE CALCULATION**

b) Bipolar: the quantization levels are distributed from  $V_{\text{-ref}}$  to  $V_{\text{+ref}}$ 

Where typically,  $V_{-ref} = -V_{+ref}$ 

Each quantization level corresponds to an input range q, where

$$q = \frac{V_{+ref} - V_{-ref}}{2^N}$$

The output code (n) of a bipolar ADC, for Vin in the range of  $V_{-ref}$  .. ( $V_{+ref}$ -q) is given by:

$$n = int\left(\frac{Vin - V_{-ref}}{V_{+ref} - V_{-ref}} * (2^N) + \frac{1}{2}\right)$$

Example: N = 10 bits,  $V_{+ref} = 5V$ ,  $V_{-ref} = -5V$ , Vin = 0V

q is 9.76 mV and the output code is 512 (10 0000 0000b)

# **ANALOG-TO-DIGITAL CONVERSION EXAMPLE**

On the upper figure, the grey line represents the input analog signal. The dashed lines indicate the sampling times. The red line is the output of the sample-and-hold. It changes value exactly at the sampling times.

In the lower figure, the red dots represent the output of the ADC. The effect of the quantization error is noticeable as the distance between the red dot and the input signal.

The output of the ADC is the following numeric sequence: 4,5,4,3,4,6,7,5,3,3,4,4,3.



**BIG IDEAS FOR EVERY SP** 

RENESAS

# SIMPLE ADC (3-BIT FLASH)

This circuit implements a 3-bit Flash ADC. It is the fastest ADC topology. Vin is in the range 0...Vref and Vref is 8V.

For an ADC with 2N possible output values, 2N -1 comparators are required. Thus, Flash ADCs are usually implemented for a small number of bits.

The resistor ladder provides the appropriate reference voltages for each comparator. In this case: 0.5V, 1.5V, 2.5V, ... 6.5V.

When a comparator detects that the input voltage (Vin) is higher than its reference voltage, its output changes to level 1.

The priority encoder (I7 is highest priority and I0 is lowest) generates the binary code corresponding to the highest priority active input.



### **ADC CHARACTERISTICS**

**Resolution**: the number of bits (N) of the output code of the ADC. The number of quantization levels is given by  $2^{N}$ . A 10-bit ADC has 1024 quantization levels. Hence, for a reference voltage of 1V, each quantization level is 0.97mV (1V/1024). The quantization error is up to  $\pm 0.485$ mV (.97/2).

**Conversion time**: how long does it take to the ADC to perform a conversion. Currently, most ADCs integrated in MCUs take from 0.1 $\mu$ s to 1 $\mu$ s. Flash ADCs may take less than 10 ns. The conversion time determines the maximum **sampling frequency** (f<sub>sampling</sub>). By the Nyquist theorem, the sampling frequency should be larger than twice the highest frequency in the input signal, i.e. f<sub>sampling</sub> > 2 \* f<sub>signal</sub>.

# **ADC CHARACTERISTICS**

### DC (and low frequency) errors.

The green line represents the ideal transfer function.

The black line represents the actual transfer function including **offset** errors and **non-linearity** errors.

The red line corrects non-linearities but offset errors are still present.



source: Renesas DevCon2015 Mitch Ferguson - ADC Specifications



### **ADC CHARACTERISTICS**

### **Differential non-linearity (DNL)**

The ideal transfer function is shown as the dotted line.

Actual transfer function is shown in bold line.

DNL causes wider or narrower code widths. Also, increases quantization noise.



source: Renesas DevCon2015 Mitch Ferguson - ADC Specifications



## **ADC IMPLEMENTATIONS**

The most common ADC architectures (topologies) are:

### Description

It is the fastest but also the one that requires the most circuitry (2<sup>N</sup> comparators and resistors).

Two ADCs in sequence, the first resolves the MSb and the second the LSb.

Resolves bit-by-bit, thus, requiring a single comparator. Takes N clock cycles to generate the result.

Based on sigma-delta modulation, it is a 1-bit ADC that tracks the signal. It is based on oversampling, digital filtering and decimation.

Uses a single comparator whose reference voltage is a ramp. Counts the number of clock pulses to the ramp to reach the value of the input signal.

Integrates the input signal then integrates -Vref until the result of the integration reaches 0. Measures the time for the -Vref integration which is proportional to the amplitude of Vin.



### SAR ADC

A SAR ADC (Successive Approximation Register Analog-to-Digital Converter) is based on a SAR, a Digital-to-Analog Converter and a Comparator.

The basic operation is to sequentially compare in input value to half of the analog range, decide if the input is in the upper or lower half, store this bit of information and move to the next comparison.



The same example as in the slide <u>Quantization</u>. Vin = 3.8V, Vref = 8V, 3-bit ADC.

On the first clock cycle (Clk0):

- The SAR consists of a Shift Register (top) and a register holding the partial results (bottom).
- The start input of SAR is 1, this sets the first bit of the Shift Register in the SAR.
- The bit of the shift-register that is set, is used to compose the current reference value.
- The output 100 of the SAR is converted by the DAC to 4V, producing a 3.5V reference.
- The 3.8V input is compared to the 3.5V reference producing a 1 at the output of the comparator.

This is the MSb of the result that is latched in the SAR at the start of Clk1.





On the second clock cycle (Clk1):

- The start input of SAR is 0.
- The SARs Shift Register shifted the 1 bit to the next position.
- The partial result register holds a 1 at b2 that was latched at the start of the cycle, while b1 holds a 1 from the middle bit of the shift-register.
- The output 110 of the SAR is converted by the DAC to 6V, producing a 5.5V reference.
- The 3.8V input is compared to the 5.5V reference producing a 0 at the output of the comparator.

This is the next bit of the result that is latched in the SAR at the start of Clk2.



On the third clock cycle (Clk2):

- The start input of SAR is 0.
- The SARs Shift Register shifted the 1 bit to the next position.
- The partial result register holds a 10 at b2 b1 from the two previous comparisons, while b0 holds a 1 from the last bit of the shiftregister.
- The output 101 of the SAR is converted by the DAC to 5V, producing a 4.5V reference.
- The 3.8V input is compared to the 4.5V reference producing a 0 at the output of the comparator.

This is the next bit of the result that is latched in the SAR at the start of the next clock



On the next clock cycle the result is available.

- The last bit of the shift-register is shifted out to EOC (end-of-conversion).
- The result of the conversion is presented at b2 b1 b0 that hold the results of the three previous comparisons.





## **DIGITAL TO ANALOG CONVERSION**

The Digital to Analog Converter (DAC) performs the opposite conversion of the ADC, i.e. it converts a digital value into the corresponding analog value according to the formula:

Analog output (V) = 
$$\frac{Digital Value}{2^N} V_{ref}$$

for an N-bit DAC whose input value is Digital Value and its analog reference voltage is V<sub>ref</sub>



# **DIGITAL TO ANALOG CONVERSION**

The schematics symbol for a DAC is:



The number of digital input lines is N for an N-bit DAC.



# **SINGLE-BIT DIGITAL TO ANALOG CONVERTER**

A single-bit DAC is the simplest form of a DAC. A single switch, which is controlled by the digital input, either connects the input of the analog amplifier to Vref or to ground. Hence, the possible analog output values are either 0 or Vref.





### **USING A PWM AS A DAC**

The effect of 5 different duty cycles after passing a low-pass filter whose cutoff frequency is much lower than the PWM frequency.



#### source: commons.wikimedia.org (CC)



# USING A PWM AS A DAC

The topology presented is a Kelvin Divider DAC, also called a string DAC. Among its advantages are its monotonicity and low-glitch.

It requires 2<sup>N</sup> resistors and switches for an N-bit DAC, which makes it impractical for a larger number of bits.





# **OPERATION OF THE 3-BIT DAC**

In this example, Vref is 8V and the digital input has the value 4 (100b).

Output O4 of the decoder is active and commands the corresponding switch. The resistor string has values 1V apart

at each of its taps.

The output analog amplifier simply provides isolation, avoiding that the impedance of the load affects the analog value at the taps of the resistor string.





### **R2R LADDER DAC**

The R2R resistor ladder topology has the advantages of requiring only 2N resistors in the ladder and the values of these resistors are either R or 2R, avoiding components with a significant difference in value, as would be the case for the binaryweighted DAC that requires values of R, 2R, 4R, 8R, 16R, ...



source: <u>The Data Conversion Handbook</u>, Edited by Walt Kester, Analog Devices Inc.



# DAC CASE STUDY THE S7G2 DAC

Characteristics:

- Two 12-bit DACs available: DAC0 and DAC1,
- The 12-bit value present at the DADRi register is converted to an analog value of  $V_{(ref)} DADRi/4096$ ,
- Output amplifier is available, may be enabled under SW control,
- DAC operation may be synchronized to ADC1,
- DAC conversion may be started by an ELC event.

# DAC CASE STUDY THE S7G2 DAC

DAC0 and DAC1

block diagram



## DAC CASE STUDY THE S7G2 DAC

#### Renesas S7G2 DAC characteristics:

| Item                     | Min | Тур  | Max         | Unit | Test conditions       |
|--------------------------|-----|------|-------------|------|-----------------------|
| Resolution               | -   | -    | 12          | Bits | -                     |
| Without output amplifier |     |      | I           | 1    |                       |
| Absolute accuracy        | -   | -    | ±24         | LSB  | Resistive load 2 MΩ   |
| DNL                      |     | ±1.0 | ±2.0        | LSB  | Resistive load 2 MΩ   |
| Output impedance         | -   | 7.5  | -           | kΩ   | -                     |
| Conversion time          | -   | -    | 3.0         | μs   | Capacitive load 20 pF |
| With output amplifier    | ŀ   |      | ł           | ł    | 1                     |
| INL                      | -   | ±2.0 | ±4.0        | LSB  | -                     |
| DNL                      | -   | ±1.0 | ±2.0        | LSB  | -                     |
| Conversion time          | -   | -    | 4.0         | μs   | -                     |
| Resistive load           | 5   | -    | -           | kΩ   | -                     |
| Capacitive load          | -   | -    | 50          | pF   | -                     |
| Output voltage range     | 0.2 | -    | VREFH - 0.2 | V    | -                     |

#### Table 2.43 D/A conversion characteristics

source: Renesas S7G2 datasheet



# **8 – SERIAL COMMUNICATIONS**

Serial Communications - Introduction

### UART

- Concepts, Block Diagram, Registers
- SPI
  - Concepts, Block Diagram, Registers
- I2C
  - Concepts, Block Diagram, Registers



# 8.1 – INTRODUCTION TO SERIAL COMMUNICATIONS

### Concept:

- In serial communications ONE bit is transmitted at a time, from the transmitter device (TX) to the receiver device (RX). As opposed to parallel communications where several bits, e.g. 8 bits or 1 byte, are transmitted concurrently.
- In serial communications a reduced number of wires are required.
- Long distance wired communications typically use serial communication.

## **EXAMPLES OF SERIAL COMMUNICATIONS STANDARDS**

- UART: Universal Asynchronous Receiver Transmitter
- SPI: Serial Peripheral Interface
- I2C: Inter-Integrated Circuit
- USB: Universal Serial Bus
- Ethernet

# **DIRECTION OF COMMUNICATION**

- Simplex: the communication occurs in a single direction one device transmits and the other receives.
- Half-Duplex: the communication occurs in both directions but not simultaneously. Both communicating devices (DevA and DevB) have transmitters and receivers. At a given time, either DevA transmits and DevB receives or vice-versa. A single wire is needed to carry the communication.
- Full-Duplex: the communications occurs in both directions and can be simultaneous. Usually two wires are used: one to transmit from DevA to DevB and another to transmit from DevB to DevA.

rem: a transceiver consists of a transmitter and a receiver.





source: Renesas



## SYNCHRONOUS VS ASYNCHRONOUS COMMUNICATIONS

- **Synchronous:** there is clock signal that identifies the time instances when a data bit is valid. Thus, the receiver uses the clock signal to recover the transmitted information. SPI and I2C are examples of synchronous communication protocols.
- Asynchronous: there is no common clock signal, thus, the two communicating devices must previously agree on a mechanism to identify each bit in the data stream. Therefore, the synchronization information must be embedded in the data signal. Quite often there are transitions in the data signal to identify the time slot of each bit in the data stream. RS-232 is an example of asynchronous communication.

### **BIT RATE VS BAUD RATE**

Symbols: when transmitting signals over a wire, each possible combination of amplitude, phase and frequency is called a symbol. Simple schemes use only two symbols: for instance 0V and 3.3V to represent 0 and 1, or the coding used by
 RS-232 where amplitudes from -3 to -15 represent a 0.



BIG IDEAS FOR EVERY SPACE RENESAS

### **BIT RATE VS BAUD RATE**

• **Symbols(cont):** a much larger set of symbols is also possible, for instance, 256QAM, one of the many encodings used for high speed ethernet, has 256 possible symbols, hence, each symbol encodes 8 bits.

| <ul> <li>Bit rate: is the number of bits that are transmitted<br/>per time unit. Expressed in bits/s.</li> </ul>        |                          | •       | • | 0       | • | • | • | • |   | <b>?</b> | • | 0 | 0 | • | 0 | 0 | •       |
|-------------------------------------------------------------------------------------------------------------------------|--------------------------|---------|---|---------|---|---|---|---|---|----------|---|---|---|---|---|---|---------|
| Baud rate: is the number of symbols that are                                                                            |                          | •       | • | •       | • | • | • | • | • | 0        | • | 0 | • | • | • | • | •       |
| <ul><li>transmitted per time unit. Expressed in baud/s.</li><li>If a symbol encodes a single bit, such as the</li></ul> |                          | •       | • | •       | • | • | • | • | • | 0        | • | 0 | 0 | • | 0 | • | •       |
| case for RS-232, then the baud rate and the                                                                             |                          | •       | • | •       | • | • | • | • | • | 0        | • | • | • | • | • | 0 | → <br>● |
| bit rate are the same.<br>Yet, for 256QAM, the bit rate is 8 times higher                                               |                          | •       | • | •       | • | • | • | • | • | 0        | • | 0 | 0 | • | 0 | 0 | •       |
| than the baud rate.                                                                                                     |                          | •       | • | •       | • | • | • | • | • | •        | • | • | • | • | • | • | •       |
| source: cor                                                                                                             | nmons.wikimedia.org (CC) | $\circ$ | 0 | $\circ$ | 0 | 0 | 0 | 0 | • | 0        | • | 0 | 0 | • | 0 | • | •       |

### 8.2 – UART

A UART is a peripheral present in most MCUs. Typically it receives data from the processor over the bus, hence, in parallel format, and handles the serialization and frame formatting.

A UART (Universal Asynchronous Receiver Transmitter) is capable of transmitting asynchronous data frames to another device as well as receiving. Both devices must be configured for the same speed and frame format.

Typical speeds used for asynchronous serial communication are: 110, 150, 300, 600, 1200, 2400, 4800, 9600, 19200,

38400, 57600, 115200 bits per second. Higher speeds may also be used as long as agreed among transmitter and receiver. Typically, the bit encoding defined by the RS-232 standard is used.

RS-232 defines separate lines for transmission and reception, thus, it is **full duplex** communication.



**Asynchronous** frame format – consists of a start bit, data bits, an optional parity bit and stop bits.

The frame format is configurable:

- number of data bits: 5 to 8,
- number of stop bits: 1, 1.5 or 2,
- parity: none, odd, even.



source: commons.wikimedia.org (CC)

**BIG IDEAS FOR EVERY SPA** 

RENESAS



How does the receiver synchronize with the transmitter?

- 1. Both the transmitter and the receiver are configured in the same way: speed and frame format.
- 2. Maximum clock skew allowed between the two sides is typically lower than 2%.
- 3. Receiver samples at a higher rate (e.g. 16 times de baud rate) for the start-bit transition. A delay of half-bit period determines the mid-bit position. From then on, sample every one-bit time.



How does the receiver synchronize with the transmitter?



source: Renesas





Example of the transmission of the character G (ASCII code 0x47) over an asynchronous line. Note that the LSb is transmitted first.

Upper figure shows UART levels while lower figure shows RS-232 levels.

Configuration: 8O1.5 (eight bits, odd parity, 1.5 stop bits).

For a 9600 bps, the duration of each bit is 104.16 us.





A frequently used connector for RS-232 is the DB-9. Shown here are the signals on each pin. TxD carries the transmitted data and RxD carries incoming data to the receiver.





### 8.3 – SPI: SERIAL PERIPHERAL INTERFACE

### **SPI = Serial Peripheral Interface**

- Is a synchronous serial communication intended to be used to connect an MCU to external memory devices and peripherals such as: Flash EEPROM, ADC, DAC, temperature sensor, digital potentiometer, Real-Time Clock, ...
- The **topology** is based in master and slave devices. There can be a single master, but multiple slaves are allowed.
- It uses 4 wires: data from master to slave, data from slave to master, clock and slave select. It is full duplex communication.
- There are many possible configurations; it has been reported that not all SPI devices are compatible, i.e. have a common configuration.



Single-slave connection:

- SCLK: Serial Clock. Generated by the master;
- MOSI: Master Out Slave In;
- MISO: Master In Slave Out;
- SS: Slave Select (active low).



## **SPI – OPERATION**

- The Master selects a Slave by activating the /SS line.
- On every clock cycle, one bit is transferred from the master to the slave and another bit is transferred from the slave to the master.
  - Not every transfer is significant.
- Typically the transfers occur in multiples of 8 bits.





# **SPI – CONFIGURATION**

 CPOL: clock polarity selection

• CPHA:

clock phase selection

Observe that bits change on one clock edge and they are sampled on the other.



# **SPI – MULTI-SLAVE**

- MISO lines must be tri-state to be interconnected. They must go to high-impedance when the /SS line is not active.
- The Master selects one of the slaves to exchange data with it.
   Hence, separate Slave Select lines are required.



# 8.4 – I2C: INTER-INTEGRATED CIRCUIT

- Synchronous half-duplex communications among multiple devices on a bus.
- Developed by a division of Philips in the 80's. This division is now NXP.
- Needs only two wires: data and clock.
- Bus drivers are open-drain with pull-up resistors, allows for multiple transmitters connected to the same line.
- Multiple masters are allowed on a bus. A master is the one that initiates a data transfer. Addressing modes use 7-bit and 10-bit addressing.
- Data rates: 100kbps, 400 kbps, 1 Mbps, 3.4 Mbps. (version 4 added a 5 Mbps data rate using push-pull drivers on a unidirectional bus).
- Recommended reading: <u>UM10204</u> I2C-bus specification and user manual. Rev 6 4-April-2014. NXP.





- The SCL line (Serial Clock) is driven by the bus master. When SCL is high the data line (SDA) is stable and can be read. When SCL is low then the data line can change.
- The exception of this rule is the signaling of the start-bit (negative edge of SDA while SCL is high) and stop-bit (positive) edge of SDA while SCL is high).



# **I2C – OPERATION (7-BIT ADDRESSING MODE, MASTER WRITE)**

- 1. Master: sends the start bit.
- 2. Master: sends 7-bit slave address.
- 3. Master: sends the direction bit (0 = write).
- 4. Addressed slave: sends an ACK bit (0 = acknowledge).
- 5. Master: sends 8-bit data.
- 6. Addressed slave: sends ACK bit.
- 7. repeat steps 5 and 6 while there is data to transmit.
- 8. Master: sends stop bit.



# **I2C – OPERATION (7-BIT ADDRESSING MODE, MASTER WRITE)**

### I2C peripheral of Renesas S7G2 MCU

Timing diagram of a master sending data to a slave:

#### [7-bit address format: slave reception]



source: Renesas S7 Series Microcontrollers User's Manual



# **I2C – OPERATION (7-BIT ADDRESSING MODE, MASTER READ)**

- 1. Master: sends the start bit.
- 2. Master: sends 7-bit slave address.
- 3. Master: sends the direction bit (1 = read).
- 4. Addressed slave: sends an ACK bit (0 = acknowledge).
- 5. Addressed slave: sends 8-bit data.
- 6. Master: sends ACK bit.
- 7. repeat steps 5 and 6 while there is data to transmit.
- 8. Master: sends stop bit.



# **I2C – OPERATION (7-BIT ADDRESSING MODE, MASTER READ)**

### I2C peripheral of Renesas S7G2 MCU

Timing diagram of a slave sending data to a master:

[7-bit address format: slave transmission]



source: Renesas S7 Series Microcontrollers User's Manual

**BIG IDEAS FOR EVERY SPACE** 

RENESAS

### **I2C CASE STUDY – S7G2 IIC**

| Register | Name                             |
|----------|----------------------------------|
| ICCRx    | I2C Control Register 1,2         |
| ICMRx    | I2C Mode Register 1,2,3          |
| ICFER    | I2C Function Enable Register     |
| ICSER    | I2C Status Enable Register       |
| ICIER    | I2C Interrupt Enable Register    |
| ICSRx    | I2C Status Register 1,2          |
| ICWUR    | I2C Wakeup Unit Register         |
| SARLx    | Slave Address Register L 0,1,2   |
| SARUx    | Slave Address Register U 0,1,2   |
| ICBRL    | I2C Bit Rate Low-Level Register  |
| ICBRH    | I2C Bit Rate High-Level Register |
| ICDRT    | I2C Transmit Data Register       |
| ICDRR    | I2C Receive Data Register        |
| ICDRS    | I2C Shift Register               |



source: Renesas S7 Series Microcontrollers User's Manual



### **I2C CASE STUDY – S7G2 IIC**

- Characteristics of the I2C Bus Interface of the Renesas S7G2 MCU:
- May operate as master or as slave of an I2C bus with data rates up to 1 Mbps.
- Up to 3 different slave addresses may be configured, 7-bit or 10-bit.
- Digital noise filters for SCL and SDA signals.
- Four interrupt sources: Receive data full, Transmit data empty, Transmit end, Error (NACK, timeout, ...).

## **I2C CASE STUDY – S7G2 IIC**

Connection of multiple devices on the I2C bus.

Notice open-drain outputs and pull-up resistors forming a wired AND.



source: Renesas S7 Series Microcontrollers User's Manual

### 9 – CAN

- Introduction
- Block Diagram
- Registers
- SW Stack

## 9.1 – INTRODUCTION

CAN is an acronym for Controller Area Network. It is defined by the ISO-11808: 2003 standard and has been mainly motivated by the needs of the automotive industry, such as the ever increasing use of embedded sensors into the vehicles and the need to optimize the internal space and reduce costs with cabling.

Characteristics of CAN:

- Two-wire multi-master serial bus
- Message-based protocol
- Contention resolution via decentralized arbitration
- All messages are broadcast and processed by the nodes only if needed
- Speeds up to 1 Mbps



## **CAN TOPOLOGY**

CAN nodes are interconnected in a bus topology.

CAN physical layer is implemented with two wires (CANH and CANL).

A logical 0 (called "dominant") is obtained when CANH is approx. 3.5V and CANL is approx. 1.5V.

A logical 1 (called "recessive") is obtained when both CANH and CANL are at approx. 2.5V.



source: Authors



### **CAN BUS FRAME**

The standard CAN frame is defined as follows:

- Arbitration field (Identifier)  $\rightarrow$  defines the message identifier and its priority;
- Data  $\rightarrow$  data to be transmitted (0 to 64 bits);
- SOF, CRC, ACK and End of Frame  $\rightarrow$  error checking and synchronization;
- IFS (Interframe Space)  $\rightarrow$  idle time used to process buffers.



# **CAN BUS FRAME (CONT.)**

Control  $\rightarrow$  define the following sub-fields:

- Data length (0 to 8 bytes),
- Requ. Request (RTR)  $\rightarrow$  used to identify a Remote Frame  $\rightarrow$  see following slides,
- ID Ext. (IDE)  $\rightarrow$  used to identify a Standard or Extended Frame:
  - Standard Frame  $\rightarrow$  IDE is dominant "0", 11-bit identifier as shown in picture,
  - Extended Frame → IDE is recessive "1", 29-bit identifier. The remaining 18 bits of the identifier are placed right after the IDE bit, followed by an extra RTR bit. The original RTR is called SRR (Substitute Remote Request) and acts as a placeholder.



### **CAN MESSAGE TYPES**

- **Data** Frame  $\rightarrow$  carries data sent by a Node:
  - The RTR bit is dominant "0" to identify a Data Frame;
  - It is always preceded by an Interframe Space.
- **Remote** Frame  $\rightarrow$  carries a request for a transmission of data from another Node:
  - The Arbitration/Identifier field carries the Identifier of the requested Node;
  - The RTR bit is recessive "1" to identify a Remote Frame;
  - The Data field is empty and the Data Length part of Control field determines the length of the requested message;
  - It is always preceded by an Interframe Space.



### **CAN MESSAGE TYPES**

- Error frame  $\rightarrow$  special format used to signal an error;
  - Not preceded by an Interframe Space.
- **Overload** frame  $\rightarrow$  special format used to provide an extra delay between messages (receiver too busy);
  - Not preceded by an Interframe Space.

# **CAN ARBITRATION PROCESS**

- Every message has a priority level corresponding to its identifier (arbitration field) → the lower the value, the higher the priority.
- When two or more nodes try to transmit at the same frame time:
  - Identifier bits 0 are "dominant" over identifier bits 1 "recessive";
  - The node that sends a 1 and reads back a 0 stops transmitting on that frame  $\rightarrow$  retries on the next frame;
  - The node that sends a 0 and reads back a 0 retains control and goes on to send the next identifier bit;
  - After all the identifier bits are tested, the node that keeps on retaining control (i. e. the node whose message identifier has the highest priority) sends the message contents.

## 9.2 – BLOCK DIAGRAM

Implementation for the CAN Module of the S7G2 MCU.

Message reception and transmission organized in *mailboxes* → configurable as single or FIFOs for different types of messages.



Source: Renesas Synergy MCUs User's Manual: Hardware

**BIG IDEAS FOR EVERY SPACE** 

RENESAS



Implementation for the CAN Module of the R7FS7G27H3A01CFC Renesas ARM Cortex-M4 MCU:

- CTLR  $\rightarrow$  mailbox mode, bus operation and/or reset, timestamp configuration;
- BCR  $\rightarrow$  data transfer rate configuration;
- MKR[0...7]  $\rightarrow$  define masks for reception of specific messages (IDs) into specific mailboxes (depending on MKR index);
- FIDCR[0..1] → similar to MKR but for FIFO mailboxes;
- MKIVLR → enables or disables masking (via MKR) for message acceptance;
- MIER → enable/disable mailbox interrupts;
- MCTL\_TX[0..31]  $\rightarrow$  transmission control for each mailbox;
- MCTL\_RX[0..31]  $\rightarrow$  reception control for each mailbox;



- MB[0..31]  $\rightarrow$  register groups for each mailbox:
  - MB[0..31].ID  $\rightarrow$  received or transmitted message identifiers;
  - MB[0..31].DL  $\rightarrow$  data length;
  - MB[0..31].D[0..7]  $\rightarrow$  received or transmitted data;
  - MB[0..31].TS  $\rightarrow$  timestamp for received messages.
- RFCR, TFCR  $\rightarrow$  receive and transmit FIFO control;
- RFPCR, TFPCR  $\rightarrow$  increment of the CPU-controlled pointer for receive and transmit FIFOs;
- STR → global CAN status register (new data received, receive and transmit FIFO status, CAN mode status and error status);
- EIER  $\rightarrow$  enable / disable error interrupts;
- EIFR → status of error detection.



- RECR, TECR  $\rightarrow$  receive / transmit error count;
- ECSR → status of CAN bus errors;
- TSR  $\rightarrow$  stores the timestamp;
- TCR  $\rightarrow$  test control.

# 9.4 – SOFTWARE STACK – CASE STUDY

Example of CAN stack for Renesas Synergy microcontroller hardware.

(https://www.renesas.com/en-

us/software/D6001427.html)



Source: Renesas Synergy CAN HAL Driver Module Guide <u>r11an0065eu0101-synergy-can-hal-mod-guide</u>



# 9.4 – SOFTWARE STACK – CASE STUDY

Example of CAN API for Renesas Synergy microcontroller hardware

| Function Name | Example API Call and Description                                                                                                                                                                                                                                                                                                              | ]                                                      |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| .open         | <pre>g_can0.p_api-&gt;open(g_can0.p_ctrl, g_can0.p_cfg) The open API configures CAN Channel 0. This function must be called before any other CAN functions. Note: This call is made automatically during system initialization, prior to entering the users thread. Unless the user closes the module, open will not need to be called.</pre> |                                                        |
| .close        | g_can0.p_api->close(g_can0.p_ctrl)<br>The close API handles the clean-up of internal driver data.                                                                                                                                                                                                                                             | Basic API                                              |
| .read         | g_can0.p_api->read (g_can0.p_ctrl, p_args->mailbox,<br>&receiveFrame)<br>The read API reads received CAN data.                                                                                                                                                                                                                                | functions                                              |
| .write        | g_can0.p_api->write (g_can0.p_ctrl, 0, &transmitFrame)<br>The write API write data into the CAN transmit frame buffer and send it out.                                                                                                                                                                                                        |                                                        |
| .control      | <pre>g_can0.p_api-&gt;control(g_can0.p_ctrl, CAN_COMMAND_MODE_SWITCH,<br/>&amp;mode); With can_mode_t mode = CAN_MODE_LOOPBACK_INTERNAL;<br/>The control API can change the CAN mode of operation.</pre>                                                                                                                                      |                                                        |
| .infoGet      | g_can0.p_api->infoGet(g_can0.p_ctrl, p_info)<br>The infoGet API retrieves the CAN mode of operation.                                                                                                                                                                                                                                          | Source: Renesas Synergy CAN HAL<br>Driver Module Guide |
| versionGet    | g_can0.p_api->versionGet(version)<br>The versionGet API retrieves the module version information.                                                                                                                                                                                                                                             | <u>r11an0065eu0101-synergy-can-hal-mod-</u><br>guide   |



#### 10 – USB

- Introduction
- Block Diagram
- Registers
- SW Stack



USB is an acronym for **Universal Serial Bus**. It has been proposed by a consortium of companies, such as Microsoft, Intel, IBM, Compaq and NEC and is designed to support a wide range of applications that require communication with distinct characteristics (real-time, high or low bandwidth, with or without message delivery guarantee etc.).

Current specification is 3.2 (Sep, 2017).



# **10.1 – INTRODUCTION**

Examples of devices that make use of USB:

- Printers
- Cameras  $\rightarrow$  interface for photo and video upload
- Smartphones  $\rightarrow$  interface for battery charging and file transfer
- Human Interface Devices  $\rightarrow$  keyboard, mouse etc.
- Development electronic boards  $\rightarrow$  debug interface (JTAG emulation)
- Game joysticks
- ....



RENESAS

**BIG IDEAS FOR EVERY SPACE** 

Characteristics of USB:

- Four (or five)-wire serial bus with single master (host) and up to 127 slaves (devices);
  - Exception  $\rightarrow$  USB On-The-Go (OTG)  $\rightarrow$  allows negotiation between two devices (point to point) to be a temporary host;
  - Example of OTG use: a camera device connected to a printer device to print photos;
- Defines low speed (1.5 Mbps), full speed (12 Mbps) and high speed (up to 5 Gbps at version 3.0) bandwidth
- Rem: USB 3.0 uses a 9-pin connector (USB-A 3.0 connector) or a 24-pin USB-C connector.

# **10.1 – INTRODUCTION**

- Four types of data transfers  $\rightarrow$  meet the requirements of different communication types
- Device class identification by the host via enumeration protocol → allows plug-and-play and hot swap capabilities, as well
  as instantiation of the proper class driver software by the host
- Bus power capabilities → some USB devices do not need an extra power source
  - USB host is able to detect overcurrent conditions, so that power can be removed from the device causing the problem without affecting the other devices already connected

#### **USB TOPOLOGY**

- USB Host Controller is the master and generates transactions (via Root Hub).
- Each Hub is physically connected (by wire) to a Node or another Hub.
- Nodes are slaves which perform the functions → also known as **Devices**.
- Each level defines a tier → maximum of 7 as USB 2.0
   Specification.
- Nodes can be inserted or removed when necessary → upon insertion, the enumeration process is executed to identify the device class and configure it.



source: Authors



# **USB PHYSICAL INTERFACE**

USB 1.1 and 2.0  $\rightarrow$  4 shielded wires.

- 2 wires for data  $\rightarrow$  differential
- 2 wires for power (5 Vdc and GND)

Type A  $\rightarrow$  host.

Type  $B \rightarrow$  device.

Mini and Micro variations use the same electrical interface in smaller form factors.

OTG  $\rightarrow$  extra pin to identify the role of the device (A or B). The receptacle is called Micro-AB and accepts both Micro-A and Micro-B connectors.

USB 3.0  $\rightarrow$  5 extra wires.



Source: By Milos.bmx (Own work) [CC BY-SA 3.0

(https://creativecommons.org/licenses/by-sa/3.0)], via Wikimedia Commons https://commons.wikimedia.org/wiki/File%3AUSB3.0\_connectors.svg



<u>CC0</u> https://commons.wikimedia.org/wiki/File:USB\_Type-C\_icon.svg



# **USB LOGICAL VIEW**

Communication flows are performed via **pipes**  $\rightarrow$  composed of **endpoints**  $\rightarrow$  unidirectional data paths.

Endpoint / pipe bundles form an **interface**  $\rightarrow$  a view to the function / device behavior as it is exposed to the host.

The host side instantiates a class **driver** during device enumeration  $\rightarrow$ manages the interfaces and provides an API to the app level.

**Default pipe** is bidirectional (endpoint 0 in both directions) and is used for device configuration.



**BIG IDEAS FOR EVERY SPACE** 

# **USB HOST CONTROLLER**

- The USB Host Controller hardware layer offers an HCI (Host Controller Interface) to the Host Controller Driver in software
   → standardizes the register access and allows interoperability between the host OS and different hardware implementations.
- Some HCI standards have been historically defined:
  - OHCI (Open Host Controller Interface) → defined for USB 1.1, manages the USB bus mainly in hardware (internal FIFO descriptors management)
  - UHCI (Universal Host Controller Interface) → proprietary interface by Intel, defined for USB 1.1, manages most of the USB bus operation in software (HCD level)

# **USB HOST CONTROLLER**

- EHCI (Enhanced Host Controller Interface) → defined for USB 2.0, manages high-speed communication on a USB bus.
   EHCI controllers have been usually implemented in PC motherboards in conjunction with UHCI or OHCI drivers (that managed the low and full-speed devices).
- xHCI (Extensible Host Controller Interface) → defined for USB 3.0, manages all the USB bus speeds. It is meant to replace the previous UHCI/OHCI/EHCI standards.



#### **USB PACKETS**

USB Transfers are performed by a sequence of transactions, which are composed of:

- A Token packet, carrying addressing, direction and packet type information (IN, OUT or SETUP). The token can be of PID type Start-Of-Frame (SOF), issued every 1 ms (full-speed) or 125 us (highspeed) and used for synchronization.
  - Frame → interval during which a sequence of transactions is performed for the endpoints controlled by the host..

| Field        | PID               | ADDR              | ENDP                | CRC5                 |
|--------------|-------------------|-------------------|---------------------|----------------------|
| Bits         | 8                 | 7                 | 4                   | 5                    |
| Desc         | Type of<br>packet | Device<br>address | Endpoint<br>address | CRC of ADDR and ENDP |
| Token packet |                   |                   |                     |                      |

| Field | PID            | Frame number  | CRC5                   |  |
|-------|----------------|---------------|------------------------|--|
| Bits  | 8              | 11            | 5                      |  |
| Desc  | Type of packet | Current frame | CRC of Frame<br>Number |  |
|       |                |               |                        |  |

SOF packet

**BIG IDEAS FOR EVERY SPACE** 

KENESAS

#### **USB PACKETS**

- A Data packet, carrying the effective data being transferred. Data packets are issued either by the host or the device, depending on the endpoint direction (identified by the previous Token packet).
   PID indicates type DATA0 or DATA1 (toggling for full-speed transfers) or DATA2 (high-speed transfers).
- A Handshake packet, used to report the status of a data transaction. Handshake packets are issued by the receiver of the Data packet. PID indicates ACK, NACK, a halt condition (STALL) or no response yet (NYET).

| Field       | PID            | DATA   | CRC16          |
|-------------|----------------|--------|----------------|
| Bits        | 8              | 0-8192 | 16             |
| Desc        | Type of packet | Data   | CRC of<br>DATA |
| Data packet |                |        |                |

| Field | PID               |
|-------|-------------------|
| Bits  | 8                 |
| Desc  | Type of<br>packet |

Handshake packet





USB defines four types of data transfers:

- **Control**  $\rightarrow$  control commands to configure device, delivery guaranteed, low bandwidth required.
  - Control transfers are performed in three stages:
    - A Setup stage, starting with a token packet of type SETUP and a data packet containing a USB device request → see following slides.
    - An optional Data stage, starting with a token packet of type IN or OUT (depending on direction) and a data packet containing the data pertaining to the USB device request.
    - A Status stage, starting with a token packet of type IN or OUT (inverse of Data direction) and containing request status information.





- Bulk → large amounts of data, non real-time, delivery guaranteed, variable use of bandwidth → used for reliable data transfers, such as mass storage data.
  - Token packets for bulk transfers are of type IN or OUT, depending on transfer direction.
- Interrupt  $\rightarrow$  real-time, small and periodic amounts of data  $\rightarrow$  used for event notification (e.g. key typed on a keyboard).
  - Token packets for interrupt transfers are of type IN or OUT, depending on transfer direction.



#### **USB TRANSFERS**

- Isochronous → large amounts of data, delivery not guaranteed, steady rate of transmission and reception, bandwidth depending on sampling characteristics → used for streaming data, such as voice or video.
  - Token packets for isochronous transfers are of type IN or OUT, depending on transfer direction.
  - Isochronous transfers do not use Handshake packets.

Individual endpoints are configured to a specific type of data transfer, depending on the class driver loaded by the host during the enumeration process  $\rightarrow$  see following slides.

## **USB TRANSFERS SCHEDULING**

Rules for transfer scheduling:

- Periodic transfers (isochronous and interrupt)  $\rightarrow$  limited to 90% of the bandwidth of a frame.
- Control → use as much as necessary of the remaining 10% (plus the remaining amount in the 90% of the bandwidth that is not used for periodic transfers).
- Bulk  $\rightarrow$  use the bandwidth that is left.



The USB enumeration protocol is executed whenever a new device is inserted into the bus. This protocol comprises the following steps:

- USB root hub detects when a device is connected (D- or D+ are pulled up with resistors).
- USB host powers and resets the device.
- USB host issues device requests through the Default Control Pipe (default address 0) to get the Device Descriptor → see following slides.
- USB host assigns a unique address to the device.
- USB host issues device requests through the Default Control Pipe to get the Configuration Descriptors → see following slides.
- USB host enables a valid configuration → all corresponding interfaces and endpoints are configured, and the device may draw the current described in the descriptor for the selected configuration.

Some steps of the enumeration protocol require issuing USB device requests to the device being enumerated.

The USB device requests are issued during the Setup stage of a Control transfer. A device request is 8 bytes long and contains the following fields:

- bmRequestType (1 byte) → request direction, type (standard, class, vendor, reserved) and recipient (device, interface, endpoint, other).
- bRequest (1 byte) → specific request (set address, get and set configuration, get and set descriptor, get and set interface etc.).
- *wValue* (2 bytes), *wIndex* (2 bytes)  $\rightarrow$  value and index that depend on request.
- *wLength* (2 bytes)  $\rightarrow$  number of bytes to transfer if there is a data stage.

Refer to USB 2.0 Specification, Section 9.3 for more detailed information.



Descriptors sent by the device during enumeration process (in response to GET\_DESCRIPTOR requests):

 Device descriptor → defines the device class, device subclass, device protocol, max packet size for default endpoint, vendor, product, release number, indices for manufacturer, product and serial number strings, and the number of configurations.

| Device | Descriptor |
|--------|------------|
| 000100 | Docomptor  |

| Field              | Size<br>(bytes) | Descr                                 |
|--------------------|-----------------|---------------------------------------|
| bLength            | 1               | Size of descriptor                    |
| bDescriptorType    | 1               | DEVICE descriptor type                |
| bcdUSB             | 2               | USB Spec Relase Number in BCD         |
| bDeviceClass       | 1               | Class code                            |
| bDeviceSubClass    | 1               | Subclass code                         |
| bDeviceProtocol    | 1               | Protocol code                         |
| bMaxPacketSize0    | 1               | Max packet size for endp 0            |
| idVendor           | 2               | Vendor ID                             |
| idProduct          | 2               | Product ID                            |
| bcdDevice          | 2               | Device release number in BCD          |
| iManufacturer      | 1               | Index of string desc for manufacturer |
| iProduct           | 1               | Index of string desc for product      |
| iSerialNumber      | 1               | Index of string desc for serial       |
| bNumConfigurations | 1               | Number of possible configurations     |



- Configuration descriptor → defines the number of interfaces for this configuration, the configuration value and an index for this configuration's string, if the device is self-powered when running that configuration and the max power consumption (in case it is bus powered).
  - A GET\_DESCRIPTOR request to a Configuration
     Descriptor returns also the Interface and Endpoint descriptors pertaining to the given Configuration, in sequential order → see next slides.

#### **Configuration Descriptor**

| Field               | Size<br>(bytes) | Descr                                                                                       |
|---------------------|-----------------|---------------------------------------------------------------------------------------------|
| bLength             | 1               | Size of descriptor                                                                          |
| bDescriptorType     | 1               | CONFIGURATION descriptor type                                                               |
| wTotalLength        | 2               | Total length of configuration data<br>(includes Interface and Endpoint<br>descriptor sizes) |
| bNumInterfaces      | 1               | Number of interfaces                                                                        |
| bConfigurationValue | 1               | Configuration ID                                                                            |
| iConfiguration      | 1               | Index of string desc for this config                                                        |
| bmAttributes        | 1               | Configuration characteristics                                                               |
| bMaxPower           | 1               | Max power consumption in mA when operating on this configuration                            |



 Interface descriptor → defines the interface number, the number of endpoints, the interface class, subclass and protocol, and an index to a string describing this interface.

#### Interface Descriptor

| Field              | Size<br>(bytes) | Descr                                      |
|--------------------|-----------------|--------------------------------------------|
| bLength            | 1               | Size of descriptor                         |
| bDescriptorType    | 1               | INTERFACE descriptor type                  |
| bInterfaceNumber   | 1               | Zero-based number of this interface        |
| bAlternateSetting  | 1               | Value to select this alternate setting     |
| bNumEndpoints      | 1               | Number of endpoints used by this interface |
| bInterfaceClass    | 1               | Class code for this interface              |
| bInterfaceSubClass | 1               | Subclass code for this interface           |
| bInterfaceProtocol | 1               | Protocol code for this interface           |
| iInterface         | 1               | Index of string desc for this interface    |



- Endpoint descriptor → defines the endpoint address and direction, the endpoint type (control, isochronous, bulk or interrupt), the max packet size and the polling interval for periodic endpoints (isochronous and interrupt).
- Refer to USB 2.0 Specification, Section 9.6 for more detailed information.

#### **Endpoint Descriptor**

| Field            | Size<br>(bytes) | Descr                             |
|------------------|-----------------|-----------------------------------|
| bLength          | 1               | Size of descriptor                |
| bDescriptorType  | 1               | ENDPOINT descriptor type          |
| bEndpointAddress | 1               | Address for this endpoint         |
| bmAttributes     | 1               | Endpoint attributes (type etc.)   |
| wMaxPacketSize   | 2               | Max packet size for this endpoint |
| bInterval        | 1               | Polling interval in frames        |





© 2020 Renesas Electronics Corporation. All rights reserved.

BIG IDEAS FOR EVERY SPACE **RENESAS** 

# **10.2 – BLOCK DIAGRAM – CASE STUDY**

The R7FS7G27H3A01CFC Renesas ARM Cortex-M4 MCU implements two USB modules:

 USB 2.0 FS → operates only on low and full speed modes. Based on registers and a FIFO controller to manage buffers to be received / transmitted.



Source: Renesas Synergy MCUs User's Manual: Hardware



# **10.2 – BLOCK DIAGRAM – CASE STUDY**

 USB 2.0 HS → operates in high speed mode (480 Mbps). Uses
 DMA FIFOs to maximize memory transfer speed.



Source: Renesas Synergy MCUs User's Manual: Hardware



Implementation for the USB 2.0 FS Module of the R7FS7G27H3A01CFC Renesas ARM Cortex-M4 MCU:

- SYSCFG → enabling/disabling USB, pull up / pull down resistor config
- SYSSTS0 → line status, overcurrent status (from an external overcurrent detector), status bits for entering / exiting the "suspended" mode
- DVSTCTR0 → connection status (reset, low-speed or full-speed), wakeup detection, enable / resume / reset control
- CFIFO, D0FIFO and D1FIFO → read/write from/to FIFOs associated to control pipe and to other communication pipes
- CFIFOSEL → configure control pipe and associate to CFIFO
- D0FIFOSEL, D1FIFOSEL → associate pipes to D0FIFO and D1FIFO, configure DMA



- CFIFOCTR, D0FIFOCTR, D1FICOCTR → received data length, status of FIFO read
- INTENB0, INTENB1  $\rightarrow$  enable / disable USB interrupts
- BRDYENB → enable / disable BRDY (data transfer successful) interrupt for each USB pipe
- NRDYENB → enable / disable NRDY (data transfer not successful) interrupt for each USB pipe
- BEMPENB → enable / disable BEMP (buffer empty or incorrect packet size) interrupt for each USB pipe
- SOFCFG  $\rightarrow$  configuration for SOF (start-of-frame) and frame timing (LS and FS)
- INTSTS0, INTSTS1 → status of several interrupt sources (SOF, resume, BRDY, NRDY, overcurrent, disconnection etc.)

- BRDYSTS → status of BRDY interrupt for each USB pipe
- NRDYSTS → status of NRDY interrupt for each USB pipe
- BEMPSTS → status of BEMP interrupt for each USB pipe
- FRNUM → frame number, status of CRC error and overrun/underrun in isochronous transfers
- DVCHGR → used when device recovers from deep software standby mode due to USB events
- USBADDR → USB device address, configuration for recovery from deep software standby mode
- USBREQ  $\rightarrow$  fields of setup requests used for control transfers.
- USBVAL → stores the wValue field of setup transactions (received and for transmitting)



- USBLENG → stores the wLengths field of setup transactions (received and for transmitting)
- DCPCFG → enabling and direction of the Default Control Pipe
- DCPMAXP → maximum packet size for the Default Control Pipe
- DCPCTR → controls transfers for the Default Control Pipe
- PIPESEL  $\rightarrow$  select pipe to be configured by PIPECFG, PIPEMAXP etc.
- PIPECFG  $\rightarrow$  configures selected pipe (endp number, direction, transfer type etc.)
- PIPEMAXP → configures maximum packet size for selected pipe
- PIPEPERI → configures error detection interval for isochronous pipes
- PIPECTR[1..9] → controls transfers for the corresponding pipe
- PIPETRE[1..5] → enables / disables transaction counter

- PIPETRN[1..5]  $\rightarrow$  transaction counters for the corresponding pipes
- DEVADD $[0..5] \rightarrow$  configures the transfer speed for the device to which the corresponding pipe is communicating
- PHYSLEW  $\rightarrow$  adjust the physical driver to host or function operation
- DPUSR0R → configures pull-up / pull-down resistors, reads status of overcurrent and VBUS inputs
- DPUSR1R → configures and reads status concerning deep software standby mode
- USBMC  $\rightarrow$  enables / disables battery charging mode and regulator circuit
- USBBCCTRL0  $\rightarrow$  configures parameters for battery charging mode

# **10.4 – SOFTWARE STACK – CASE STUDY**

- Example of USB Host stack for Renesas microcontroller hardware (part of SSP – Synergy Sofware Package):
- Uses a Mass Storage Module on top as class driver.
- Uses Thread X RTOS to manage the threads concerning USB components.



 (https://www.renesas.com/enus/software/D6001255.html)

Source: Renesas Synergy USBX Host Class Mass Storage Module Guide r11an0173eu0100-synergy-ux-host-class-mass-storage-mod-guide

**BIG IDEAS FOR EVERY SPACE** 

RENESAS

## **10.4 – SOFTWARE STACK – CASE STUDY**

- The application for the shown example uses the top-level API provided by the USBX Host Class Mass Storage component:
- This component instantiates a file manager (FileX) when a mass storage device (e. g. an USB memory) is inserted.
- The application uses the API provided by FileX to access the mass storage device contents → file open, close, read, write etc.

| UINT | <pre>fx_file_allocate(FX_FILE *file_ptr, ULONG size);</pre>                    |            |
|------|--------------------------------------------------------------------------------|------------|
| UINT | fx_file_attributes_read(FX_MEDIA *media_ptr, CHAR                              |            |
|      | *file_name, UINT *attributes_ptr);                                             |            |
| UINT | fx_file_attributes_set(FX_MEDIA *media_ptr, CHAR                               |            |
|      | *file_name, UINT attributes);                                                  |            |
| UINT | fx file best effort allocate(FX_FILE *file_ptr, ULONG                          |            |
|      | size, ULONG *actual_size_allocated);                                           |            |
| UINT | fx_file_close(FX_FILE *file_ptr);                                              |            |
| UINT | fx_file_create(FX_MEDIA *media_ptr, CHAR *file_name);                          |            |
| UINT | fx_file_date_time_set(FX_MEDIA *media_ptr, CHAR *file_name,                    |            |
|      | UINT year, UINT month, UINT day, UINT hour, UINT minute, UINT second);         |            |
| UINT | fx_file_delete(FX_MEDIA *media_ptr, CHAR *file_name);                          |            |
| UINT | fx_file_open(FX_MEDIA *media_ptr, FX_FILE *file_ptr,                           |            |
|      | CHAR *file_name, UINT open_type);                                              |            |
| UINT | fx_file_read(FX_FILE *file_ptr, VOID *buffer_ptr, ULONG                        | Basic API  |
|      | request_size, ULONG *actual_size);                                             | Basic API  |
| UINT | fx_file_relative_seek(FX_FILE *file_ptr, ULONG byte_offset, UINT seek_from);   | functions  |
| UINT | fx_file_rename(FX_MEDIA *media_ptr, CHAR *old_file_name, CHAR *new_file_name); | Iditotiono |
| UINT | <pre>fx_file_seek(FX_FILE *file_ptr, ULONG byte_offset);</pre>                 |            |
| UINT | <pre>fx_file_truncate(FX_FILE *file_ptr, ULONG size);</pre>                    |            |
| UINT | fx_file_truncate_release(FX_FILE *file_ptr, ULONG size);                       |            |
| UINT | fx_file_write(FX_FILE *file_ptr, VOID *buffer_ptr, ULONG size);                |            |
|      |                                                                                |            |

Source: FileX Services

(https://rtos.com/wp-content/uploads/2017/10/EL-filex-programmers-guide.pdf)

**BIG IDEAS FOR EVERY SP** 

RENESAS

#### **11 – ETHERNET**

- Introduction
- Block Diagram
- Registers
- SW Stack

# **11.1 – INTRODUCTION**

Ethernet is a wired network technology used to interconnect devices in a Local Area Network (LAN). It has been standardized as IEEE802.3, comprising the physical and data link layers of the OSI model.

Main characteristics:

- Packet-based protocol,
- All messages are broadcast and processed by the nodes only if needed,
- Nodes can transmit at any time  $\rightarrow$  Ethernet provides for automatic collision management (electrical or logical),
- Up to 10 Gbps (10GBASE-SR and further).

# **11.1 – INTRODUCTION**

Ethernet standard has evolved across different versions:

- Ethernet (IEEE 802.3) standard → makes use of coaxial connections (named 10BASE2 and 10BASE5) to achieve bandwidths up to 10 Mbps;
- Fast Ethernet (IEEE 802.3u) → evolved from 10BASE-T (4-pair unshielded twisted pair) to 100BASE-TX and 100BASE-FX (fiber-optic cable) to achieve bandwidths up to 100 Mbps;
- Gigabit Ethernet (IEEE 802.3z) → variation of Fast Ethernet (1000BASE-T); that supports full duplex operation to provide higher data rates (up to 1 Gbps);
- 10 Gigabit Ethernet (IEEE 802.3ae)  $\rightarrow$  entirely based on optical fiber (10GBASE-SR), up to 10 Gbps.



## **ETHERNET TOPOLOGY**

Earlier Ethernet versions (10BASE2 and 10BASE5) used coaxial cables to interconnect nodes in a physical and logical bus topology.

Later versions (10BASE-T) rely on a physical star topology based on **hubs**  $\rightarrow$  connected to nodes with twisted pair cabling.

Current versions (100BASE-TX and further) rely on a physical star topology based on **switches**  $\rightarrow$  physically isolate the nodes so that a packet is delivered solely to its destination node  $\rightarrow$  minimizes the network congestion due to packet collision.

Ethernet is always a bus topology from the logical point-of-view.



source: Authors

# **ETHERNET CONNECTION INFRASTRUCTURE**

A Hub acts as a **repeater**:

- Data received by the hub from an Ethernet node is sent to all other Ethernet nodes connected to the hub.
- Therefore, multiple simultaneous transmissions are mixed and equally propagated to all connected nodes → possibility of collisions.
- A Switch acts as a **filtered repeater**:

Destination address of every transmitted Ethernet packet (frame) is checked by the switch.

- The frame is forwarded only to the corresponding Ethernet node.
- This allows multiple simultaneous transmissions to succeed, provided that the pair of source-destination nodes for each of the transmissions is different.
- Packet collisions are avoided, as the switch is able to enqueue and serialize multiple frames addressed to the same destination node.

# **ETHERNET COLLISION MANAGEMENT**

Because multiple Ethernet nodes share a logical bus, it is possible that more than one node try to transmit at the same time  $\rightarrow$  collision.

To manage collisions, Ethernet uses the **Carrier Sense Multiple Access / Collision Detection (CSMA/CD)** protocol.

- The sender node starts transmitting a packet (frame) and uses carrier-sensing to detect if other nodes are trying to transmit at the same time.
- While no collision is detected, the sender node keeps on sending the frame bits until the end.
- If a collision is detected, a jam signal is sent to warn the other nodes about the collision, a retransmission counter is incremented, and the frame transmission is restarted after a random amount of time.
- If the retransmission counter reaches the maximum number of attempts, the transmission is aborted.



Source: https://upload.wikimedia.org/wikipedia/commons/3/37/CSMACD-Algorithm.svg

#### **ETHERNET PACKET**

An Ethernet frame encapsulates the data packet.

The frame includes addressing information (MAC) and error detection features.

• CRC checking is performed over all fields (except Preamble and SFD) and compared to FCS.

*Dest addr* defines special values for broadcast (all nodes receive and process the packet) and multicast (a group of nodes receives and processes the packet).

| Field | Preamble | Start of<br>Frame<br>Delimiter | Dest<br>MAC<br>addr | Src<br>MAC<br>addr | Length<br>/ type | Data       | Frame<br>Check Seq |
|-------|----------|--------------------------------|---------------------|--------------------|------------------|------------|--------------------|
| Bytes | 8        | 1                              | 6                   | 6                  | 2                | 46 to 1500 | 4                  |

802.3 packet

RENESAS

**BIG IDEAS FOR EVERY SPACE** 

# 11.2 – BLOCK DIAGRAM – CASE STUDY

Implementation for the Ethernet Controller Module of the R7FS7G27H3A01CFC Renesas ARM Cortex-M4 MCU.

- Two-channel controller → can operate two independent ETH interfaces.
- Depends on a DMA controller (EDMAC) to handle the TX and RX buffers without CPU intervention.

MII (Media Independent Interface) and RMII (Reduced MMI) are used to connect the ETH controller to the PHY hardware that implements the electrical interface.



Source: Renesas Synergy MCUs User's Manual: Hardware

**BIG IDEAS FOR EVERY SPACE** 

**RENESAS** 

#### 11.3 – REGISTERS – CASE STUDY

Implementation for the Ethernet Controller Module of the R7FS7G27H3A01CFC Renesas ARM Cortex-M4 MCU:

- ECMR  $\rightarrow$  enable / disable, operation mode configuration
- RFLR  $\rightarrow$  maximum frame length (between 1518 and 2048 bytes)
- ECSR  $\rightarrow$  detection of line events (e. g. false carrier)
- ECSIPR → enable/disable line events interrupt
- PIR  $\rightarrow$  access PHY registers
- PSR → status of PHY
- RDMLR  $\rightarrow$  upper limit for random number generation
- IPGR  $\rightarrow$  sets the interpacket gap (in bit times)



## 11.3 – REGISTERS – CASE STUDY

- APR  $\rightarrow$  set pause time for an automatic PAUSE frame (used for flow control)
- MPR  $\rightarrow$  set pause time for a manual PAUSE frame (used for flow control)
- RFCF → number of received PAUSE frames
- TPAUSER → max number of PAUSE frame retransmission
- TPAUSECR → PAUSE retransmit counter
- BCFRR → max number of received broadcast frames
- MAHR → upper bits of MAC address
- MALR → lower bits of MAC address
- TROCR → number of frames that failed to be retransmitted



# 11.3 – REGISTERS – CASE STUDY

- CDCR → number of late collisions detected
- LCCR → number of losses of carrier detected
- CNDCR  $\rightarrow$  number of times a carrier is not detected
- CEFCR → number of received frames with CRC error
- FRECR → number of times a frame receive error has occurred
- TSFRCR → number of short frames received
- TLFRCR → number of long frames (longer than RFLR value) received
- RFCR  $\rightarrow$  number of frames received with alignment error (not integral number of octets)
- MAFCR → number of multicast frames received



# 11.4 – SOFTWARE STACK – CASE STUDY

- Example of Ethernet stack for Renesas microcontroller hardware (part of the SSP → Synergy Software Package).
- The Ethernet layer depends on upper layers to manage the network protocols that generate or consume the data encapsulated into Ethernet packets → the "Application" layer.

Application
ThreadX®
RTOS
Framework
NetX Port ETHER
sf\_el\_nx
BSP

 (https://www.renesas.com/enus/software/D6001601.html)

> Source: Renesas Synergy NetX Port Module Guide <u>r11an0218eu0101-synergy-sf-el-nx-mod-guide</u>



# 11.4 – SOFTWARE STACK – CASE STUDY

Example of Ethernet API for Renesas microcontroller hardware 
 part of NetX Framework for Renesas Synergy Software
 Package (SSP).

| void      | edmac_eint_isr (void)<br>edmac_eint_isr More                                                                                                                                                            |           | sf_el_nx_cfg_t *sf_el_nx_cfg_ptr)                                                 |                  |                                                      |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------------------------------------------------------------------|------------------|------------------------------------------------------|
| UINT      | <pre>nx_synergy_ethernet_init (NX_REC *nx_rec_ptr, sf_el_nx_cfg_t<br/>*sf_el_nx_cfg_ptr, bool hw_padding)<br/>nx_synergy_ethernet_init More</pre>                                                       |           | nx_ether_driver More                                                              |                  |                                                      |
| void      | nx_driver_event_handler (NX_REC *nx_rec_ptr)<br>nx_driver_event_handler More                                                                                                                            | void      | nx_ether_interrupt (NX_REC *nx_rec_ptr)<br>nx_ether_interrupt More                |                  |                                                      |
| void      | enet_hw_enable_interrupt (NX_REC *nx_rec_ptr)<br>enet_hw_enable_interrupt More                                                                                                                          | ssp_err_t | nx_ethernet_version_get (ssp_version_t *<br>Retrieve the API version number. More | const p_version) |                                                      |
|           | nx_synergy_ethernet_deinit (NX_REC *nx_rec_ptr, sf_el_nx_cfg_t<br>*sf_el_nx_cfg_ptr)<br>nx_synergy_ethernet_deinit More                                                                                 |           |                                                                                   |                  | ergy Software<br>5 User's Manual<br>106-synergy-ssp- |
| ssp_err_t | nx_ether_custom_packet_send (NX_PACKET_POOL *pool_ptr, NX_REC<br>*nx_record_ptr, UCHAR *data, UINT length, USHORT ether_type,<br>nx_mac_address_t dest_mac_address)<br>nx_ether_custom_packet_send More |           | Basic comm API<br>functions                                                       | <u>v175</u>      |                                                      |

RENESAS

**BIG IDEAS FOR EVERY SPACE** 

## **12 – SOFTWARE DEVELOPMENT PROCESS**

- Software Process Overview
- UML Class Diagram
- UML State Machine Diagram

#### WATERFALL PROCESS





### **SOFTWARE PROCESS**







Unified Modeling Language

- Originally by Grady Booch, James Rumbaugh and Ivar Jacobson
- Based on the integration of several existing modeling languages
- OMG standard (<u>www.omg.org</u>) in 1998
- Language based on visual models
- Current version: 2.5 (March 2015)
- Non-proprietary language





The basic elements of a structural model are:

- THINGS
- Interaction among THINGS





Physical things:

• Coffee bean, processor, equipment, vehicle, planet ...

Logical things:

Bank account, contract, variable stored in memory ...



## **INTERACTION AMONG THINGS**

Examples:

processor is connected to memory

personA and personB are married

personX is responsible for bank\_account\_12345





A cohesive entity that has attributes, behavior and (optionally) state.

Characteristics of a Class / Object:

- Data attributes
- Behavior operations, methods, services, functions
- State memory of its past
- Identity unique identifier
- Responsibilities



## **CLASS / OBJECT IN PROGRAMMING LANGUAGES**

| Class                   | Object                   |
|-------------------------|--------------------------|
| example: a type in C    | example: a variable in C |
| Compile time existence  | runtime existence        |
|                         | Ocupies memory           |
| the design of an object | an instance of a class   |



#### **CLASS REPRESENTATION**



| Radar      |
|------------|
| attributes |
| methods    |







An additional (informal) form of classification.

Notation:

icon

text: <<stereotype\_name>>



class is represented by an icon





«HW» Teclado

# **ATTRIBUTES / METHODS – VISIBILITY**

A typical class representation has:

- class name (+ stereotype)
- attributes
- methods

The visibility of the methods and attributes is indicated by:

| Symbol | Meaning          | Visibility                                      |
|--------|------------------|-------------------------------------------------|
| +      | public           | accessible to all                               |
| #      | protected        | accessible by derived classes                   |
| -      | private          | accessible only by this class                   |
| ~      | package<br>scope | accessible to the other classes in this package |

#### С attr\_publico: int ÷ attr\_protegido: int # attr\_privado: int attr\_escopo\_pacote: int $\sim$ metodo\_publico(): void ÷ # metodo\_protegido(): int metodo\_p(): char -+ metodo\_escopo\_pacote(): void



## **INTERACTION AMONG THINGS**

Relationships:

- Association
- Aggregation
- Composition
- Generalization
- Dependency

## **ASSOCIATION**

A and B know of the existence of each other and may interact:

- access to public methods
- access to public attributes









# MULTIPLICITY

How many objects of each class participate of this relationship?



| 1     | exactly one      |
|-------|------------------|
| *     | many (0 or more) |
| n     | many (0 or more) |
| 1*    | 1 or more        |
| 320   | from 3 to 20     |
| 4,6,8 | 4 or 6 or 8      |



# AGGREGATION

This relationship represents a weak part-whole or part-of.

The parts lifetime are different from the lifetime of the whole.

Read as:

Whole has a Part.



# **COMPOSITION**

- Strong whole-part relationship.
- The whole and the parts form a single entity.
- Same lifespan for the whole and the parts.





## **GENERALIZATION**

- Represents inheritance.
- The derived class inherits all methods and attributes of the base class.
- Reading:

Derived is-a Base.



};

## USING UML TO DESIGN AN EMBEDDED SOLUTION

- Classes may represent: classes (e.g. C++), set of cohesive functions in C, hardware components, ...
- Since classes represent such a variety of things, the use of stereotypes is encouraged to inform the type: «HW», «ISR», «device driver»,...
- Associations also have several possible interpretations, from actual physical connections to pointers (e.g. in C). The use
  of stereotypes is also encouraged.
- A common mistake is to consider the navigation adornment as an indication of the direction of flow of data. It is not!



This is an example of a class diagram representing the components of a very simple digital scope.

Stereotypes are used to document what type of thing is being represented by each class: HW, Device Driver, ISR, ...



# **13 – CONCURRENT PROGRAMMING**

- Tasks
  - Processes vs Threads
  - Context Switching
  - Scheduling
- Inter-task Communications and Synchronization
- Caveats

Consider a single-person company. Suppose you could specify his activities by writing a program-like script. Wouldn't it be very complex? Full of interleaved chores that would be hard to specify in a single script?



source: pixabay.com



Now, consider a simple embedded system with:

- 3 serial ports operating at 115 Kbps (aprox. 1 char every 87us);
- USB, requiring processing every 125 us for packets with about 1KBytes;
- IHM: touch screen plus LCD;
- activities implemented in SW:
  - A1: every 2 ms process data from the touch screen;
  - A2: every 7 ms process USB data;
  - A3: every 500 us manage the USB protocol;
  - A4: every 100 ms manage the menu system.

Wouldn't it be very hard to program a single sequential code to execute all these tasks, even more if several possible interleavings could occur?



As embedded systems increase constantly in complexity and code size, this complexity can be better managed if a single program (responsible for all activities) could be divided into many smaller programs, each one responsible for a single activity. Each one of these small programs is called a **task**. The multiple tasks that compose a concurrent program execute concurrently and cooperate among them to achieve the desired functionality.

#### It is TEAM WORK!!

How can multiple tasks execute concurrently on a single processor?

Answer: each task will execute on a "virtual processor". The combined performance of all virtual processors is about the same as the performance of the actual processor, as the virtual processor **share** the physical resources: processor, memory and peripherals.

The sharing of the actual hardware (processor, memory, peripherals) is managed by an embedded operating system (or RTOS - Real-Time Operating System).



The storage regions of a single sequential program (e.g a C-program) are:



## **MULTITHREADING**

For simplicity and to reduce the usage of computational resources, RTOS for MCUs typically rely on multithreading to implement concurrency.

A **thread** is a program segment that executes concurrently to other threads (program segments). Hence, each thread is characterized by its own PC (program counter), its own set of processor registers and its own stack, while sharing the other memory regions with the other threads.

On MCUs, each task (abstract concept) is implement by one thread.



## **MULTITHREADING**

Some sections of RAM (shown in red) are of **exclusive** use of a thread. These sections hold the stacks and a copy of the set of processor registers.

Other sections of Memory (shown in blue) are **shared** among all threads. While this sharing provides efficient access to shared data, it does not provide means of protection among threads.



**BIG IDEAS FOR EVERY SPACE** 

STACK n

RENESAS

**STACK 1** 

Flash

CODE

(.text) (.const)

RAM

DATA

(.data)

(.bss)

**HEAP** 

## **MULTITHREADING**

Differences between threads and processes:

- On processors with MMUs (Memory Management Units), it is possible to create an exclusive addressing space for each task. This type of implementation is called **process**. In a process, it is possible to host several threads, hence, there are single-threaded processes and multi-threaded processes.
- On processors without MMUs, all tasks share the available memory. This type of implementation is called **thread**.
- A **task** is a logical concept that can be implemented by a process or by a thread.



## **MULTITHREADING – CONCEPTS**

#### **Context Switch**

How do multiple threads share a single processor?

- An RTOS manages the physical resources (processor, memory, peripherals).
- A context switch consists of saving the state of the processor when one thread is executing and restoring the state of another thread:
  - 1. Task A is executing;
  - 2. All CPU registers are saved onto the stack of Task A;
  - 3. The RTOS executes and selects another task to execute: Task B. The criteria for selecting another task is defined by the scheduling policy;
  - 4. The state of task B is restored from Task B stack onto the CPU registers. Execution proceeds on Task B's code and using Task B's stack.

## **MULTITHREADING – CONCEPTS**

#### **Preemptive vs Non-Preemptive RTOS**

- A preemptive RTOS has control of the processor during all times. It releases the processor to a thread and at any time may get back the control of the processor to releases to another thread. This is the case when a higher priority thread becomes ready to run.
- When a non-preemptive RTOS releases control to a thread, it is unable to regain control of the processor until that thread, voluntarily, releases the processor back to the RTOS.



## **MULTITHREADING – CONCEPTS**

#### Task Priority

Each task is created with a defined priority level, which typically can be changed during execution. When a task of higher priority than the running task becomes ready, a priority-based preemptive scheduler will interrupt the running task and context switch to the higher priority task. Once this task releases the processor, the preempted task can resume its execution.



source: ARM, CMSIS-RTOS specs

http://www.keil.com/pack/doc/CMSIS\_Dev/RTOS2/html/theory\_of\_operation.html

**BIG IDEAS FOR EVERY SPACE** 

RENESAS

## **MULTITHREADING – CAVEATS**

If all tasks in a concurrent program are independent, then the only control that is needed is the allocation of the processor to the tasks (**scheduling**).

However, if tasks share resources (memory regions or peripherals) then an adequate control of resource sharing must be performed to guarantee **exclusive access to shared resources** and to avoid **deadlocks** and **priority inversion**.



## 14 – RTOS – REAL-TIME OPERATING SYSTEM

- Introduction
- Thread Management
- Inter-thread communication and synchronization
- Timing Services
- Memory Management



## **RTOS – INTRODUCTION**

- An RTOS is a layer of Software between the hardware and the application software that allows the implementation of concurrent tasks implemented by multithreading.
- The RTOS manages the hardware, sharing resources among multiple "virtual processors": VP1 to VPn so that each thread has the illusion of owning a processor and stack while sharing global data, heap, code area and peripherals.
- The RTOS implements sharing of the processor via context switching and provides several important functionalities for the threads: timing, inter-thread communication and synchronization, and thread management.



## **THREAD EXECUTION – LARGE GRAIN VIEW**

Observing at a time scale of seconds, one has the impression that all threads execute in parallel.



## **THREAD EXECUTION – FINE GRAIN VIEW**

Observing on a fine grain scale (milliseconds) it is possible

to realize that the tasks share the processor as the RTOS

switches among them the utilization of the CPU.





## **TASK STATES**

A typical state diagram of a task in a multithreaded environment:

- Ready: tasks that is willing to use the processor and is expected to be scheduled.
- Running: the state of the task that is using the processor.
- Waiting: tasks whose execution is blocked due due to time, synchronization or communication.





## CMSIS (CORTEX MICROCONTROLLER SOFTWARE INTERFACE STANDARD)

- v 1.0 (2008)
   Drivers API
- v 2.0
  - DSP Lib
- v 3.0 (2012)
  - API RTOS
  - DAP (Debug)
- V 4.0 (2014)
  - CMSIS-Driver
  - CMSIS-Pack
- V 5.0 (2016) CMSIS-RTOS v2

As of March, 2020, CMSIS is at version 5.6



## **CMSIS-RTOS DOCUMENTATION**

Available online

| General                                              | CMSIS-Core(A)                  | CMSIS-Core(M) Driver DSP                | RTOS v1 RTOS v2 Pack SVD DAP Zone                                                |  |  |  |  |
|------------------------------------------------------|--------------------------------|-----------------------------------------|----------------------------------------------------------------------------------|--|--|--|--|
| Main Page                                            | Usage and Description          | Reference                               |                                                                                  |  |  |  |  |
| CMSIS-RTOS2     Revision History                     |                                | Reference                               |                                                                                  |  |  |  |  |
| <ul> <li>Generic RT</li> <li>Function O</li> </ul>   |                                | Here is a list of all modules:          | Here is a list of all modules:                                                   |  |  |  |  |
| <ul> <li>RTOS Valid</li> <li>Migration fr</li> </ul> | dation<br>rom API v1 to API v2 | CMSIS-RTOS2 API                         | Describes the C function interface of CMSIS-RTOS API v2                          |  |  |  |  |
| RTX v5 Imp                                           | plementation                   | Kernel Information and Control          | Provides version/system information and starts/controls the RTOS Kernel          |  |  |  |  |
| Reference                                            |                                | Thread Management                       | Define, create, and control thread functions                                     |  |  |  |  |
| Data Struct                                          | tures                          | Thread Flags                            | Synchronize threads using flags<br>Synchronize threads using event flags         |  |  |  |  |
| Data Structure Index                                 |                                | Event Hugs                              |                                                                                  |  |  |  |  |
| Data Fields                                          | 3                              | Generic Wait Functions                  |                                                                                  |  |  |  |  |
|                                                      |                                |                                         |                                                                                  |  |  |  |  |
|                                                      |                                | Mutex Management                        | genere i i i i i i i i i i i i i i i i i i                                       |  |  |  |  |
|                                                      |                                |                                         |                                                                                  |  |  |  |  |
|                                                      |                                | Memory Pool                             | Exchange messages between threads in a FIFO-like operation                       |  |  |  |  |
|                                                      |                                | Message Queue                           | Constants and enumerations used by many CMSIS-RTOS functions                     |  |  |  |  |
|                                                      |                                | Definitions                             | Constants used by Thread Flags and Event Flags to return error codes             |  |  |  |  |
|                                                      |                                | Flags Functions Error Codes OS Tick API | Provides a low level API between an device agnostic RTOS implementation and spec |  |  |  |  |
|                                                      |                                | RTX5 Specific API                       | This section describes CMSIS-RTOS RTX5 specifics                                 |  |  |  |  |
|                                                      |                                | Macros                                  | RTX5 macros                                                                      |  |  |  |  |
|                                                      |                                | Structs                                 | RTX5 structs                                                                     |  |  |  |  |
|                                                      |                                | Functions                               | RTX5 functions                                                                   |  |  |  |  |
|                                                      |                                | Event functions                         | RTX5 Event Recorder functions                                                    |  |  |  |  |
|                                                      |                                | Memory Functions                        | Events generated memory functions                                                |  |  |  |  |
|                                                      |                                | Kernel Functions                        | Events generated by kernel functions                                             |  |  |  |  |
|                                                      |                                | Throad Euroctions                       | Events generated by thread functions                                             |  |  |  |  |

#### CMSIS code is available in GITHUE



## PLANNING A MULTITHREADED APPLICATION





## **CMSIS-RTOS: OVERVIEW 1/4**

#### Kernel Information and Control

- **<u>osKernelInitialize</u>** : Initialize the RTOS kernel.
- osKernelStart : Start the RTOS kernel.
- **osKernelRunning** : Query if the RTOS kernel is running.
- **<u>osKernelSysTick</u>** \$ : Get RTOS kernel system timer counter.
- **<u>osKernelSysTickFrequency</u>** \$ : RTOS kernel system timer frequency in Hz.
- **<u>osKernelSysTickMicroSec</u>** \$ : Convert microseconds value to RTOS kernel system timer value.

#### Thread Management

- <u>osThreadCreate</u> : Start execution of a thread function.
- **<u>osThreadTerminate</u>** : Stop execution of a thread function.
- **<u>osThreadYield</u>** : Pass execution to next ready thread function.
- <u>osThreadGetId</u> : Get the thread identifier to reference this thread.
- **<u>osThreadSetPriority</u>** : Change the execution priority of a thread function.
- **<u>osThreadGetPriority</u>** : Obtain the current execution priority of a thread function.

## **CMSIS-RTOS: OVERVIEW 2/4**

#### **Generic Wait Functions**

- **<u>osDelay</u>** : Wait for a specified time.
- osWait \$ : Wait for any event of the type Signal, Message, or Mail.

#### Timer Management \$

- **<u>osTimerCreate</u>** : Define attributes of the timer callback function.
- osTimerStart : Start or restart the timer with a time value.
- **<u>osTimerStop</u>** : Stop the timer.
- **<u>osTimerDelete</u>** : Delete a timer.

## **CMSIS-RTOS: OVERVIEW 3/4**

#### **Signal Management**

- osSignalSet : Set signal flags of a thread.
- osSignalClear : Reset signal flags of a thread.
- osSignalWait : Suspend execution until specific signal flags are set.

#### **Mutex Management \$**

- **<u>osMutexCreate</u>** : Define and initialize a mutex.
- osMutexWait : Obtain a mutex or Wait until it becomes available.
- osMutexRelease : Release a mutex.
- <u>osMutexDelete</u> : Delete a mutex.

#### **Semaphore Management \$**

- osSemaphoreCreate : Define and initialize a semaphore.
- osSemaphoreWait : Obtain a semaphore token or Wait until it becomes available.
- osSemaphoreRelease : Release a semaphore token.
- osSemaphoreDelete : Delete a semaphore.

## **CMSIS-RTOS: OVERVIEW 4/4**

#### Memory Pool Management \$

osPoolCreate : Define and initialize a fix-size memory pool.

**osPoolAlloc** : Allocate a memory block.

**osPoolCAlloc** : Allocate a memory block and zero-set this block.

osPoolFree : Return a memory block to the memory pool.

#### Message Queue Management \$

- **<u>osMessageCreate</u>** : Define and initialize a message queue.
- <u>osMessagePut</u> : Put a message into a message queue.
- **osMessageGet** : Get a message or suspend thread execution until message arrives.

#### Mail Queue Management \$

- **<u>osMailCreate</u>** : Define and initialize a mail queue with fix-size memory blocks.
- **osMailAlloc** : Allocate a memory block.
- **osMailCAlloc** : Allocate a memory block and zero-set this block.
- **<u>osMailPut</u>** : Put a memory block into a mail queue.
- **<u>osMailGet</u>** : Get a mail or suspend thread execution until mail arrives.
- <u>osMailFree</u> : Return a memory block to the mail queue.



## **CMSIS-RTOS – INTER-TASK COMMUNICATIONS**

# Message: Integer or Pointer

## Mail: Memory Blocks



Source: ARM, CMSIS documentation



## **CMSIS-RTOS – INTER-TASK COMMUNICATIONS**

Mutex: Synchronization



Semaphore: Shared Access



Source: ARM, CMSIS documentation



## LAB1 – SYNERGY PLATFORM

#### **Objectives:**

- Execute the e2\_studio and SSP installation procedures.
- Setup the development environment for the S7G2 kit.
- Run a sample program to verify the installation.
- Overview of e2\_studio.
- Overview of SSP.

## LAB1 – SYNERGY PLATFORM

#### Activities:

- 1. Create an account on Renesas, Install e2\_studio (including SSP and tools);
- 2. Setup the SK-S7G2 board;

Run a sample program to verify ISDE setup;

- 3. Overview of the Synergy Platform;
- 4. Overview of the e2 studio ISDE;
- 5. Overview of the SSP (Synergy Software Package).



## LAB1 – SYNERGY PLATFORM

Activity 1 – Create an account on Renesas, Install e2\_studio (including SSP and tools)

- 1. Register an account at <u>https://www.renesas.com</u>
- 2. Sign in
- 3. Download Platform Installer
- 4. Execute the installation
- 5. Execute e2\_studio



## LAB 1 – ACTIVITY 1 – STEP 1

#### Register

a) create an account with Renesas

- click on sign in



Find information about recommended products and solutions created by Renesas and our development partners to help you



https://www.renesas.com/

## LAB 1 – ACTIVITY 1 – STEP 1

#### Register

- a) click on Register now
- b) follow the registration process

| R My Renesas                    | Login X           | +            |
|---------------------------------|-------------------|--------------|
| $\leftrightarrow \   \ni \   G$ | update.renesas.co | om/SSO/login |

#### RENESAS

#### **My** Renesas

| Enter your Email | Address and password and click "Login" to access your account.                          |
|------------------|-----------------------------------------------------------------------------------------|
| Email Address    |                                                                                         |
| Password         |                                                                                         |
|                  | Stay signed in Login                                                                    |
|                  | <ul><li>Forgot your password?</li><li>Don't have an account yet?Register here</li></ul> |

| Registration Proc            | cess                             |                        |                                     |                          |
|------------------------------|----------------------------------|------------------------|-------------------------------------|--------------------------|
| 1.Register MyRenes           | as                               |                        |                                     |                          |
| STEP1                        | STEP2                            | > STEP3                | STEP4                               |                          |
| Register<br>Email<br>Address | Receive<br>registration<br>Email | Enter user information | Subscribe<br>to content/<br>service | Registration<br>complete |
|                              |                                  |                        |                                     | Register now!            |

| 0 | My | Renesas | Email | Address | Regi | × | - |
|---|----|---------|-------|---------|------|---|---|
|---|----|---------|-------|---------|------|---|---|

 $\leftrightarrow$   $\rightarrow$ 

C

update.renesas.com/gur/ssoRegisterUser.do?languageCode=en&orgUrl=https%3A%2F%2Fupdate.renesas.com%2FSSO%2Fauth%3Fwebsit

### **My** Renesas

#### **Email Address Registration**

Step 1 🔹 Step 2 🔹 Step 3 🔹 Step 4 💿 Step 5 💿

To register, please provide the following information.

\* indicates required fields

| Country / Region [see not | Select Country/F | Region                                                           |
|---------------------------|------------------|------------------------------------------------------------------|
| Given Name / First Nam    | e *              |                                                                  |
| Family Name / Last Nam    | e *              |                                                                  |
| Email Addres              | is *             |                                                                  |
| Email Address (confirm    | 1) *             |                                                                  |
|                           |                  | te Policy, Privacy Policy, and export control law or regulation. |
|                           | Submit           | Undo Changes                                                     |

| Complete Email Address Registration |                                                                                   |  |
|-------------------------------------|-----------------------------------------------------------------------------------|--|
|                                     |                                                                                   |  |
|                                     | Step 1         Step 2         Step 3         Step 4         Step 5         Step 5 |  |
|                                     | Your information has been submitted.                                              |  |
|                                     | An email for entering personal information has been sent to the Email             |  |
|                                     | Address you provided.                                                             |  |
|                                     |                                                                                   |  |
|                                     |                                                                                   |  |
|                                     |                                                                                   |  |
|                                     |                                                                                   |  |
|                                     |                                                                                   |  |
|                                     |                                                                                   |  |
|                                     |                                                                                   |  |
|                                     |                                                                                   |  |

by clicking on the link sent by mail, the registration process proceeds

| <b>My</b> Renesas          |                                                                                                | Step 1 Step 2           | O Step 3 O Step      | 4 O Step 5 O                    |                                         |
|----------------------------|------------------------------------------------------------------------------------------------|-------------------------|----------------------|---------------------------------|-----------------------------------------|
| New Account Registrati     | on                                                                                             | Please select the       | e products for whic  | h you would like to se          | ee update notifications.                |
| Step 1 O Step 2 O Step     | 3 • Step 4 • Step 5 •                                                                          | Subscribe A             | All Uns              | subscribe All                   |                                         |
|                            |                                                                                                | 🛨 🗹 Boards and Kits     |                      | 🛨 🗹 Software (OS/N              | /liddleware/Driver)                     |
| Please enter a password    | I                                                                                              | 🛨 🗹 Tools               |                      | 🛨 🗹 MPU and MCU                 |                                         |
| Country / Region           | :                                                                                              | 🛨 🗹 Renesas Synergy     | TM I                 | H Intersil MCU Pr               | roduct                                  |
| Language                   | : English                                                                                      | 🗄 🗹 Power Managemer     | nt                   | Automotive                      |                                         |
| Title                      | Dr.                                                                                            | 🛨 🗹 Discrete & Power 🛙  | Devices              | 🕂 🗹 Amplifiers & Bu             | iffers                                  |
|                            | UI.                                                                                            | 🚹 🗌 Audio & Video       |                      | 🛨 🗹 Data Converter              | rs                                      |
| iven Name / First Name     |                                                                                                | 🚹 🗹 Interface           |                      | 🕂 🗹 Memory                      |                                         |
| Family Name / Last         |                                                                                                | 🞛 🗹 Optoelectronics     |                      | 🗄 🗹 Other Analog                |                                         |
| Name                       |                                                                                                | 🚹 🗌 Space & Harsh En    | vironment            | Switches, MUX                   | s & Crosspoints                         |
| Nickname                   | Doug                                                                                           | 🕂 🗌 Timing & Digital Lo | gic ICs              | LSI for Commu                   | nications and Mobile Devices            |
| Email Address              | :                                                                                              | LSI for Factory Aut     | omation              | 🚼 🗹 Smart Analog                |                                         |
|                            |                                                                                                | 🞛 🗹 ICs for Motor Drive | er/Actuator Driver   | 🕂 🗌 Renesas USB f               | Power Delivery Family                   |
| "indicates required fields |                                                                                                | RF Devices              |                      | 🕂 🗹 Boards & Kits               |                                         |
| Password *                 |                                                                                                | 🕂 🗹 Sensors             |                      |                                 |                                         |
|                            | Password must be 8 to 16 characters.<br>Please use a mixture of letters, numbers, and symbols. |                         | New Account F        | Registration                    |                                         |
| Password (confirm) *       |                                                                                                |                         |                      |                                 |                                         |
| Company                    |                                                                                                | Ne                      |                      |                                 |                                         |
| Company                    |                                                                                                |                         | Step 1 💿 Step        | 2 O Step 3 O Step 4             | 4 💿 Step 5 💿                            |
| Department/Faculty         |                                                                                                |                         |                      |                                 |                                         |
| Job Title                  |                                                                                                |                         | Thank you. Yo        | ur registration is com          | plete.                                  |
|                            |                                                                                                |                         | If you would like to | edit your profile, log in to My | y Renesas and click "Edit your profile" |
| Postal Code                |                                                                                                |                         |                      |                                 |                                         |
|                            |                                                                                                |                         | Next                 |                                 |                                         |



New Account Registration



## LAB 1 – ACTIVITY 1 – STEP 2

#### Sign In:

return to renesas.com and sign in with your mail address and the password you defined

| ickup    |                  |             |                     |           |          |    |
|----------|------------------|-------------|---------------------|-----------|----------|----|
| latforms | Design & Support | Aboı        | <b>it</b> Search    |           | ۹ ۲      |    |
|          | 🖽 News           | 🗠 Investors | 幸 Parametric Search | 💄 Sign in | Americas | Î  |
|          |                  |             |                     | 🔪 💩 N     | © 🔤 🕷    | 0: |
|          |                  |             | •                   |           | -        |    |

#### **My** Renesas

| Enter your Email | I Address and password and click "Login" to access your account. |
|------------------|------------------------------------------------------------------|
| Email Address    |                                                                  |
| Password         |                                                                  |
|                  | Stay signed in Log                                               |
|                  | <ul> <li>Forgot your password?</li> </ul>                        |
|                  | <ul> <li>Don't have an account yet?Register</li> </ul>           |

BIG IDEAS FOR EVERY SPACE

RENESAS

## LAB 1 – ACTIVITY 1 – STEP 3

Download platform

#### installer

(further registration info may be requested)



#### Solutions

Find information about recommended products and solutions created by Renesas and our development partners to help vou

BIG IDEAS FOR EVERY SPACE RENESAS



**Download platform** 

#### installer

(further registration info may be requested)

| Renesas Electronics × +            |                                                                               |  |  |  |  |
|------------------------------------|-------------------------------------------------------------------------------|--|--|--|--|
| → C 🗎 renesas.com/br/en/           | Q 🛧 🛛 🖸 🖾 🖓                                                                   |  |  |  |  |
|                                    | 🕮 News 🗹 Investors 💠 Parametric Search 🛛 🛔 Sample Student Course 🗸 🛛 🥥 Brazil |  |  |  |  |
| RENESAS Solutions Products         | Platforms Design & Support About Search Q                                     |  |  |  |  |
| Microcontrollers & Microprocessors | Embedded System Platforms                                                     |  |  |  |  |
| RA MCUs                            | Renesas autonomy™ Platform for Automotive                                     |  |  |  |  |
| RZ MPUs                            | R-IN Platform for Industrial                                                  |  |  |  |  |
| RL78 MCUs                          | RZ/G Platform for HMI                                                         |  |  |  |  |
| RX MCUs                            | Renesas Synergy™ Platform for IoT                                             |  |  |  |  |
| RH850 MCUs                         |                                                                               |  |  |  |  |
| Renesas Synergy™ MCUs              | Analog & Power                                                                |  |  |  |  |
| Other MCUs / MPUs                  | Analog Products                                                               |  |  |  |  |
|                                    | Interface                                                                     |  |  |  |  |
| Automotive                         | Memory                                                                        |  |  |  |  |
| Automotive MCUs (RH850)            | Optoelectronics                                                               |  |  |  |  |
| Systems-on-Chip (SOC)              | Power Devices                                                                 |  |  |  |  |
| Power Devices                      | Sensors                                                                       |  |  |  |  |
| Battery Management                 | Space & Harsh Environment                                                     |  |  |  |  |
| Video & Display                    | Timing & Digital Logic                                                        |  |  |  |  |
| Software & Tools                   | All Products >                                                                |  |  |  |  |
| Boards & Kits                      | Find Products                                                                 |  |  |  |  |

BIG IDEAS FOR EVERY SPACE RENESAS

**Download platform** 

installer

(further registration info

may be

requested)



### **Download platform**

#### installer

(further registration info

may be

requested)



#### Overview

Software and tools are included in the Synergy Platform with no fees or royalties. The Synergy Software Package (SSP) integrates all the functionality needed to build IoT applications including Express Logic's ThreadX RTOS and X-ware middleware, application frameworks, functional libraries, HAL drivers, and board support packages for the Synergy kits. When developing application code using the SSP, developers can choose their preferred development environment as both Renesse a2studio and IAR Embedded Workbench® for Renesas Synergy<sup>34</sup> are supported.

#### Explore Synergy Microcontrollers >

#### **Synergy Software**





### **Download platform**

#### installer

(further registration info

may be

requested)



#### Overview

Designed to accelerate time to market through rapid code development, Synergy Tools facilitate file management, software and MCU configuration, code generation, compilation, debugging, and intuitive graphic interface design. All Synergy Tools, support, development seats, and maintenance are included with the Synergy Platform.

#### IAR Embedded Workbench<sup>®</sup> for Renesas Synergy™ (EW for Synergy)

Fully integrated with the Synergy Platform, EW for Synergy includes an optimized compiler, code analysis tools such as C-STAT® and C-RUN®, and deep RTOSaware debugging with C-SPY®.

Explore IAR EW for Synergy

#### e<sup>2</sup> studio ISDE

An Eclipse-based development environment with a comprehensive set of tools and plug-in features such as intuitive configuration, error and format checking, and code generation to accelerate development.

Explore e<sup>2</sup> studio

TraceX<sup>®</sup> by Express Logic



#### **Download platform**

#### installer

(further registration info

may be

requested)





**Download platform** 

#### installer

(further registration info

may be

requested)

| RENES             | SAS                     |   | Renes | is Syne | rgy" |   |
|-------------------|-------------------------|---|-------|---------|------|---|
| synergygallery.re | nesas.com/sso/register  |   | e     | 2 \$    | 4    | N |
| sas Electronics X | Renesas Synergy Gallery | × | +     |         |      |   |

| esas Synergy™ Gallery                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| llery offers all the software libraries and tools that you need to get your Synergy project up<br>e a User Account, with no fee, and you can immediately download the latest versions of<br>kage (SSP), the e <sup>2</sup> studio Integrated Solution Development Environment (ISDE),<br>ety of software development tools for graphics, deep debugging and more after<br>rough license agreements. Additionally you can browse and select from a variety of<br>s, and Verified Software Add-on (VSA) software add-on components. This allows you to<br>stigation and assessment with broad access to the Synergy Platform and the SSP.<br>time for extensive software development and even eventual production of your Synergy<br>ou can quickly sign up and obtain a SSP Development/Production license.<br>oblems creating your user account, please <u>contact us</u> .<br>changed at MyRenesas, <u>edit now</u> . |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Required fields are marked with an asterisk (*)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| al<br>te<br>ric<br>hr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### **Download platform**

### installer

(further registration info

may be

requested)

|                                                                                                                                             | //software/tools/e2-studio.html                                                                                                          |                                                                                                                             | Q                                       | ☆ 🙆 😬    | 2 |
|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|----------|---|
|                                                                                                                                             | 1997 N                                                                                                                                   | lews 🗵 Investors 😤 Parametric Searc                                                                                         | h 🛔 Sample Student Course 🗸 🛛           | 🛛 Brazil |   |
|                                                                                                                                             | Products Platforms                                                                                                                       | Design & Support Abou                                                                                                       | nt Search O                             | 1 👷      |   |
| Renesas Electronics > All Products > Re                                                                                                     | nesas Synergy™ Platform ⇒ Synergy Software ⇒ [                                                                                           | Development Tools                                                                                                           |                                         |          |   |
| e² studio                                                                                                                                   |                                                                                                                                          |                                                                                                                             |                                         |          |   |
|                                                                                                                                             | Renesas                                                                                                                                  |                                                                                                                             |                                         |          |   |
|                                                                                                                                             | Details                                                                                                                                  |                                                                                                                             |                                         |          |   |
| e² studio                                                                                                                                   | The e² studio ISDE is specifically design<br>design process: preparation phase, bui                                                      |                                                                                                                             | rs tools for three phases of the soft   | ware     |   |
|                                                                                                                                             | For the preparation phase, e <sup>2</sup> studio fea<br>assignments, and software options suc<br>selections are made, notifying the user | h as RTOS thread assignments. Built                                                                                         |                                         |          |   |
|                                                                                                                                             | e <sup>2</sup> studio also includes features designe<br>code templates, and automated code c<br>autocomplete, and context-aware man      | onstructs. Keyword color-coding, jun                                                                                        | np-to declarations, variable            | ilt-in   |   |
|                                                                                                                                             | For the debug phase, e² studio provide:<br>dynamic tracking of thread execution ti<br>behavior. Comprehensive debug and a                | mes and interrupt service routines, a                                                                                       | as well as visualization of overall sys | stem     |   |
|                                                                                                                                             | , ,                                                                                                                                      |                                                                                                                             | 5                                       |          |   |
|                                                                                                                                             |                                                                                                                                          |                                                                                                                             |                                         |          |   |
| Download                                                                                                                                    |                                                                                                                                          |                                                                                                                             |                                         |          |   |
| Version 7.5.1                                                                                                                               |                                                                                                                                          |                                                                                                                             | Download Platform Installer             |          |   |
| Current Public Release<br>Release Date: 2019-09-10<br>MCUs Supported: 57G2, S3A<br>S5D5, S5D3, S3A6, S3A1, S1J/<br>MD5: 91fb1300b32c297-929 |                                                                                                                                          |                                                                                                                             | Download Standalone Installer           |          |   |
| What's New?<br>New Features in e2Studio 7.5.                                                                                                |                                                                                                                                          |                                                                                                                             |                                         |          |   |
|                                                                                                                                             | e The Stack Analysis feature has been enabled to                                                                                         | analyze stack information file output by                                                                                    | GNU                                     |          |   |
|                                                                                                                                             | eature can be used to check the function call stru                                                                                       |                                                                                                                             | ion.                                    |          |   |
| Arm Embedded toolchain. This t<br>Memory Usage View Shows Lo<br>addresses. When a section is co                                             |                                                                                                                                          | ucture and stack size, used by each funct<br>m®, the memory usage view can now sh<br>ory Address, the Load Memory Address i | low load                                |          |   |

e2 studio sessions. When users open e2 studio, the real-time refresh state of each expression is in its prior state when e2 studio



#### **Download platform**

#### installer

(further registration info

may be

requested)





Download these two PDFs: getting started and release notes they contain important information about the tools and their installation.

platform installer download in progress



RENESAS

BIG IDEAS FOR EVERY SPACE

#### Installation process

Unzip the downloaded file to obtain the installation executable,

run it.





### Installation process

Note in red where the user must make appropriate selections

| 🗟 Renesas Synergy Softw | are Package (SSP) v1.7.5 with e2 studio 7.5.1 Setup                                                |        |       | ×  |
|-------------------------|----------------------------------------------------------------------------------------------------|--------|-------|----|
| Renesas Synergy Softwa  | are Package (SSP) v1.7.5 with e2 studio 7.5.1 Setup                                                |        |       | ſ  |
| Install Type            |                                                                                                    |        |       |    |
|                         | Select Install Type:<br>Quick Install<br>Default installation of e2 studio, SSP & GCC ARM Embedded |        |       |    |
|                         | Custom Install<br>Installation of e2 studio & SSP along with optional components                   |        |       |    |
|                         |                                                                                                    |        |       |    |
|                         |                                                                                                    |        |       |    |
| <u>v202001072111</u>    | < <u>B</u> ack <u>N</u> ext > <u>I</u>                                                             | nstall | Canco | el |







| 🗟 Renesas Synergy Software Package (SSP) v1.7.5 with e2 studio 7.5.1 Setup — 🗆 🗙 |                                                                                   |                      |  |                                                                                                                                                                                                                |             |        |   |  |
|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|---|--|
|                                                                                  | <b>sas Synergy Softw</b><br>It the components yo                                  | -                    |  | with e2 studio 7.5.1 Setup                                                                                                                                                                                     |             |        | P |  |
| 9                                                                                | Welcome<br>Optional<br>Components<br>Licenses<br>Summary<br>Installing<br>Results | ☑<br>☑<br>Select All |  | User Manual for Renesas SSP v1.7.5<br>Renesas SSP User Manual<br>GCC ARM Embedded v7.2 2017q4<br>GCC ARM Embedded toolchain - v7.2 2017q4<br>GUIX Studio<br>GUIX Studio provides a complete GUI application de | esign envir | onment |   |  |
|                                                                                  | <u>v202001072111</u>                                                              |                      |  | < <u>B</u> ack <u>N</u> ext > <u>I</u> nstal                                                                                                                                                                   |             | Cance  | I |  |





| 🛃 Re | 🔜 Renesas Synergy Software Package (SSP) v1.7.5 with e2 studio 7.5.1 Setup —      |                                                                              |           |            |     |  |  |
|------|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------|-----------|------------|-----|--|--|
| Rene | sas Synergy Softw                                                                 | are Package (SSP) v1.7.5 with e2 studio 7.5.1 Setup                          |           |            | P   |  |  |
| ۲    | Welcome<br>Optional<br>Components<br>Licenses<br>Summary<br>Installing<br>Results | Please wait while Renesas Synergy Software Package (SSP) v1.7.5 with e2 stur | dio 7.5.1 | is install | ed. |  |  |
|      | <u>v202001072111</u>                                                              | < <u>B</u> ack <u>N</u> ext > <u>I</u> nstall                                |           | Cance      | :   |  |  |







| 😼 Re | Renesas Synergy Software Package (SSP) v1.7.5 with e2 studio 7.5.1 Setup – 🛛 🗙 |                                                                                                                                                                                                                                                                                                            |          |    |  |  |  |
|------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----|--|--|--|
| Rene | enesas Synergy Software Package (SSP) v1.7.5 with e2 studio 7.5.1 Setup        |                                                                                                                                                                                                                                                                                                            |          |    |  |  |  |
|      | Welcome                                                                        | Installation of Renesas Synergy Software Package (SSP) v1.7.5 with e2 studio 7.5.1 is                                                                                                                                                                                                                      | complete | £. |  |  |  |
|      | Optional<br>Components                                                         | Please click <b>OK</b> to close.                                                                                                                                                                                                                                                                           |          |    |  |  |  |
|      | Licenses                                                                       | ☑ Run e2 studio?                                                                                                                                                                                                                                                                                           |          |    |  |  |  |
|      | Summary                                                                        | ✓ View Renesas SSP User Manual?                                                                                                                                                                                                                                                                            |          |    |  |  |  |
|      | Installing                                                                     |                                                                                                                                                                                                                                                                                                            |          |    |  |  |  |
| •    | Results                                                                        | Useful Links:<br><u>Renesas Synergy SSP: C:\Renesas\Synergy\e2studio v7.5.1 ssp v1.7.5</u><br><u>Renesas SSP User Manual: C:\Renesas\Synergy\e2studio v7.5.1 ssp v1.7.5\SSP Docu<br/><u>GCC ARM Embedded:</u><br/><u>C:\Renesas\Synergy\e2studio v7.5.1 ssp v1.7.5\toolchains\gcc arm\7.2.1 2017q4</u></u> | umentati | on |  |  |  |
|      | <u>v202001072111</u>                                                           | < <u>B</u> ack <u>N</u> ext > OK                                                                                                                                                                                                                                                                           | Cance    | 1  |  |  |  |







execute e2studio: C:\Renesas\Synergy\e2studio\_v7.5.1\_ssp\_v1.7.5\eclipse\e2studio.exe

| RENESAS                            |                                                                                                        |
|------------------------------------|--------------------------------------------------------------------------------------------------------|
|                                    | e <sup>2</sup> Eclipse Launcher X                                                                      |
|                                    | Select a directory as workspace                                                                        |
|                                    | e <sup>2</sup> studio uses the workspace directory to store its preferences and development artifacts. |
| e <sup>2</sup> studio              | Workspace: C:\Users\Douglas\e2_studio\workspace                                                        |
| v7.5.1                             | Use this as the default and do not ask again                                                           |
| Loading org.eclipse.oomph.setup.ui |                                                                                                        |





### LAB 1 – ACTIVITY 1 – LEARN YOUR CONFIGURATION!

- From e2studio | Help | About get the version of e2studio: 7.5.1
- In C:\Renesas\Synergy\e2studio\_v7.5.1\_ssp\_v1.7.5 the folder name indicates the version of the SSP: 1.7.5
- In C:\Renesas\Synergy\e2studio\_v7.5.1\_ssp\_v1.7.5\toolchains\gcc\_arm see the version of the GCC tools: 7.2.1.2017
- From the microcontroller chip on the development board: S7G27H3CFC

| e <sup>2</sup> About e <sup>2</sup> studio | - D X                                                                                                                                                                                 | C:\Renesas\Synergy\e2 | studio_v7.5 | .1_ssp_v1.7.0\toolchains <sup>\</sup> | \gcc_arm |                 |             | ٽ ~  |
|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------|---------------------------------------|----------|-----------------|-------------|------|
|                                            | Renesas e <sup>2</sup> studio                                                                                                                                                         |                       | * ^         | Name                                  | ^        | Date modified   | Туре        | Size |
| ~ 2                                        | Version: 7.5.1<br>Build Id: R20190813-1458                                                                                                                                            |                       | *           | 7.2.1_2017q4                          |          | 16-Oct-19 10:00 | File folder |      |
|                                            | Parts Copyright (C) 2010-2018 Renesas Electronics Corp.<br>All rights reserved.                                                                                                       | ure                   | *           |                                       |          |                 |             |      |
|                                            | e2 studio IDE is an extension of software developed for<br>eclipse.org.                                                                                                               |                       | *           |                                       |          |                 |             |      |
|                                            | e2 studio IDE is based on Eclipse SDK 4.7.3 (Oxygen.3)<br>and CDT version 9.4.3.                                                                                                      |                       |             |                                       |          |                 |             |      |
|                                            | Source code for the Eclipse Foundation plug-ins is available<br>from www.eclipse.org, under the Eclipse Public License "EPL",<br>see http://www.eclipse.org/org/documents/epl-v10.php |                       |             |                                       |          |                 |             |      |
| <u></u>                                    | Z 😑 e² 🕟 🚱 🚱 🔛 🖉 😂                                                                                                                                                                    |                       |             |                                       |          |                 |             |      |
| ? Installatio                              | n Details <u>C</u> lose                                                                                                                                                               |                       |             |                                       |          |                 |             |      |

RENESAS

**BIG IDEAS FOR EVERY SPACE** 

## LAB1 – SYNERGY PLATFORM

### Activity 2 – Setup the SK-S7G2 board

- 1. Verify the position of the jumpers on the board.
- Connect the micro-USB cable to the DEBUG\_USB port on the board and to your PC.
- Verify the setup of the board and e2Studio by running a sample demo (Blinky).



source: Renesas.com



### **SK-S7G2 BOARD FEATURES**

- Uses a 176-pin LQFP MCU
   240 MHz S7G2 Cortex-M4 based microcontroller.
- 2. All pins of the MCU are accessible via header pins (access to CAN, SPI, UART, I2C).
- 3. Resistive touch TFT colour LCD ( 320 x 240 pixels).
- 4. Capacitive touch slider.
- 5. Connectors:
  - 1. USB Host High speed
  - 2. USB Device Full speed.
  - 3. Ethernet 10/100
  - 4. 2 PMOD type 2A
  - 5. audio connector
  - 6. CAN, RS-232/RS-485
  - 7. Arduino shields compatible connector
- 6. Wireless connectivity: on-board Bluetooth Low Energy (BLE) device
- 7. QSPI flash memory (8 MBytes).
- 8. USB JTAG (on-board Segger JLink).
- 9. 3 user leds and 2 push buttons.
- 10. WiFi connectivity using add-on boards (e.g. AE-CLOUD1).

### SK-S7G2 board block diagram



source: Renesas Starter Kit SK-S7G2 User's Manual

BIG IDEAS FOR EVERY SPACE **RENESAS** 

### Verify the position of the jumpers on the board:

| Jumper | Position                                                                 |
|--------|--------------------------------------------------------------------------|
| J1     | 1-2: normal boot                                                         |
| J2     | open (reset released)                                                    |
| J8     | 1-2: signals a GPIO pin that RS-232 should be selected instead of RS-485 |
| J9     | 1-3 and 2-4: use RS-232 driver                                           |
| J13    | 1-2: output 3V3 to PMODA connector                                       |
| J15    | 1-2: output 3V3 to PMODB connector                                       |
| J31    | closed - used for current<br>measurement to MCU                          |

pin 1 is marked by a triangle next to the connector J9 (double row of pins is numbered as: 2 4 6

1 3 5



RENESAS

BIG IDEAS FOR EVERY SPACE

Suggested reading: Renesas Synergy Starter Kit SK-S7G2 User's Manual (<u>r12um0004eu0100</u>)

(https://www.renesas.com/us/en/doc/products/renesas-synergy/doc/r12um0004eu0100\_synergy\_sk\_s7g2.pdf)

this manual has detailed explanation on the board functionality, schematics and configuration

Connect the micro-USB cable to the DEBUG\_USB port on the board and to your PC.

LED 4 should light up to indicate that the board powered up.



BIG IDEAS FOR EVERY SPACE **RENESAS** 



| <ol> <li>Run e2studio<br/>(StartMenu   Renesas Synerg<br/>7.5.1)<br/>if the welcome screen shows<br/>Workbench.</li> </ol>                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Project         Project name         Blinky         Use default location         Location:       C:\Users\Douglas\e2_studio\workspace_tst2\Blinky         Browse         Choose file system:         default         License       | Toolchains<br>GCC ARM Embedded                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| <ol> <li>File   New   Synergy C/C++ F<br/>Renesas Synergy C Executa<br/>Project name: Blinky</li> </ol>                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | License file:<br>C:\Renesas\Synergy\e2studio_v7.5.1_ssp_v1.7.5\internal\projectgen\arm\lice<br>License Details:<br>CUSTOMER INFORMATION:<br>Company: Renesas Electronics America Inc.<br>UserName: Renesas Synergy Evaluation User | Change license file<br>enses\SSP_License_Example_EvalLicense |
| Eclipse Launcher Select a directory as workspace e <sup>2</sup> studio uses the workspace directory to store its preferences and development artifacts.                                                                                       | X      X      X      X      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y      Y | X Email: noreply@renesas.com LICENSE INFORMATION: Issued: 25/07/2019                                                                                                                                                               | •                                                            |
| Workspace:       C:\Renesas\RenesasDrRepo\SE_course_v12 <ul> <li>Browse</li> <li>Use this as the default and do not ask again</li> <li>Recent Workspaces</li> <li>SE course_v12</li> <li>workspace</li> <li>Launch</li> <li>Cancel</li> </ul> | All       Renesas Synergy C Executable Project         C/C++       Renesas Synergy C Library Project for Renesas Synergy.         Renesas Synergy C Library Project       A C Library Project for Renesas Synergy.         Renesas Synergy C Project Using Synergy Library       Renesas Synergy C Project Using Synergy Library         Renesas Creates a C application project which uses an existing for the project of the proje                                                                                                                                                                    | Visit the Apps Gallery for license file and Pack file downloads         *         ?         <                                                                                                                                      | > <u>Finish</u> Cancel                                       |
|                                                                                                                                                                                                                                               | (?) < <u>Back</u> <u>Next</u> > <u>Finish</u> Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                    |                                                              |

e<sup>2</sup> e2 studio - Project Configuration (Synergy C Executable Project)

Specify the new project details.

e2 studio - Project Configuration (Synergy C Executable Project)



 $\rightarrow$ 

×

3. Select board: S7G2 SK

Select the MCU that is used in your board Select the toolchain version that was installed during Activity 1 of this Lab Select J-Link ARM as the debugger interface

| e <sup>2</sup> e2 studio - Projec                            | t Configuration (Synergy C Executable                      | Project)                  | _                                                                                                                                                                                    |        |
|--------------------------------------------------------------|------------------------------------------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| -                                                            | Configuration (Synergy C Executory oport that you require. | table Project)            |                                                                                                                                                                                      |        |
| · · · · ·                                                    | 7.5 ~<br>7G2 SK ~<br>7FS7G27H3A01CFC                       | Board Details             |                                                                                                                                                                                      |        |
| Select Tools<br>Toolchain:<br>Toolchain version<br>Debugger: | GCC ARM Embedded<br>7.2.1.20170904<br>J-Link ARM           | ~                         | Available Tools<br>- GCC ARM Embedded<br>7.2.1.20170904<br>- Debuggers<br>J-Link ARM<br>- RTOS<br>Express Logic Threa<br>- Smart Manual<br>IO Registers Suppor<br>Software Manual Su | ted    |
| ?                                                            | < [                                                        | <u>B</u> ack <u>N</u> ext | > <u>F</u> inish                                                                                                                                                                     | Cancel |

e<sup>2</sup> Open Associated Perspective?

Remember my decision

4. Select **Blinky** as the Template Finish (press Finish button)

accept the suggested perspective





- On the Project Explorer right click on the Blinky project Build Project (should compile without errors or warnings).
- 6. Right click again on Blinky project **Debug As | Debug Configurations...**
- On the Debug Configurations Window expand Renesas GDB Hardware Debugging select Blinky Debug.

**Debug** (press Debug button) if offered to upgrade the J-Link firmware, accept if offered to change perspective, accept.

| *                             | 🔳 🐐 De                             | bug              | ✓ C Blinky Debug                                  |                                        | 🥖 🖾 🚸 🕶 💁 •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | r 🗀 🛷 👻                                  |
|-------------------------------|------------------------------------|------------------|---------------------------------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| s = *16 I                     | • 💷 😭 🖏 d                          | 5 @ 9 -          | ₩ - *> -> -                                       | Quick Access                           | 🗄 🔂 🔤 C/C++ 👸                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Synergy Configuratio                     |
| Project Ex                    | plorer 🔀                           |                  | Notifications in the Smart Brow                   | 💮 [Blinky] Synergy Configuration 🕱 🖵 1 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
| Blinky                        |                                    | \$\$  \$₽ ▽      | Summary                                           |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Q 🔍 🕶   🏢 🕶 Ab                           |
| > 29 sr<br>> 29 sr<br>> 29 sy | c<br>mergy                         |                  | Project Summary                                   |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 12 12 12 12 12 12 12 12 12 12 12 12 12 1 |
|                               | nergy_cfg                          |                  | Board: S7G2 SK                                    |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
|                               | inky Debug.laun                    | :h               | Device: R7FS7G27H                                 | I3A01CFC                               | P400 221                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | $\frown$                                 |
|                               | onfiguration.xml                   |                  | Toolchain: GCC ARM E                              | mbedded                                | P401 22 2<br>P402 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ()                                       |
|                               | 7FS7G27H3A01CF                     | C.pincfg         | Toolchain Version: 7.2.1.201709                   | 904                                    | P403 2 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                          |
|                               | 7G2-SK.pincfg<br>eveloper Assistan |                  | SSP Version: 1.7.5                                |                                        | P404 22 5<br>P405 22 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $\bigcirc$                               |
|                               | eveloper Assistan                  |                  | Selected software components                      |                                        | P406 327<br>P700 328<br>P701 329<br>P702 3210<br>P703 3211                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          |
|                               |                                    |                  | Board support package for R7FS                    | S7G27H3A01CFC v1.7.5                   | P704 22 12<br>P705 22 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                          |
|                               |                                    |                  | Board support package for S7G                     | 2 v1.7.5                               | P706 22 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          |
|                               |                                    |                  | Board support package for S7G2                    | 2 v175                                 | P707 2215<br>P800 2216                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                          |
|                               |                                    |                  | Summary BSP Clocks Pins Threads M                 | essaging Components                    | VBAT 18<br>VCL 19<br>XCIN 20<br>XCVT 22<br>VSC 22<br>P212 22<br>P212 22<br>P2<br>XCVT 22<br>P213 22<br>P212 22<br>P213 22<br>P213 22<br>P214 22<br>P214 22<br>P215 P215 P215 P215 P215 P215 P215 P215 | >                                        |
| Properties                    | s 🔝 Problems                       | 🌸 Smart Brows    | er 🛛 🗖 E                                          | Pin Conflicts 🔀                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ₩ ▽ □ [                                  |
|                               |                                    |                  | ◇ ▲ ⇒ ≫ 間 塗 鯊 / ✓ 丶                               |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
| evice: -                      |                                    |                  |                                                   | Description                            | Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Pin                                      |
| Context He                    | lp User's Manu                     | al Technical Upo | date Application Notes Tool News 🔸                |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
| Total: 20                     |                                    |                  |                                                   |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
|                               | Received Date                      | Category         | Contents ^                                        |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
| UNREAD                        | 2019/10/16                         | Tool Topics      | FAQ Update related to IDE (e2 studio              |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
|                               | 2019/10/16                         | Tool Topics      | FAQ Update related to IDE (e2 studio              |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
| UNREAD                        | 2019/10/16                         | Tool Topics      | FAQ Update related to IDE (e2 studio              |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
| UNREAD                        | 2019/10/16                         | Tool Topics      | FAQ Update related to IDE (e2 studio $\checkmark$ |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
| <                             |                                    |                  | >                                                 |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |
|                               |                                    |                  |                                                   | <                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                          |

**BIG IDEAS FOR EVERY SPACE** 

RENESAS

- 8. The debug perspective should be presented at this time (see \* Debug on upper right)
- Press Resume ( ) and the code is executed up to the start of the main function green line
- Press Resume again and the code executes: three leds blink near the LCD of the board.

You succeeded in the installation of e2studio!

Debug - Blinky/src/synergy\_gen/main.c - e2 studio <u>File Edit Source Refactor Navigate Search Project Renesas Views Run Window H</u>elp ٩ + 및 🐘 🕲 + 🔨 + 🕄 🏔 🗽 🖬 🔳 🖬 🗶 👁 👉 🖶 🖘 🖘 😳 🙆 🌽 😂 🖉 + 🔕 + 🚱 🖉 + 🏷 - 🕹 + Quick Access 😭 🔤 C/C++ 🍈 Synergy Configuration 🎄 Debug 🗱 🔊 🔊 🔊 (x)= Varia... 🕺 💁 Brea... 🔐 Regi... 🛋 Mod... 🍕 Expr... 🥊 Even... 🦷 IO R... 🛼 Peri... 🍇 🔩 🔻 🎭 🕪 💷 😭 🍪 🕹 🙌 🚺 🍪 . 🎋 Debug 🔀 Blinky Debug [Renesas GDB Hardware Debugging] 物→推回||◎ 新業隆||11 11 ✓ ₩ Blinky.elf [1] Name Type ✓ Inread #11 (single core) (Suspended : Breakpoint) main() at main.c:5 0x31ca C:/Renesas/e2\_studio/DebugComp/arm-none-eabi-gdb (7.8.2) GDB server 📑 Outline 🎦 Project Explorer 💥 - -(Blinky) Synergy Configuration c startup S7G2.c c main.c 🔀 🖻 🕏 /\* generated main source file - do not edit \*/ extern void hal entry (void); 🗸 😂 Blinky int main(void) > 🐰 Binaries 000031c8 > 🔊 Includes 000031ca hal entry (); > 🔑 src return 0; > 🔑 synergy 000031ce > 👝 Debug > 🗁 script > 📂 synergy\_cfg Blinky Debug.jlink Blinky Debug.launch configuration.xml R7FS7G27H3A01CFC.pincfg S7G2-SK.pincfg 📮 Console 🐹 🐙 Tasks 😤 Renesas ... 👔 Memory ... 🕐 Performa... 🥐 Profile 🖏 Real-time... 👒 Trace 🕥 Visual Ex... 🖄 ARM Cor... 🎡 Smart Br... 🦹 Problems 👔 Executabl... 👖 Memory 🗧 🗖 🔳 🗙 🔆 🖳 🔐 🔛 🔚 🔚 🚝 🛃 🚽 🗂 ୟ Blinky Debug [Renesas GDB Hardware Debugging] C:/Renesas/e2\_studio/DebugComp/arm-none-eabi-gdb (7.8.2) Program received signal SIGTRAP, Trace/breakpoint trap. Reset Handler () at ../synergy/ssp/src/bsp/cmsis/Device/RENESAS/S7G2/Source/startup S7G2.c:60 60 Temporary breakpoint 1, main () at ../src/synergy\_gen/main.c:5 hal entry ();

**BIG IDEAS FOR EVERY SPACE** 

**RENESAS** 



# LAB1 – SYNERGY PLATFORM

### Activity 3 – Overview of the Synergy Platform

- 1. How platform is defined in this context
- 2. What is included in the Synergy Platform
- 3. Effect on the development process



#### **Concept of the Synergy Platform**

In this context, **Platform** is defined as a complete **set of hardware and software components** that can be easily combined to form the foundation upon which a solution is built. Furthermore, the Platform also provides the infrastructure for development (development tools, example of end-product design, technology building-block examples, web accessible repository of tools and software).



# LAB1 – ACTIVITY 3

### What is included in the Synergy Platform?

- 1. A family of Microcontrollers (S1, S3, S5, S7)
- SSP (Synergy Software Package) complete package of qualified software
- Development tools
   (e.g. the e2studio ISDE)
- 4. Development Boards (e.g. SK-S7G2)
- 5. Product examples
- 6. Application examples
- 7. Synergy Gallery

(web accessible repository)



#### Synergy Software Package (SSP)

| ThreadX <sup>®</sup><br>RTOS                                                                                         | FileX®                                                                                                                                                               | USBX™                                                                                                                                                                |                                                           | JIX™                                                                        | NetX⊺<br>NetX⊺                                                              | ™ and<br><sup>M</sup> Duo                                           |                                                                      | lication<br>nework                                 | Functional<br>Libraries                                    |
|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------|------------------------------------------------------------|
| Advanced<br>Scheduler<br>Inter-process and<br>Inter-thread<br>Communication<br>Memory<br>Management<br>Message Queue | FAT12/16/32,<br>exFAT, SD,<br>microSD, CF, and<br>MemoryStick<br>Complete Flash<br>Management with<br>Wear Leveling<br>Very Fast<br>Performance and<br>Low Footprint | Host Classe<br>(Storage, CD<br>HID)<br>Host Stack<br>Host Controll<br>Device Classe<br>(Storage, CD<br>Audio, HID,<br>Printer, Hub<br>Device Stack<br>Device Control | C, Run Tir<br>Ca<br>er Dra<br>es So<br>C, Sy<br>) Wi<br>k | K Studio<br>me Library<br>anvas<br>awing<br>creen<br>rstem<br>idget<br>ndow | FTP<br>TFIP<br>Telnet<br>PPP<br>SMTP<br>POP3<br>HTTP<br>DNS<br>SNMP<br>DHCP | SNTP<br>NAT<br>TCP<br>IPv4/v6<br>UDP<br>ICMP<br>IGMP<br>ARP<br>RARP | Audio<br>Console<br>JPEG<br>Touch Pan<br>External<br>IRQ<br>Messaoin | Monitor<br>Power<br>Profile                        | Security &<br>Encryption<br>CMSIS DSP<br>Captouch          |
|                                                                                                                      |                                                                                                                                                                      |                                                                                                                                                                      | Hardwa                                                    | are Abstrac                                                                 | tion Lay                                                                    | er (HAI                                                             | L) Drivers                                                           |                                                    |                                                            |
|                                                                                                                      | Ethernet MAC<br>Controller<br>USBHS<br>USBFS                                                                                                                         | CAN<br>UART<br>SDHI<br>QSPI                                                                                                                                          | SPI<br>IIC<br>SSI<br>RTC                                  | ADC12<br>ADC14<br>DAC12<br>Safety                                           | Data Tra<br>Contro<br>DMA Con<br>Timing &                                   | oller<br>ntroller                                                   | Clock<br>Management<br>Security &<br>Encryption                      | Graphics LCD<br>Controller<br>2D Drawing<br>Engine | Segment LCD<br>Controller<br>Parallel Data<br>Capture Unit |

#### Board Support Package (BSP)

source: Renesas, Synergy Platform Architecture

BIG IDEAS FOR EVERY SPA

RENESAS

# LAB1 – ACTIVITY 3

### Traditional Development



# LAB1 – SYNERGY PLATFORM

#### Activity 4 – Overview of e2studio

- 1. Understanding the organization of e2studio
- 2. Common tasks in e2studio





# LAB1 – ACTIVITY 4

The e2studio ISDE (Integrated Solutions Development Environment)

Features:

- 1. Built on the Eclipse Framework
- 2. Compiler/Linker GNU or IAR
- Editor (with syntax highlighting and autocomplete)
- 4. Configuration tools (pin, clock, interrupt, ...)
- 5. SSP module selector and configurator
- 6. RTOS awareness, execution profiler, tracing
- 7. JTAG debugger interface (J-Link)





# LAB1 – ACTIVITY 4

Eclipse is a framework upon which many open source development environments are built.

Some important concepts of eclipse are:

- The workbench window (identified by an orange border)
- Several areas in the workbench, in this example the areas are identified in red
- In each area, several parts can be superimposed, selectable by a tab

| C/C++ - Blinky/synergy/ssp/src/bsp/cmsis/Device/RENE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                      | – 🗆 X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>File Edit Source Refactor Navigate Search Project</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                      | C/C++ 👹 Synergy Configuration 💠 Debug                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ြာ Project Explorer 🔀 🔲 🖻 🛱 🗸 🖓 🖓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 🗆 💱 [Blinky] Synergy Configuration 🛛 🔓 startup_S762.c 💥 🖻 main.c 👘 🗖 | E Outline 😫 💿 Make Target 🛛 🗖                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <ul> <li>Binky [Debug]</li> <li>Binaries</li> <li>Si Includes</li> <li>Si Src</li> <li>Si Sr</li> <li>Si</li></ul> | <pre> 2</pre>                                                        | I a bsp_api.h<br>exc_ptr_t: void(')(void)<br>exc_ptr_t: void(')(void)<br>exc_ptr_t: void(')(void)<br>exc_ptr_t: void(')(void)<br>befault_Handler(void): void<br>Default_Handler(void): void<br>befault_Handler(void): void<br>befault_Handler(void): void<br>befault_Handler(void): void<br>weak.REF_ATTRIBUTE<br>WEAK.REF_ATTRIBUTE<br>WEAK.REF_ATTRIBUTE<br>WEAK.REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_ATTRIBUTE<br>WEAK_REF_A |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Device: -                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | User's Manual Technical Update Application Notes Tool News           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Title     Document     Rev.     Issue Date     Remarks               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                      | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Willable Shall State                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



A part is either an editor or a view.

An **editor** area (shown here) may have many open files, selectable by a tab (in red). In this example the file *startup\_S7G2.c* is shown on the editor panel.

The eclipse editor uses syntax highlighting, hence, comments are in green, types are in magenta, function names in bold, header blocks are in blue, ...

| ş | [Blinky] Synergy ( | Configuration 😡 startup_S7G2.c 🛞 🖻 main.c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |
|---|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|   | 10                 | Cypeace void ( CAC_per_o) (void),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ^    |
|   | 41                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
|   | 43                 | • Exported global variables (to be accessed by other files).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |
|   | 45                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
|   | 47                 | Private global variables and functions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | - 10 |
|   | 49                 | void Reset Handler (void);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |
|   | 50                 | <pre>void Default_Handler(void);</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |
|   | 51                 | <pre>void main(void);</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |
|   | 52                 | * Evention News, Denot Handler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |
|   | 54<br>59           | ★ Function Name: Reset_Handler.     Arrow And Arrow Arrow And Arrow And Arrow |      |
|   | 59<br>60           | ⊖void Reset_Handler (void)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |
|   | 61                 | {     /* Initialize system using BSP. */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |
|   | 62                 | SystemInit();                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |
|   | 63                 | Systeminic(),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |
|   | 64                 | /* Call user application. */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |
|   | 65                 | main();                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |
|   | 66                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
|   | 67                 | ⊖ while (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |
|   | 68                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
|   | 69                 | /* Infinite Loop. */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |
|   | 70                 | }                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |
|   | 71                 | }                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |
|   | 72                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
|   | 74                 | ⊕ * Function Name: Default Handler.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |
|   | 79                 | ⊖void Default Handler (void)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |
|   | 80                 | {                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |
|   | 81                 | $\odot$ /** A error has occurred. The user will need to investigate the cause.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Cc   |
|   | 84                 | <pre>BSP_CFG_HANDLE_UNRECOVERABLE_ERROR(0);</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |
|   | 85                 | }                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |
|   | 86                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
|   | 87                 | ⊖ /* Stacks. */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
|   | 0.0                | (+ M-12 +/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | >    |
|   |                    | ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | -    |

A view is used mainly to present information.

The **project explorer** view presents the files that compose the Blinky project.

The **outline** view presents the elements (variable, constants, functions, ...) that compose the file that is open in the currently active editor pane (in this example the startup\_S7G2.c file of the previous slide).

Each view may have its own menu. Accessible by the icon identified in a red box.

There are hundreds of views available in the submenu of Window | ShowView.







Parts (editors and views) can be freely rearranged and grouped to fit the user needs.

A given organization of parts is called a **perspective**. Some are predefined, but the user can create his own perspectives.

Perspectives are selected by buttons on the upper right (C/C++ perspective identified in red). Each perspective is conceived to fit a given activity, such as source file editing, synergy platform configuration, debugging, ...

Choose Window | Perspective | Reset Perspective... to restore a perspective back to its default organization.



A **project** consists of a set of inputs files (source files and configuration files) as well as the output files generated during the compile/link process.

A project is presented in the **Project Explorer** window in the form of a tree with files and folders.

The user can create folders to better organize the files of a project

A project generates a **single binary executable** or a **library**.

Several configurations of a project may be stored for easy access. Such as: a configuration that generates debug info vs one that does not.

Here shown is the **Blinky** project in its Debug configuration.

e<sup>2</sup> C/C++ - Blinky/s rgy/ssp/src/bsp/cmsis/Device/RENESAS/S7G2/Source/startup\_S7G2.c - e2 studio \_ <u>File Edit Source</u> factor <u>N</u>avigate Se<u>a</u>rch <u>P</u>roject Renesas<u>V</u>iews <u>R</u>un <u>W</u>indow <u>H</u>elp K + K 🗈 V 😳 🖉 🖅 🖆 + 🖄 + 👌 + 🔇 + 🛠 + 🔿 + 隆 🖌 + 🗐 🔳 🕤 🍠 🐓 + 🖓 + 🖓 🗝 🗕 🗖 🗖 🖛 Quick Access 😰 📴 C/C++ 👼 Synergy Configuration 🚸 Debug ~ - - -Project Explorer 🇊 [Blinky] Synergy Configuration 👘 💦 startup\_S7G2.c 🙁 🔂 main.c 😑 🗖 🔚 Outline 🔀 🛞 Make 🖪 🕵 -✓ 🕵 Blinky [Debug] ⊕ \* Copyright [2015-2017] Renegas Electronics Corporation and/or its licensor; ∧ E la, > 🐰 Binaries • \* File Name : startup\_S7G2.c[] 🔛 bsp\_api.h > 🔊 Includes exc\_ptr\_t : void(\*)(void) Includes <System Includes> , "Project Includes"... > 🔑 src + Reset Handler(void) : void #include "bsp api.h" > 😂 synergy Default Handler(void): void
 > 📂 Debug ++ main(void) : void /\* Only build this file if this board is chosen. \*/ > > > script Reset Handler(void) : void #if defined(BSP MCU GROUP S7G2) > > by synergy\_cfg Default\_Handler(void) : void Blinky Debug.jlink § g\_main\_stack : uint8\_t[] Macro definitions Blinky Debug.launch g\_process\_stack : uint8\_t[] configuration.xml 🔊 <sup>S</sup> g heap : uint8 t[] Typedef definitions. R7FS7G27H3A01CFC.pincfg 🖋 WEAK REF ATTRIBUTI /\* Defines function pointers to be used with vector table. \*, S7G2-SK.pincfg # WEAK REF ATTRIBUTE typedef void (\* exc ptr t) (void); 41 + NMI Handler(void) : void Exported global variables (to be accessed by other files). + HardFault\_Handler(void) : void 43 45 H MemManage Handler(void): void Private global variables and functions. H BusEault Handler(void) : void 49 void Reset Handler(void); + UsageFault\_Handler(void) : void void Default Handler(void); ++ SVC\_Handler(void) : void void main(void); + DebugMon\_Handler(void) : void ++ PendSV\_Handler(void) : void \* Function Name: Reset Handler. 54 ++ SysTick\_Handler(void) : void void Reset Handler (void) C \_\_Vectors : const exc\_ptr\_t[] /\* Initialize system using BSP. \*/ 62 SystemInit(); /\* Call user application. \*/ main(); while (1) 🚸 🖶 🗸 🗖 🗖 🧔 Tasks 📃 Console 🔲 Properties 🔋 Memory Usage 🏽 🛞 Smart Browser Device: User's Manual Technical Update Application Notes Tool News Title Document ... Rev Issue Date Remarks 39:36 Writabl Smart Insert



🗸 💭 Blinky [Debug]

A workspace is a set of projects.

Typically, projects in the same workspace share common features such as libraries and hardware platforms.

For instance, you can create a single workspace for all projects of this Embedded Systems course, since they all will be running on the SK-S7G2 board and may share libraries.

On the file system a workspace corresponds to a folder and each of its projects is a folder therein.

(figure shows two projects in the same workspace)



The **Synergy Configuration** perspective.

Select this perspective when using the **Synergy Configuration Tool** to configure the SSP, define pin functions, create threads, ...

|   | un <u>W</u> indow <u>H</u> elp                                                                                                 |                                                                                                 |                      |                            |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | X                                                        |
|---|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----------------------|----------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
|   | • O • 💁 • 🔗 • 🖢 • 🖗                                                                                                            |                                                                                                 |                      |                            |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Quick Access 📴 🛛 🔤 C/C++ 🌼 Synergy Configuration 🎄 Debug |
| ~ | [Blinky] Synergy Configuration S                                                                                               | 🖇 🔂 startup_S7G2.c                                                                              | main.c               |                            | - 8                                     | 👩 Package 🔀                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ⊝ ⊕ ▼   🏢 ▼ 🖾 ▼ 🗖 🗖                                      |
|   | Pins                                                                                                                           |                                                                                                 |                      | 🔘<br>Generate Proje        | ct Content                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                          |
|   | Select pin configuration                                                                                                       |                                                                                                 |                      |                            | <b>b</b> , J                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                    |
|   | S7G2-SK.pincfg ~                                                                                                               | Generate data: g_bsp_                                                                           | pin_cfg              |                            | •••• <u>•</u>                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                          |
|   | Pin Selection                                                                                                                  | Pin Configuration                                                                               |                      |                            |                                         | P400 22 1<br>P401 22 2<br>P402 22 3<br>P403 22 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                          |
|   | type filter text 🥖 🕒 🖻                                                                                                         |                                                                                                 |                      |                            | ſ                                       | P404 225<br>P405 226<br>P406 227                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                          |
|   |                                                                                                                                | Module name:<br>Symbolic Name:<br>Comment:<br>Port Capabilities:<br>P200 Configuration<br>Mode: | P200                 |                            |                                         | 7700         22           7701         22           7702         22           7703         22           7704         22           7705         22           7706         22           7706         22           7706         22           7706         22           7806         22           7806         22           7804         22           7804         22           7804         22           7804         22           7804         22           7804         22           7804         22           7804         22           7804         22           7804         23           7804         23           7804         24           7804         24           7804         24           7804         24           7804         24           7804         24           7804         24           7804         24           7804         24           7805         24           7804                                          | R7FS7G27xxxxxxFC<br>176LQFP                              |
|   | <ul> <li>P206</li> <li>P207</li> <li>P212</li> <li>P213</li> <li>P4</li> <li>P5</li> <li>P6</li> <li>P7</li> <li>P8</li> </ul> | Pull up:<br>IRQ:<br>Chip input/output<br>P200:                                                  | None<br>None<br>None | ~<br>~                     | >                                       | F23         E23           VCC         E3           VCC         E3           VCC         E3           VCC         E3           VCC         E3           VCC         E3           VSCUSHS         E3           VSSUSHS         E3           VS | (Top View)                                               |
|   | Summary BSP Clocks Pins Thread                                                                                                 | as   Messaging   ICU   Compor                                                                   |                      | 🛛 🔀 Pin Conflicts 📃 Consol |                                         | <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | >                                                        |
|   |                                                                                                                                |                                                                                                 |                      | Synergy                    | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                          |
|   |                                                                                                                                |                                                                                                 |                      |                            |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                          |



SSP Configuration Tool (Synergy Configuration)

The user selects the desired configuration of a module of the SSP (in this example the **clock**) using a graphical tool.

Generate Project Content will produce the corresponding C code.

#### 鬱 \*Synergy Configuration [MySynergyProject] 🛛 0 Clocks Generate Project Content Restore Defaults XTAL 24MHz → ICLK 240MHz > ICLK Div /1 > PLL Src: XTAL PCLKA Div /2 PCLKA 120MHz PLL Div /2 PCLKB Div /4 → PCLKB 60MHz PLL Mul x20.0 PCLKC Div /4 → PCLKC 60MHz

▼ PCLKD Div /2

SDCLKout On

BCLK Div /2

UCLK Div /5

> FCLK Div /4

Clocks Pins Threads ICU

BCK/2

✓ → PCLKD 120MHz

✓ → SDCLKout 120MHz

→ BCLK 120MHz

 → BCLKout 60MHz

 → UCLK 48MHz

✓ → FCLK 60MHz

Components

Synergy Project Editor – Clock Configurator

> Clock Src: PLL

Configure the clock tree on the Clock Configurator Tab

ccelerate Innovate Differentiat

source: Renesas Synergy ISDE Tour



PLL 240MHz

BSP

HOCO 16MHz

LOCO 32768Hz

MOCO 8MHz

SUBCLK 32768Hz

Summary

# Another example of the usage of the Synergy Configuration Tool

The graphical tool is used to define the function of each pin.

Configuration errors (e.g. pin conflicts) are identified and can be corrected.

Again, Generate Project Content will generate the corresponding C code.

| gy Configuration [MySynergyP | Project] 23              |                   |                |      |          | •                  |     | 🗗 Pa | ckage  | 23   |        |           |      |           |         |         |      |      |                                       | 0           | • -        | •       |
|------------------------------|--------------------------|-------------------|----------------|------|----------|--------------------|-----|------|--------|------|--------|-----------|------|-----------|---------|---------|------|------|---------------------------------------|-------------|------------|---------|
|                              |                          |                   |                |      | Gene     | rate Project Contr | ent |      | 1      | 2    | 3      | 4         | 5    | 6 7       | 8       | 9       | 10   | 11   | 12                                    | 13          | 14         | 15      |
|                              |                          |                   |                |      |          | ,,                 |     | A    | NC     | P302 | 9303   | VSS       | /SS  | P905 P91  |         | VLO     | va.1 | P902 | P202                                  | VCC_<br>USB | USB_<br>DP | P407 A  |
| in configuration             |                          |                   |                |      |          |                    |     | в    | P109   | P108 | 9301   | vcc       | ~~ I | P312 P91  | 12 P200 | VLO     | VSS  | P901 | P203                                  | VSS_<br>USB | US8_<br>DM | P408 B  |
| 27H2A01CBD.pincfg 🔹          |                          |                   |                |      |          |                    |     |      | _      | P110 | 24.1.2 | mo        | 309  | P310 P31  |         | P904    | V55  | P315 | P205                                  |             |            | P410 C  |
| ction                        | Pin Configuration        |                   |                |      |          |                    |     |      |        | -    |        |           | _    |           |         |         |      |      |                                       |             |            |         |
|                              |                          |                   |                |      |          |                    | _   | D    | vœ     | VSS  | 2113   | P305 1    | 306  | P307 P30  | 08 P910 | P903    | VCC  | P204 | P413                                  | P412        | P411       | P708 D  |
| ertext 🖉 🕀 🖻                 |                          |                   |                |      | Use tag: | type new tag       | •   | Ε    | P610   | P611 | 9115   | P114      | 914  | P915 P90  | 18 P909 | P900    | F313 | P414 | P711                                  | P709        | P415       | VSS E   |
| Peripherals AGT              | Module name:             | Ethernet_Cont     | troller_1_RMII |      |          |                    | -   | F    | P614   | P612 | 613    | P608      | 300  | 906 P90   | 7 RES   | P314    | P710 | P712 | VSS1_                                 | vcc_        | USBHS      | USBHS F |
| BUS                          | Ethernet_Controller_1_RM | MII Configuration |                |      |          |                    |     | -    | _      | _    |        |           |      | ~         | ~       | ~       | P    | imi  | · · · · · · · · · · · · · · · · · · · | ()(         | AVSS_      |         |
| CAC_AD                       | Operation Mode:          | Enabled           |                | •    |          |                    |     | - F  | _      | -    | _      |           |      | PA11 PA   |         |         |      | PBU/ | USBHS                                 | RREF        | USBHS      | USBHS   |
| CAN<br>CLKOUT_COMP_RTC       | Input/Output             |                   |                |      |          |                    |     | HV   | a_F    | VSS  | vœ     | PA09      | A10  | PAD2 PA   | 13 P913 | 2960    | PB04 | PBO6 | VCC                                   | USBHS       | P213       | P212 H  |
| CTSU                         | ET1_EXOUT:               | v P713            |                | -    |          |                    |     | 3    | PA07   | PA06 | PAOS   | PA04      | A03  | PA01 PA   | 00 900  | P406    | P704 | P802 | PBOS                                  | VSS         | xcour      | XCIN J  |
| Debug<br>ETHER MII           | ET1_LINKSTA:             | V PB07            |                | ā —— |          | 4                  |     | ĸ    | P605   | P604 | ***    | PH 07     |      | P606 P80  |         | P515    | P404 | 1 mm | V                                     | V CROX      | Lear       | Valo K  |
| ETHER_RMII                   | ET1_MDC:                 | ~ P403            |                |      |          |                    |     | -    | -003   |      | -003   | -107      | 007  | -0.00 PO  | Pour    |         | -    |      |                                       |             |            |         |
| Ethernet_Controller_         | ET1 MDIO:                | ~ P404            |                |      |          |                    |     |      | maa II | DCO1 | xoo li | Dane II a | 644  | 2013 J.WC | ~ YSS   | P007    | P003 | VSS  | VCC                                   |             | P706       |         |
| GPTO                         | ET1 WOL:                 | ~ P806            | ,              |      |          |                    | R   | e-   | m      | ar   | ).     | Re        | -    |           | 015     | P014    | P010 | P004 | P806                                  | P405        | P700       | P701 M  |
| GPT1<br>KEY                  | REFSOCK1:                | P701              |                |      |          |                    |     |      |        |      |        |           |      |           |         | AVS50   | P011 | P008 | P002                                  | P400        | P402       | P403 1  |
| LCD_GRAPHICS +               | RMITL CRS DV-            | × P705            |                |      |          |                    | co  | nt   | IQ     | ur   | е      | pII       | าร   |           |         | C VRER  | -    | ~    | ~                                     |             | ~          | -       |
|                              | A NULL CRU DA            | J ID/IN           |                |      |          |                    |     |      | _      |      | _      |           |      | -         | •       | 0       | P006 | P001 | P807                                  | P513        | P514       | P401 P  |
|                              |                          | 1                 |                |      |          |                    | _   | R    | P100   | P801 | 802    | P500      | 504  | az vs     | S VREP  | H VREPH | P009 | P005 | P000                                  | P805        | P512       | P511 R  |

| 💱 "Synergy Configuration [MySynergyProject] 🙁 |                    |           | - 0                       | 🔂 Package 🔀 Pin Conflicts      | 2                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------|--------------------|-----------|---------------------------|--------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pins                                          |                    |           | 0                         | 2 errors, 0 warnings, 0 others |                   | la nacionali de la compañía de |
|                                               |                    |           | Generate Project Content  | Description                    | Module            | Pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Select pin configuration                      |                    |           |                           | Oangling connection            | IIC1_Pin_Option_A | SCL1_A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                               |                    |           |                           | O Dangling connection          | IIC1_Pin_Option_A | SDA1_A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| R7FS7G27H2A01CBD.pincfg 🔻                     |                    |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Pin Selection Pin Configurat                  | on                 |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| type filter text 🖉 🕒 🖽 🖻                      |                    |           | 🖞 Use tag: type new tag 👻 |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CLKOUT_COMP_RTC     Module name     CTSU      | IIC1_Pin_Option_A  |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                               | on_A Configuration |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ETHER_MII     Operation Mo                    | de: Enabled        | -         |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ▶ ETHER_RMII                                  |                    |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| GPT0 Input/Output                             |                    |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ▷ GPT1 SCL1_A: KEY =                          | P205               | •         | $\Rightarrow$             |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| LCD_GRAPHICS SDA1_A:                          | P206               | •         | 4                         |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PDC                                           | <u> </u>           |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ⊳ QSPI                                        |                    |           | Identify a                | and resolve                    | nin cou           | aflicte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| A RIIC                                        |                    |           | identity a                | and resolve                    | - pin coi         | mick                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| IIC0_Pin_Option_A                             |                    |           | In the                    | e Pin Conf                     | liata Via         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| IICO_Pin_Option_B                             |                    |           |                           |                                | licis vie         | vv                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| IIC1_Pin_Option_A<br>IIC1_Pin_Option_B        |                    |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                               |                    |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                               |                    |           |                           |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Summary BSP Cloc                              | ka 🙆 Dina Th       | roade ICU | Components                |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Summary BSP Cloc                              | ks 🐷 Pins In       | reaus ICU | Components                |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| -                                             |                    |           | •                         |                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

source: Renesas Synergy ISDE Tour



Use the Synergy Configuration tool to chose HAL modules, to create threads and configure them.

### HAL =

Hardware Abstraction Layer see Embedded Systems Architecture starting on slide <u>arch</u>



source: Renesas Synergy ISDE Tour



To start a debug session use the debug icon.

A debug configuration window is used to setup the debug configuration

| Debug Configurations Create, manage, and run configurations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ×                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Image: Second Secon | Name: Blinky Debug<br>Main 35 Debugger Startup Common 55 Source<br>Debug hardware: J-Link ARM Target Device: R7F57G27H<br>GDB Settings Connection Settings Debug Tool Settings<br>GDB Connection Settings<br>@ Autostart local GDB server<br>Connect to remote GDB server<br>GDB port number: 61234<br>ADM port number: 61236<br>GDB Command:<br>S(eclipse_home)/DebugComp/arm-none-eabi-gdb<br>Browse Variables<br>< |
| Filter matched 14 of 16 items                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Re <u>v</u> ert Apply                                                                                                                                                                                                                                                                                                                                                                                                 |
| ?                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Debug Close                                                                                                                                                                                                                                                                                                                                                                                                           |



debug perspective

When entering a debug

session,

the current perspective

changes to Debug.

Several debug buttons become available.



source (also for some other figures in this section):

e<sup>2</sup> studio Integrated Development Environment User's Manual: Getting Started Guide r20ut2771ej0400\_e2\_start\_s.pdf

https://www.renesas.com/us/en/doc/products/tool/doc/006/r20ut2771ej0400\_e2\_start\_s.pdf

### LAB1 – SYNERGY PLATFORM

#### Activity 5 – Overview of the SSP

- 1. Synergy Software Package
- 2. How to use the SSP



The Synergy Software Package (SSP) internal structure is presented inside the red box; the grey

The Hardware Abstraction Layer provides an abstraction of the internal peripherals of the MCU: timer, communication interfaces, gpio, ADC, DAC, ...

BSP - Board Support Package is the part of SSP that provides an abstraction to the functionality implemented on a board, outside the MCU. Such as: leds, push-buttons, ...

screen, audio, block media, ...

training.

The ThreadX RTOS, and the aggregated FileX, USBX, GUIX, NetX are part of the SSP providing multitasking, communication, file system and user interface.



**BIG IDEAS FOR EVERY SPACE** 

RENESAS

The Synergy Software Package (SSP) internal structure is further detailed here:

### Synergy Software Package (SSP)

#### Application Programming Interface (API)

| ThreadX <sup>®</sup><br>RTOS                                                           | Applic<br>Frame                       |                                                        |                                                                               | Mi                                                                                       | ddleware                                           |                                             |                                                   | Functional<br>Libraries                      |
|----------------------------------------------------------------------------------------|---------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------|---------------------------------------------|---------------------------------------------------|----------------------------------------------|
| Fully Preemptive<br>Scheduler                                                          | Audio                                 | Audio Wi-Fi FileX <sup>TM</sup> USBX <sup>TM</sup>     |                                                                               | GUIX™                                                                                    | NetX <sup>™</sup> and I                            | NetX Duo™                                   | Encryption and<br>Hashing Library                 |                                              |
|                                                                                        | Console                               | BLE                                                    | FAT 12/16/32                                                                  | Host Classes                                                                             | Run Time Library                                   | FTP                                         | SNTP                                              | AES, RSA, ECC,<br>SHA1/256, ARC4,            |
| Inter-process and<br>Inter-thread                                                      |                                       | Cellular                                               | Formats                                                                       | (Storage, CDC,<br>HID, Hub)                                                              | Image Processing                                   | TFTP                                        | NAT                                               | 3TDES, MD5, TRNO                             |
| Communication                                                                          | JPEG                                  | (NB-IOT,<br>CAT1/3/M1)                                 | SDSC, SDHC,                                                                   | Host Stack                                                                               | Widget Library                                     | Telnet                                      | ТСР                                               | CMSIS DSP Librar                             |
| Memory                                                                                 | Touch Panel                           | ADC                                                    | eMMC Support                                                                  | Host Controller                                                                          | Event Processing                                   | PPP                                         | IPv4/v6                                           | Software Safety                              |
| Management                                                                             |                                       | Thread                                                 | Simultaneous                                                                  | Device Classes                                                                           | Canvas Processing                                  | SMTP                                        | UDP                                               | Library                                      |
|                                                                                        | Capacitive<br>Touch                   | Monitor                                                | Media Support                                                                 | (Storage, CDC,<br>HID, UVC)                                                              | Rotation, Scaling                                  | POP3                                        | ICMP                                              | Signature Generation<br>and Verification     |
| Interrupt<br>Management                                                                | Cryptographic                         | Power<br>Profile                                       | Fault tolerant,                                                               | Device Stack                                                                             | Blend, Anti-alias                                  | TLS                                         | MQTT -                                            |                                              |
|                                                                                        |                                       | External                                               | Journal-Based                                                                 | Device Controller                                                                        | SDSC, SDHC,                                        | DNS                                         | ARP                                               | Wrapped Key<br>Generation                    |
| Execution Profiling                                                                    | X-Ware<br>Interface                   | Interrupt                                              | LevelX Flash<br>Wear Leveling                                                 | Isochronous                                                                              | eMMC Support                                       | DHCP                                        | RARP                                              | Key Installation                             |
| Execution Froming                                                                      |                                       | Mass Storage<br>(SDMMC, USB,                           |                                                                               | Transfer                                                                                 |                                                    | HTTP/1.1                                    | SNMP                                              | Public Key Encrypti                          |
|                                                                                        | UART                                  | QSPI, RAM)                                             |                                                                               |                                                                                          |                                                    | HTTPS                                       | BSD Socket                                        | Public Key Encrypt<br>Private Key Decryp     |
| Picokemel™                                                                             |                                       | Q311, 104WI)                                           |                                                                               |                                                                                          |                                                    |                                             | Library                                           | rivate key Decrypt                           |
| Picokemel™<br>Architecture<br>Event-Chaining™<br>Technology                            | UART                                  | SPI                                                    | Hard<br>ADC 12/14/                                                            | dware Abstractic                                                                         | Data Flash                                         |                                             | Library                                           | CRC                                          |
| Architecture<br>Event-Chaining™<br>Technology                                          |                                       |                                                        | ADC 12/14/                                                                    | Code Flash                                                                               |                                                    | ) Drivers                                   |                                                   |                                              |
| Architecture<br>Event-Chaining <sup>™</sup><br>Technology<br>Preemption-<br>Threshold™ | UART                                  | SPI                                                    | ADC 12/14/                                                                    | Code Flash                                                                               | Data Flash<br>GPIO                                 | ) Drivers<br>QSPI                           | SDHI<br>JPEG Codec                                | CRC<br>PDC                                   |
| Architecture<br>Event-Chaining™<br>Technology<br>Preemption-                           | UART                                  | SPI<br>I2C<br>SSI<br>C Factory M                       | ADC 12/14/<br>Sigma Delta<br>DAC 8                                            | ADC Code Flash                                                                           | Data Flash<br>GPIO                                 | ) Drivers<br>QSPI<br>RTC                    | SDHI<br>JPEG Codec                                | CRC<br>PDC                                   |
| Architecture<br>Event-Chaining <sup>™</sup><br>Technology<br>Preemption-<br>Threshold™ | UART<br>USBHS<br>USBFS<br>Ethernet MA | SPI<br>I2C<br>SSI<br>C Factory M<br>Informa<br>Functio | ADC 12/14,<br>Sigma Delta<br>DAC 8<br>MCU<br>tion<br>DAC 12<br>nal Data Tranf | ADC Code Flash<br>ADC CAN<br>Timer<br>Independent<br>Watchdog Tmr<br>er Capacitive Touch | Data Flash<br>GPIO<br>Watchdog Timer<br>2D Drawing | Drivers QSPI RTC DMA Controller Low Voltage | SDHI<br>JPEG Codec<br>AGT 16-BitTime<br>Low Power | CRC<br>PDC<br>r GPT 32-BitTim<br>Segment LCI |

source: Renesas SSP v 1.7.5 documentation

The Synergy Software Package (SSP) is downloadable from the Renesas website (see Lab 1, Activity 1, Step 5).

It is installed in *C:\Renesas\Synergy\e2studio\_v7.5.1\_ssp\_v1.7.5.* The ISDE e2studio will access the SSP directly from there.

The HTML documentation for SSP is installed in

C:\Renesas\Synergy\e2studio\_v7.5.1\_ssp\_v1.7.5\SSP\_Documentation.

By opening in a browser the file

ssp-user-manual-html-v1.00-sspv1.7.5.html

the doxygen generated documentation is presented.

SSP documentation is also available in pdf from the Renesas website



#### source: Renesas Synergy ISDE Tour



## Using the Synergy Software Package (SSP)

The SSP is made available as a large set of source files that implement its functionality.

The SSP is also highly configurable to the application needs.

The task of configuring the SSP is significantly simplified by the use of the **Synergy Configuration Tool** available in e2studio.

This tool provides a graphical interface for the programmer to select the proper configuration. Once selected, the button Generate Project Contents will generate the appropriate C files that match the selected configuration.



**BIG IDEAS FOR EVERY SP** 

RENESAS

### **Objectives:**

- In Lab 2, the student will develop a simple game. The game's objective is simply to respond as fast as possible to a visual stimulus. A led goes on after a random time and the player has to press a button. The current response time is presented.
- The main objective of this Lab is to guide the student through a proposed development process that should be used in the following labs.

### LAB2 – SAMPLE C PROGRAM

#### Learning Objectives:

- Project planning
- Problem definition, specification, hardware platform study, software framework study, design
- Project generation
- SSP Configuration
- Threads configuration
- Source code editing
- Compile/Link
- Debug



RENESAS

BIG IDEAS FOR EVERY SPACE

### LAB2 – SAMPLE C PROGRAM

#### Activities:

- 1. Plan the phases of the development process
- 2. Problem definition
- 3. Specification
- 4. Hardware platform study
- 5. Software framework study
- 6. Design
- 7. Use the Wizard to generate a Synergy C Project
- 8. Configure the SSP
- 9. Use the Editor
- 10. Compile and link the project
- 11. Debug on the SK-S7G2 board

further reading for this Lab:

e<sup>2</sup> studio Integrated Development Environment User's Manual: Getting Started Guide r20ut2771ej0400\_e2\_start\_s.pdf https://www.renesas.com/us/en/doc/products/tool/doc/006/r20ut2771ej0400\_e2\_start\_s.pdf (it is also the source of some figures of this section)





#### Activity 1 – Plan the phases of the development process

In Lab2, the student is faced with a simple problem to be implemented in C, using many of the functionalities made available in e2studio. The objectives in this lab are not limited to understanding the functionality of the tool, but also to follow a planned approach to a software development activity.

- 1. Problem definition: the problem statement should clearly define the scope of the problem.
- 2. Specification: a clear and precise set of statements that define the functionality of the resulting software as well as its non-functional characteristics (performance, ...)
- 3. Study of the hardware platform: one must have a clear understanding of the features of the MCU and of the board that will be used in this development
- 4. Software framework study: some of the functionality needed for the solution is available in the form of software components in the SSP, these must be identified and understood
- 5. Design: identification of the SW components that need to be developed, their interfaces, algorithms and interfaces to other software components.
- 6. Tool usage: project generation, SSP configuration, source code editing, compilation, linkage, debug



#### Activity 2 – Problem Definition

Game objective: to respond as fast as possible to a visual stimulus

Game operation: once the game is turned on, after 1 second an LED is turned on, the player must respond by pressing a button.

Game cycle repeats indefinitely.

Game presents the player response time.

Basic solution: response times are saved in variables and can be visualized in the debugger





#### Activity 3 – Specification

- S1 The ResponseTimeGame console shall provide an LED, a push-button and an LCD.
- S2 The operation of the ResponseTimeGame, after power up, is:
  - 1. wait for 1 second
  - 2. turn on LED
  - 3. start measuring time
  - 4. wait for player to press the push-button
  - 5. stop measuring time, save measure as current response time
  - 6. turn off LED
  - 7. a variable should hold the current response time
  - 8. go to step 1
- S3 discard response time measurements above 3 seconds

#### Activity 4 – Study the Hardware platform (SK-S7G2 board and S7G2 MCU)

The first manual to be studied is the Starter Kit SK-S7G2 <u>User's Manual.pdf</u> Relevant information in this manual concerning the current project is:

- Block diagram
- LEDs
- push-button
- LCD



Relevant blocks of the SK-S7G2 board are marked in red



Figure 2: SK-S7G2 block diagram

source: Starter Kit SK-S7G2 User's Manual



There are two push-buttons on the SK-S7G2: S4 and S5.

They are directly connected to GPIO pins: P0.6 and P0.5 respectively. There is no debounce circuit between the push-buttons and the MCU pins.

P0.6 (P006) can generate interrupts at IRQ11.P0.5 (P005) can generate interrupts at IRQ10



source: Starter Kit SK-S7G2 User's Manual



There are three LEDs on the SK-S7G2 that are controllable by GPIO pins: LED1 (green), LED2 (red), and LED3 (yellow).

They are connected to GPIO pins P6.0, P6.1 and P6.2 respectively.

The LEDs turn on when a logic level 0 is written to the pin and they turn off writing a logic level 1.



#### Activity 4 – Study the Hardware platform (SK-S7G2 board and S7G2 MCU)

The next manual to be studied is the Renesas S7 Series Microcontrollers <u>User's Manual.pdf</u> Relevant information in this manual concerning the current project is:

- Overview
- CPU
- Clock Generation
- Event Link Controller
- I/O Ports
- Timers



S7G2 microcontroller's block diagram with indication of blocks of interest.

Since the user's manual of the S7G2 has more than 2000 pages, it is important to keep focus on what is relevant to this project.



The S7G2 microcontroller's clock generation circuit is very flexible and can provide several different clock frequencies to different parts of the MCU. Following limits must be observed:

Flash clock (FCLOCK) - 60 MHz

Core clock (ICLOCK) - 240 MHz PCLKA - 120 MHz

PCLKB - 60 MHz

PCLKC - 60 MHz

PCLKD - 120 MHz



#### source: Renesas S7 Series Microcontrollers User's Manual

BIG IDEAS FOR EVERY SPACE **RENESAS** 



| Item                                 | Clock Source                     | Clock Supply                                                                                                                                                     | Specification                                                                          |
|--------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| System clock (ICLK)                  | MOSC/SOSC/HOCO/MOCO/<br>LOCO/PLL | CPU, DTC, DMAC, ROM, RAM                                                                                                                                         | Up to 240 MHz<br>Division ratio:<br>1/2/4/8/16/32/64                                   |
| Peripheral module clock A<br>(PCLKA) | MOSC/SOSC/HOCO/MOCO/<br>LOCO/PLL | Peripheral module (ETHERC,<br>EDMAC, USB2.0 HS, QSPI, SPI,<br>SCIF, TSIP, Graphics LCD,<br>SDHI, CRC, JPEG Engine,<br>DRW, IrDA, GPT Bus-clock,<br>Standby SRAM) | Up to 120 MHz<br>Division ratio:<br>1/2/4/8/16/32/64                                   |
| Peripheral module clock B<br>(PCLKB) | MOSC/SOSC/HOCO/MOCO/<br>LOCO/PLL | Peripheral module (WDT, IWDT,<br>RTC, IIC, SSI, SRC, DOC, CAC,<br>CAN, ADC12, DAC12, POEG,<br>AMI, TSN, SCI)                                                     | Up to 60 MHz<br>Division ratio:<br>1/2/4/8/16/32/64                                    |
| Peripheral module clock C<br>(PCLKC) | MOSC/SOSC/HOCO/MOCO/<br>LOCO/PLL | Peripheral module (ADC unit 0,<br>unit 1 (only HM))                                                                                                              | Up to 60 MHz<br>Division ratio:<br>1/2/4/8/16/32/64                                    |
| Peripheral module clock D<br>(PCLKD) | MOSC/SOSC/HOCO/MOCO/<br>LOCO/PLL | Peripheral module<br>(GPT Count-clock)                                                                                                                           | Up to 120 MHz<br>Division ratio:<br>1/2/4/8/16/32/64                                   |
| FlashIF clock (FCLK)                 | MOSC/SOSC/HOCO/MOCO/<br>LOCO/PLL | FlashIF                                                                                                                                                          | 4 MHz to 60 MHz (P/E)<br>Up to 60 MHz (Read) *1<br>Division ratio:<br>1/2/4/8/16/32/64 |

#### Table 9.2 Clock generation circuit specifications (internal clock) (1/3)

source: Renesas S7 Series Microcontrollers User's Manual

BIG IDEAS FOR EVERY SPACE RENESAS

The ELC (Event Link Controller) connects events generated by peripheral modules to other peripheral modules. This direct communication among modules does not require intervention from the CPU.

The ELC is not required in this project, however, it is a compulsory module in the configuration of the SSP.



Figure 19.1 ELC block diagram (n = 0 to 18)

source: Renesas S7 Series Microcontrollers User's Manual

**BIG IDEAS FOR EVERY SPACE** 

RENESAS

The block diagram of a GPIO pin.

Among the configurable features of a pin are:

- Input or output,
- Enable a pull-up on input,
- Output drive capability: low, medium, high
- Use pin for analog function (ADC or DAC);
- Use pin for peripheral function (e.g. SPI);
- Some inputs are 5V tolerant;
- Pins can generate interrupt on edges of input signal.





source: Renesas S7 Series Microcontrollers User's Manual



The block diagram of GPT (General PWM Timer).

GPT characteristics:

- 32-bit counter
- Counts up or down
- Can generate interrupts
- Can start an ADC conversion
- Counts PCLKD pulses
- Periodic or single-shot
- 14 channels, each is a 32-bit counter



#### source: Renesas S7 Series Microcontrollers User's Manual

BIG IDEAS FOR EVERY SPACE

RENESAS



The 14 timer channels are grouped into:

- 4x EH enhanced high resolution
- 4x E enhanced
- 6x conventional

| CH13    | CH12    | CH11    | CH10    | CH9    | CH8    | CH7     | CH6     | CH5     | CH4     | CH3      | CH2      | CH1      | CH0      |
|---------|---------|---------|---------|--------|--------|---------|---------|---------|---------|----------|----------|----------|----------|
|         |         |         |         |        |        |         |         |         |         |          |          |          |          |
|         |         |         |         |        |        |         |         |         |         |          |          |          |          |
| GPT3213 | GPT3212 | GPT3211 | GPT3210 | GPT329 | GPT328 | GPT32E7 | GPT32E6 | GPT32E5 | GPT32E4 | GPT32EH3 | GPT32EH2 | GPT32EH1 | GPT32EH0 |
|         | GPT32   |         |         |        |        |         | GPT     | 32E     |         |          | GPT      | 32EH     |          |
|         |         |         |         |        |        |         |         |         |         |          |          |          |          |

source: Renesas S7 Series Microcontrollers User's Manual





Activity 5 – Software Framework Study

Study the Renesas Synergy Software Package v1.7.5 (<u>link</u>) available in the Synergy Gallery; specifically Section 4.2.21 about the HAL GPT (General PWM Timer).

https://synergygallery.renesas.com/media/products/1/384/en-US/r11um0140eu0106-synergy-ssp-v175.pdf

Also, study the Module Guide for the GPT HAL (link).

https://www.renesas.com/us/en/doc/products/renesas-synergy/apn/r11an0091eu0101-synergy-gpt-hal-mod-guide.pdf





#### Activity 6 – Design

(identification of the SW components that need to be developed, their interfaces, algorithms and interfaces to other software components)

Components of the SSP to be used:

- Timer Driver on r\_gpt. This component uses one of the 14 channels of the General PWM Timer. We selected channel 8 for no particular reason.
- External IRQ Driver on r\_icu. This component manages the interrupt generated by one of the GPIO lines. Here we select IRQ 11 because on the SK-S7G2 board, the S5 push-button is connected to the IRQ11 pin.



#### e<sup>2</sup> SE\_course\_v12 - Lab2\_Game/configuration.xml - e<sup>2</sup> studio

<u>File Edit Navigate Search Project Renesas Views Run Window Help</u>



#### 🔲 Properties 🔀 🔝 Problems 🛯 🛶 Smart Browser

| Property                                                  | Value                                      |  |  |  |  |
|-----------------------------------------------------------|--------------------------------------------|--|--|--|--|
| <ul> <li>Property</li> <li>✓ Common</li> </ul>            |                                            |  |  |  |  |
| Parameter Checking                                        | Default (BSP)                              |  |  |  |  |
| <ul> <li>Module g_timer0 Timer Driver on r_gpt</li> </ul> |                                            |  |  |  |  |
| Name                                                      | g_timer0                                   |  |  |  |  |
| Channel                                                   | 8                                          |  |  |  |  |
| Mode                                                      | One Shot                                   |  |  |  |  |
| Duty Cycle Range (only applicable in PWM mode)            | Shortest: 2 PCLK, Vongest: (Period 1) PCLK |  |  |  |  |
| Period Value                                              | 1                                          |  |  |  |  |
| Period Unit                                               | Seconds                                    |  |  |  |  |
| Duty Cycle Value                                          | 50                                         |  |  |  |  |
| Duty Cycle Unit                                           | Unit Raw Counts                            |  |  |  |  |
| Auto Start                                                | True                                       |  |  |  |  |
| GTIOCA Output Enabled                                     | False                                      |  |  |  |  |
| GTIOCA Stop Level                                         | Pin Level Low                              |  |  |  |  |
| GTIOCB Output Enabled                                     | False                                      |  |  |  |  |
| GTIOCB Stop Level                                         | Pin Level Low                              |  |  |  |  |
| Callback                                                  | cb0                                        |  |  |  |  |
| Overflow Interrupt Priority                               | Priority 4                                 |  |  |  |  |
|                                                           |                                            |  |  |  |  |
|                                                           |                                            |  |  |  |  |
|                                                           |                                            |  |  |  |  |
|                                                           |                                            |  |  |  |  |



LAB2 – ACTIVITY 6

Timer Driver

on r\_gpt

e<sup>2</sup> SE\_course\_v12 - Lab2\_Game/configuration.xml - e<sup>2</sup> studio

<u>File Edit Navigate Search Project Renesas Views Run Window H</u>elp



BIG IDEAS FOR EVERY SPACE **RENESAS** 

### LAB2 – ACTIVITY 6

External IRQ Driver

on r\_icu



Algorithm:

- 1. Initialize the components for the Timer Driver and the External IRQ Driver by calling their open API functions. This also starts the timer on its 1 second period as configured in the Synergy Configuration Tool.
- 2. Turn off the LEDs
- 3. Wait for the timer to expire. Its callback function informs via a flag (shared volatile global variable).
- 4. Reprogram the timer for 3 seconds and restart count (API functions reset, periodSet, restart).
- 5. Wait for the push-button to be pressed. Again, its callback function informs via another flag.
- 6. Get the current count of the timer (API functions counterGet) and save this value to a variable (this variable will be examined with the debugger).

This algorithm is to be implemented by modifying the function hal\_entry, adding two callback functions and the required global variables.

# LAB2 – ACTIVITIES 7 TO 11

Based on the previous study:

- After creating a new Synergy C project (lab2) based on the Blinky template, on the Threads tab of Synergy Configuration, add a Timer Driver (on r\_gpt) and configure its properties to: channel 8, single shot, period of 1 second, callback cb0, interrupt priority 4.
- Modify the file hal\_entry.c to:
  - Turn off all three LEDs, a LED is turned off by writing IOPORT\_LEVEL\_HIGH to the GPIO pin.
  - Call the GPT API function open(g\_timer0.p\_ctrl,g\_timer0.p\_cfg) to configure and start the timer. The two
    parameters of this function are created by the Synergy Configuration tool when the button "Generate Project Content" is
    pressed.
  - Create a callback function named cb0. This function must inform the hal\_entry function that the timer expired by setting a flag. This flag must be a volatile global variable. Reminder: volatile informs the compiler that its value changes outside the control of the hal\_entry function.

**BIG IDEAS FOR EVERY SPACE** 

# LAB2 – ACTIVITIES 7 TO 11

Modify the file hal\_entry.c to (cont.):

- In function hal\_entry, wait for the flag to change value, meaning 1 second has passed;
- Turn LEDs on;
- Reset the timer (API function reset);
- Set a new period of 3 seconds (API function periodSet);
- Start the timer again (API function start);
- Make sure the timer is operating by making successive calls to API function counterGet;
- Test if the program is operating correctly up to this point.



# LAB2 – ACTIVITIES 7 TO 11

- In the Synergy Configuration tab, add an input driver of type external IRQ driver on r\_icu. Configure its properties to: channel 11, callback function switch\_callback, interrupt priority 5. Recall that, from the study of the board manual, we learned that push-button S4 is connected to IRQ 11.
- Modify the file hal\_entry.c to:
  - In the hal\_entry function, call the open API function of the g\_external\_irq0 to configure this component;
  - Create a callback function named switch\_callback. This function also informs the hal\_entry function that the timer expired by setting another volatile flag;
  - In the hal\_entry function, wait for this flag to change then get the number of ticks from the counter up to this point.
     Save it to a variable;
  - Put a breakpoint right after the variable is updated and play the game.



# LAB3 – ASSEMBLY PROGRAMMING AND ATPCS

**Objectives:** 

- Develop an assembly routine that is callable from a C program. The assembly routine must follow the ATPCS standard.
- The function to be implemented in assembly generates the histogram of an 8-bit grayscale image.

# LAB3 – ASSEMBLY PROGRAMMING AND ATPCS

#### Learning Objectives:

- Apply the embedded software development process presented in Lab 2
- Define the interface between the C program (caller) and the Assembly function (callee)
- Plan the data structures to be used
- Devise an algorithm to generate a histogram
- Implement, Test, Debug

# LAB3 – ASSEMBLY PROGRAMMING AND ATPCS

#### Activities:

- 1. Understanding the Problem Domain
- 2. Problem definition
- 3. Designing the Data Structures
- 4. Parameter passing and return of the result
- 5. Algorithm
- 6. Implementation
- 7. Test cases





#### Activity 1 – Understanding the Problem Domain

- A raster image or bitmap is composed of dots, or pixels, lay out as a matrix. On a grayscale image, each pixel is represented by a number indicating the level of lighting of that pixel.
- On an 8-bit grayscale image, each pixel is represented by an 8-bit value. Hence, there are 256 levels of gray, ranging from 0 (black) to 255 (white).
- Shown below is a 3 x 3 8-bit grayscale image (9 pixels in total) and the corresponding 9-pixel image.

0 16 32 64 96 128 160 224 255







#### Activity 1 – Understanding the Problem Domain

A histogram is a graphical representation of the tonal distribution of an image. On the horizontal axis there are the possible values that a pixel can have (0-255 in this example) and the vertical axis presents the quantities of pixels with a given luminosity level.

An image with N pixels were half of them are white and half of them are black would have a histogram like this:

Histograms are very useful in digital image processing, to determine thresholds, to adjust brightness and contrast, to identify problems, and many more.

To construct a histogram, all pixels of an image have to be processed, hence, it is desirable to have efficient algorithms and implementations for better performance.







#### Activity 2 – Problem Definition 1/2

Develop a function, to be implemented in assembly, that constructs the histogram of an

8-bit grayscale bitmap image.

Input parameters:

- Image width number of pixels across the image.
- Image height height of image in pixels
- Starting address address of the first pixel in memory. Each pixel occupies one byte. The image is represented by a
  matrix were image[0][0] is the upper left pixel of the image. The matrix is stored by rows, hence, the next address holds
  image[0][1] (next pixel on the upper row).
- Histogram address of a 256-position vector holding 16-bit unsigned integers that hold the pixel counts. The histogram
  has invalid data when the function is called.

Output: 16-bit unsigned integer indicating the total number of pixels processed.





#### Activity 2 – Problem Definition 2/2

Restrictions:

The total number of pixels in the image (i.e. width x height) must be less than 64K (65,536)

Error codes:

Function returns 0 to indicate an error (e.g. image too large)

Function prototype

uint16\_t EightBitHistogram(uint16\_t width, uint16\_t height, uint8\_t \* p\_image, uint16\_t \*
p\_histogram);



#### Activity 3 – Designing the Data Structures

The two important data structures for this problem are the matrix that holds the bitmap and the vector that stores the histogram.

The bitmap matrix has its number of columns equal to the width of the image and its number of rows equal to the height of the image. Each element stored in the matrix is an 8-bit unsigned integer (uint8\_t) that represents the gray level of the corresponding pixel, 0 being black and 255 being white.

The histogram vector has size 256, hence, its indexes run from 0 to 255. The i<sub>th</sub> element of the vector stores the count of pixels at value i.

histogram[i] = number of pixels whose value is i. Hence, adding up all elements of the vector must result in a number equal to width x height.







#### Activity 4 – Parameter passing and return of the result

Considering that the function prototype is:

uint16\_t EightBitHistogram(uint16\_t width, uint16\_t height, uint16\_t \* p\_image, uint8\_t \*
p histogram);

By ATPCS the parameters are in registers R0 to R3:

width - in R0 (upper half of R0 is 0)

height - in R1 (upper half of R1 is 0)

p\_image - in R2

p\_histogram - in R3

The result is passed by R0 (upper half is 0)



#### Activity 5 – Algorithm

One possible solution design is presented here using the UML 2.5 Activity diagram notation.

If the implementation requires registers other than R0..R3 and R12 then there is the need to push these registers at the start and restore them at the end.

Note that the histogram is constructed in a very efficient way by simply using the value of each pixel as an index to the position in the histogram that must be incremented.



#### Activity 6 – Implementation

A possible organization of the source files is:

hal\_entry.c this is the C program that calls the assembly function
 hal\_entry is executed after initialization;
 it calls EightBitHistogram
 then presents the results on the virtual console.

 histogram.asm this is the assembly source file where

EightBitHistogram is defined.

images.c holds the matrices with the test images.



**BIG IDEAS FOR EVERY SPACE** 

RENESAS

#### Tips on how to use the Renesas Virtual Console are in slide: <u>LAB 5 - Activity 3</u>

#### Activity 6 – Implementation

The assembly source file requires and images.c the startup S7G2.c the hall entry.c Shistogram.asm & the main.c the system S7G2.c assembler directives at the s as shown here.

| quires | 🖻 images.c | 🖻 startup_S7G2.c 🔓 hal_entry.c 🔝 histogram.asm 🔀 🖻 main.c 🔂 system_S7G2.c                      |
|--------|------------|------------------------------------------------------------------------------------------------|
| otort  | 1          | /*                                                                                             |
| start, | 2          | * histogram.s                                                                                  |
|        | 3          | *                                                                                              |
|        | 4          | * Created on: Nov 5, 2017                                                                      |
|        | 5          | * Author: Douglas                                                                              |
|        | 6          | */                                                                                             |
|        | 7          | #define VALUE_64K 0x10000                                                                      |
|        | 8          | #define HIST_SIZE 256                                                                          |
|        | 9          | .syntax unified                                                                                |
|        | 10         | .text                                                                                          |
|        | 11         | .align 2                                                                                       |
|        | 12         | .global EightBitHistogram                                                                      |
|        | 13         | .thumb_func                                                                                    |
|        | 14         |                                                                                                |
|        | 15         | EightBitHistogram:                                                                             |
|        | 16         | <pre>push {lr} //return address is saved so lr can be used for scratch</pre>                   |
|        | 17         | mul r0,r0,r1                                                                                   |
|        | 18         | cmp r0,#VALUE_64K                                                                              |
|        | 19         | itt hs                                                                                         |
|        | 20         | movhs r0,#0                                                                                    |
|        | 21         | bhs ret                                                                                        |
|        | 22         | <pre>add rl,r3,#(HIST_SIZE &lt;&lt; 2) //rl = address of last element of histogram[] + 2</pre> |
|        | 23         | mov r12,#0                                                                                     |
|        | 24         | //                                                                                             |

BIG IDEAS FOR EVERY SPACE RENESAS



#### Activity 7 – Test Cases

Two test cases are provided. The first is matrix image0 that has only 3 lines and 4 columns. Such a small test case is important to debug the implementation on a step-by-step execution.

Shown here is the contents of image0 and the corresponding histogram.

| <pre>#define WIDTH0 4 #define HEIGTH0 3</pre>        |
|------------------------------------------------------|
| <pre>const uint8_t image0[HEIGTH0][WIDTH0] = {</pre> |
| $\{20, 16, 16, 18\},\$                               |
| {255, 255, 0, 0},                                    |
| { 32, 32, 32, 32}                                    |
| };                                                   |

| image0 Histogram |                                         |  |  |  |  |  |
|------------------|-----------------------------------------|--|--|--|--|--|
| 5 -              |                                         |  |  |  |  |  |
| 4 -              |                                         |  |  |  |  |  |
| 3 -              |                                         |  |  |  |  |  |
| 2 -              |                                         |  |  |  |  |  |
| 1 -              |                                         |  |  |  |  |  |
| 0 -              | 0 0 112 112 112 112 112 112 112 112 112 |  |  |  |  |  |





#### Activity 7 – Test Cases

The second test case is the test image presented here. Its pixels are encoded in the matrix image1. Its size is 160 x 120 pixels.

The corresponding histogram is presented below:







### LAB4 – TIMER DEVICE DRIVER

**Objectives:** 

Use a GPT (General PWM Timer) to generate a 100 Hz rectangular waveform with a 25% duty cycle. The SSP components for the GPT are NOT to be used. Here, the student is to exercise the direct interaction with the GPT hardware.



### LAB4 – TIMER DEVICE DRIVER

#### Learning Objectives:

- Study a hardware peripheral with the objective to develop its device driver
- Identify the relevant registers of a peripheral for a given application
- Design an algorithm of a device driver
- Evaluate alternatives of means to interact with the registers of hardware peripheral



### LAB4 – TIMER DEVICE DRIVER

#### **Activities:**

- 1. Study the GPT (General PWM Timer of the S7G2 MCU)
- 2. Determine the sequence that the GPT registers must be programmed and the respective values
- 3. Design an algorithm to achieve the purpose
- 4. Implement and test

further reading for this Lab:

Renesas Synergy Software Package v1.7.5 User's Manual r11um0140eu0106-synergy-ssp-v175

GPT HAL Module Guide r11an0091eu0101-synergy-gpt-hal-mod-guide.pdf



### **Activities:**

- S7G2 microcontroller's block diagram with indication of blocks of interest.
- Since the user's manual of the S7G2 has more than 2000 pages, it is important to keep focus on what is relevant to this project.



The block diagram of GPT (General PWM Timer).

- GPT characteristics:
- 32-bit counter
- counts up or down
- can generate interrupts
- can start an ADC conversion
- counts PCLKD pulses
- periodic or single-shot
- 14 channels, each is a 32-bit counter



source: Renesas S7 Series Microcontrollers User's Manual

BIG IDEAS FOR EVERY SPACE **RENESAS** 



The 14 timer channels are grouped into:

- 4x EH enhanced high resolution
- 4x E enhanced
- 6x conventional

| CH13    | CH12     | CH11    | CH10    | CH9    | CH8    | CH7     | CH6     | CH5     | CH4     | CH3       | CH2      | CH1      | CH0        |
|---------|----------|---------|---------|--------|--------|---------|---------|---------|---------|-----------|----------|----------|------------|
|         |          |         |         |        |        |         |         |         |         |           |          |          |            |
| GPT3213 | GPT3212  | GPT3211 | GPT3210 | GPT329 | GPT328 | GPT32E7 | GPT32E6 | GPT32E5 | GPT32F4 | GPT32EH3  | GPT32EH2 | GPT32EH1 | GPT32EH0   |
| 0113213 | 01 13212 |         | T32     | 011323 | 011020 | GINZER  |         | 32E     | 0113224 | OF 132END |          | 32EH     | OF TOZETIO |
|         |          |         |         |        |        |         |         |         |         | <         |          |          |            |



| OTHE    | Our and DMM Trans Mills Data for Data for                                               | OTEE      | Ore and DMM Times Orely Or the Designed                                            |
|---------|-----------------------------------------------------------------------------------------|-----------|------------------------------------------------------------------------------------|
| GTWP    | : General PWM Timer Write-Protection Register                                           | GTPR      | : General PWM Timer Cycle Setting Register                                         |
| GTSTR   | : General PWM Timer Software Start Register                                             | GTPBR     | : General PWM Timer Cycle Setting Buffer Register                                  |
| GTSTP   | : General PWM Timer Software Stop Register                                              | GTPDBR    | : General PWM Timer Cycle Setting Double-Buffer Register                           |
| GTCLR   | : General PWM Timer Software Clear Register                                             | GTADTRA   | : General PWM Timer A/D Converter Start Request Timing Register A                  |
| GTSSR   | : General PWM Timer Start Source Select Register                                        | GTADTBRA  | : General PWM Timer A/D Converter Start Request Timing Buffer Register A           |
| GTPSR   | : General PWM Timer Stop Source Select Register                                         | GTADTDBRA | : General PWM Timer A/D Converter Start Request Timing Double-Buffer<br>Register A |
| GTCSR   | : General PWM Timer Clear Source Select Register                                        | GTADTRB   | : General PWM Timer A/D Converter Start Request Timing Register B                  |
| GTUPSR  | : General PWM Timer Up Count Source Select Register                                     | GTADTBRB  | : General PWM Timer A/D Converter Start Request Timing Buffer Register B           |
| GTDNSR  | : General PWM Timer Down Count Source Select Register                                   | GTADTDBRB | : General PWM Timer A/D Converter Start Request Timing Double-Buffer<br>Register B |
| GTICASR | : General PWM Timer Input Capture Source Select Register A                              | GTDTCR    | : General PWM Timer Dead Time Control Register                                     |
| GTICBSR | : General PWM Timer Input Capture Source Select Register B                              | GTDVU     | : General PWM Timer Dead Time Value Register U                                     |
| GTCR    | : General PWM Timer Control Register                                                    | GTDVD     | : General PWM Timer Dead Time Value Register D                                     |
| GTUDDTY | C : General PWM Timer Count Direction and Duty Setting Register                         | GTDBU     | : General PWM Timer Dead Time Buffer Register U                                    |
| GTIOR   | : General PWM Timer I/O Control Register                                                | GTDBD     | : General PWM Timer Dead Time Buffer Register D                                    |
| GTINTAD | : General PWM Timer Interrupt Output Setting Register                                   | GTSOS     | : General PWM Timer Output Protection Function Status Register                     |
| GTST    | : General PWM Timer Status Register                                                     | GTSOTR    | : General PWM Timer Output Protection Function Temporary Release Register          |
| GTBER   | : General PWM Timer Buffer Enable Register                                              |           |                                                                                    |
| GTITC   | : General PWM Timer Interrupt and A/D Converter Start Request Skipping Setting Register | OPSCR     | : Output Phase Switching Control Register                                          |
| GTCNT   | : General PWM Timer Counter                                                             |           |                                                                                    |
| GTCCRA  | : General PWM Timer Compare Capture Register A                                          |           |                                                                                    |
| GTCCRB  | : General PWM Timer Compare Capture Register B                                          |           |                                                                                    |
| GTCCRC  | : General PWM Timer Compare Capture Register C                                          |           |                                                                                    |
| GTCCRD  | : General PWM Timer Compare Capture Register D                                          |           |                                                                                    |
| GTCCRE  | : General PWM Timer Compare Capture Register E                                          |           |                                                                                    |
| GTCCRF  | : General PWM Timer Compare Capture Register F                                          |           |                                                                                    |
|         |                                                                                         | SOL       | urce: Renesas S7 Series Microcontrollers User's Manual                             |

### Registers of the GPT



Some registers outside GPT must be configured first:

- PWPR must be set to 0 and then to 0x40 to write-enable the register P107PFS (PWPR is a byte-wide register at 0x4004085C).
- P107PFS must have its field PMR set to 1 and its field PSEL set to 00011b to enable the output signal GTIOCA to be available on P107. Hence, P107 is no longer a GPIO pin but it became a pin connected to the GPT channel 8 peripheral. (P107PFS is a word-wide register at 0x4004085C).
- bit-6 of MSTPCRD must be reset to 0 to enable GPT channel 8, otherwise it remains in low power state, hence, not operational

(MSTPCRD is a word-wide register at 0x40047008);



GTWP - General PWM Timer Write-Protection Register

Most registers of the GPT are protected against accidental modification, these can only be written to after write-enabled by GTWP. After reset the registers are write-enabled.

To write-enable, GTWP must be written with  $(0 \times A5 << 8 + 0)$ 

The affected registers are: GTSSR, GTPSR, GTCSR, GTUPSR, GTDNSR, GTICASR, GTIBCSR, GTCR, GTUDDTYC, GTIOR, GTINTAD,GTST, GTBER, GTITC, GTCNT, GTCCRA, GTCCRB, GTCCRC, GTCCRD, GTCCRE, GTCCRF, GTPR, GTPBR, GTPDBR, GTADTRA, GTADTBRA, GTADTDBRA, GTADTRB, GTADTBRB, GTADTDBRB, GTDTCR, GTDVU, GTDVD, GTDBU, GTDBD, GTSOS, GTSOTR

Since the default value of GTWP is write-enable, there is no need to change this register.





GTSTR - General PWM Timer Software Start Register

One bit for each channel.

Write 1 to start that channel.

Write 0 has no effect.

Bit i controls channel i

A channel may be started by GTCR as well.





GTUDDTYC - General PWM Timer Count Direction and Duty Setting Register

bit 0 - UD - set to count UP

bits 17,16 - OADTY - 00 = GTIOCA duty cycle depends on compare match

other bits must remain 0

GTUDDTYC is a word-wide register at 0x40078830.





GTIOR - General PWM Timer I/O Control Register

bits 4..0 - 11001b - Initial output is high, low output at GTCCRA compare match, high output at cycle end.

bit 8 - OAE - set to 1 to enable the GTIOCA pin output

other bits must remain at 0.

GTIOR is a word-wide register at 0x40078834.





GTCCRA - General PWM Timer Compare Capture Register A

Holds the number of PCLKD ticks at the moment when the PWM signal changes to low, this is, after 25% of the cycle, considering that the cycle starts at high (configured in GTIOR) and remains high for the first 25% of the cycle.

When PCLKD is configured for 120 MHz, and the desired PWM cycle is 10 ms, 25% corresponds to 7.5ms. It is required 300,000 PCLKD cycles for the high time and 1,200,000 PCLKD cycles for the PWM cycle. Since the counting starts at zero, the actual value programmed to GTCCRA is 299,999 (or 0x493DF).

GTCCRA is a word-wide register at 0x4007884C.





GTPR - General PWM Timer Cycle Setting Register

Considering the calculation presented for GTCCRA, GTPR must be configured with the value 1.200,000 -1 (or 0x124F7F).

GTPR is a word-wide register at 0x40078864.





GTCR - General PWM Timer Control Register

Bits 0 - CST - 1 means count in progress

Bits 18..16 - MD - 000 means saw-wave PWM

Bits 26..24 - TPCS - Timer Prescaler - 000 means PCLKD/1

GTCR is a word-wide register at 0x4007882C.





Algorithm

- 1. Program PWPR to write-enable P107PFS. Write 0 then 0x40 to PWPR.
- 2. Program P107PFS to put P107 into GTIOCA mode. PSEL = 3, PMR =1
- 3. Program MSTPCRD bit 6 to enable the power to GPT channel 8. MSTPD6 = 0.
- Program GTUDDTYC so that the timer counts up and GTIOCA duty cycle depends on compare match to GTCCRA.
   GTUDDTYC = 1.
- 5. Program GTIOR so that the cycle starts high and changes to low when a match to GTCCRA occurs. Also, enable GTIOCA output. GTIOR = 0x119.
- 6. Program GTCCRA to 25% of the cycle (300,000 -1).
- 7. Program GTPR to the cycle period (1,200,000-1).
- 8. Start the timer in saw-wave mode with PCLKD/1.



Verify the operation of the PWM.

Connect a scope to pin P107 (labeled P17 on the board) and verify that a 100 Hz rectangular waveform with a 25% duty cycle is present.



BIG IDEAS FOR EVERY SPACE

RENESAS

## **LAB5 – SERIAL COMMUNICATIONS**

**Objectives:** 

In the Serial Communications lab, the objective is to utilize the software components of the SSP to build a simple application to transmit and receive via an UART. The actual communication signals are monitored with a scope.



# **LAB5 – SERIAL COMMUNICATIONS**

#### Learning Objectives:

- Selecting software components in the SSP
- Planning a solution
- SSP Configuration
- Threads configuration
- Implementation/Test/Debug
- Checking serial comm signals with a scope

## LAB5 – SERIAL COMMUNICATIONS

#### Activities:

- 1. Problem definition
- 2. Hardware platform study
- 3. Software framework study
- 4. Configure the SSP
- 5. Build/Test/Debug
- 6. Check signals with scope

further reading for this Lab:

Renesas Synergy Software Package v1.7.5 User's Manual r11um0140eu0106-synergy-ssp-v175

UART Communications Framework Module Guide r11an0192eu0100-synergy-uart-comms-fw-mod-guide.pdf





#### Activity 1 – Problem Definition

Transmit the string "Lab5: Serial Comm over RS-232" using the SCI3 TX channel of S7G2

Receive bytes over the RX channel of the same SCI3 port.

Present the received chars on the virtual comm console of e2studio

Non-functional requirements:

make use of the SSP components for UART communication





#### Activity 2 - Hardware Platform Study (SK-S7G2 board and S7G2 MCU)

Information obtained from the Starter Kit SK-S7G2 User's Manual.pdf

- Block diagram
- RS-232 interface and related jumpers



relevant blocks of the SK-S7G2 board are marked in red



Figure 2: SK-S7G2 block diagram



U7 converts TTL signals to RS-232, these signals are available on J7, pins 5 (TX) and 6 (RX).

J9 must have jumpers on 1-3 and 2-4 so that the board is configured for RS-232. The UART\_RXD and UART\_TXD signals are connected to P7\_6 and P7\_7 of the MCU.



**BIG IDEAS FOR EVERY** 

RENESAS



#### P7\_6 and P7\_7 are RX and TX for

SCI 3 of the MCU

# LAB5 – ACTIVITY 2

| Table 20.18                              | Table 20.18         Register settings for input/output pin function (Port 7) |            |           |            |            |             |                  |                                 |                                 |  |  |  |
|------------------------------------------|------------------------------------------------------------------------------|------------|-----------|------------|------------|-------------|------------------|---------------------------------|---------------------------------|--|--|--|
| PSEL[4:0]                                |                                                                              | Pin        |           |            |            |             |                  |                                 |                                 |  |  |  |
| settings                                 | Function                                                                     | P700       | P701      | P702       | P703       | P704        | P705             | P706                            | P707                            |  |  |  |
| 00000b (value Hi-Z/JTAG/SWD after reset) |                                                                              | Hi-Z       | ·         | ·          |            |             |                  |                                 |                                 |  |  |  |
| 00011b                                   | GPT                                                                          | GTIOC5A_B  | GTIOC5B_B | GTIOC6A_B  | GTIOC6B_B  | -           | -                | _                               | _                               |  |  |  |
| 00101b                                   | SCI                                                                          | -          | -         | -          | -          | -           | - (              | RXD3_B,<br>SSCL3_B,<br>SMISO3_B | TXD3_B,<br>SSDA3_B,<br>SMOSI3_B |  |  |  |
| 10100b                                   | USBHS                                                                        | -          | -         | -          | -          | -           | -                | USBHS_OVRC<br>URB               | USBHS_OVRC<br>URA               |  |  |  |
| 10110b                                   | ETHERC                                                                       | ET1_ETXD1  | ET1_ETXD0 | ET1_ERXD1  | ET1_ERXD0  | ET1_RX_CLK  | ET1_CRS          | -                               | _                               |  |  |  |
| 10111b                                   | ETHERC                                                                       | RMII1_TXD0 | REF50CK1  | RMII1_RXD0 | RMII1_RXD1 | RMII1_RX_ER | RMII1_CRS_D<br>V | -                               | -                               |  |  |  |
| 11000b                                   | PDC                                                                          | PIXD3      | PIXD2     | PIXD1      | PIXD0      | HSYNC       | PIXCLK           | -                               | _                               |  |  |  |
| ASEL bit                                 | +                                                                            |            |           |            |            |             |                  |                                 |                                 |  |  |  |
| ISEL bit                                 |                                                                              |            |           |            |            |             |                  | IRQ7                            | IRQ8                            |  |  |  |
| DSCR[1:0] bits Drive capacity control    |                                                                              | L/M/H      | L/M/H     | L/M/H      | L/M/H      | L/M/H       | L/M/H            | L/M/H                           | L/M/H                           |  |  |  |
| NCODR bit                                | N-ch open-drain                                                              | ~          | ~         | ✓          | ✓          | ×           | ~                | ✓                               | ×                               |  |  |  |
| PCR bit                                  | Pull-up                                                                      | ✓          | ✓         | ✓          | ✓          | ~           | ✓                | ✓                               | ×                               |  |  |  |

source: Renesas S7 Series Microcontrollers User's Manual

One of the operating modes of an SCI is asynchronous communications (UART).

Among the possible interrupt sources of the SCI are end of transmission and char received (receive data full).

| ltem                       | Description                                                                                                  |  |  |  |  |  |
|----------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Serial communication modes | Asynchronous                                                                                                 |  |  |  |  |  |
|                            | Clock synchronous                                                                                            |  |  |  |  |  |
|                            | Smart card interface                                                                                         |  |  |  |  |  |
|                            | Simple IIC                                                                                                   |  |  |  |  |  |
|                            | Simple SPI                                                                                                   |  |  |  |  |  |
| Interrupt sources          | Transmit end, transmit data empty, receive data full, receive error, receive                                 |  |  |  |  |  |
|                            | data ready, and address match                                                                                |  |  |  |  |  |
|                            | Completion of generation of a start condition, restart condition, or stop<br>condition (for simple IIC mode) |  |  |  |  |  |

#### Table 34.1 SCI specifications (1/2)

source: Renesas S7 Series Microcontrollers User's Manual



## LAB5 – ACTIVITY 3 – STUDY

These are the services available in

the UART Framework of the SSP.

source: UART Communications Framework Module Guide r11an0192eu0100-synergy-uart-comms-fw-mod-guide.pdf

| Table I OART Communications Framework module AFT Summary | Table 1 | UART Communications Framework Module API Summary |
|----------------------------------------------------------|---------|--------------------------------------------------|
|----------------------------------------------------------|---------|--------------------------------------------------|

| Function Name        | Example API Call and Description                                                         |
|----------------------|------------------------------------------------------------------------------------------|
| .open                | <pre>g_sf_comms0.p_api-&gt;open(g_sf_comms0.p_ctrl,</pre>                                |
|                      | <pre>g_sf_comms0.p_cfg);</pre>                                                           |
|                      |                                                                                          |
|                      | Initialize communications driver.                                                        |
| .close               | <pre>g_sf_comms0.p_api-&gt;close(g_sf_comms0.p_ctrl);</pre>                              |
|                      |                                                                                          |
|                      | Clean up communications driver.                                                          |
| .read                | g_sf_comms0.p_api->read(g_sf_comms0.p_ctrl, &destination,                                |
|                      | <pre>bytes, timeout);</pre>                                                              |
|                      | Read data from communications driver. This call will return after the number of          |
|                      | bytes requested is read or if a timeout occurs while waiting for access to the           |
|                      | driver.                                                                                  |
| .write               | g sf comms0.p api->write(g sf comms0.p ctrl, &source, bytes,                             |
|                      | timeout);                                                                                |
|                      |                                                                                          |
|                      | Write data to communications driver. This call will return after all bytes are written   |
|                      | or if a timeout occurs while waiting for access to the driver.                           |
| .lock                | <pre>g_sf_comms0.p_api-&gt;lock(g_sf_comms0.p_ctrl, lock_type,</pre>                     |
|                      | <pre>timeout);</pre>                                                                     |
|                      |                                                                                          |
|                      | Lock the communications driver. Reserve exclusive access to the communications driver.   |
| .unlock              | g sf comms0.p api->unlock(g sf comms0.p ctrl, lock type);                                |
| UNIOCK               | g_si_comms0.p_api=>uniock(g_si_comms0.p_ccli, iock_cype),                                |
|                      | Unlock the communications driver. Release exclusive access to the                        |
|                      | communications driver.                                                                   |
| .versionGet          | <pre>g sf comms0.p api-&gt;version(&amp;version);</pre>                                  |
|                      |                                                                                          |
|                      | Store the driver version in the provided version.                                        |
| Note: For details on | operation and definitions for the function data structures, typedefs, defines, API data, |
|                      | and function variables, review the SSP User's Manual API References for the              |
| associated mo        | odule.                                                                                   |



How to use the Renesas Debug Virtual Console so that printf() messages appear onto a console of e2studio?

- follow instructions from the Renesas Knowledge Base <u>link</u>
- basically:
  - #include <stdio.h>
  - call initialise\_monitor\_handles(); during thread inicialization
  - confirm that --specs=rdimon.specs is part of the linker flags
- open a Renesas Debug Virtual Console during debugging and pin it (so that it is always visible).



# LAB5 – ACTIVITY 4 – CONFIGURATION

- Create new Synergy C project, use Blinky with ThreadX as template.
   Build and run to verify it is operational.
- In the Synergy Configuration tab, add to the Blinky Thread a Connectivity Framework called sf\_uart\_comms
- Configure g\_uart0 to Channel 3 and all four interrupt priorities to Priority 3
- Verify that the Pins for SCI3 are P707 (TXD) and P706 (RXD)

|                                            | 868 -            | ≪ ▼ 🔜 : 0, ▼ 🎨 🕪 💷 | 16 El 2 El 19 10 10 10            | [如 • 何 • 🏷 |
|--------------------------------------------|------------------|--------------------|-----------------------------------|------------|
| [Lab5_Serial] Synergy Configuration 🔀      |                  |                    |                                   |            |
| ins Configuration                          |                  |                    |                                   |            |
| elect pin configuration                    |                  |                    |                                   |            |
| S7G2-SK.pincfg 🗸 🗸 🗸 General               | te data: g_bsp_p | pin_cfg            |                                   |            |
| Pin Selection                              |                  | Pin Configuration  |                                   |            |
| type filter text                           | 2 🗉 🖻            |                    |                                   |            |
| > ✓ P2<br>> ✓ P3                           | ^                | Module name:       | P706                              |            |
| > ✓ P3<br>> ✓ P4                           |                  | Symbolic Name:     | SCI3_RXD3_SCL3_MISO3              |            |
| > 🗸 P5                                     |                  | Comment:           |                                   |            |
| > 🗸 P6                                     |                  |                    |                                   |            |
| ✓ ✓ P7                                     |                  | Port Capabilities: | IRQ0: IRQ07<br>SCI3: RXD_MISO     |            |
| ✓ P700 ✓ P701                              |                  |                    | SCI3: SCL                         |            |
| <ul> <li>✓ P702</li> </ul>                 |                  |                    | USBHS0: OVRCURB                   |            |
| ✓ P703                                     |                  | P706 Configuration |                                   |            |
| ✓ P704                                     |                  | Mode:              | Peripheral mode 🗸 🗸               |            |
| <ul> <li>✓ P705</li> <li>✓ P706</li> </ul> |                  | Pull up:           | None                              |            |
| <ul> <li>✓ P700</li> <li>✓ P707</li> </ul> |                  |                    |                                   |            |
| > 🗸 P8                                     |                  | IRQ:               | None 🗸                            |            |
| > 🗸 P9                                     |                  | Drive Capacity:    | Medium $\sim$                     |            |
| > - PA<br>> - PB                           |                  | Output type:       | CMOS ~                            |            |
| > V Pro                                    |                  | Chie innut (autout |                                   |            |
| > Other Pins                               |                  | Chip input/output  |                                   |            |
|                                            | v                | P 706:             | <ul> <li>SCI3_RXD_MISO</li> </ul> |            |



The Module Guide has important configuration information for each SSP component

| 5                                           | 📕 🎋 Debug 🗸 🗸                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 💽 Lab4_PWM Debug 🛛 🗸 🔅                                                                             | 📬 🕶 🔚 🐚   🥸 🕶 🍕 🕶 🔜 🗄 🗞 🕶 🎨                                                                                                                                                                  | 🗅 💷 😭 🕹 🔯 💋 🖾 🛊 🕶 💁 🖬 🔗 🕶 😓 🖉 🕶                                                      |  |  |  |  |  |  |  |
|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Project E                                   | xplorer 🛛 🕞 🔄 🗊 🗸 🗖                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 🗖 👹 [Lab5_Serial] Synergy Configuration 🔀                                                          |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
| > 🎏 Lab1                                    | _Game                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Threads Configuration                                                                              |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
| > 🞏 Lab3<br>> 🞏 Lab4                        | }_Histogram<br>↓PWM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Threads                                                                                            | Threads 🖗 New Thread 🕷 Remove 🥅 Blinky Thread Stacks                                                                                                                                         |                                                                                      |  |  |  |  |  |  |  |
| 🗸 😴 Lab5                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                    |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
| > (a) li<br>> (a) s<br>> (b) s<br>> (b) s   | ncludes<br>rc<br>Debug                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <ul> <li></li></ul>                                                                                | port                                                                                                                                                                                         | <ul> <li>g_sf_comms0 Communications Framework on sf_uart_comms</li> <li>i</li> </ul> |  |  |  |  |  |  |  |
| > 🗁 s                                       | ynergy_cfg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 🖑 g_fmi FMI Driver on r_fmi                                                                        |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
|                                             | configuration.xml                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <ul> <li>Blinky Thread</li> <li>g_sf_comms0 Communications</li> </ul>                              | Framework on sf uart comms                                                                                                                                                                   | 🕀 g_uart0 UART Driver on r_sci_uart                                                  |  |  |  |  |  |  |  |
|                                             | .ab5_Serial Debug.jlink<br>.ab5_Serial Debug.launch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ↓ <u>J_n_</u> common common common com                                                             |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
|                                             | R7FS7G27H3A01CFC.pincfg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                    |                                                                                                                                                                                              | Image: Click to access Module Guid                                                   |  |  |  |  |  |  |  |
|                                             | 7G2-SK.pincfg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                    |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
|                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Blinky Thread Objects                                                                              | Remove 😥 Remove                                                                                                                                                                              | g_transfer0 Transfer     Driver on r_dtc SCI3     TXI     TXI     TXI     TXI        |  |  |  |  |  |  |  |
|                                             | B_USB_Activ4<br>B_USB_Activ5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                    |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
| > 📂 Lab9                                    | 0_loT_SSP120                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Summary BSP Clocks Pins Threads Mess                                                               | aging Components                                                                                                                                                                             |                                                                                      |  |  |  |  |  |  |  |
| c                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                    | aging Components                                                                                                                                                                             |                                                                                      |  |  |  |  |  |  |  |
| C Propertie                                 | es 👷 🛐 Problems 🏽 🌚 Smart Brow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                    | aging Components                                                                                                                                                                             |                                                                                      |  |  |  |  |  |  |  |
| C Propertie                                 | es 🛛 📳 Problems 🛞 Smart Brow<br>JART Driver on r_sci_uart                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                    |                                                                                                                                                                                              |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🛿 🛐 Problems 🛞 Smart Brow<br>JART Driver on r_sci_uart<br>Property                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                    | aging Components                                                                                                                                                                             |                                                                                      |  |  |  |  |  |  |  |
| C Propertie                                 | es 🛿 📳 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>V Common                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                    | Value                                                                                                                                                                                        |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🕺 💽 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>V Common<br>External RTS Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                    | Value                                                                                                                                                                                        |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🕺 📳 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>🗸 Common<br>External RTS Operation<br>Reception                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                    | Value<br>Disable<br>Enable                                                                                                                                                                   |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es & Problems & Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                    | Value<br>Disable<br>Enable<br>Enable                                                                                                                                                         |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🛿 🔐 Problems 🌚 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>V Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ser                                                                                                | Value<br>Disable<br>Enable                                                                                                                                                                   |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🛿 Problems 🌚 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>V Module g_uart0 UART Driver on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ser                                                                                                | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)                                                                                                                                        |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🔀 Problems 🌚 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>V Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>V Module g_uart0 UART Driver on<br>Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ser                                                                                                | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0                                                                                                                             |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🕺 💽 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br><ul> <li>Common<br/>External RTS Operation<br/>Reception<br/>Transmission<br/>Parameter Checking</li> <li>Module g_uart0 UART Driver on to<br/>Name<br/>Channel</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ser                                                                                                | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3                                                                                                                        |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🔀 Problems 🌚 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>V Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>V Module g_uart0 UART Driver on<br>Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ser                                                                                                | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0                                                                                                                             |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🛞 💽 Problems 🌚 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br><ul> <li>Common</li> <li>External RTS Operation</li> <li>Reception</li> <li>Transmission</li> <li>Parameter Checking</li> <li>Module g_uart0 UART Driver on the<br/>Name</li> <li>Channel</li> <li>Baud Rate</li> <li>Data Bits</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ser                                                                                                | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3<br>9600                                                                                                                |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es & Problems & Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>Module g_uart0 UART Driver on to<br>Name<br>Channel<br>Baud Rate<br>Data Bits<br>Parity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ser                                                                                                | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uartO<br>3<br>9600<br>8bits<br>None                                                                                               |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es & Problems & Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>Module g_uart0 UART Driver on to<br>Name<br>Channel<br>Baud Rate<br>Data Bits<br>Parity<br>Stop Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ser                                                                                                | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3<br>9600<br>& Bbits<br>None<br>1bit                                                                                     |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🕺 💽 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br><ul> <li>Common</li> <li>External RTS Operation</li> <li>Reception</li> <li>Transmission</li> <li>Parameter Checking</li> <li>Module g_uart0 UART Driver on to<br/>Name</li> <li>Channel</li> <li>Baud Rate</li> <li>Data Bits</li> <li>Parity</li> <li>Stop Bits</li> <li>CTS/RTS Selection</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ser<br>r_sci_uart                                                                                  | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uartO<br>3<br>9600<br>8bits<br>None                                                                                               |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🛞 💽 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br><ul> <li>Common</li> <li>External RTS Operation</li> <li>Reception</li> <li>Transmission</li> <li>Parameter Checking</li> <li>Module g_uart0 UART Driver on the second secon</li></ul> | ser<br>r_sci_uart                                                                                  | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3<br>9600<br>8bits<br>None<br>1bit<br>RTS (CTS is disabled)<br>i NULL                                                    |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🛞 💽 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br><ul> <li>Common</li> <li>External RTS Operation</li> <li>Reception</li> <li>Transmission</li> <li>Parameter Checking</li> <li>Module g_uart0 UART Driver on I<br/>Name</li> <li>Channel</li> <li>Baud Rate</li> <li>Data Bits</li> <li>Parity</li> <li>Stop Bits</li> <li>CTS/KTS Selection</li> <li>Name of UART callback func-<br/>Name of UART callback func-</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ser<br>r_sci_uart                                                                                  | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3<br>9600<br>8bits<br>None<br>1bit<br>RTS (CTS is disabled)<br>in NULL<br>NULL                                           |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🛞 💽 Problems 🌚 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>Module g_uart0 UART Driver on<br>Name<br>Channel<br>Baud Rate<br>Data Bits<br>Parity<br>Stop Bits<br>CTS/RTS Selection<br>Name of UART callback func<br>Name of UART callback func<br>Clock Source                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ser r_sci_uart tion to be defined by user tion for the RTS external pin control to be defined by t | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3<br>9600<br>8bits<br>None<br>1bit<br>RTS (CTS is disabled)                                                              |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es & Problems & Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>Module g_uart0 UART Driver on the<br>Name<br>Channel<br>Baud Rate<br>Data Bits<br>Parity<br>Stop Bits<br>CTS/RTS Selection<br>Name of UART callback funct<br>Clock Source<br>Baudrate Clock Output from                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ser r_sci_uart tion to be defined by user tion for the RTS external pin control to be defined by t | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3<br>9600<br>8bits<br>None<br>1bit<br>RTS (CTS is disabled)                                                              |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es & Problems & Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>Module g_uart0 UART Driver on to<br>Name<br>Channel<br>Baud Rate<br>Data Bits<br>Parity<br>Stop Bits<br>CTS/RTS Selection<br>Name of UART callback funce<br>Name of UART callback funce<br>Clock Source<br>Baudrate Clock Output from<br>Start bit detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ser r_sci_uart tion to be defined by user tion for the RTS external pin control to be defined by t | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uartO<br>3<br>9600<br>8bits<br>None<br>1bit<br>RTS (CTS is disabled)<br>NULL<br>NULL<br>Internal Clock<br>Disable<br>Falling Edge |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es 🕺 💽 Problems 🌒 Smart Brow<br>JART Driver on r_sci_uart<br>Property<br><ul> <li>Common</li> <li>External RTS Operation</li> <li>Reception</li> <li>Transmission</li> <li>Parameter Checking</li> <li>Module g_uart0 UART Driver on to<br/>Name</li> <li>Channel</li> <li>Baud Rate</li> <li>Data Bits</li> <li>Parity</li> <li>Stop Bits</li> <li>CTS/RTS Selection</li> <li>Name of UART callback funce</li> <li>Clock Source</li> <li>Baudrate Clock Output from</li> <li>Start bit detection</li> <li>Noise Cancel</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ser r_sci_uart tion to be defined by user tion for the RTS external pin control to be defined by t | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uart0<br>3<br>9600<br>8bits<br>None<br>1bit<br>RTS (CTS is disabled)                                                              |                                                                                      |  |  |  |  |  |  |  |
| C Propertie<br><b>g_uart0 L</b><br>Settings | es & Problems & Smart Brow<br>JART Driver on r_sci_uart<br>Property<br>Common<br>External RTS Operation<br>Reception<br>Transmission<br>Parameter Checking<br>Module g_uart0 UART Driver on to<br>Name<br>Channel<br>Baud Rate<br>Data Bits<br>Parity<br>Stop Bits<br>CTS/RTS Selection<br>Name of UART callback funce<br>Name of UART callback funce<br>Clock Source<br>Baudrate Clock Output from<br>Start bit detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ser r_sci_uart tion to be defined by user tion for the RTS external pin control to be defined by t | Value<br>Disable<br>Enable<br>Enable<br>Default (BSP)<br>g_uartO<br>3<br>9600<br>8bits<br>None<br>1bit<br>RTS (CTS is disabled)<br>NULL<br>NULL<br>Internal Clock<br>Disable<br>Falling Edge |                                                                                      |  |  |  |  |  |  |  |

- 5. In blinky thread entry.c make the changes required for the Renesas Debug Virtual Console
- 6. Modify blinky\_thread\_entry to include the appropriate calls to the API of g\_sf\_comms0: write to send the string and read to receive it.
- 7. Use printf() to show the transmitted and received strings in the virtual console

Code running

Virtual Console in operation

|                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               | Diria                                                                      |                                                                                                       | D                                                                                                                               | D                                        |                                                                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------------------------------------------------------------------|
| [Lab5_Serial] S<br>64                                                                                                                                                                | ynergy Confi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | guration                                                      | blinky_thread_e                                                            | entry.c 🐹                                                                                             | .c startup_S7G2.c                                                                                                               | .c] main.c                               | c_tx_port_wait_thread_ready() at tx_thread_schedule.c:382 0x6874 |
| 65                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | lev                                                           | el = IOPORT LEVE                                                           | LOW:                                                                                                  |                                                                                                                                 |                                          |                                                                  |
| 66                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | }                                                             |                                                                            | _                                                                                                     |                                                                                                                                 |                                          |                                                                  |
| 67                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ,                                                             |                                                                            |                                                                                                       |                                                                                                                                 |                                          |                                                                  |
| 68                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /* Upda                                                       | te all board LED                                                           | s */                                                                                                  |                                                                                                                                 |                                          |                                                                  |
| 69 00004bea                                                                                                                                                                          | Θ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | for(uin                                                       | t32_t ii = 0; ii                                                           | < leds.1                                                                                              | <pre>led_count; ii++)</pre>                                                                                                     |                                          |                                                                  |
| 70                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | {                                                             |                                                                            | N - 2010 - 12 - 11                                                                                    |                                                                                                                                 | 1002270                                  |                                                                  |
| 71 00004bf4                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               | oport.p_api->pin                                                           | Write(led                                                                                             | s.p_leds[ii], l                                                                                                                 | evel);                                   |                                                                  |
| 72<br>73                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | }                                                             |                                                                            |                                                                                                       |                                                                                                                                 |                                          |                                                                  |
| 74 00004bd4                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | sprintf                                                       | ((char*)tx data,                                                           | "%s %41d\                                                                                             | c\n" ty uart da                                                                                                                 | ta i++):                                 |                                                                  |
| 75 00004c18                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               |                                                                            |                                                                                                       |                                                                                                                                 |                                          | , tx data, strlen((char*)tx data)+1, TX WAIT FOREVER)            |
| 76 00004c32                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               |                                                                            |                                                                                                       |                                                                                                                                 |                                          | ; } else {str = sp; }                                            |
| 77 00004c40                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | printf(                                                       | "TX: %d %s %s",e                                                           | rr,str,tx                                                                                             | (_data);                                                                                                                        |                                          |                                                                  |
| 78                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               |                                                                            |                                                                                                       |                                                                                                                                 |                                          |                                                                  |
| 79 00004bde                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                             | _sf_comms0.p_api                                                           | 10-                                                                                                   |                                                                                                                                 | -                                        |                                                                  |
| 80 00004c56                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               |                                                                            |                                                                                                       |                                                                                                                                 | <pre>) { str = to;</pre>                 | ;                                                                |
| 81 00004c64<br>82                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | print+(                                                       | "RX: %d %s %s\r\                                                           | n",err,st                                                                                             | r,in_butter);                                                                                                                   |                                          |                                                                  |
| 83                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               |                                                                            |                                                                                                       |                                                                                                                                 |                                          |                                                                  |
| 84                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /* Dela                                                       | */                                                                         |                                                                                                       |                                                                                                                                 |                                          |                                                                  |
|                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /                                                             | · · · · · · · · · · · · · · · · · · ·                                      |                                                                                                       |                                                                                                                                 |                                          |                                                                  |
| 85 00004c6c                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | tx thre                                                       | ad sleep (delay)                                                           | :                                                                                                     |                                                                                                                                 |                                          |                                                                  |
| 85 <b>00004c6c</b><br>86                                                                                                                                                             | }                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | tx_thre                                                       | ad_sleep (delay)                                                           | ;                                                                                                     |                                                                                                                                 |                                          |                                                                  |
|                                                                                                                                                                                      | }                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | tx_thre                                                       | ad_sleep (delay)                                                           | ;                                                                                                     |                                                                                                                                 |                                          |                                                                  |
| 86                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | tx_thre                                                       | ad_sleep (delay)                                                           | ;                                                                                                     |                                                                                                                                 |                                          |                                                                  |
| 86<br>87                                                                                                                                                                             | }<br>}<br><                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | tx_thre                                                       | ad_sleep (delay)                                                           | ;                                                                                                     |                                                                                                                                 |                                          |                                                                  |
| 86<br>87<br>88                                                                                                                                                                       | <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                               |                                                                            |                                                                                                       | as Debug Virtual Cor                                                                                                            | sole X                                   |                                                                  |
| 86<br>87<br>88<br>9 C 🔀 🧟 T                                                                                                                                                          | <<br>🕄 P 🜔 E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R D 🐠                                                         | s », 🗖 🗖                                                                   | Renesa                                                                                                | as Debug Virtual Cor<br>Serial Communic                                                                                         |                                          |                                                                  |
| 86<br>87<br>88<br>C X 2 T                                                                                                                                                            | < <tr>            P            Image: Constraint of the second s</tr> | € D (%)<br>€ (₽)                                              | s », – – –                                                                 | Renesa                                                                                                | -                                                                                                                               |                                          |                                                                  |
|                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                               |                                                                            |                                                                                                       |                                                                                                                                 |                                          |                                                                  |
| 86<br>87<br>88<br>9 C 🛱 🖉 T [<br>🔳 🗶 🔆<br>b5_Serial Debug                                                                                                                            | P D E [Renesas GD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R D 🐝                                                         | s », 🗖 🗖                                                                   | Renesa<br>Lab 5 -<br>TX: 0 SU                                                                         | Serial Communic                                                                                                                 | ations Lab                               |                                                                  |
| 86<br>87<br>88<br>9 C X T V<br>B X X<br>b5_Serial Debug<br>tarting target                                                                                                            | P D E<br>Renesas GD<br>connect:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R D 🐝<br>F F<br>B Hardware<br>ion                             | s », – – –                                                                 | Renesa<br>Lab 5 -<br>TX: 0 SU<br>RX: 0 SU                                                             | Serial Communic<br>CCESS Lab5:<br>JCCESS Lab5:                                                                                  | ations Lab<br>0<br>0                     |                                                                  |
| B6<br>B7<br>B7<br>B7<br>B7<br>B7<br>B7<br>B7<br>B7<br>B7<br>B7                                                                                                                       | P D E<br>Renesas GD<br>connect:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R D 🐝<br>F F<br>B Hardware<br>ion                             | s », – – –                                                                 | Renesa<br>Lab 5 -<br>TX: 0 SU<br>RX: 0 SU<br>TX: 0 SU                                                 | Serial Communic<br>JCCESS Lab5:<br>JCCESS Lab5:                                                                                 | ations Lab<br>0<br>0                     |                                                                  |
| 86<br>87<br>88<br>C X T I<br>b5_Serial Debug<br>tarting target<br>inished targe<br>08: 55455                                                                                         | P D E<br>Renesas GD<br>connect:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | D W                                                           | s », – – –                                                                 | Renesa<br>Lab 5 -<br>TX: 0 SU<br>RX: 0 SU<br>TX: 0 SU                                                 | Serial Communic<br>CCESS Lab5:<br>JCCESS Lab5:                                                                                  | ations Lab<br>0<br>0                     |                                                                  |
| 86<br>87<br>88<br>9 C X T (<br>b5_Serial Debug<br>tarting target<br>inished targe<br>08: 55455<br>arget connect                                                                      | P DE<br>[Renesas GD<br>et connect:<br>et connect:<br>tion statu:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | B Hardware<br>ion<br>s - OK                                   | s », – – –                                                                 | Renesa<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>RX: 0 SL                                     | Serial Communic<br>JCCESS Lab5:<br>JCCESS Lab5:<br>JCCESS Lab5:<br>JCCESS Lab5:                                                 | ations Lab<br>0<br>0<br>1<br>1           |                                                                  |
| 86<br>87<br>88<br>C X T (<br>D X X<br>b5_Serial Debug<br>tarting targe<br>DB: 55455<br>arget connect<br>arget connect                                                                | P D E<br>[Renesas GD<br>t connect:<br>t connect:<br>tion statu:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | B Hardware<br>ion<br>s - OK                                   | s », – – –                                                                 | Renesa<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>TX: 0 SL<br>TX: 0 SL                         | Serial Communic<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:                                 | ations Lab<br>0<br>1<br>1<br>2           |                                                                  |
| 86<br>87<br>88<br>C X T I<br>b5_Serial Debug<br>tarting targe<br>inished targe<br>DB: 55455<br>arget connect<br>arget connect<br>tarting down<br>ption Function                      | P D E<br>Renesas GD<br>et connect:<br>et connect:<br>tion statu:<br>load<br>on Select,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | B Hardware<br>ion<br>s - OK<br>writing                        | S »9 P P<br>Debugging] Renesa:                                             | Renesa<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>TX: 0 SL<br>TX: 0 SL                         | Serial Communic<br>JCCESS Lab5:<br>JCCESS Lab5:<br>JCCESS Lab5:<br>JCCESS Lab5:                                                 | ations Lab<br>0<br>0<br>1<br>1           |                                                                  |
| 86<br>87<br>88<br>C X T I<br>b5_Serial Debug<br>tarting target<br>inished targe<br>D8: 55455<br>arget connect<br>tarting down<br>ption Functio<br>ECMPUXXX, wri                      | P DE<br>[Renesas GD<br>et connect:<br>et connect:<br>tion statu:<br>load<br>on Select,<br>iting to au                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | B Hardware<br>ion<br>s - OK<br>writing                        | S ≫ <sub>9</sub> □ □<br>■ ■ ▼ <sup>™</sup> ▼<br>Debugging] Renesa:         | Renesa<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>RX: 0 SL             | Serial Communic<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:                                 | ations Lab<br>0<br>1<br>1<br>2           |                                                                  |
| 86<br>87<br>88<br>9 C X T I<br>b5_Serial Debug<br>tarting target<br>inished targe<br>08: 55455<br>arget connect<br>tarting down1<br>ption Function<br>ECMPUxxx, wri<br>inished down1 | P DE<br>[Renesas GD<br>et connect:<br>et connect:<br>tion statu:<br>load<br>on Select,<br>iting to au<br>load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | B Hardware<br>ion<br>s - OK<br>s - OK<br>writing<br>ddress 0x | S »9 □ □<br><br>Debugging] Renesa:<br>^<br>to address 0x<br>:00000408 with | Reness<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>TX: 0 SL<br>TX: 0 SL | Serial Communic<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:                 | ations Lab<br>0<br>1<br>1<br>2<br>2      |                                                                  |
| 86<br>87<br>88<br>9 C X T I<br>b5_Serial Debug<br>tarting target<br>inished targe<br>08: 55455<br>arget connect<br>tarting down1<br>ption Function<br>ECMPUxxx, wri<br>inished down1 | P DE<br>[Renesas GD<br>et connect:<br>et connect:<br>tion statu:<br>load<br>on Select,<br>iting to au<br>load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | B Hardware<br>ion<br>s - OK<br>s - OK<br>writing<br>ddress 0x | S »9 P P<br>Debugging] Renesa:                                             | Reness<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>TX: 0 SL<br>TX: 0 SL | Serial Communic<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5: | ations Lab<br>0<br>1<br>1<br>2<br>2<br>3 |                                                                  |
| 86<br>87<br>88<br>9 C X T 1<br>b5_Serial Debug<br>tarting target<br>inished targe<br>08: 55455<br>arget connect<br>tarting down1<br>btion Function<br>CCMPUxxx, wri<br>inished down1 | P DE<br>[Renesas GD<br>et connect:<br>et connect:<br>tion statu:<br>load<br>on Select,<br>iting to au<br>load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | B Hardware<br>ion<br>s - OK<br>s - OK<br>writing<br>ddress 0x | S »9 □ □<br><br>Debugging] Renesa:<br>^<br>to address 0x<br>:00000408 with | Reness<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>TX: 0 SL<br>TX: 0 SL | Serial Communic<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5: | ations Lab<br>0<br>1<br>1<br>2<br>2<br>3 |                                                                  |
| 86<br>87<br>88<br>9 C X T I<br>b5_Serial Debug<br>tarting target<br>inished targe<br>08: 55455<br>arget connect<br>tarting down1<br>ption Function<br>ECMPUxxx, wri<br>inished down1 | P DE<br>[Renesas GD<br>et connect:<br>et connect:<br>tion statu:<br>load<br>on Select,<br>iting to au<br>load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | B Hardware<br>ion<br>s - OK<br>s - OK<br>writing<br>ddress 0x | S »9 □ □<br><br>Debugging] Renesa:<br>^<br>to address 0x<br>:00000408 with | Reness<br>Lab 5 -<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>RX: 0 SL<br>TX: 0 SL<br>TX: 0 SL<br>TX: 0 SL | Serial Communic<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5:<br>ICCESS Lab5: | ations Lab<br>0<br>1<br>1<br>2<br>2<br>3 |                                                                  |



8. With a scope examine the transmitted signal on J9-pin 3

The first transmitted char is shown between the two cursor lines. Takes 1.04ms to transmit 10 bits: start, 8 data bits and the stop bit.



**BIG IDEAS FOR EVERY SPACE** 

RENESAS

9. With a scope examine the transmitted signal on J7-pin 5

On this pin the signal is at RS-232 levels. Logic 1 is represented by -6V and Logic 0 is represented by +6V.



BIG IDEAS FOR EVERY SPACE

RENESAS

- 10. Place a jumper on pins 5 and 6 of J7 so that the transmitted signal is received back.
- 11. The Virtual Console must present the same strings being transmitted and received
- 12. Include a counter in the transmitted string to verify that every transmitted message is different from the previous

## LAB6 – DISPLAY AND TOUCH

**Objectives:** 

Perform the process of creating a two screen Graphical User Interface making use of the graphical LCD and Touch Screen available on the SK-S7G2 board.



## LAB6 – DISPLAY AND TOUCH

#### Activities:

- 1. Study the physical connection of the LCD and Touch Screen to the MCU
- 2. Study the SSP API for graphical interfaces and input via touch screen
- 3. Perform the experiment described in the Renesas Application Note: GUIX "Hello World" for the SK-S7G2.

### **ADDITIONAL READING FOR LAB6**

- Renesas Synergy Starter Kit SK-S7G2 User's Manual (<u>r12um0004eu0100</u>) (https://www.renesas.com/eneu/doc/products/renesas-synergy/doc/r12um0004eu0100\_synergy\_sk\_s7g2.pdf)
- Renesas S7 Series Microcontrollers User's Manual
- Renesas Synergy Software Package v1.7.5 Manual (<u>link</u>) available in the Synergy Gallery (<u>https://synergygallery.renesas.com/media/products/1/384/en-US/r11um0140eu0106-synergy-ssp-v175.pdf</u>)
- Renesas Application Note R12AN0021EU0118 (<u>link</u>) (<u>https://www.renesas.com/us/en/doc/products/renesas-synergy/apn/r12an0021eu0118-synergy-sk-s7g2-pk-s5d9-guix-hello-world.pdf</u>)
- Sample Software for GUIX "Hello World" from: <u>https://www.renesas.com/us/en/doc/products/renesas-synergy/apn/r12an0021eu0119-synergy-sk-s7g2-pk-s5d9-guix-hello-world.pdf</u>
   <u>https://www.renesas.com/us/en/software/D6003641.html</u>



S7G2 microcontroller's block diagram with indication of blocks of interest.

Since the user's manual of the S7G2 has more than 2000 pages, it is important to keep focus on what is relevant to this project.



Relevant blocks of the SK-S7G2 board are marked in red



Figure 2: SK-S7G2 block diagram



The LCD is connected

directly to the

LCD Interface of the MCU



The LCD uses an Ilitek driver connected to an SCI (Serial Communications Interface) of the MCU. The serial communication is configured to 4-wire 8 bits.





The Touch Screen is connected to the MCU via an I2C interface.



The GLCD (Graphics LCD Controller) of the MCU is configurable to many different LCDs. Its physical interface may be up to 24 data bits plus several synchronization and clock signals.



BIG IDEAS FOR EVERY SPACE **RENESAS** 

The Renesas Synergy Software Package v1.7.5 Manual (link), available in the Synergy Gallery, describes the API for:

- The Graphics Display, on section 4.2.14
- The Touch Panel, on section 4.1.19



• Download the zip file available at:

#### https://www.renesas.com/us/en/software/D6004128.html

this zip includes the pdf with the application note R12AN0021EU0118 and the source files for the corresponding lab experiment.

The pdf is also available at: <u>link</u>

The sample code may be also obtained by accessing page:

https://www.renesas.com/us/en/products/synergy/hardware/microcontrollers.html#productinfo

and searching for r12an0021

- The aim here is to go through the 48 pages describing in detail how to build a very simple Graphical User Interface.
- This lab requires the GUIX Studio, a tool that was installed as part of Lab1.





**Objectives:** 

Create a simple multithreaded application that uses mutex and message queue. Make use of RTOS-aware debugging.





The diagram (next slide) presents the desired application.

- Thread Sender1 sends messages to RX\_Thread via queue0, workload is simulated by 40 ticks delay and green led on.
- Thread Sender2 sends messages to RX\_Thread via queue0, workload is simulated by 60 ticks delay and yellow led on.
- Thread RX\_Thread receives messages from both sender threads
- mutex0 prevents simultaneous execution of Sender 1 and Sender 2 (while LEDs are on)
- red led indicates one of the sender threads is blocked on the mutex

#### LAB7 – RTOS

Diagram presenting the architecture of Lab 7 (UML class diagram notation).



#### LAB7 – RTOS

Adding additional threads and

ThreadX object (Mutex and Queue)

using the Synergy Configuration tab.



### LAB7 – RTOS

The Partner OS | RTOS Resources view allows the visualization of the state of the threads and of the objects (Queue and Mutex).

| Run Window |                           | Hel                |                |             |
|------------|---------------------------|--------------------|----------------|-------------|
|            | >                         | 8                  | <del>ت</del> ا | 0 - 0       |
| n toolkit  | >                         |                    |                |             |
| 5          | $\rightarrow$             | 2                  | RTOS Res       | ources      |
| S          | >                         |                    |                |             |
|            | >                         | L .                |                |             |
|            | Run Win<br>n toolkit<br>S | n toolkit ><br>S > | n toolkit >    | n toolkit > |

| 🤁 RT    | OS Resour   | ces 🛛   | 3        |           |                   |                 |                  |               |         |            | 🍄 🗕 🖓   🧇   🔡   🍕        |
|---------|-------------|---------|----------|-----------|-------------------|-----------------|------------------|---------------|---------|------------|--------------------------|
| Profile | e Thread    | Stack   | Messag   | eQueue    | CountingSemaphore | Mutex EventFlag | MemoryBlockPool  | MemoryBytePoo | I Timer | System     | ReadyQueue(No.=Priority) |
| No.     | Name        | En      | ntry     | Status    | SuspendedFactor   | (ControlBlock*) | OwnedTX_MUTEX*(t | op) Priority  | RunCou  | unt        |                          |
| 1       | Blinky T    | bli     | inky_t   | SLEEP     |                   |                 |                  | 2             | 1       |            |                          |
| 2       | Sender1     | se      | nder1    | RUNNIN    | IG g_mutex0       |                 | g_mutex0         | 3             | 38      |            |                          |
| 3       | Sender2     | se      | nder2    | SLEEP     | g_mutex0          |                 |                  | 3             | 28      |            |                          |
| 4       | RX Three    | ad RX   | (_threa  | QUEUE     | g_queue0          |                 |                  | 3             | 45      |            |                          |
| 5       |             |         |          | Not crea  |                   |                 |                  |               |         |            |                          |
| 6       |             |         |          | Not crea  |                   |                 |                  |               |         |            |                          |
| 7       |             |         |          | Not crea  |                   |                 |                  |               |         |            |                          |
| 8       |             |         |          | Not crea  |                   |                 |                  |               |         |            |                          |
| 🛷 R     | lun : sende | er1_thr | ead_func | : (No.:2) |                   |                 |                  |               | 0       | OS : Threa | Xbe                      |

|           | <sup>2</sup> RTOS Resources <sup>C</sup> → ( <sup>C</sup> / <sub>2</sub> )   ⊗   □ |       |             |       |          |             |         |          |         |             |         |              |        | 🍳        |        |                |         |
|-----------|------------------------------------------------------------------------------------|-------|-------------|-------|----------|-------------|---------|----------|---------|-------------|---------|--------------|--------|----------|--------|----------------|---------|
| Profile   | Thread                                                                             | Stac  | ( Message(  | Queue | Countin  | igSemaphore | Mutex   | EventFl  | lag Me  | emoryBlockP | ool Me  | moryBytePoo  | I Time | r System | Ready  | /Queue(No.=Pr  | iority) |
| No.       | Name                                                                               | ι     | JsedCount   | FreeC | Count 1  | TotalCount  | Messag  | eSize S  | Suspen  | dedTX_THRE  | AD*(top | ) Suspende   | dCount | StartA   | ddress | EndAddress     |         |
| 1         | Queue                                                                              | 0 0   |             | 3     | 3        | 3           | 2       | F        | RX_thre | ad          |         | 1            |        | 1ffe01   | 30     | 1ffe0148       |         |
| 2         |                                                                                    |       |             |       |          |             |         |          |         |             |         |              |        |          |        |                |         |
| RTOS      | Resourc                                                                            | es 🛛  |             |       |          |             |         |          |         |             |         |              |        | (        | 2y - Q | 4   🔗   🖫      | ୍ଭ      |
| Profile 1 | Thread S                                                                           | Stack | MessageQu   | Jeue  | Counting | Semaphore   | Mutex   | EventFla | g Mer   | moryBlockPo | ol Mem  | noryBytePool | Timer  | System   | ReadyC | )ueue(No.=Pric | ority)  |
| No. I     | Name                                                                               | Ov    | vnerTX_THF  | READ* | Owner    | Count Sus   | pendedT | X_THRE   | AD*(to  | p) Suspend  | ledCour | nt           |        |          |        |                |         |
| 1 1       | Mutex0                                                                             | ser   | nder1_threa | d     | 1        |             |         |          |         | 0           |         |              |        |          |        |                |         |
| 2         |                                                                                    |       |             |       |          |             |         |          |         |             |         |              |        |          |        |                |         |



Observe that due to the Mutex, it never happens that the green LED and the yellow LED are on at the same time.

If, however, you disable (comment out) the calls to the Mutex, then the behavior is quite different.





### **Objectives:**

In Lab 8, the student will be presented to an e2 Studio project which uses the USBX and related components of the SSP to implement an USB Device.

The SK-S7G2 board is configured by this application to respond to USB requests as a Communication Device. That means, the OS installed in a PC, to which the SK-S7G2 board is connected, will handle the device as a virtual COM port, allowing a terminal application running on the PC to send and receive bytes to/from the device.

To do this lab you will need the following materials:

- SK-S7G2 kit with the USB Micro-B debug cable.
- An extra USB Micro-B cable to connect the kit to a PC.



### LAB8 – USB DEVICE

### Activities:

- 1. Tool setup and new project creation.
- 2. Setup of Synergy Configuration to use the Communications Framework on USB.
- 3. Low-level function prototyping.
- 4. Application requirements, coding and testing.
- 5. Challenge: multi-threaded version.



### Activity 1 – Tool setup and new project creation

- 1. Ensure that the e2 Studio and the SSP are properly installed. If necessary, (re)run the activities 1 to 5 of Lab 1 to do so.
- 2. Create a new Renesas Synergy Project for the SK-S7G2 board and name it "Lab8\_USB".
  - This project can be based on the "Blinky" template project



Activity 2 – Setup of Synergy Configuration to use the Communications Framework on USB

 Create a new Thread using the Synergy Configuration and add the Communications

Framework on

*sf\_el\_ux\_comms* (New Stack

- $\rightarrow$  Framework  $\rightarrow$  Connectivity).
- 2. Rename the thread to

"Lab8\_Thread".





Click on "Add USBX Port DCD" 3. and select the "USBX Port DCD on sf el ux for USBFS". This will select the Full-Speed Device Controller Driver for the R7FS7G27H3A01CFC Renesas ARM Cortex-M4 MCU Device Controller. See Section 10, "USB Logical View", to review the exact role of each of the component blocks included by Synergy Configuration.



4. Set the USBX Port DCD
Property "Full Speed Interrupt
Priority" to a priority level
compatible with Cortex-M4 (e.
g. Priority 3).

| Threads                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Lab8 Thread Stacks                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>(</b> ) |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| HAL/Common<br>g_cgc CGC Driver on r_cgc<br>g_elc ELC Driver on r_elc<br>g_fmi FMI Driver on r_fmi Lab8 Thread                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ⊕ g_sf_comms0 Comm                      | unications Framework on sf_el_ux_comms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |
| g_sf_comms0 Communications Framework on sf_el_ux_cor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         | Ic_acm0 USBX Device Class CDC-ACM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            |
| Lab8 Thread Objects                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | الم | USBX Device Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                         | Image: Second state of the second s |            |
| ummary BSP Clocks Pins Threads Messaging ICU Compone                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         | for TX [Recommended   for RX [Recommended   [Optional]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |
| a prince of the prince of | ties 🛛                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |
| Settings Property Value Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |
| Full Speed Interrupt Priorit Priority 3 (CM-<br>Module g_st_el_ux_dcd_ts_0 (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |
| Name         g_sf_el_ux_dcc           USB Controller Selection         USBFS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1_IS_0                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |



5. Build the project. Verify that the files Lab8\_Thread.c and Lab8\_Thread.h were created into the src/synergy\_gen folder. These files contain the initialization for the Communications Framework and the other common HAL modules.

| ငြာ Project Explorer 🛛 🗧 🔄 🔻 🗖 🗖    | common_data.c | 🖻 common_data.h 📧 hal_data.c 🗈 hal_data.h 🛛 🖬 🗟 Lab8_Thread.c 🛛 🖻 Lab8_Thread.h 🔹 [Lab8_US8_sc 🥍 | - 8 |
|-------------------------------------|---------------|--------------------------------------------------------------------------------------------------|-----|
| > 🌮 Communications_USBX_FW_MG_AP    | 112           | }                                                                                                | ^   |
| > 🚰 Lab8 USB                        | 113           |                                                                                                  |     |
| ✓ <sup>™</sup> Lab8 USB screenshots | 114           | estatic void Lab8_Thread_func(ULONG thread_input)                                                |     |
| > & Binaries                        | 115           |                                                                                                  |     |
| >   Includes                        | 116           | /* Not currently using thread_input. */                                                          |     |
|                                     | 117           | <pre>SSP_PARAMETER_NOT_USED (thread_input);</pre>                                                |     |
| ∽ 🥵 src                             | 118           |                                                                                                  |     |
| ✓ ≥ synergy_gen                     | 119           | /* First thread will take care of common initialization. */                                      |     |
| > 🜆 common_data.c                   | 120           | UINT err;                                                                                        |     |
| > 脑 common_data.h                   | 121           | err = tx_semaphore_get (&g_ssp_common_initialized_semaphore, TX_WAIT_FOREVER);                   |     |
| > 🖻 hal data.c                      | 122           |                                                                                                  |     |
| bal data b                          | 123           | <pre>while (TX_SUCCESS != err)</pre>                                                             |     |
| Lab8_Thread.c                       | 124           |                                                                                                  |     |
| Lab8_Thread.h                       | 125           | /* Check err, problem occurred. */                                                               |     |
|                                     | 126<br>127    | BSP_CFG_HANDLE_UNRECOVERABLE_ERROR (0);                                                          |     |
| > la main.c                         | 127           | }                                                                                                |     |
| > 🖻 pin_data.c                      | 128           | /* Only perform common initialization if this is the first thread to execute. */                 |     |
| > 🖻 hal_entry.c                     | 130           | <pre>if (false == g ssp common initialized)</pre>                                                |     |
| > Lab8_Thread_entry.c               | 130           | ( (also g_ssp_common_initialized)                                                                |     |
| > 😂 synergy                         | 132           | /* Later threads will not run this code. */                                                      |     |
| > 🗁 Debug                           | 133           | g sp common initialized = true;                                                                  |     |
| > 🗁 script                          | 134           | g_ssp_common_initialized blac,                                                                   |     |
| > b synergy_cfg                     | 135           | /* Perform common module initialization. */                                                      |     |
| # configuration.xml                 | 136           | g hal init ();                                                                                   |     |
|                                     | 137           |                                                                                                  |     |
| Lab8_USBscreeshots Debug.launch     | 138           | /* Now that common initialization is done, let other threads through. */                         |     |
| R7FS7G27H3A01CFC.pincfg             | 139           | /* First decrement by 1 since 1 thread has already come through. */                              |     |
| S7G2-SK.pincfg                      | 140           | g ssp common thread count;                                                                       |     |
| synergy_cfg.txt                     | 141           | while (g ssp common thread count > 0)                                                            |     |
| NetXPortETHER_SF_EL_NX_MG_AP        | 142           |                                                                                                  |     |
| 🗀 teste1 🗸 🗸                        | 143           | err = tx_semaphore_put (&g_ssp_common_initialized_semaphore);                                    | ~   |
| < >                                 |               | <                                                                                                | >   |



CDT Build Console [Lab8\_USB\_screenshots]

1.1

• •

<

11:32:38 Build Finished. 0 errors, 0 warnings. (took 37s.589ms)



### Activity 3 – Low-level function prototyping

Our Lab8 application will make use of the SK\_S7G2 onboard LEDs and communication port via USB.

The next step for this lab consists on prototyping the low-level functions to control the LEDs and USB and doing basic tests before dealing with the application requirements and full coding.





 Create a function to turn the LEDs on/off at Lab8\_Thread\_entry.c.

Hints:

- The hardware mapping for each LED can be done in two ways:
- a) The GPIO pin for each LED can be explicitly mapped to constants. Refer to Lab 2, Activity 4, to learn how to discover which of the GPIO pins are mapped to the LEDs on the SK-S7G2 board. Constant definitions for the GPIO can be found in the *r\_ioport\_api.h* file.

| ြို့ Project Explorer 🕱 🖻 🔄 🄝 🖻 🗄 | Lab8_Thread.c       | 🖻 Lab8_Thread.h 🛛 🦛 [Lab8_US8_sc 🖻 r_ioport.h 🗈 r_ioport_api.h 🛙 🍾              |           |
|-----------------------------------|---------------------|---------------------------------------------------------------------------------|-----------|
| ✓                                 | <b>^</b> 100        | <pre>} ioport_port_t;</pre>                                                     | ^         |
| > 尾 common_data.c                 | 101                 |                                                                                 |           |
| > h common_data.h                 | 102                 | <pre>/** Superset list of all possible IO port pins. */</pre>                   |           |
| > 🖻 hal_data.c                    | 103                 | <pre>etypedef enum e_ioport_port_pin_t</pre>                                    |           |
| > h hal_data.h                    | 104                 | {                                                                               |           |
| > 🗟 Lab8 Thread.c                 | 105                 | $IOPORT\_PORT\_00\_PIN\_00 = 0x0000,$                                           | //        |
|                                   | 106                 | $IOPORT\_PORT\_00\_PIN\_01 = 0x0001,$                                           |           |
| > 🖻 Lab8_Thread.h                 | 107                 | $IOPORT\_PORT\_00\_PIN\_02 = 0x0002,$                                           |           |
| > 🖻 main.c                        | 108                 | $IOPORT\_PORT\_00\_PIN\_03 = 0x0003,$ $IOPORT\_PORT\_00\_PIN\_04 = 0x0004,$     |           |
| > 🖻 pin_data.c                    | 110                 |                                                                                 | //        |
| > le hal_entry.c                  | 110                 |                                                                                 | <i>''</i> |
| > Lab8_Thread_entry.c             | 112                 |                                                                                 | 11        |
| 🗸 🐸 synergy                       | 113                 |                                                                                 | 11        |
| > 🗁 board                         | 114                 |                                                                                 | 11        |
| 🗸 🗁 ssp                           | 115                 |                                                                                 | 11        |
| ✓ inc                             | 116                 |                                                                                 | 11        |
| > 🦻 bsp                           | 117                 | IOPORT PORT 00 PIN 12 = 0x000C,                                                 | 11        |
| ✓ ➢ driver                        | 118                 |                                                                                 | //        |
|                                   | 119                 |                                                                                 | //        |
| V 🗁 api                           | 120                 | $IOPORT\_PORT\_00\_PIN\_15 = 0x000F$ ,                                          | //        |
| > 🖻 r_cgc_api.h                   | 121                 |                                                                                 |           |
| > 🖻 r_elc_api.h                   | 122                 |                                                                                 | //        |
| <u> </u>                          | 123                 |                                                                                 | //        |
| 📂 🗈 r_ioport_api.h                | 124                 |                                                                                 | //        |
| > 🖻 r_transfer_api.h              | 125<br>126          |                                                                                 | //        |
| 🗸 🗁 instances                     | 126                 |                                                                                 |           |
| > 🖻 r_cgc.h                       | 128                 | IOPORT PORT 01 PIN 06 = 0x0106,<br>IOPORT PORT 01 PIN 06 = 0x0106,              | // 、      |
| > 🖻 r_elc.h                       | 100                 | TODODE DODE 01 DIN 07 = 0.0107                                                  | //        |
| > 🔓 r_fmi.h                       |                     | <                                                                               | >         |
| > 🔓 r_ioport.h                    | 🕄 Problems 🧔 Tag    | sks 📮 Console 🛛 🗖 Properties 🔋 Memory Usage 👒 Smart Browser 🔗 Search 🎲 Call Hie | rarchy    |
| > 🗁 framework                     |                     | ↓ ↑ ¶5                                                                          |           |
| > 🖻 ssp_common_api.h              | CDT Build Console I | Lab8_USB_screenshots]                                                           |           |
| > h ssp_features.h                |                     |                                                                                 |           |
| > h ssp_version.h                 |                     |                                                                                 |           |
| > 🗁 src                           |                     |                                                                                 |           |
| > 📇 Debug                         | ×                   |                                                                                 |           |
| < >                               |                     |                                                                                 |           |

b) The BSP function R\_BSP\_LedsGet ()
(defined in bsp\_common\_leds.c) can be called to fill an instance of bps\_leds\_t with the LED information.



Source: Authors

RENESAS

BIG IDEAS FOR EVERY SPACE

 The g\_ioport instance of the I/O port driver (included as a HAL component into the Synergy Configuration) should be used to command the GPIO pins concerning the LEDs.

Reference the *p\_api* field to access the API and then the *pinWrite()* function to write to the LED pin.





 The g\_ioport instance of the I/O port driver (included as a HAL component into the Synergy Configuration) should be used to command the GPIO pins concerning the LEDs.

Reference the *p\_api* field to access the API and then the *pinWrite()* function to write to the LED pin.

#### pinWrite

| ssp_err_t(* ioport_api_t::pinWrite) (ioport_port_pin_t pin, ioport_level_t level) |       |                                 |  |  |
|-----------------------------------------------------------------------------------|-------|---------------------------------|--|--|
| Write specified level to a pin.                                                   |       |                                 |  |  |
| <pre>Implemented as</pre>                                                         |       |                                 |  |  |
| [in]                                                                              | pin   | Pin to be written to.           |  |  |
| [in]                                                                              | level | State to be written to the pin. |  |  |
|                                                                                   |       |                                 |  |  |

Source: Renesas Synergy Software Package v1.7

//turn the LED on or off, depending on the hardware //configuration. //Change the TARGET\_IO\_PORT to the desired port. //Change the TARGET\_LEVEL to IOPORT\_PIN\_LOW or IOPORT\_PIN\_HIGH, //depending on the desired level. g\_ioport.p\_api->pinWrite(TARGET\_IO\_PORT, TARGET\_LEVEL);



- Insert at Lab8\_Thread\_entry() the API calls to send and receive data through the Communications port. Hints:
  - use the instance g\_sf\_comms0 of the Communications Framework component that is configured in the Synergy Configuration Tool





Reference the *p\_api* field and then the functions *read()* and *write()* to receive and send data to the PC, respectively. The first parameter for the *read()* and *write()* functions is a pointer to a *sf\_comms\_ctrl\_t* structure, which is a device control block previously initialized for communication. This pointer can be obtained from the *p\_ctrl* member of the g\_sf\_comms0 instance

#### 🔷 write

ssp\_err\_t(\* sf\_comms\_api\_t::write) (sf\_comms\_ctrl\_t \*const p\_ctrl, uint8\_t const \*const p\_src, uint32\_t const bytes, UINT const timeout)

Write data to communications driver. This call will return after all bytes are written or if a timeout occurs while waiting for access to the driver.

#### Parameters

| [in] | p_ctrl  | Pointer to device control<br>block initialized in Open cal<br>for communications driver.                                                                                              |
|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [in] | p_src   | Source address to read data out from                                                                                                                                                  |
| [in] | bytes   | Write data length                                                                                                                                                                     |
| [in] | timeout | ThreadX timeout. Options<br>include TX_NO_WAIT<br>(0x00000000),<br>TX_WAIT_FOREVER<br>(0xFFFFFFF), and timeout<br>value (0x00000001 through<br>0xFFFFFFFE) in ThreadX tick<br>counts. |

Source: Renesas Synergy Software Package v1.7

BIG IDEAS FOR EVERY SPACE

Source: Authors

RENESAS



The last parameter for the read() and write() functions defines the timeout for the read and write operations. To command a transmission and wait as long as necessary for the driver access to be scheduled, use TX WAIT FOREVER. In case of reception, use TX\_NO\_WAIT to return immediately regardless of the number of received bytes.

#### write

ssp\_err\_t(\* sf\_comms\_api\_t::write) (sf\_comms\_ctrl\_t \*const p\_ctrl, uint8\_t const \*const p\_src, uint32 t const bytes, UINT const timeout)

Write data to communications driver. This call will return after all bytes are written or if a timeout occurs while waiting for access to the driver.

#### Parameters

| [in] | p_ctrl  | Pointer to device control<br>block initialized in Open cal<br>for communications driver.                                                                                              |
|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [in] | p_src   | Source address to read data<br>out from                                                                                                                                               |
| [in] | bytes   | Write data length                                                                                                                                                                     |
| [in] | timeout | ThreadX timeout. Options<br>include TX_NO_WAIT<br>(0x00000000),<br>TX_WAIT_FOREVER<br>(0xFFFFFFF), and timeout<br>value (0x00000001 through<br>0xFFFFFFFE) in ThreadX tick<br>counts. |

Source: Renesas Synergy Software Package v1.7

**BIG IDEAS FOR EVERY SPACE** 



- 3. Start a debug session. Refer to Lab 1, Activity 4 for details on debugging.
- 4. Connect the SK-S7G2 board to the PC via USB interface (connector J5). This will allow the OS installed on the PC to enumerate the board as an USB Communication Device.
  - If the installed OS is Windows 10, the Device Manager will show a new "Communication Device" under "Ports (COM & LPT)", after the proper USB enumeration and driver installation that follows the first execution of debugging application.
  - In this case, there is a driver issue that may prevent the USB COM port to be opened by a terminal application on the PC. To fix it, select the driver for the enumerated COM port, right-click on "Update driver", search for drivers installed on the computer, uncheck the "Show compatible hardware" option and select SEGGER 
    JLink CDC UART Port.
- 5. Open a Terminal Application on the PC and connect it to the enumerated COM port.
- 6. Test the LED control and USB communications prototype functions.

### Activity 4 – Application requirements, coding and testing

Use the prototyped low-level functions, implemented to control the LEDs and access the USB communications port, to implement an application logic that performs the following operations:

- 1. Turn on the LEDs in a binary pattern given by a counter (0 to 7 0b000 to 0b111)
- 2. Increment the counter and sleep for an interval of N ticks (hint: use *tx\_thread\_sleep(N)*).
- 3. For every increment of the counter, send the current counter value to the terminal application running on PC via the USB communications port.
- 4. Repeat steps 1 to 3 in 16 iterations.
- 5. Check if the user has typed and sent a character from the PC via the terminal application connected to the USB communications port. If so, test the character and increase or decrease the number N of ticks of the sleep interval, depending on the typed character.
- 6. Repeat this process (steps 1 to 5) in an infinite loop.

Test the application and check the resulting behavior.





HINTS:

If an error condition occur, such as arriving on error\_callback function, or on a call to BSP\_CFG\_HANDLE\_UNRECOVERABLE\_ERROR (0); or if nothings shows up on the terminal, then:

- both micro-USB ports of the S7G2 must be connected to the PC, one for debugging and the other for USB communications
- check is the COM port was correctly enumerated by the PC and if the driver in use is actually the SEGGER JLink CDC Uart.
- check if the terminal is configured for 115K baud and 8N1 frame format
- reset the terminal, possibly closing and reopening the terminal application



|                              | 💹 Tera Term Web 3.1 - VT                                            | _                                                                          | - 🗆 X |
|------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------|-------|
| Example of output on a       | <u>File Edit Setup Web Control W</u> indow <u>H</u> elp             |                                                                            |       |
| terminal emulator.           | 2<br>3<br>4<br>5                                                    |                                                                            | ^     |
| In this example, when the    | 0<br>7<br>8<br>9                                                    | Tera Term: Serial port setup                                               |       |
| second USB cable was         | 10<br>11<br>12                                                      | Port: COM5  OK                                                             |       |
| connected and the software   | 10<br>11<br>12<br>13<br>14<br>15<br>16                              | Baud rate:         115200 ▼           Data:         8 bit ▼         Cancel |       |
| executed on the S7G2,        | 16<br>Press 'a' to decrease, 's' to increase speed<br>1             | Parity: none                                                               |       |
| Windows identified the board | 2<br>3<br>4                                                         | Stop: 1 bit ▼ Help<br>Elow control: none ▼                                 |       |
| as COM5.                     | 5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13                       | Transmit delay<br>0 msec/ <u>c</u> har 0 msec/ <u>l</u> ine                |       |
|                              | 14<br>15<br>16<br>Press 'a' to decrease, 's' to increase speed<br>■ |                                                                            |       |

### Activity 5 – Challenge: multi-threaded version

Modify the application structure to separate the logic into two different threads:

- Thread #1  $\rightarrow$  increments the counter and sends its current value via the USB Communications port.
  - Remove the limit of 16 iterations, allowing the counter to increase limited only by the size of the counter variable.
- Thread #2  $\rightarrow$  waits for user input and changes the sleep interval (counting period).

The sleep interval will be able to be changed while the counter is still running.

Hint: the *g\_sf\_comms0* instance is defined in one of the threads (depending on Synergy Configuration). To access this instance in the other thread, use the #include preprocessor directive to include the header file of the thread where the instance has been created and initialized.



Activity 5 – Challenge: multi-threaded version

| Tera Term Web 3.1 - VT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | _ | × |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|
| le <u>E</u> dit <u>S</u> etup We <u>b</u> C <u>o</u> ntrol <u>W</u> indow <u>H</u> elp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |
| ab 8 - Multithreaded !! Press a to decrease and s to increase speed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   | - |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
| i de la constante de |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |
| •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |





### **Objectives:**

In Lab 9, the student will be presented to an e2 Studio project that makes use of the Renesas Synergy Wi-Fi Framework to implement an example of IoT (Internet-Of-Things) application.

The SK-S7G2 board is configured to act as an IoT node that reads some sensors (internal CPU temperature) and writes to an actuator (a LED). The commands to read / write are sent to the node by a Remote Client application running on a PC or a smartphone, by means of the network infrastructure (LAN) to which both the IoT node and the Remote Client are connected.

To do this lab you will need the following materials / resources:

- SK-S7G2 kit with the USB Micro-B debug cable
- A GT202 Wi-Fi module with a PMOD plug-in
- A Local Area Network (LAN) with an accessible (i. e. known SSID and password) Wi-Fi AP/Router





### **Activities:**

- 1. Hardware setup.
- 2. Follow Renesas application note R12AN0055EU0106 to build a thermostat application.
- Based on Renesas application note R12AN0034EU0105, modify this project to include WiFi and access the temperature sensor and the LEDs from a web page.

Note: LAN SSID and password shall be set in the file src\wifi\_app\_thread\_entry.c



### Activity 1 – Hardware Setup:

- Connect the GT202 Module to SK-S7G2 PMOD B interface.
- Make sure that jumper J15 is at 3V3 position □ provides the correct voltage level (3.3V) to the module.

**Caution!** If J15 is not properly configured, the Wi-Fi module can be damaged!



BIG IDEAS FOR EVERY SPACE **RENESAS** 

Source: Synergy Wi-Fi Application Project for SK-S7G2 r11an0082eu0101-synergy-wifi-framework-app-note.pdf



Activity 2 –

1. The application note **R12AN0055EU0106** is provided as part of the lab files for this course in pdf format. Follow the instructions therein.

Note: this AN is applicable to four different boards. Make sure to target it to the SK-S7G2.





Activity 3 –

1. The application note **R12AN0034EU0105** is provided as part of the lab files for this course in pdf format. Based on its contents, modify your project to include a WiFi framework and the functionality of remote accessing a sensor and an actuator (LEDs).

The Wi-Fi Framework is designed as a layered architecture that is integrated to other SSP components as shown in the figure.

Notice that it can provide a low-level network layer to NetX protocol stack, as well as be directly accessed by an application via its APIs (including on-chip stack implementations).

The IoT Example Project makes use of the NetX Protocol Stack, as shown in the next slides.

Source: Renesas Synergy Software Package v1.7 Manual (<u>link</u>)







Build and run the application. Verify that the SK-S7G2 kit shows information on the display. If the kit is successfully connected to the Wi-Fi AP, the IP address leased by the DHCP server can be identified in the settings | Network menu entry.

The temperature sensor and the LEDs are configured as a "sensor" and an "actuator" that can be accessed / controlled by the Remote Client via Wi-Fi interface.





The IoT Node can be remotely accessed by the Remote Client, via HTTP, by browsing its IP address.

Use the web page to control the IoT "actuator" (the LED) and check the status of the "sensor" (thermostat).

The web page also shows date/time as provided by the IoT Node.



The HTTP server thread configured into the WiFI Application Project (http\_server\_thread\_entry.c) sends the contents defined in http\_server.c as an HTML page to the web browser.

Try editing the HTML contents in *http\_server.c*, rebuilding and running the project, and check the results.

| [Wi_Fi_Appli |                                                                     |   |
|--------------|---------------------------------------------------------------------|---|
| 14           | <pre>#include "blink_thread.h" ^</pre>                              |   |
| 15           |                                                                     |   |
| 16           |                                                                     |   |
| 17           | UINT get_notify(NX HTTP SERVER *server_ptr, UINT request_type, CHAR |   |
| 18           |                                                                     |   |
| 19           | extern void brightup(void);                                         |   |
| 20           | extern void brightdown(void);                                       |   |
| 21           |                                                                     |   |
| 22           |                                                                     |   |
| 23           | <pre>static char buff[2048];</pre>                                  |   |
| 24<br>25     | <pre>static char buff_send[2048];</pre>                             |   |
| 26           |                                                                     |   |
| 27           | /* here is my local HTML contents */                                |   |
| 28           | <pre>char my get contents updated[] =</pre>                         |   |
| 29           | " <html>"</html>                                                    |   |
| 30           | " <head><title>NetX HTTP Server</title></head> "                    |   |
| 31           | <pre>"<body bgcolor='\"#0080FF\"'>"</body></pre>                    |   |
| 32           | <pre>"<font color='\"Gold\"'>"</font></pre>                         |   |
| 33           |                                                                     | - |
| 34           | "<br>\r\n"                                                          |   |
| 35           | "<br>\r\n"                                                          |   |
| 36           | "<br>\r\n"                                                          |   |
| 37           |                                                                     |   |
| 38           | " <h1 align='\"center\"'>"</h1>                                     |   |
| 39           | <pre>"<meta content='\"2\"' http-equiv='\"refresh\"'/>"</pre>       |   |
| 40           | " <u>Renesas Synergy</u> "                                          |   |
| 41           | "\r\n"                                                              |   |
| 42           |                                                                     |   |
| 43           | " <h1 align='\"center\"'>"</h1>                                     |   |
| 44           | " Wi-Fi Framework Application Demo "                                |   |
| 45           | "\r\n"                                                              | 8 |
| 46           | ▼                                                                   |   |
| 7            | <pre>#</pre>                                                        |   |

#### Source: Authors

\$



