Zephyr API Documentation  2.7.0-rc2
A Scalable Open Source RTOS
tpidrro_el0.h File Reference

tpidrro_el0 bits allocation More...

Go to the source code of this file.

Macros

#define TPIDRROEL0_IN_EL0   0x0000000000000001
 
#define TPIDRROEL0_CURR_CPU   0x0000fffffffffff8
 
#define TPIDRROEL0_EXC_DEPTH   0xff00000000000000
 
#define TPIDRROEL0_EXC_UNIT   0x0100000000000000
 
#define TPIDRROEL0_EXC_SHIFT   56
 

Detailed Description

tpidrro_el0 bits allocation

Among other things, the tpidrro_el0 holds the address for the current CPU's struct _cpu instance. But such a pointer is at least 8-bytes aligned, and the address space is 48 bits max. That leaves plenty of free bits for other purposes.

Macro Definition Documentation

◆ TPIDRROEL0_CURR_CPU

#define TPIDRROEL0_CURR_CPU   0x0000fffffffffff8

◆ TPIDRROEL0_EXC_DEPTH

#define TPIDRROEL0_EXC_DEPTH   0xff00000000000000

◆ TPIDRROEL0_EXC_SHIFT

#define TPIDRROEL0_EXC_SHIFT   56

◆ TPIDRROEL0_EXC_UNIT

#define TPIDRROEL0_EXC_UNIT   0x0100000000000000

◆ TPIDRROEL0_IN_EL0

#define TPIDRROEL0_IN_EL0   0x0000000000000001