mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	Add chip revision B support for STM32MP25, for displaying it in trace. Reviewed-by: Patrice Chotard <patrice.chotard@foss.st.com> Signed-off-by: Yann Gautier <yann.gautier@foss.st.com> Signed-off-by: Patrick Delaunay <patrick.delaunay@foss.st.com>
		
			
				
	
	
		
			197 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			197 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// SPDX-License-Identifier: GPL-2.0-or-later OR BSD-3-Clause
 | 
						|
/*
 | 
						|
 * Copyright (C) 2023, STMicroelectronics - All Rights Reserved
 | 
						|
 */
 | 
						|
 | 
						|
#define LOG_CATEGORY LOGC_ARCH
 | 
						|
 | 
						|
#include <log.h>
 | 
						|
#include <syscon.h>
 | 
						|
#include <asm/io.h>
 | 
						|
#include <asm/arch/stm32.h>
 | 
						|
#include <asm/arch/sys_proto.h>
 | 
						|
 | 
						|
/* SYSCFG register */
 | 
						|
#define SYSCFG_DEVICEID_OFFSET		0x6400
 | 
						|
#define SYSCFG_DEVICEID_DEV_ID_MASK	GENMASK(11, 0)
 | 
						|
#define SYSCFG_DEVICEID_DEV_ID_SHIFT	0
 | 
						|
#define SYSCFG_DEVICEID_REV_ID_MASK	GENMASK(31, 16)
 | 
						|
#define SYSCFG_DEVICEID_REV_ID_SHIFT	16
 | 
						|
 | 
						|
/* Device Part Number (RPN) = OTP9 */
 | 
						|
#define RPN_SHIFT	0
 | 
						|
#define RPN_MASK	GENMASK(31, 0)
 | 
						|
 | 
						|
/* Package = bit 0:2 of OTP122 => STM32MP25_PKG defines
 | 
						|
 * - 000: Custom package
 | 
						|
 * - 011: TFBGA361 => AL = 10x10, 361 balls pith 0.5mm
 | 
						|
 * - 100: TFBGA424 => AK = 14x14, 424 balls pith 0.5mm
 | 
						|
 * - 101: TFBGA436 => AI = 18x18, 436 balls pith 0.5mm
 | 
						|
 * - others: Reserved
 | 
						|
 */
 | 
						|
#define PKG_SHIFT	0
 | 
						|
#define PKG_MASK	GENMASK(2, 0)
 | 
						|
 | 
						|
static u32 read_deviceid(void)
 | 
						|
{
 | 
						|
	void *syscfg = syscon_get_first_range(STM32MP_SYSCON_SYSCFG);
 | 
						|
 | 
						|
	return readl(syscfg + SYSCFG_DEVICEID_OFFSET);
 | 
						|
}
 | 
						|
 | 
						|
u32 get_cpu_dev(void)
 | 
						|
{
 | 
						|
	return (read_deviceid() & SYSCFG_DEVICEID_DEV_ID_MASK) >> SYSCFG_DEVICEID_DEV_ID_SHIFT;
 | 
						|
}
 | 
						|
 | 
						|
u32 get_cpu_rev(void)
 | 
						|
{
 | 
						|
	return (read_deviceid() & SYSCFG_DEVICEID_REV_ID_MASK) >> SYSCFG_DEVICEID_REV_ID_SHIFT;
 | 
						|
}
 | 
						|
 | 
						|
/* Get Device Part Number (RPN) from OTP */
 | 
						|
u32 get_cpu_type(void)
 | 
						|
{
 | 
						|
	return get_otp(BSEC_OTP_RPN, RPN_SHIFT, RPN_MASK);
 | 
						|
}
 | 
						|
 | 
						|
/* Get Package options from OTP */
 | 
						|
u32 get_cpu_package(void)
 | 
						|
{
 | 
						|
	return get_otp(BSEC_OTP_PKG, PKG_SHIFT, PKG_MASK);
 | 
						|
}
 | 
						|
 | 
						|
int get_eth_nb(void)
 | 
						|
{
 | 
						|
	int nb_eth;
 | 
						|
 | 
						|
	switch (get_cpu_type()) {
 | 
						|
	case CPU_STM32MP257Fxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP257Dxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP257Cxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP257Axx:
 | 
						|
		nb_eth = 5; /* dual ETH with TSN support */
 | 
						|
		break;
 | 
						|
	case CPU_STM32MP253Fxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP253Dxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP253Cxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP253Axx:
 | 
						|
		nb_eth = 2; /* dual ETH */
 | 
						|
		break;
 | 
						|
	case CPU_STM32MP251Fxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP251Dxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP251Cxx:
 | 
						|
		fallthrough;
 | 
						|
	case CPU_STM32MP251Axx:
 | 
						|
		nb_eth = 1; /* single ETH */
 | 
						|
		break;
 | 
						|
	default:
 | 
						|
		nb_eth = 0;
 | 
						|
		break;
 | 
						|
	}
 | 
						|
 | 
						|
	return nb_eth;
 | 
						|
}
 | 
						|
 | 
						|
void get_soc_name(char name[SOC_NAME_SIZE])
 | 
						|
{
 | 
						|
	char *cpu_s, *cpu_r, *package;
 | 
						|
 | 
						|
	cpu_s = "????";
 | 
						|
	cpu_r = "?";
 | 
						|
	package = "??";
 | 
						|
	if (get_cpu_dev() == CPU_DEV_STM32MP25) {
 | 
						|
		switch (get_cpu_type()) {
 | 
						|
		case CPU_STM32MP257Fxx:
 | 
						|
			cpu_s = "257F";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP257Dxx:
 | 
						|
			cpu_s = "257D";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP257Cxx:
 | 
						|
			cpu_s = "257C";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP257Axx:
 | 
						|
			cpu_s = "257A";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP255Fxx:
 | 
						|
			cpu_s = "255F";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP255Dxx:
 | 
						|
			cpu_s = "255D";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP255Cxx:
 | 
						|
			cpu_s = "255C";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP255Axx:
 | 
						|
			cpu_s = "255A";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP253Fxx:
 | 
						|
			cpu_s = "253F";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP253Dxx:
 | 
						|
			cpu_s = "253D";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP253Cxx:
 | 
						|
			cpu_s = "253C";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP253Axx:
 | 
						|
			cpu_s = "253A";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP251Fxx:
 | 
						|
			cpu_s = "251F";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP251Dxx:
 | 
						|
			cpu_s = "251D";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP251Cxx:
 | 
						|
			cpu_s = "251C";
 | 
						|
			break;
 | 
						|
		case CPU_STM32MP251Axx:
 | 
						|
			cpu_s = "251A";
 | 
						|
			break;
 | 
						|
		default:
 | 
						|
			cpu_s = "25??";
 | 
						|
			break;
 | 
						|
		}
 | 
						|
		/* REVISION */
 | 
						|
		switch (get_cpu_rev()) {
 | 
						|
		case CPU_REV1:
 | 
						|
			cpu_r = "A";
 | 
						|
			break;
 | 
						|
		case CPU_REV2:
 | 
						|
			cpu_r = "B";
 | 
						|
			break;
 | 
						|
		default:
 | 
						|
			break;
 | 
						|
		}
 | 
						|
		/* PACKAGE */
 | 
						|
		switch (get_cpu_package()) {
 | 
						|
		case STM32MP25_PKG_CUSTOM:
 | 
						|
			package = "XX";
 | 
						|
			break;
 | 
						|
		case STM32MP25_PKG_AL_TBGA361:
 | 
						|
			package = "AL";
 | 
						|
			break;
 | 
						|
		case STM32MP25_PKG_AK_TBGA424:
 | 
						|
			package = "AK";
 | 
						|
			break;
 | 
						|
		case STM32MP25_PKG_AI_TBGA436:
 | 
						|
			package = "AI";
 | 
						|
			break;
 | 
						|
		default:
 | 
						|
			break;
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	snprintf(name, SOC_NAME_SIZE, "STM32MP%s%s Rev.%s", cpu_s, package, cpu_r);
 | 
						|
}
 |