Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
Nobuhiro Iwamatsu | c6ccb47 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 2 | /* |
Nobuhiro Iwamatsu | 091bc06 | 2014-03-28 11:07:39 +0900 | [diff] [blame] | 3 | * arch/arm/cpu/armv7/rmobile/cpu_info-rcar.c |
Nobuhiro Iwamatsu | c6ccb47 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 4 | * |
Nobuhiro Iwamatsu | 091bc06 | 2014-03-28 11:07:39 +0900 | [diff] [blame] | 5 | * Copyright (C) 2013,2014 Renesas Electronics Corporation |
Nobuhiro Iwamatsu | c6ccb47 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 6 | */ |
7 | #include <common.h> | ||||
8 | #include <asm/io.h> | ||||
9 | |||||
Marek Vasut | 14cdf95 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 10 | #define PRR_MASK 0x7fff |
11 | #define R8A7796_REV_1_0 0x5200 | ||||
12 | #define R8A7796_REV_1_1 0x5210 | ||||
Biju Das | 4e93dc9 | 2020-09-15 15:15:22 +0100 | [diff] [blame] | 13 | #define R8A7796_REV_1_3 0x5211 |
Nobuhiro Iwamatsu | c6ccb47 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 14 | |
Marek Vasut | e298526 | 2018-10-18 20:28:19 +0200 | [diff] [blame] | 15 | static u32 rmobile_get_prr(void) |
16 | { | ||||
Hai Pham | 9046b5f | 2023-02-28 22:22:03 +0100 | [diff] [blame] | 17 | if (IS_ENABLED(CONFIG_RCAR_64)) |
Marek Vasut | 43f5dc0 | 2023-02-28 07:27:51 +0100 | [diff] [blame] | 18 | return readl(0xFFF00044); |
19 | |||||
Marek Vasut | e298526 | 2018-10-18 20:28:19 +0200 | [diff] [blame] | 20 | return readl(0xFF000044); |
Marek Vasut | e298526 | 2018-10-18 20:28:19 +0200 | [diff] [blame] | 21 | } |
Marek Vasut | ab7899b | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 22 | |
Nobuhiro Iwamatsu | c6ccb47 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 23 | u32 rmobile_get_cpu_type(void) |
24 | { | ||||
Marek Vasut | ab7899b | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 25 | return (rmobile_get_prr() & 0x00007F00) >> 8; |
Nobuhiro Iwamatsu | c6ccb47 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 26 | } |
27 | |||||
28 | u32 rmobile_get_cpu_rev_integer(void) | ||||
29 | { | ||||
Marek Vasut | ab7899b | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 30 | const u32 prr = rmobile_get_prr(); |
Biju Das | 4e93dc9 | 2020-09-15 15:15:22 +0100 | [diff] [blame] | 31 | const u32 rev = prr & PRR_MASK; |
Marek Vasut | 14cdf95 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 32 | |
Biju Das | 4e93dc9 | 2020-09-15 15:15:22 +0100 | [diff] [blame] | 33 | if (rev == R8A7796_REV_1_1 || rev == R8A7796_REV_1_3) |
Marek Vasut | 14cdf95 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 34 | return 1; |
35 | else | ||||
36 | return ((prr & 0x000000F0) >> 4) + 1; | ||||
Nobuhiro Iwamatsu | c6ccb47 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 37 | } |
Nobuhiro Iwamatsu | 520d06d | 2014-03-28 11:15:59 +0900 | [diff] [blame] | 38 | |
39 | u32 rmobile_get_cpu_rev_fraction(void) | ||||
40 | { | ||||
Marek Vasut | ab7899b | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 41 | const u32 prr = rmobile_get_prr(); |
Biju Das | 4e93dc9 | 2020-09-15 15:15:22 +0100 | [diff] [blame] | 42 | const u32 rev = prr & PRR_MASK; |
Marek Vasut | 14cdf95 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 43 | |
Biju Das | 4e93dc9 | 2020-09-15 15:15:22 +0100 | [diff] [blame] | 44 | if (rev == R8A7796_REV_1_1) |
Marek Vasut | 14cdf95 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 45 | return 1; |
Biju Das | 4e93dc9 | 2020-09-15 15:15:22 +0100 | [diff] [blame] | 46 | else if (rev == R8A7796_REV_1_3) |
47 | return 3; | ||||
Marek Vasut | 14cdf95 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 48 | else |
49 | return prr & 0x0000000F; | ||||
Nobuhiro Iwamatsu | 520d06d | 2014-03-28 11:15:59 +0900 | [diff] [blame] | 50 | } |