Merge branch 'master' of git://git.denx.de/u-boot-sunxi
[oweals/u-boot.git] / arch / arm / include / asm / armv8 / cpu.h
1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * Copyright 2018 NXP
4  */
5
6 #define MIDR_PARTNUM_CORTEX_A35 0xD04
7 #define MIDR_PARTNUM_CORTEX_A53 0xD03
8 #define MIDR_PARTNUM_CORTEX_A72 0xD08
9 #define MIDR_PARTNUM_SHIFT      0x4
10 #define MIDR_PARTNUM_MASK       (0xFFF << 0x4)
11
12 static inline unsigned int read_midr(void)
13 {
14         unsigned long val;
15
16         asm volatile("mrs %0, midr_el1" : "=r" (val));
17
18         return val;
19 }
20
21 #define is_cortex_a35() (((read_midr() & MIDR_PARTNUM_MASK) >> \
22                          MIDR_PARTNUM_SHIFT) == MIDR_PARTNUM_CORTEX_A35)
23 #define is_cortex_a53() (((read_midr() & MIDR_PARTNUM_MASK) >> \
24                          MIDR_PARTNUM_SHIFT) == MIDR_PARTNUM_CORTEX_A53)
25 #define is_cortex_a72() (((read_midr() & MIDR_PARTNUM_MASK) >>\
26                          MIDR_PARTNUM_SHIFT) == MIDR_PARTNUM_CORTEX_A72)