45 lines
		
	
	
		
			943 B
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			45 lines
		
	
	
		
			943 B
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								#ifndef _RISCV_BITS_H
							 | 
						||
| 
								 | 
							
								#define _RISCV_BITS_H
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef __cplusplus
							 | 
						||
| 
								 | 
							
								extern "C" {
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define likely(x) __builtin_expect((x), 1)
							 | 
						||
| 
								 | 
							
								#define unlikely(x) __builtin_expect((x), 0)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define ROUNDUP(a, b) ((((a)-1)/(b)+1)*(b))
							 | 
						||
| 
								 | 
							
								#define ROUNDDOWN(a, b) ((a)/(b)*(b))
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define MAX(a, b) ((a) > (b) ? (a) : (b))
							 | 
						||
| 
								 | 
							
								#define MIN(a, b) ((a) < (b) ? (a) : (b))
							 | 
						||
| 
								 | 
							
								#define CLAMP(a, lo, hi) MIN(MAX(a, lo), hi)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define EXTRACT_FIELD(val, which) (((val) & (which)) / ((which) & ~((which)-1)))
							 | 
						||
| 
								 | 
							
								#define INSERT_FIELD(val, which, fieldval) (((val) & ~(which)) | ((fieldval) * ((which) & ~((which)-1))))
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define STR(x) XSTR(x)
							 | 
						||
| 
								 | 
							
								#define XSTR(x) #x
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef __riscv64
							 | 
						||
| 
								 | 
							
								# define SLL32    sllw
							 | 
						||
| 
								 | 
							
								# define STORE    sd
							 | 
						||
| 
								 | 
							
								# define LOAD     ld
							 | 
						||
| 
								 | 
							
								# define LWU      lwu
							 | 
						||
| 
								 | 
							
								# define LOG_REGBYTES 3
							 | 
						||
| 
								 | 
							
								#else
							 | 
						||
| 
								 | 
							
								# define SLL32    sll
							 | 
						||
| 
								 | 
							
								# define STORE    sw
							 | 
						||
| 
								 | 
							
								# define LOAD     lw
							 | 
						||
| 
								 | 
							
								# define LWU      lw
							 | 
						||
| 
								 | 
							
								# define LOG_REGBYTES 2
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								#define REGBYTES (1 << LOG_REGBYTES)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef __cplusplus
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif
							 |