mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-22 08:38:15 +01:00 
			
		
		
		
	Upgrade SCFW API to 1.16 Add more APIs: sc_misc_get_button_status sc_pm_reboot sc_seco_v2x_build_info Signed-off-by: Peng Fan <peng.fan@nxp.com>
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier:     GPL-2.0+ */
 | |
| /*
 | |
|  * Copyright 2018 NXP
 | |
|  */
 | |
| 
 | |
| #ifndef SC_RM_API_H
 | |
| #define SC_RM_API_H
 | |
| 
 | |
| #include <firmware/imx/sci/types.h>
 | |
| 
 | |
| /* Defines for type widths */
 | |
| #define SC_RM_PARTITION_W   5U      /* Width of sc_rm_pt_t */
 | |
| #define SC_RM_MEMREG_W      6U      /* Width of sc_rm_mr_t */
 | |
| #define SC_RM_DID_W         4U      /* Width of sc_rm_did_t */
 | |
| #define SC_RM_SID_W         6U      /* Width of sc_rm_sid_t */
 | |
| #define SC_RM_SPA_W         2U      /* Width of sc_rm_spa_t */
 | |
| #define SC_RM_PERM_W        3U      /* Width of sc_rm_perm_t */
 | |
| 
 | |
| /* Defines for ALL parameters */
 | |
| #define SC_RM_PT_ALL        ((sc_rm_pt_t)UINT8_MAX)   /* All partitions */
 | |
| #define SC_RM_MR_ALL        ((sc_rm_mr_t)UINT8_MAX)   /* All memory regions */
 | |
| 
 | |
| /* Defines for sc_rm_spa_t */
 | |
| #define SC_RM_SPA_PASSTHRU  0U   /* Pass through (attribute driven by master) */
 | |
| #define SC_RM_SPA_PASSSID   1U   /* Pass through and output on SID */
 | |
| #define SC_RM_SPA_ASSERT    2U   /* Assert (force to be secure/privileged) */
 | |
| #define SC_RM_SPA_NEGATE    3U   /* Negate (force to be non-secure/user) */
 | |
| 
 | |
| /* Defines for sc_rm_perm_t */
 | |
| #define SC_RM_PERM_NONE         0U /* No access */
 | |
| #define SC_RM_PERM_SEC_R        1U /* Secure RO */
 | |
| #define SC_RM_PERM_SECPRIV_RW   2U /* Secure privilege R/W */
 | |
| #define SC_RM_PERM_SEC_RW       3U /* Secure R/W */
 | |
| #define SC_RM_PERM_NSPRIV_R     4U /* Secure R/W, non-secure privilege RO */
 | |
| #define SC_RM_PERM_NS_R         5U /* Secure R/W, non-secure RO */
 | |
| #define SC_RM_PERM_NSPRIV_RW    6U /* Secure R/W, non-secure privilege R/W */
 | |
| #define SC_RM_PERM_FULL         7U /* Full access */
 | |
| 
 | |
| /* Types */
 | |
| 
 | |
| /*
 | |
|  * This type is used to declare a resource partition.
 | |
|  */
 | |
| typedef u8 sc_rm_pt_t;
 | |
| 
 | |
| /*
 | |
|  * This type is used to declare a memory region.
 | |
|  */
 | |
| typedef u8 sc_rm_mr_t;
 | |
| 
 | |
| /*
 | |
|  * This type is used to declare a resource domain ID used by the
 | |
|  * isolation HW.
 | |
|  */
 | |
| typedef u8 sc_rm_did_t;
 | |
| 
 | |
| /*
 | |
|  * This type is used to declare an SMMU StreamID.
 | |
|  */
 | |
| typedef u16 sc_rm_sid_t;
 | |
| 
 | |
| /*
 | |
|  * This type is a used to declare master transaction attributes.
 | |
|  */
 | |
| typedef u8 sc_rm_spa_t;
 | |
| 
 | |
| /*
 | |
|  * This type is used to declare a resource/memory region access permission.
 | |
|  * Refer to the XRDC2 Block Guide for more information.
 | |
|  */
 | |
| typedef u8 sc_rm_perm_t;
 | |
| 
 | |
| #endif /* SC_RM_API_H */
 |