52 lines
		
	
	
		
			985 B
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			985 B
		
	
	
	
		
			C
		
	
	
	
// SPDX-License-Identifier: GPL-2.0
 | 
						|
/*
 | 
						|
 * arch/arm/cpu/armv7/rmobile/cpu_info-rcar.c
 | 
						|
 *
 | 
						|
 * Copyright (C) 2013,2014 Renesas Electronics Corporation
 | 
						|
 */
 | 
						|
#include <common.h>
 | 
						|
#include <asm/io.h>
 | 
						|
 | 
						|
#define PRR_MASK		0x7fff
 | 
						|
#define R8A7796_REV_1_0		0x5200
 | 
						|
#define R8A7796_REV_1_1		0x5210
 | 
						|
#define R8A7796_REV_1_3		0x5211
 | 
						|
 | 
						|
static u32 rmobile_get_prr(void)
 | 
						|
{
 | 
						|
#ifdef CONFIG_RCAR_GEN3
 | 
						|
	return readl(0xFFF00044);
 | 
						|
#else
 | 
						|
	return readl(0xFF000044);
 | 
						|
#endif
 | 
						|
}
 | 
						|
 | 
						|
u32 rmobile_get_cpu_type(void)
 | 
						|
{
 | 
						|
	return (rmobile_get_prr() & 0x00007F00) >> 8;
 | 
						|
}
 | 
						|
 | 
						|
u32 rmobile_get_cpu_rev_integer(void)
 | 
						|
{
 | 
						|
	const u32 prr = rmobile_get_prr();
 | 
						|
	const u32 rev = prr & PRR_MASK;
 | 
						|
 | 
						|
	if (rev == R8A7796_REV_1_1 || rev == R8A7796_REV_1_3)
 | 
						|
		return 1;
 | 
						|
	else
 | 
						|
		return ((prr & 0x000000F0) >> 4) + 1;
 | 
						|
}
 | 
						|
 | 
						|
u32 rmobile_get_cpu_rev_fraction(void)
 | 
						|
{
 | 
						|
	const u32 prr = rmobile_get_prr();
 | 
						|
	const u32 rev = prr & PRR_MASK;
 | 
						|
 | 
						|
	if (rev == R8A7796_REV_1_1)
 | 
						|
		return 1;
 | 
						|
	else if (rev == R8A7796_REV_1_3)
 | 
						|
		return 3;
 | 
						|
	else
 | 
						|
		return prr & 0x0000000F;
 | 
						|
}
 |