mirror of
				https://github.com/riscv-software-src/opensbi
				synced 2025-11-04 05:50:22 +00:00 
			
		
		
		
	These can be used by platform code to save the PLIC priority state, if it would otherwise be lost during non-retentive suspend. The platform is responsible for allocating all necessary storage. As a space optimization, store the saved priority values as 8-bit integers, since that is large enough to hold any priority value on the relevant platforms. Reviewed-by: Anup Patel <anup@brainfault.org> Signed-off-by: Samuel Holland <samuel@sholland.org>
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * SPDX-License-Identifier: BSD-2-Clause
 | 
						|
 *
 | 
						|
 * Copyright (c) 2019 Western Digital Corporation or its affiliates.
 | 
						|
 *
 | 
						|
 * Authors:
 | 
						|
 *   Anup Patel <anup.patel@wdc.com>
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef __IRQCHIP_PLIC_H__
 | 
						|
#define __IRQCHIP_PLIC_H__
 | 
						|
 | 
						|
#include <sbi/sbi_types.h>
 | 
						|
 | 
						|
struct plic_data {
 | 
						|
	unsigned long addr;
 | 
						|
	unsigned long num_src;
 | 
						|
};
 | 
						|
 | 
						|
/* So far, priorities on all consumers of these functions fit in 8 bits. */
 | 
						|
void plic_priority_save(const struct plic_data *plic, u8 *priority);
 | 
						|
 | 
						|
void plic_priority_restore(const struct plic_data *plic, const u8 *priority);
 | 
						|
 | 
						|
void plic_context_save(const struct plic_data *plic, int context_id,
 | 
						|
		       u32 *enable, u32 *threshold);
 | 
						|
 | 
						|
void plic_context_restore(const struct plic_data *plic, int context_id,
 | 
						|
			  const u32 *enable, u32 threshold);
 | 
						|
 | 
						|
int plic_context_init(const struct plic_data *plic, int context_id,
 | 
						|
		      bool enable, u32 threshold);
 | 
						|
 | 
						|
int plic_warm_irqchip_init(const struct plic_data *plic,
 | 
						|
			   int m_cntx_id, int s_cntx_id);
 | 
						|
 | 
						|
int plic_cold_irqchip_init(const struct plic_data *plic);
 | 
						|
 | 
						|
#endif
 |