



**User's Manual** 

www.Micrium.com

## Disclaimer

Specifications written in this manual are believed to be accurate, but are not guaranteed to be entirely free of error. Specifications in this manual may be changed for functional or performance improvements without notice. Please make sure your manual is the latest edition. While the information herein is assumed to be accurate, **Micriµm** assumes no responsibility for any errors or omissions and makes no warranties. **Micriµm** specifically disclaims any implied warranty of fitness for a particular purpose.

## **Copyright notice**

You may not extract portions of this manual or modify the PDF file in any way without the prior written permission of **Micrium**. The software described in this document is furnished under a license and may only be used or copied in accordance with the terms of such a license.

© 2004-2009 Micrium, Weston, Florida 33327-1848, U.S.A.

### **Trademarks**

Names mentioned in this manual may be trademarks of their respective companies. Brand and product names are trademarks or registered trademarks of their respective holders.

## Registration

Please register the software via email. This way we can make sure you will receive updates or notifications of updates as soon as they become available. For registration please provide the following information:

- Your full name and the name of your supervisor
- Your company name
- Your job title
- Your email address and telephone number
- Company name and address
- Your company's main phone number
- Your company's web site address
- Name and version of the product

Please send this information to: <a href="mailto:licensing@micrium.com">licensing@micrium.com</a>

## **Contact address**

## Micrium

949 Crestview Circle Weston, FL 33327-1848

U.S.A.

Phone : +1 954 217 2036 FAX : +1 954 217 2037 WEB : <u>www.micrium.com</u> Email : <u>support@micrium.com</u>

## **Manual versions**

If you find any errors in this document, please inform us and we will make the appropriate corrections for future releases.

| Manual Version | Date       | Ву  | Description           |
|----------------|------------|-----|-----------------------|
| V1.23          | 2009/06/22 | SR  | Created Manual        |
| V1.23          | 2009/07/05 | ITJ | Updated Manual        |
| V1.23          | 2009/07/13 | ITJ | Released Manual V1.23 |

# **Table Of Contents**

| I          | Introduction                            |     |
|------------|-----------------------------------------|-----|
| I.1        | Portable                                | 6   |
| I.2        | Scalable                                |     |
| I.3        | Coding Standards                        |     |
| I.4        | MISRA C                                 |     |
| I.5        | Safety Critical Certification           |     |
| I.6        | µC/CPU Limitations                      |     |
| 1          | Getting Started with µC/CPU             | ε   |
| 1.00       | Installing µC/CPU                       |     |
| 2          | uC/CDLL Processor/Compiler Port File(s) | 1.1 |
|            | μC/CPU Processor/Compiler Port File(s)  |     |
| 2.01       | Standard Data Types                     |     |
| 2.02.01    | CPU Word Sizes                          |     |
| 2.02.02    | CPU Word-Memory Order                   |     |
| 2.03       | CPU Stacks                              |     |
| 2.04       | CPU Critical Sections                   | 12  |
| 2.04.01    | CPU_SR_ALLOC()                          | 13  |
| 2.04.02.01 | CPU_CRITICAL_ENTER()                    |     |
| 2.04.02.02 | CPU_CRITICAL_EXIT()                     |     |
| 2.04.03.01 | CPU_INT_DIS()                           |     |
| 2.04.03.02 | CPU_INT_EN()                            |     |

| 3          | μC/CPU Library                           | 18 |
|------------|------------------------------------------|----|
| 3.00       | µC/CPU Configuration                     | 18 |
| 3.01       | CPU_Init()                               |    |
| 3.02.01    | CPU_NameClr()                            |    |
| 3.02.02    | CPU_NameSet()                            |    |
| 3.02.03    | CPU_NameGet()                            |    |
| 3.03       | CPU Timestamps                           |    |
| 3.03.01.01 | CPU_TS_Get()                             |    |
| 3.03.01.02 | CPU_TS_GetLo()                           |    |
| 3.03.02    | CPU_TS_Update()                          |    |
| 3.03.03.01 | CPU_TS_TmrInit()                         |    |
| 3.03.03.02 | CPU_TS_TmrRd()                           |    |
| 3.03.04    | CPU_TS_to_uSec()                         |    |
| 3.04       | CPU Interrupts Disable Time Measurements |    |
| 3.04.01    | CPU_IntDisMeasMaxGet()                   |    |
| 3.04.02    | CPU_IntDisMeasMaxCurGet()                | 32 |
| 3.04.03    | CPU_IntDisMeasMaxCurReset()              |    |
| 3.05       | CPU_CntLeadZeros()                       |    |
| Α          | μC/CPU Licensing Policy                  | 35 |

## Introduction

Designed with **Micriµm**'s renowned quality, scalability and reliability, the purpose of  $\mu$ C/CPU is to provide a clean, organized ANSI C implementation of each processor's/compiler's hardware-dependent.

#### I.1 Portable

 $\mu$ C/CPU was designed for the vast variety of embedded applications. The processor-dependent source code for  $\mu$ C/CPU is designed to be ported to any processor (CPU) and compiler while  $\mu$ C/CPU's core library source code is designed to be independent of and used with any processor/compiler.

## I.2 Scalable

The memory footprint of  $\mu C/CPU$  can be adjusted at compile time based on the features you need and the desired level of run-time performance.

## I.3 Coding Standards

Coding standards have been established early in the design of µC/CPU and include the following:

- C coding style
- Naming convention for #define constants, macros, variables and functions
- Commenting
- Directory structure

## I.4 MISRA C

The source code for  $\mu$ C/CPU follows the Motor Industry Software Reliability Association (MISRA) C Coding Standards. These standards were created by MISRA to improve the reliability and predictability of C programs in critical automotive systems. Members of the MISRA consortium include Delco Electronics, Ford Motor Company, Jaguar Cars Ltd., Lotus Engineering, Lucas Electronics, Rolls-Royce, Rover Group Ltd., and other firms and

universities dedicated to improving safety and reliability in automotive electronics. Full details of this standard can be obtained directly from the MISRA web site, <a href="http://www.misra.org.uk">http://www.misra.org.uk</a>.

## I.5 Safety Critical Certification

 $\mu$ C/CPU has been designed and implemented with safety critical certification in mind.  $\mu$ C/CPU is intended for use in any high-reliability, safety-critical systems including avionics RTCA DO-178B and EUROCAE ED-12B, medical FDA 510(k), IEC 61508 industrial control systems, and EN-50128 rail transportation and nuclear systems.

For example, the FAA (Federal Aviation Administration) requires that **ALL** the source code for an application be available in source form and conforming to specific software standards in order to be certified for avionics systems. Since most standard library functions are provided by compiler vendors in uncertifiable binary format, µC/CPU provides its library functions in certifiable source-code format.

If your product is **NOT** safety critical, you should view the software and safety-critical standards as proof that  $\mu C/CPU$  is a very robust and highly-reliable software module.

## I.6 µC/CPU Limitations

By design, we have limited some of the feature of µC/CPU. Table I-1 describes those limitations.

Support for 64-bit data **NOT** available for all CPUs

Table I-1, µC/CPU limitations for current software version

## **Chapter 1**

# Getting Started with µC/CPU

This chapter provides information on the distribution and installation of  $\mu C/CPU$ .

1.00 Installing µC/CPU

The distribution of  $\mu\text{C/CPU}$  is typically included in a ZIP file called: uC-CPU-Vxyy.zip.  $\mu\text{C/CPU}$  could also have been included in the distribution of another Micriµm ZIP file ( $\mu\text{C/OS-II}$ ,  $\mu\text{C/TCP-IP}$ ,  $\mu\text{C/FS}$ , etc.). The ZIP file contains all the source code and documentation for  $\mu\text{C/CPU}$ . All modules are placed in their respective directories as shown in Figure 1-1.



Figure 1-1, µC/CPU Module Directories and Files

\uC-CPU

This directory contains CPU-specific code which depends on the processor and compiler used by your application, as well as CPU-independent source files.

The main  $\mu$ C/CPU directory contains three master CPU files :

```
\MICRIUM\SOFTWARE\uC-CPU\cpu_def.h
\MICRIUM\SOFTWARE\uC-CPU\cpu_core.h
\MICRIUM\SOFTWARE\uC-CPU\cpu_core.c
```

### cpu\_def.h

This file declares #define constants used to configure processor/compiler-specific CPU word sizes, endianness word order, critical section methods, and other processor configuration.

```
cpu core.c and cpu core.h
```

These files contain source code that implements  $\mu C/CPU$  features such as host name allocation, timestamps, time measurements, and counting lead zeros. See Chapter 3 for more details.

```
\Cfg\Template\cpu cfg.h
```

This template file includes configuration for  $\mu$ C/CPU features such as host name allocation, timestamps, time measurements, and assembly optimization. Your application **MUST** include a cpu\_cfg.h configuration file with application-specific configuration settings.

```
\BSP\Template\cpu_bsp.c
```

This file includes function templates for the Board-Specific (BSP) code required if certain  $\mu$ C/CPU features such as timestamp time measurements and assembly optimization are enabled. Your application **MUST** include code for all BSP functions enabled in cpu\_cfg.h.

µC/CPU directory also contains additional sub-directories specific for each processor/compiler combination organized as follows:

```
\MICRIUM\SOFTWARE\uC-CPU\<CPU Type>\<Compiler>\cpu.h
\MICRIUM\SOFTWARE\uC-CPU\<CPU Type>\<Compiler>\cpu.c
\MICRIUM\SOFTWARE\uC-CPU\<CPU Type>\<Compiler>\cpu_a.asm
\cpu_a.s
```

#### cpu.h

This file contains  $\mu$ C/CPU configuration specific to the processor (CPU Type) and compiler (Compiler), such as data type definitions, processor address and data word sizes, endianness word order, and critical section macros. See Chapter 2 for more details.

```
cpu_a.asm or cpu_a.s
```

These (optional) files contains assembly code to enable/disable interrupts, implement critical section methods, and any other processor-specific code **NOT** already defined or implemented in the processor's cpu.h (or cpu.c).

#### cpu.c

This (optional) file contains C and/or assembly code to implement processor-specific code **NOT** already defined or implemented in the processor's cpu.h (or cpu\_a.asm).

```
\Template\cpu.h and cpu a.asm
```

These template  $\mu C/CPU$  configuration files include example configurations for a generic processor/compiler.

An example of ARM-specific CPU processor files is shown in Figure 1-2.



Figure 1-2, µC/CPU ARM CPU Directories and Files Example

## \Application

This directory represents the application's directory or directory tree. Application files which intend to make use of  $\mu C/CPU$  constants, macros, or functions should #include the desired  $\mu C/CPU$  header files.

## cpu\_cfg.h

This application-specific configuration file is required by  $\mu C/CPU$  to #define its configuration constants.

## **Chapter 2**

## µC/CPU Processor/Compiler Port File(s)

µC/CPU contains configuration specific to each processor and compiler, such as standard data type definitions, processor address and data word sizes, endianness word order, critical section macros, and possibly other functions and macros. These are defined in each specific processor/compiler subdirectory's cpu.h.

## 2.01 Standard Data Types

µC/CPU ports define standard data types such as CPU\_CHAR, CPU\_BOOLEAN, CPU\_INT08U, CPU\_INT16S, CPU\_FP32, etc. These data types are used in Micriµm applications, and may be used in your applications, to facilitate portability independent of and between processors/compilers. Most µC/CPU processor/compiler port files minimally support 32-bit data types, but MAY optionally support 64-bit (or greater) data types.

In addition, several regularly-used function pointer data types are defined.

## 2.02.01 CPU Word Sizes

µC/CPU ports include word size configuration such as CPU\_CFG\_ADDR\_SIZE and CPU\_CFG\_DATA\_SIZE, configured via CPU\_WORD\_SIZE\_08, CPU\_WORD\_SIZE\_16, and CPU\_WORD\_SIZE\_32.

In addition, the following CPU word sizes are also defined based on the configured sizes of CPU\_CFG\_ADDR\_SIZE and CPU\_CFG\_DATA\_SIZE: CPU\_ADDR, CPU\_DATA, CPU\_ALIGN, and CPU\_SIZE\_T.

## 2.02.02 CPU Word-Memory Order

µC/CPU ports configure CPU\_CFG\_ENDIAN\_TYPE to indicate the processor's word-memory order endianness. CPU\_ENDIAN\_TYPE\_LITTLE indicates that a CPU stores/reads data words in memory with the most significant octets at lower memory addresses (and the least significant octets at higher memory addresses) while a CPU\_ENDIAN\_TYPE\_BIG CPU stores/reads data words in memory with the most significant octets at higher memory addresses (and the least significant octets at lower memory addresses).

## 2.03 CPU Stacks

µC/CPU ports configure CPU\_CFG\_STK\_GROWTH to indicate the direction in memory a CPU updates its stack pointers after pushing data onto its stacks. CPU\_STK\_GROWTH\_HI\_TO\_LO indicates that a CPU decrements its stack pointers to the next lower memory address after data is pushed onto a CPU stack while a CPU\_STK\_GROWTH\_LO\_TO\_HI CPU increments its stack pointers to the next higher memory address after data is pushed.

In addition, each µC/CPU processor port defines a CPU\_STK data type to the CPU's stack word size.

### 2.04 CPU Critical Sections

µC/CPU ports include CPU critical section configuration CPU\_CFG\_CRITICAL\_METHOD that indicates how a CPU disables/re-enables interrupts when entering/exiting critical, protected sections:

CPU\_CRITICAL\_METHOD\_INT\_DIS\_EN merely disables/enables interrupts on critical section enter/exit. This is NOT a preferred method since it does NOT support multiple levels of interrupts. However, with some processors/compilers, this is the only available method.

CPU\_CRITICAL\_METHOD\_STATUS\_STK pushes/pops interrupt status onto stack before disabling/re-enabling interrupts. This is one preferred method since it supports multiple levels of interrupts. However, this method assumes that the compiler provides C-level &/or assembly-level functionality for pushing/saving the interrupt status onto a local stack, disabling interrupts, and popping/restoring the interrupt status from the local stack.

CPU\_CRITICAL\_METHOD\_STATUS\_LOCAL saves/restores interrupt status to a local variable before disabling/reenabling interrupts. This also is a preferred method since it supports multiple levels of interrupts. However, this method assumes that the compiler provides C-level &/or assembly-level functionality for saving the interrupt status to a local variable, disabling interrupts, and restoring the interrupt status from the local variable.

Each  $\mu$ C/CPU processor port implements critical section macros with calls to interrupt disable/enable macros. Applications should **ONLY** use the critical section macros (Section 2.04.02) since interrupt disable/enable macros (Section 2.04.03) are only intended for use by core  $\mu$ C/CPU functions.

Each µC/CPU processor port may define its interrupt disable/enable macros with inline-assembly directly in cpu.h, or calls to C functions defined in cpu.c, or calls to assembly subroutines defined in cpu\_a.asm (or cpu\_a.s). The specific implementation **SHOULD** be based on the processor port's configured CPU critical section method (see Section 2.04.03).

In addition, each µC/CPU processor port defines an appropriately-sized CPU\_SR data type large enough to completely store the processor's/compiler's status word. CPU\_CRITICAL\_METHOD\_STATUS\_LOCAL method requires each function that calls critical section macros or interrupt disable/enable macros to declare local variable cpu\_sr of type CPU\_SR, which SHOULD be declared via the CPU\_SR\_ALLOC() macro (see Section 2.04.01).

## 2.04.01 CPU\_SR\_ALLOC()

Allocates CPU status register word as local variable cpu\_sr, when necessary, for use with critical section macros.

## **Prototype**

```
CPU_SR_ALLOC();
```

## **Arguments**

None.

## **Returned Value**

None.

## **Notes / Warnings**

1) **CPU\_SR\_ALLOC() MUST** be called immediately after the last local variable declaration in a function.

## 2.04.02.01 CPU\_CRITICAL\_ENTER()

Enters critical sections, disabling interrupts.

## **Prototype**

```
CPU_CRITICAL_ENTER();
```

## **Arguments**

None.

#### **Returned Value**

None.

## **Notes / Warnings**

- 1) CPU\_CRITICAL\_ENTER()/CPU\_CRITICAL\_EXIT() SHOULD be used to protect critical sections of code from interrupted or concurrent access when no other protection mechanisms are available or appropriate. For example, system code that must be re-entrant but without use of a software lock should protect the code using CPU critical sections.
- 2) Since interrupts are disabled upon calling CPU\_CRITICAL\_ENTER() and are not re-enabled until after calling CPU\_CRITICAL\_EXIT(), interrupt and operating system context switching are postponed while all critical sections have not completely exited.
- 3) Critical sections can be nested any number of times as long as CPU\_CFG\_CRITICAL\_METHOD is NOT configured as CPU\_CRITICAL\_METHOD\_INT\_DIS\_EN, which would re-enable interrupts upon the first call to CPU\_CRITICAL\_EXIT(), not the last call.
- 4) CPU\_CRITICAL\_ENTER() SHOULD/MUST ALWAYS call CPU\_CRITICAL\_EXIT() once critical section protection is no longer needed.

## 2.04.02.02 CPU\_CRITICAL\_EXIT()

Exits critical sections, restoring previous interrupt status and/or enabling interrupts.

## **Prototype**

```
CPU_CRITICAL_EXIT();
```

## **Arguments**

None.

#### **Returned Value**

None.

## **Notes / Warnings**

- 1) CPU\_CRITICAL\_ENTER()/CPU\_CRITICAL\_EXIT() SHOULD be used to protect critical sections of code from interrupted or concurrent access when no other protection mechanisms are available or appropriate. For example, system code that must be re-entrant but without use of a software lock should protect the code using CPU critical sections.
- 2) Since interrupts are disabled upon calling CPU\_CRITICAL\_ENTER() and are not re-enabled until after calling CPU\_CRITICAL\_EXIT(), interrupt and operating system context switching are postponed while all critical sections have not completely exited.
- 3) Critical sections can be nested any number of times as long as CPU\_CFG\_CRITICAL\_METHOD is NOT configured as CPU\_CRITICAL\_METHOD\_INT\_DIS\_EN, which would re-enable interrupts upon the first call to CPU\_CRITICAL\_EXIT(), not the last call.
- 4) **CPU\_CRITICAL\_EXIT() MUST ALWAYS** call **CPU\_CRITICAL\_ENTER()** at the start of critical section protection.

## 2.04.03.01 CPU\_INT\_DIS()

Saves current interrupt status, if processor/compiler capable, & then disables interrupts.

## **Prototype**

```
CPU_INT_DIS();
```

## **Arguments**

None.

#### **Returned Value**

None.

## **Notes / Warnings**

1) CPU\_INT\_DIS() SHOULD be defined based on the processor port's configured CPU critical section method, CPU\_CFG\_CRITICAL\_METHOD; and may be defined with inline-assembly directly in cpu.h, or with calls to C functions defined in cpu.c, or calls to assembly subroutines defined in cpu\_a.sm (or cpu\_a.s). See also Section 2.04.

## **Example Templates**

The following example templates assume corresponding functions are defined in either cpu.c or cpu\_a.asm:

## 2.04.03.02 CPU\_INT\_EN()

Restores previous interrupt status and/or enables interrupts.

## **Prototype**

```
CPU_INT_EN();
```

## **Arguments**

None.

#### **Returned Value**

None.

## **Notes / Warnings**

1) CPU\_INT\_DIS() SHOULD be defined based on the processor port's configured CPU critical section method, CPU\_CFG\_CRITICAL\_METHOD; and may be defined with inline-assembly directly in cpu.h, or with calls to C functions defined in cpu.c, or calls to assembly subroutines defined in cpu\_a.sm (or cpu\_a.s). See also Section 2.04.

## **Example**

The following example templates assume corresponding functions are defined in either cpu.c or cpu\_a.asm:

# **Chapter 3**

# **µC/CPU** Library

µC/CPU contains library features such as host name allocation, timestamps, time measurements, counting lead zeros, etc. These functions are defined in cpu\_core.c.

## 3.00 µC/CPU Configuration

The following µC/CPU configurations may be optionally configured in cpu\_cfg.h:

| CPU_CFG_NAME_EN                | Includes code to set & get a configured CPU host name (see Section 3.02). This feature may be configured to either DEF_DISABLED or DEF_ENABLED.         |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU_CFG_NAME_SIZE              | Configures the maximum CPU name size (in number of ASCII characters, including the terminating <b>NULL</b> character).                                  |
| CPU_CFG_TS_EN                  | Includes CPU timestamp functionality (see Section 3.03). This feature may be configured to either DEF_DISABLED or DEF_ENABLED.                          |
| CPU_CFG_INT_DIS_MEAS_EN        | Includes code to measure & return maximum interrupts disabled time (see Section 3.04). This feature is enabled if the macro is #define'd in cpu_cfg.h.  |
| CPU_CFG_INT_DIS_MEAS_OVRHD_NBR | Configures the number of times to measure & calculate the interrupts disabled time measurement overhead.                                                |
| CPU_CFG_LEAD_ZEROS_ASM_PRESENT | Implements counting lead zeros functionality in assembly (see Section 3.05). This feature is enabled if the macro is #define'd in cpu_cfg.h (or cpu.h). |

## 3.01 **CPU\_Init()**

Initializes the core CPU module.

## **Prototype**

```
void CPU_Init (void);
```

## **Arguments**

None.

## **Returned Value**

None.

## **Notes / Warnings**

- 1) **MUST** be called prior to calling any other core CPU functions :
  - a) CPU host name
  - b) CPU timestamps
  - c) CPU interrupts disabled time measurements

Clears the CPU host name.

## **Prototype**

```
void CPU_NameClr (void);
```

## **Arguments**

None.

## **Returned Value**

None.

## **Notes / Warnings**

1) This function enabled **ONLY** if **CPU\_CFG\_NAME\_EN** is **DEF\_ENABLED** in **cpu\_cfg.h** (see Section 3.00).

```
CPU_NameClr(); /* Clear CPU host name. */
```

#### 3.02.02 CPU\_NameSet()

Sets the CPU host name.

## **Prototype**

```
void CPU_NameSet (CPU_CHAR
                            *p_name,
                  CPU_ERR
                            *p_err);
```

## **Arguments**

Pointer to CPU host name to set (see Note #2). p\_name

p\_err Pointer to variable that will receive the return error code from this function:

> CPU\_ERR\_NONE CPU host name successfully set. Argument p\_name passed a NULL pointer. CPU\_ERR\_NULL\_PTR

Invalid CPU host name size. CPU\_ERR\_NAME\_SIZE

#### **Returned Value**

None.

## **Notes / Warnings**

- 1) This function enabled **ONLY** if **CPU\_CFG\_NAME\_EN** is **DEF\_ENABLED** in **cpu\_cfg.h** (see Section 3.00).
- p\_name ASCII string size, including the terminating NULL character, MUST be less than or equal to 2) CPU\_CFG\_NAME\_SIZE.

```
CPU_CHAR *p_name;
CPU_ERR
           err;
p_name = "ARM Target";
CPU_NameSet(p_name, &err); /* Set CPU host name. */
if (err != CPU_ERR_NONE) {
   printf("COULD NOT SET CPU HOST NAME.");
```

## 3.02.03 **CPU\_NameGet()**

Gets the CPU host name.

## **Prototype**

## **Arguments**

p\_name Pointer to an ASCII character array that will receive the return CPU host name ASCII

string from this function (see Note #2).

p\_err Pointer to variable that will receive the return error code from this function:

CPU\_ERR\_NONE CPU host name successfully returned.
CPU\_ERR\_NULL\_PTR Argument p\_name passed a NULL pointer.

#### **Returned Value**

None.

## **Notes / Warnings**

- 1) This function enabled **ONLY** if **CPU\_CFG\_NAME\_EN** is **DEF\_ENABLED** in **cpu\_cfg.h** (see Section 3.00).
- 2) The size of the ASCII character array that will receive the return CPU host name ASCII string:
  - a) **MUST** be greater than or equal to the current CPU host name's ASCII string size including the terminating **NULL** character;
  - b) **SHOULD** be greater than or equal to **CPU\_CFG\_NAME\_SIZE**.

```
CPU_CHAR *p_name;
CPU_ERR err;

CPU_NameGet(p_name, &err); /* Get CPU host name. */

if (err == CPU_ERR_NONE) {
    printf("CPU Host Name = %s", p_name);
} else {
    printf("COULD NOT GET CPU HOST NAME.");
}
```

## 3.03 CPU Timestamps

CPU timestamps emulate a real-time 64-bit timer by accumulating timer counts via **CPU\_TS\_Update()** which must be called periodically by an application-/developer-defined function (see Section 3.03.02). An application can then get CPU timestamps and use either as raw timer counts or converted to microseconds (see Section 3.03.04).

Note that if either the CPU timestamp feature **OR** the interrupts disable time measurement feature is enabled (see Section 3.00), then the application/developer **MUST** provide CPU timestamp timer functions (see Sections 3.03.03).

## 3.03.01.01 CPU\_TS\_Get()

Gets current CPU timestamp.

## **Prototype**

## **Arguments**

p\_ts\_lo Pointer to timestamp variable that will receive the current CPU timestamp's lower half (in timestamp timer counts), if available.

p\_ts\_hi Pointer to timestamp variable that will receive the current CPU timestamp's higher half (in timestamp timer counts), if available.

#### **Returned Value**

None.

## **Notes / Warnings**

- 1) This function enabled **ONLY** if **CPU\_CFG\_TS\_EN** is **DEF\_ENABLED** in **cpu\_cfg.h** (see Section 3.00).
- 2) The amount of time measured by CPU timestamps is calculated by either of the following equations :
  - a) Time measured = Number timer counts \* Timer period

where

Number timer counts Number of timer counts measured

Timer period Timer's period in some units of (fractional) seconds

Time measured Amount of time measured, in same units of (fractional) seconds

as the Timer period

```
Number timer counts
b) Time measured = ------
Timer frequency
```

where

Number timer counts 
Number of timer counts measured

Timer frequency Timer's frequency in some units of counts per second

Time measured Amount of time measured, in seconds

```
CPU_TS ts_lo;
CPU_TS ts_hi;

CPU_TS_Get(&ts_lo, &ts_hi); /* Get current CPU timestamp. */
```

## 3.03.01.02 CPU\_TS\_GetLo()

Gets current CPU timestamp, lower-half only.

## **Prototype**

```
CPU_TS CPU_TS_GetLo (void);
```

## **Arguments**

None.

#### **Returned Value**

Current CPU timestamp's lower half (in timestamp timer counts).

## **Notes / Warnings**

- 1) This function enabled **ONLY** if **CPU\_CFG\_TS\_EN** is **DEF\_ENABLED** in **cpu\_cfg.h** (see Section 3.00).
- 2) The amount of time measured by CPU timestamps is calculated by either of the following equations :
  - a) Time measured = Number timer counts \* Timer period

where

Number timer counts Number of timer counts measured

Timer period Timer's period in some units of (fractional) seconds

Time measured Amount of time measured, in same units of (fractional) seconds

as the Timer period

Number timer counts

b) Time measured = -----Timer frequency

where

Number timer counts 
Number of timer counts measured

Timer frequency Timer's frequency in some units of counts per second

Time measured Amount of time measured, in seconds

```
CPU_TS ts_lo;
ts_lo = CPU_TS_GetLo(); /* Get current CPU timestamp. */
```

## 3.03.02 CPU\_TS\_Update()

Updates current CPU timestamp.

## **Prototype**

```
void CPU_TS_Update (void);
```

## **Arguments**

None.

## **Returned Value**

None.

## **Notes / Warnings**

- 1) This function enabled **ONLY** if **CPU\_CFG\_TS\_EN** is **DEF\_ENABLED** in **cpu\_cfg.h** (see Section 3.00).
- a) CPU timestamp **MUST** be updated periodically by some application (or BSP) time handler in order to (adequately) maintain the CPU timestamp time.
  - b) CPU timestamp **MUST** be updated more frequently than timestamp timer overflows; otherwise, CPU timestamp will lose time.

```
void AppPeriodicTimeHandler (void)
{
    :
          CPU_TS_Update();     /* Update current CPU timestamp (see Note #2). */
          :
}
```

Application-defined function to initialize and start the CPU timestamp's (hardware or software) timer.

## **Prototype**

```
CPU INT16U CPU TS TmrInit (void);
```

## **Arguments**

None.

#### **Returned Value**

Number of left-shifts to scale & return (hardware or software) timer as (32-bit) CPU\_TS data type (see Note #2a1), if necessary.

0 (see Note #2a2), otherwise.

## **Notes / Warnings**

- 1) **CPU\_TS\_TmrInit()** is an application/BSP function that **MUST** be defined by the developer if either of the following CPU features is enabled (see Section 3.00):
  - a) CPU timestamps
  - b) CPU interrupts disabled time measurements
- 2) a) Timer count values **MUST** be scaled & returned via (32-bit) **CPU\_TS** data type.
  - 1) If timer has less bits, left-shift timer values until the most significant bit of the timer value is shifted into the most significant bit of the return timestamp data type.
  - 2) If timer has more bits, truncate timer values' higher-order bits greater than the return timestamp data type.
  - b) Timer **SHOULD** be an 'up' counter whose values increase with each time count.
  - c) When applicable, timer period **SHOULD** be less than the typical measured time but **MUST** be less than the maximum measured time; otherwise, timer resolution inadequate to measure desired times.

### **Example Template**

Application-defined function to get current CPU timestamp timer count.

## **Prototype**

```
CPU TS CPU TS TmrRd (void);
```

## **Arguments**

None.

#### **Returned Value**

(32-bit) CPU timestamp timer count value (see Notes #2a & #2b).

#### **Notes / Warnings**

- 1) **CPU\_TS\_TmrRd()** is an application/BSP function that **MUST** be defined by the developer if either of the following CPU features is enabled (see Section 3.00):
  - a) CPU timestamps
  - b) CPU interrupts disabled time measurements
- 2) a) Timer count values **MUST** be scaled & returned via (32-bit) **CPU\_TS** data type.
  - 1) If timer has less bits, left-shift timer values until the most significant bit of the timer value is shifted into the most significant bit of the return timestamp data type.
  - 2) If timer has more bits, truncate timer values' higher-order bits greater than the return timestamp data type.
  - b) Timer **SHOULD** be an 'up' counter whose values increase with each time count.
  - c) When applicable, timer period **SHOULD** be less than the typical measured time but **MUST** be less than the maximum measured time; otherwise, timer resolution inadequate to measure desired times.

#### **Example Template**

Application-defined function to convert a CPU timestamp from timer counts to microseconds.

## **Prototype**

### **Arguments**

| ts_lo_cnts   | CPU timestamp lower half (in timestamp timer counts [see Note #2aA]).                                                           |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| ts_hi_cnts   | CPU timestamp upper half (in timestamp timer counts [see Note #2aA]).                                                           |  |  |  |
| p_ts_lo_usec | Pointer to variable that will receive the converted CPU timestamp's lower half [in microseconds (see Note #2aD)], if available. |  |  |  |
| p_ts_hi_usec | Pointer to variable that will receive the converted CPU timestamp's upper half [in microseconds (see Note #2aD)], if available. |  |  |  |

#### **Returned Value**

None.

## **Notes / Warnings**

- 1) **CPU\_TS\_to\_uSec()** is an application/BSP function that **MAY** be optionally defined by the developer when either of the following CPU features is enabled (see Section 3.00):
  - a) CPU timestamps
  - b) CPU interrupts disabled time measurements
- 2) a) The amount of time measured by CPU timestamps is calculated by either of the following equations:

A) Number timer counts
 B) Timer frequency
 C) Timer period
 D) Time measured
 Number of timer counts measured
 Timer's frequency in some units of counts per second
 Timer's period in some units of (fractional) seconds
 Amount of time measured, in microseconds

- b) Timer period **SHOULD** be less than the typical measured time but **MUST** be less than the maximum measured time; otherwise, timer resolution inadequate to measure desired times.
- c) Specific implementations may convert any number of CPU\_TS bits, up to 64, into microseconds.

## **Example Template**

## 3.04 CPU Interrupts Disable Time Measurements

time When enabled, the maximum amount of interrupts are disabled during calls to CPU\_CRITICAL\_ENTER()/CPU\_CRITICAL\_EXIT() is measured and saved. There are two maximum interrupts disable time measurements, one resetable and the other non-resetable, both measured in units of CPU timestamps (see Section 3.03).

Note that the interrupts disable time measurement feature requires that the application/developer provide CPU timestamp timer functions (see Sections 3.03.03).

## 3.04.01 CPU\_IntDisMeasMaxGet()

Gets (non-resetable) maximum interrupts disabled time.

## **Prototype**

```
CPU_TS CPU_IntDisMeasMaxGet (void);
```

## **Arguments**

None.

#### **Returned Value**

(Non-resetable) maximum interrupts disabled time (in CPU timestamp timer counts).

## **Notes / Warnings**

1) This function enabled **ONLY** if **CPU\_CFG\_INT\_DIS\_MEAS\_EN** is **#define**'d in **cpu\_cfg.h** (see Section 3.00).

```
CPU_TS time_max_cnts;

time_max_cnts = CPU_IntDisMeasMaxGet(); /* Get maximum interrupts disabled time. */
```

## 3.04.02 CPU\_IntDisMeasMaxCurGet()

Gets current/resetable maximum interrupts disabled time.

## **Prototype**

```
CPU_TS CPU_IntDisMeasMaxCurGet (void);
```

## **Arguments**

None.

#### **Returned Value**

Current maximum interrupts disabled time (in CPU timestamp timer counts).

## **Notes / Warnings**

1) This function enabled **ONLY** if **CPU\_CFG\_INT\_DIS\_MEAS\_EN** is **#define**'d in **cpu\_cfg.h** (see Section 3.00).

```
CPU_TS time_max_cnts;

time_max_cnts = CPU_IntDisMeasMaxCurGet(); /* Get current maximum interrupts disabled time. */
```

## 3.04.03 CPU\_IntDisMeasMaxCurReset()

Resets current maximum interrupts disabled time.

## **Prototype**

## **Arguments**

None.

#### **Returned Value**

Maximum interrupts disabled time (in CPU timestamp timer counts) before resetting.

## **Notes / Warnings**

1) This function enabled **ONLY** if **CPU\_CFG\_INT\_DIS\_MEAS\_EN** is **#define**'d in **cpu\_cfg.h** (see Section 3.00).

```
CPU_TS time_max_cnts;

time_max_cnts = CPU_IntDisMeasMaxCurReset(); /* Reset current maximum interrupts disabled time. */
```

## 3.05 CPU\_CntLeadZeros()

Counts the number of contiguous, most-significant, leading zero bits in a data value.

## **Prototype**

```
CPU_DATA CPU_CntLeadZeros (CPU_DATA val);
```

## **Arguments**

val

Data value to count leading zero bits.

## **Returned Value**

None.

## **Notes / Warnings**

1) This function implemented in cpu\_core.c if CPU\_CFG\_LEAD\_ZEROS\_ASM\_PRESENT is NOT #define'd in cpu\_cfg.h, and SHOULD be implemented in cpu\_a.asm (or cpu\_a.s) if CPU\_CFG\_LEAD\_ZEROS\_ASM\_PRESENT is #define'd in cpu\_cfg.h (see Section 3.00).

```
CPU_DATA val;
CPU_DATA nbr_lead_zeros;

val = 0x0643A718;
nbr_lead_zeros = CPU_CntLeadZeros(val);
```

# **Appendix A**

# **µC/CPU** Licensing Policy

You need to obtain an 'Object Code Distribution License' to embed  $\mu C/CPU$  in a product that is sold with the intent to make a profit. Each 'different' product (i.e. your product) requires its own license but, the license allows you to distribute an unlimited number of units for the life of your product. Please indicate the processor type(s) (i.e. ARM7, ARM9, MCF5272, MicroBlaze, Nios II, PPC,etc.) that you intend to use.

For licensing details, contact us at:

## Micriµm

949 Crestview Circle Weston, FL 33327-1848 U.S.A.

Phone : +1 954 217 2036 FAX : +1 954 217 2037

WEB: www.micrium.com
Email: licensing@micrium.com