mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 14:01:50 +01:00 
			
		
		
		
	When U-Boot started using SPDX tags we were among the early adopters and there weren't a lot of other examples to borrow from. So we picked the area of the file that usually had a full license text and replaced it with an appropriate SPDX-License-Identifier: entry. Since then, the Linux Kernel has adopted SPDX tags and they place it as the very first line in a file (except where shebangs are used, then it's second line) and with slightly different comment styles than us. In part due to community overlap, in part due to better tag visibility and in part for other minor reasons, switch over to that style. This commit changes all instances where we have a single declared license in the tag as both the before and after are identical in tag contents. There's also a few places where I found we did not have a tag and have introduced one. Signed-off-by: Tom Rini <trini@konsulko.com>
		
			
				
	
	
		
			94 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0+
 | |
| /*
 | |
|  * MSMC controller utilities
 | |
|  *
 | |
|  * (C) Copyright 2012-2014
 | |
|  *     Texas Instruments Incorporated, <www.ti.com>
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <asm/arch/msmc.h>
 | |
| 
 | |
| struct mpax {
 | |
| 	u32	mpaxl;
 | |
| 	u32	mpaxh;
 | |
| };
 | |
| 
 | |
| struct msms_regs {
 | |
| 	u32	pid;
 | |
| 	u32	_res_04;
 | |
| 	u32	smcerrar;
 | |
| 	u32	smcerrxr;
 | |
| 	u32	smedcc;
 | |
| 	u32	smcea;
 | |
| 	u32	smsecc;
 | |
| 	u32	smpfar;
 | |
| 	u32	smpfxr;
 | |
| 	u32	smpfr;
 | |
| 	u32	smpfcr;
 | |
| 	u32	_res_2c;
 | |
| 	u32	sbndc[8];
 | |
| 	u32	sbndm;
 | |
| 	u32	sbnde;
 | |
| 	u32	_res_58;
 | |
| 	u32	cfglck;
 | |
| 	u32	cfgulck;
 | |
| 	u32	cfglckstat;
 | |
| 	u32	sms_mpax_lck;
 | |
| 	u32	sms_mpax_ulck;
 | |
| 	u32	sms_mpax_lckstat;
 | |
| 	u32	ses_mpax_lck;
 | |
| 	u32	ses_mpax_ulck;
 | |
| 	u32	ses_mpax_lckstat;
 | |
| 	u32	smestat;
 | |
| 	u32	smirstat;
 | |
| 	u32	smirc;
 | |
| 	u32	smiestat;
 | |
| 	u32	smiec;
 | |
| 	u32	_res_94_c0[12];
 | |
| 	u32	smncerrar;
 | |
| 	u32	smncerrxr;
 | |
| 	u32	smncea;
 | |
| 	u32	_res_d0_1fc[76];
 | |
| 	struct mpax sms[16][8];
 | |
| 	struct mpax ses[16][8];
 | |
| };
 | |
| 
 | |
| 
 | |
| void msmc_share_all_segments(int priv_id)
 | |
| {
 | |
| 	struct msms_regs *msmc = (struct msms_regs *)KS2_MSMC_CTRL_BASE;
 | |
| 	int j;
 | |
| 
 | |
| 	for (j = 0; j < 8; j++) {
 | |
| 		msmc->sms[priv_id][j].mpaxh &= 0xffffff7ful;
 | |
| 		msmc->ses[priv_id][j].mpaxh &= 0xffffff7ful;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| void msmc_map_ses_segment(int priv_id, int ses_pair,
 | |
| 			  u32 src_pfn, u32 dst_pfn, enum mpax_seg_size size)
 | |
| {
 | |
| 	struct msms_regs *msmc = (struct msms_regs *)KS2_MSMC_CTRL_BASE;
 | |
| 
 | |
| 	msmc->ses[priv_id][ses_pair].mpaxh = src_pfn << 12 |
 | |
| 					     (size & 0x1f) | 0x80;
 | |
| 	msmc->ses[priv_id][ses_pair].mpaxl = dst_pfn << 8 | 0x3f;
 | |
| }
 | |
| 
 | |
| void msmc_get_ses_mpax(int priv_id, int ses_pair, u32 *mpax)
 | |
| {
 | |
| 	struct msms_regs *msmc = (struct msms_regs *)KS2_MSMC_CTRL_BASE;
 | |
| 
 | |
| 	*mpax++ = msmc->ses[priv_id][ses_pair].mpaxl;
 | |
| 	*mpax = msmc->ses[priv_id][ses_pair].mpaxh;
 | |
| }
 | |
| 
 | |
| void msmc_set_ses_mpax(int priv_id, int ses_pair, u32 *mpax)
 | |
| {
 | |
| 	struct msms_regs *msmc = (struct msms_regs *)KS2_MSMC_CTRL_BASE;
 | |
| 
 | |
| 	msmc->ses[priv_id][ses_pair].mpaxl = *mpax++;
 | |
| 	msmc->ses[priv_id][ses_pair].mpaxh = *mpax;
 | |
| }
 |