Tom Rini | 83d290c | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
Nobuhiro Iwamatsu | 1d0e927 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 2 | /* |
Nobuhiro Iwamatsu | 9b7fa2f | 2014-03-28 11:07:39 +0900 | [diff] [blame] | 3 | * arch/arm/cpu/armv7/rmobile/cpu_info-rcar.c |
Nobuhiro Iwamatsu | 1d0e927 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 4 | * |
Nobuhiro Iwamatsu | 9b7fa2f | 2014-03-28 11:07:39 +0900 | [diff] [blame] | 5 | * Copyright (C) 2013,2014 Renesas Electronics Corporation |
Nobuhiro Iwamatsu | 1d0e927 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 6 | */ |
| 7 | #include <common.h> |
| 8 | #include <asm/io.h> |
| 9 | |
Marek Vasut | e965c89 | 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 |
Nobuhiro Iwamatsu | 1d0e927 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 13 | |
Marek Vasut | bd6debb | 2018-10-18 20:28:19 +0200 | [diff] [blame] | 14 | static u32 rmobile_get_prr(void) |
| 15 | { |
| 16 | #ifdef CONFIG_RCAR_GEN3 |
| 17 | return readl(0xFFF00044); |
| 18 | #else |
| 19 | return readl(0xFF000044); |
| 20 | #endif |
| 21 | } |
Marek Vasut | aff151e | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 22 | |
Nobuhiro Iwamatsu | 1d0e927 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 23 | u32 rmobile_get_cpu_type(void) |
| 24 | { |
Marek Vasut | aff151e | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 25 | return (rmobile_get_prr() & 0x00007F00) >> 8; |
Nobuhiro Iwamatsu | 1d0e927 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 26 | } |
| 27 | |
| 28 | u32 rmobile_get_cpu_rev_integer(void) |
| 29 | { |
Marek Vasut | aff151e | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 30 | const u32 prr = rmobile_get_prr(); |
Marek Vasut | e965c89 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 31 | |
| 32 | if ((prr & PRR_MASK) == R8A7796_REV_1_1) |
| 33 | return 1; |
| 34 | else |
| 35 | return ((prr & 0x000000F0) >> 4) + 1; |
Nobuhiro Iwamatsu | 1d0e927 | 2013-11-21 17:06:45 +0900 | [diff] [blame] | 36 | } |
Nobuhiro Iwamatsu | a028abe | 2014-03-28 11:15:59 +0900 | [diff] [blame] | 37 | |
| 38 | u32 rmobile_get_cpu_rev_fraction(void) |
| 39 | { |
Marek Vasut | aff151e | 2017-11-09 21:49:48 +0100 | [diff] [blame] | 40 | const u32 prr = rmobile_get_prr(); |
Marek Vasut | e965c89 | 2017-05-13 15:57:38 +0200 | [diff] [blame] | 41 | |
| 42 | if ((prr & PRR_MASK) == R8A7796_REV_1_1) |
| 43 | return 1; |
| 44 | else |
| 45 | return prr & 0x0000000F; |
Nobuhiro Iwamatsu | a028abe | 2014-03-28 11:15:59 +0900 | [diff] [blame] | 46 | } |