mirror of
				https://git.proxmox.com/git/efi-boot-shim
				synced 2025-10-25 17:11:14 +00:00 
			
		
		
		
	 7bb0d6f71d
			
		
	
	
		7bb0d6f71d
		
	
	
	
	
		
			
			When we made lib build with the correct CFLAGS, it inherited -Werror=sign-compare, and I fixed up some parameters on console_print_box() and console_print_box_at() to avoid sign comparison errors. The fixups were *completely wrong*, as some behavior relies on negative values. So this fixes them in a completely different way, by casting appropriately to signed types where we're doing comparisons. Signed-off-by: Peter Jones <pjones@redhat.com>
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _SHIM_LIB_CONSOLE_H
 | |
| #define _SHIM_LIB_CONSOLE_H 1
 | |
| 
 | |
| EFI_STATUS
 | |
| console_get_keystroke(EFI_INPUT_KEY *key);
 | |
| void
 | |
| console_print_box_at(CHAR16 *str_arr[], int highlight,
 | |
| 		     int start_col, int start_row,
 | |
| 		     int size_cols, int size_rows,
 | |
| 		     int offset, int lines);
 | |
| void
 | |
| console_print_box(CHAR16 *str_arr[], int highlight);
 | |
| int
 | |
| console_yes_no(CHAR16 *str_arr[]);
 | |
| int
 | |
| console_select(CHAR16 *title[], CHAR16* selectors[], unsigned int start);
 | |
| void
 | |
| console_errorbox(CHAR16 *err);
 | |
| void
 | |
| console_error(CHAR16 *err, EFI_STATUS);
 | |
| void
 | |
| console_alertbox(CHAR16 **title);
 | |
| void
 | |
| console_notify(CHAR16 *string);
 | |
| void
 | |
| console_reset(void);
 | |
| #define NOSEL 0x7fffffff
 | |
| 
 | |
| #define EFI_CONSOLE_CONTROL_PROTOCOL_GUID \
 | |
|   { 0xf42f7782, 0x12e, 0x4c12, {0x99, 0x56, 0x49, 0xf9, 0x43, 0x4, 0xf7, 0x21} }
 | |
| 
 | |
| typedef struct _EFI_CONSOLE_CONTROL_PROTOCOL   EFI_CONSOLE_CONTROL_PROTOCOL;
 | |
| 
 | |
| typedef enum {
 | |
|   EfiConsoleControlScreenText,
 | |
|   EfiConsoleControlScreenGraphics,
 | |
|   EfiConsoleControlScreenMaxValue
 | |
| } EFI_CONSOLE_CONTROL_SCREEN_MODE;
 | |
| 
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *EFI_CONSOLE_CONTROL_PROTOCOL_GET_MODE) (
 | |
|   IN  EFI_CONSOLE_CONTROL_PROTOCOL      *This,
 | |
|   OUT EFI_CONSOLE_CONTROL_SCREEN_MODE   *Mode,
 | |
|   OUT BOOLEAN                           *GopUgaExists,  OPTIONAL  
 | |
|   OUT BOOLEAN                           *StdInLocked    OPTIONAL
 | |
|   );
 | |
| 
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *EFI_CONSOLE_CONTROL_PROTOCOL_SET_MODE) (
 | |
|   IN  EFI_CONSOLE_CONTROL_PROTOCOL      *This,
 | |
|   IN  EFI_CONSOLE_CONTROL_SCREEN_MODE   Mode
 | |
|   );
 | |
| 
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *EFI_CONSOLE_CONTROL_PROTOCOL_LOCK_STD_IN) (
 | |
|   IN  EFI_CONSOLE_CONTROL_PROTOCOL      *This,
 | |
|   IN CHAR16                             *Password
 | |
|   );
 | |
| 
 | |
| struct _EFI_CONSOLE_CONTROL_PROTOCOL {
 | |
|   EFI_CONSOLE_CONTROL_PROTOCOL_GET_MODE           GetMode;
 | |
|   EFI_CONSOLE_CONTROL_PROTOCOL_SET_MODE           SetMode;
 | |
|   EFI_CONSOLE_CONTROL_PROTOCOL_LOCK_STD_IN        LockStdIn;
 | |
| };
 | |
| 
 | |
| extern VOID setup_console (int text);
 | |
| extern VOID setup_verbosity(VOID);
 | |
| extern UINT8 verbose;
 | |
| #define dprint(fmt, ...) ({						\
 | |
| 		UINTN __dprint_ret = 0;					\
 | |
| 		if (verbose)						\
 | |
| 			__dprint_ret = Print((fmt), ##__VA_ARGS__);	\
 | |
| 		__dprint_ret;						\
 | |
| 	})
 | |
| #define dprinta(fmt, ...) ({									\
 | |
| 		UINTN __dprinta_ret = 0;							\
 | |
| 		if (verbose) {									\
 | |
| 			UINTN __dprinta_i;							\
 | |
| 			CHAR16 *__dprinta_str = AllocateZeroPool((strlena(fmt) + 1) * 2);	\
 | |
| 			for (__dprinta_i = 0; fmt[__dprinta_i] != '\0'; __dprinta_i++)		\
 | |
| 				__dprinta_str[__dprinta_i] = fmt[__dprinta_i];			\
 | |
| 			__dprinta_ret = Print((__dprinta_str), ##__VA_ARGS__);			\
 | |
| 			FreePool(__dprinta_str);						\
 | |
| 		}										\
 | |
| 		__dprinta_ret;									\
 | |
| 	})
 | |
| 
 | |
| #endif /* _SHIM_LIB_CONSOLE_H */
 |