

# **Application Note**

# Using the Caches of STAR with CMSIS CMO Functions

Version 1.0 Document ID: ACN-02202102-001 Non-Confidential



### **Non-Confidential Proprietary Notice**

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm China. **No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.** 

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any third party patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM CHINA PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm China makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, third party patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM CHINA BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM CHINA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm China's customers is not intended to create or refer to any partnership relationship with any other company. Arm China may make changes to this document at any time and without notice.

If any of the provisions contained in these terms conflict with any of the provisions of any click through or signed written agreement covering this document with Arm China, then the click through or signed written agreement prevails over and supersedes the conflicting provisions of these terms. This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm China corporate logo and words marked with <sup>®</sup> or <sup>™</sup> are registered trademarks or trademarks of Arm Technology (China) Co., Ltd (or its affiliates) in the People's Republic of China and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners.

Copyright © 2021 Arm China (or its affiliates). All rights reserved.

Version 1.0 Document ID: ACN-02202102-001

Copyright © 2021 Arm China. All rights reserved.

## **Release Information**

## **Document History**

| Issue | Date       | Confidentiality  | Change        |
|-------|------------|------------------|---------------|
| Α     | 23/07/2021 | Non-Confidential | Initial draft |

# **Contents**

| 1 About this document                   | 4  |
|-----------------------------------------|----|
| 1.1 References                          | 4  |
| 1.2 Terms and abbreviations             | 4  |
| 1.3 Conventions and feedback            |    |
| 1.3.1 Feedback on this product          | 5  |
| 1.3.2 Feedback on documentation         | 5  |
| 1.3.3 Other information                 | 5  |
| 2 Introduction                          |    |
| 2.1 CMSIS                               | 6  |
| 2.2 STAR DFP                            | 6  |
| 2.3 CoreMark                            | 6  |
| 3 Preparations                          | 7  |
| 4 CMO functions                         | 8  |
| 5 Using the example project of STAR CMO | 10 |

## 1 About this document

This Application Note is intended for developers/programmers/users who use the Arm China STAR *Device Family Pack* (DFP). This Application Note gives you a basic understanding of *Cache Maintenance Operation* (CMO) functions of the caches in STAR and provides guidance on how to use the example project which is using CMO functions.

## 1.1 References

| Reference | Document number | Title |
|-----------|-----------------|-------|
| -         | -               | -     |

## 1.2 Terms and abbreviations

This document uses the following terms and abbreviations.

| Term     | Meaning                                                                                                                                            |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| CMSIS    | Cortex Microcontroller Software Interface Standard                                                                                                 |
| DFP      | Device Family Pack                                                                                                                                 |
| СМО      | Cache Maintenance Operation                                                                                                                        |
| CoreMark | CoreMark® is an industry-standard benchmark that measures the performance of central processing units (CPUs) and embedded microcontrollers (MCUs). |

## 1.3 Conventions and feedback

The following describes the typographical conventions and how to give feedback:

| Convention        | Meaning                                                                                                                                                      |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| monospace         | denotes text that can be entered at the keyboard, such as commands, file and program names, and source code.                                                 |
| <u>mono</u> space | denotes a permitted abbreviation for a command or option. The underlined text can be entered instead of the full command or option name.                     |
| monospace italic  | denotes arguments to commands and functions where the argument is to be replaced by a specific value.                                                        |
| monospace bold    | denotes language keywords when used outside example code.                                                                                                    |
| italic            | highlights important notes, introduces special terminology, denotes internal cross-references, and citations.                                                |
| bold              | highlights interface elements, such as menu names. Also used for emphasis in descriptive lists, where appropriate, and for Arm China processor signal names. |

## 1.3.1 Feedback on this product

If you have any comments and suggestions about this product, contact your supplier and give:

- Your name and company.
- The serial number of the product.
- Details of the release you are using.
- Details of the platform you are using, such as the hardware platform, operating system type and version.
- A small standalone sample of code that reproduces the problem.
- A clear explanation of what you expected to happen, and what actually happened.
- The commands you used, including any command-line options.
- Sample output illustrating the problem.
- The version string of the tools, including the version number and build numbers.

## 1.3.2 Feedback on documentation

If you have comments on the documentation, e-mail errata@armchina.com. Give:

- The title.
- The number, [Document ID Value], [Issue].
- If viewing online, the topic names to which your comments apply.
- If viewing a PDF version of a document, the page numbers to which your comments apply.
- A concise explanation of your comments.

Arm China also welcomes general suggestions for additions and improvements.

Arm China periodically provides updates and corrections to its documentation on the Arm China Information Center, together with knowledge articles and *Frequently Asked Questions* (FAQs).

## 1.3.3 Other information

Arm Glossary, http://infocenter.arm.com/help/topic/com.arm.doc.aeg0014-/index.html.

## 2 Introduction

## **2.1 CMSIS**

The Cortex Microcontroller Software Interface Standard (CMSIS) is a vendor-independent hardware abstraction layer for microcontrollers.

The CMSIS defines generic tool interfaces and enables consistent device support.

The CMSIS provides:

- Simple software interfaces to processor and peripherals.
- A common approach to interface to peripherals, real-time operating systems, and middleware components.

## 2.2 STAR DFP

For CMSIS compliant toolchains such as Keil MDK, IAR EW and Development Studio, additional software components and support for microcontroller devices are provided by software packs.

A DFP is one of the CMSIS software packs. It indicates that a software pack contains support for microcontroller devices.

A DFP provides essential support for the software targets on a specific device, such as 'startup', 'system', linker scripts, and debug configuration.

The STAR processor is the first processor in the Arm China STAR series processor family.

STAR is a fully featured microcontroller class processor based on the Armv8-M mainline architecture with Arm® TrustZone® technology (depending on the actual core).

In STAR CMSIS DFP v1.3.0 and later, there are example projects of STAR application. These example projects can help you quickly build projects and run application software.

## 2.3 CoreMark

CoreMark is a simple, yet sophisticated benchmark that is designed specifically to test the functionality of a processor core. Running CoreMark produces a single-number score allowing users to make quick performance comparisons between processors.

Typically the total binary size of the pure CoreMark codes is no more than 16K using gcc on an x86 machine. The small size of CoreMark allows it to easily fit in a processor's cache, which means it is suitable for testing on a wide range of processors, from low-end to high-end devices, and you can use it to observe the performance gap between 'with' and 'without' caches.

The copyright of CoreMark is owned by EEMBC. For more information about EEMBC and CoreMark, visit <a href="https://www.eembc.org/coremark/">https://www.eembc.org/coremark/</a>.

Note that CoreMark is licensed under Apache V2.0 license.

Before you use CoreMark and STAR DFP, you must read the license and then keep in compliance with the license (http://www.apache.org/licenses/LICENSE-2.0).

# 3 Preparations

The example project of the application software will run on an MPS2 FPGA board.

Before using the example project, you need to:

- Ensure that you have an MPS2/MPS2+ FPGA board and had a STAR-based device implemented on the board.
- Check the STAR CMSIS DFP version.

#### To check the STAR CMSIS DFP version:

- 1. Start MDK.
- 2. On the toolbar, click the Pack Installer icon.



3. On the Devices tab, select a device (for example, STAR CU) and check the version of the installed pack.

As shown in the following figure, the version of the ArmChinaSTAR pack should be 1.3.0 or later.



## **4 CMO functions**

All cache maintenance operations are executed by writing to registers in the memory-mapped *System Control Space* (SCS) region of the internal PPB memory space.

The operations supported for the data cache are:

• Enable

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_EnableDCache (void)

• Disable

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_DisableDCache (void)

Invalidate

Prototype: STATIC FORCEINLINE void SCB InvalidateDCache (void)

Clean

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_CleanDCache (void)

• Clean and Invalidate

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_CleanInvalidateDCache (void)

Invalidate by address (Set/Way combination)

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_InvalidateDCache\_by\_Addr (void \*addr, int32\_t dsize)

D-cache is invalidated starting from a 32-byte aligned address in 32-byte granularity.

D-cache memory blocks which are part of given address + given size are invalidated.

Clean by address

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_CleanDCache\_by\_Addr (uint32\_t \*addr, int32\_t dsize)

This function is to clean D-Cache for the given address.

D-cache is cleaned starting from a 32-byte aligned address in 32-byte granularity.

D-cache memory blocks which are part of given address + given size are cleaned.

• Clean and Invalidate by address (Set/Way combination)

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_CleanInvalidateDCache\_by\_Addr (uint32\_t \*addr, int32\_t dsize)

D-cache is cleaned and invalidated starting from a 32-byte aligned address in 32-byte granularity.

D-cache memory blocks which are part of given address + given size are cleaned and invalidated.

Version 1.0 Document ID: ACN-02202102-001

The CMO functions for operations supported for the instruction cache are:

• Enable

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_EnableICache (void)

Disable

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_DisableICache (void)

Invalidate all

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_InvalidateICache (void)

Invalidate by address

Prototype: \_\_STATIC\_FORCEINLINE void SCB\_InvalidateICache\_by\_Addr (void \*addr, int32\_t isize)

I-cache is invalidated starting from a 32-byte aligned address in 32-byte granularity.

I-cache memory blocks which are part of given address + given size are invalidated.

## Some principles for CMO:

- After you enable or disable the instruction cache, you must issue an ISB instruction to flush the pipeline. This ensures that all subsequent instruction fetches see the effect of enabling or disabling the instruction cache.
- After reset, you must invalidate each cache before enabling it. If the INITL1RSTDIS signal is de-asserted upon reset de-assertion, the cache invalidation work for both I-cache and D-cache is done automatically by hardware. When the hardware performs such invalidate-all function, it is done in the background by marking an Invalidation Region to yield the cache memory to the foreground activities from PFU or DPU, while every access that hits the Invalidation Region is automatically turned into a non-cacheable access.
- When disabling the data cache, you must clean the entire cache to ensure that any dirty data is flushed to external memory.
- Before enabling the data cache, you must invalidate the entire data cache because external memory might have changed when
  the cache was disabled.
- Before enabling the instruction cache, you must invalidate the entire instruction cache if external memory might have changed after the cache was disabled.

# 5 Using the example project of STAR CMO

In STAR DFP v1.3.0, there is an example project which demonstrates how to use the CMO functions.

Follow these steps to get started with this example project and understand the cache maintenance operations:

1. In the Pack Installer, click the **Examples** tab.



2. On the **Examples** tab, select the example that you want to use and click **Copy**.

In STAR CMSIS DFP v1.3.0, there is an example named 'STAR CoreMark Caches' available. This example project invokes CoreMark programs to stress on STAR, and to print out the two scores of enabling and disabling I-cache and D-cache.



#### Note:

Sometimes the Copy button is disabled in gray because there are some packs need to be updated. You can check the progress bar to confirm this situation. When the progress reaches 100%, the Copy button will be enabled.



B. In the Copy Example dialog box that appears, specify the destination folder path to save the project, and then click OK.



If the destination folder does not exist, click Yes to create it.



A project is created in the destination folder.

The MDK µVision will start automatically and open the created project. In the Project pane, you can see all the required files.

4. Click the **Rebuild** icon to recompile and build the project.



5. Click **Start/Stop Debug Session** to start the debug session.



6. Click the **Run** icon to run the built software.



Then you can see the following message in the UART terminal window.



You can observe the difference between enabling and disabling the caches for CoreMark.

```
PuTTY
                                                                                                   П
                                                                                                          ×
--- Round 1 : Cache enabled
CoreMark Size
                     : 666
: 13544
otal ticks
Total time (secs): 13.544000
Iterations/Sec : 81.216775
Iterations: 1100

Compiler version: Clang 12.0.0 (ssh://ds-gerrit/armcompiler/llvm-project e64d64
4232aba72041b013571dc92e0d3fb7b4e2)
Compiler flags
                     : -Omax
 mory location : STACK
                     : 0xe714
[0]crcmatrix
                     : 0xlfd7
                    : 0x8e3a
: 0x33ff
0]crcstate
 orrect operation validated. See README.md for run and reporting rules.
 oreMark 1.0 : 81.216775 / Clang 12.0.0 (ssh://ds-gerrit/armcompiler/llvm-projec
 e64d644232aba72041b013571dc92e0d3fb7b4e2) -Omax / STACK
 oreMark 1.0: 4.060839 Coremark/Mhz
Round 1 Completed.
---- Round 2 : Cache disabled ----
nSTAR: CoreMark is running! ...
2K performance run parameters for coremark.
 oreMark Size
Total ticks : 17375

Fotal time (secs): 17.375000

Iterations/Sec : 63.309353
Iterations : 1100
Compiler version : Clang 12.0.0 (ssh://ds-gerrit/armcompiler/llvm-project e64d64423
Paba7204lb01357ldc92e0d3fb7b4e2)
Compiler flags : -Omax
Memory location : STACK
seedcrc
                     : 0xe714
[0]crcmatrix
                     : 0xlfd7
                    : 0x8e3a
: 0x33ff
01crcstate
 orrect operation validated. See README.md for run and reporting rules.
CoreMark 1.0 : 63.309353 / Clang 12.0.0 (ssh://ds-gerrit/armcompiler/llvm-project 6
64d644232aba7204lb01357ldc92e0d3fb7b4e2) -Omax / STACK
 oreMark 1.0: 3.165468 Coremark/Mhz
 ound 2 Completed.
```

## Note:

I-cache and D-cache are enabled in the SystemInit() function in system\_STAR.c.

Alternatively, you can use compiler command flags -D\_EN\_ICACHE="1" and -D\_EN\_DCACHE="1" to enable the caches in this project.

```
74 🗐 / *-----
 75 System initialization function *-----
    void SystemInit (void)
 78 ⊟ {
80 = #if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U)
81 SCB->VTOR = (uint32_t) &__VECTOR_TABLE;
 83
89 ##ifdef UNALIGNED SUPPORT DISABLE
        SCB->CCR |= SCB_CCR_UNALIGN_TRP_Msk;
     #endif
 91
 93 #if defined (_ARM_FEATURE_CMSE) && (_ARM_FEATURE_CMSE == 3U)
        TZ_SAU_Setup();
     #endif
 96
       SystemCoreClock = SYSTEM CLOCK;
99 #if defined _EN_ICACHE
100 if (SCB->CLIDR & SCB CLIDR IC Msk)
101 | SCB_EnableICache();
102 //else
100
102
         //_sys_exit("no ICache included");/*implement your __exit code to pass
105 = #if defined EN_DCACHE
106 if (SCB->CIIDR & SCB CLIDR IC Msk)
107 SCB_EnableDCache();
108 //else
          //_sys_exit("no DCache included");
     #endif
110
111
113 }
```

#### Note:

For demonstration, this example project disables I-cache/D-cache in the main() function in Round 2 by calling SCB\_DisableICache() and SCB\_DisableDCache(). However, it is strongly recommended that you enable/disable the caches when initializing the system before entering the main() function.

Based on this project, you can now start to use the caches and try more CMO functions in your STAR-based application software.