- Add RISCV64 ProcessorBind.h - Add RISCV64 to Makefiles Signed-off-by: Nikita Ermakov <sh1r4s3@mail.si-head.nl> Ack-by: Liming Gao <gaoliming@byosoft.com.cn> Acked-by: Abner Chang <abner.chang@hpe.com>
		
			
				
	
	
		
			86 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  Processor or Compiler specific defines and types for RISC-V.
 | 
						|
 | 
						|
  SPDX-License-Identifier: BSD-2-Clause-Patent
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#ifndef __PROCESSOR_BIND_H__
 | 
						|
#define __PROCESSOR_BIND_H__
 | 
						|
 | 
						|
//
 | 
						|
// Define the processor type so other code can make processor based choices
 | 
						|
//
 | 
						|
#define MDE_CPU_RISCV64
 | 
						|
 | 
						|
//
 | 
						|
// Make sure we are using the correct packing rules per EFI specification
 | 
						|
//
 | 
						|
#ifndef __GNUC__
 | 
						|
#pragma pack()
 | 
						|
#endif
 | 
						|
 | 
						|
//
 | 
						|
// Use ANSI C 2000 stdint.h integer width declarations
 | 
						|
//
 | 
						|
#include <stdint.h>
 | 
						|
typedef uint8_t   BOOLEAN;
 | 
						|
typedef int8_t    INT8;
 | 
						|
typedef uint8_t   UINT8;
 | 
						|
typedef int16_t   INT16;
 | 
						|
typedef uint16_t  UINT16;
 | 
						|
typedef int32_t   INT32;
 | 
						|
typedef uint32_t  UINT32;
 | 
						|
typedef int64_t   INT64;
 | 
						|
typedef uint64_t  UINT64;
 | 
						|
typedef char      CHAR8;
 | 
						|
typedef uint16_t  CHAR16;
 | 
						|
 | 
						|
//
 | 
						|
// Unsigned value of native width.  (4 bytes on supported 32-bit processor instructions,
 | 
						|
// 8 bytes on supported 64-bit processor instructions)
 | 
						|
//
 | 
						|
typedef UINT64  UINTN;
 | 
						|
 | 
						|
//
 | 
						|
// Signed value of native width.  (4 bytes on supported 32-bit processor instructions,
 | 
						|
// 8 bytes on supported 64-bit processor instructions)
 | 
						|
//
 | 
						|
typedef INT64   INTN;
 | 
						|
 | 
						|
//
 | 
						|
// Processor specific defines
 | 
						|
//
 | 
						|
 | 
						|
//
 | 
						|
// A value of native width with the highest bit set.
 | 
						|
//
 | 
						|
#define MAX_BIT      0x8000000000000000
 | 
						|
 | 
						|
//
 | 
						|
// A value of native width with the two highest bits set.
 | 
						|
//
 | 
						|
#define MAX_2_BITS   0xC000000000000000
 | 
						|
 | 
						|
//
 | 
						|
// The stack alignment required for RISC-V
 | 
						|
//
 | 
						|
#define CPU_STACK_ALIGNMENT  16
 | 
						|
 | 
						|
//
 | 
						|
// Modifier to ensure that all protocol member functions and EFI intrinsics
 | 
						|
// use the correct C calling convention. All protocol member functions and
 | 
						|
// EFI intrinsics are required to modify their member functions with EFIAPI.
 | 
						|
//
 | 
						|
#define EFIAPI
 | 
						|
 | 
						|
#if defined(__GNUC__)
 | 
						|
  //
 | 
						|
  // For GNU assembly code, .global or .globl can declare global symbols.
 | 
						|
  // Define this macro to unify the usage.
 | 
						|
  //
 | 
						|
  #define ASM_GLOBAL .globl
 | 
						|
#endif
 | 
						|
 | 
						|
#endif
 |