forked from rpms/kernel
		
	* Thu Aug 13 2020 Fedora Kernel Team <kernel-team@fedoraproject.org> [5.9.0-0.rc0.20200813gitdc06fe51d26e.1]
- dc06fe51d26e rebase
- More mismatches ("Justin M. Forbes")
- Fedora config change due to deps ("Justin M. Forbes")
- CONFIG_SND_SOC_MAX98390 is now selected by SND_SOC_INTEL_DA7219_MAX98357A_GENERIC ("Justin M. Forbes")
- Config change required for build part 2 ("Justin M. Forbes")
- Config change required for build ("Justin M. Forbes")
- Fedora config update ("Justin M. Forbes")
- Revert "Merge branch 'make_configs_fix' into 'os-build'" (Justin Forbes)
- redhat/configs/process_configs.sh: Remove *.config.orig files (Prarit Bhargava)
- redhat/configs/process_configs.sh: Add process_configs_known_broken flag (Prarit Bhargava)
- redhat/Makefile: Fix '*-configs' targets (Prarit Bhargava)
- Updated changelog for the release based on v5.8 (Fedora Kernel Team)
- Add ability to sync upstream through Makefile (Don Zickus)
- Add master merge check (Don Zickus)
- Replace hardcoded values 'os-build' and project id with variables (Don Zickus)
- gitattributes: Remove unnecesary export restrictions (Prarit Bhargava)
- redhat/Makefile.common: Fix MARKER (Prarit Bhargava)
Resolves: rhbz#
Signed-off-by: Justin M. Forbes <jforbes@fedoraproject.org>
		
	
			
		
			
				
	
	
		
			186 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | |
| From: Peter Jones <pjones@redhat.com>
 | |
| Date: Mon, 2 Oct 2017 18:22:13 -0400
 | |
| Subject: [PATCH] Add efi_status_to_str() and rework efi_status_to_err().
 | |
| 
 | |
| This adds efi_status_to_str() for use when printing efi_status_t
 | |
| messages, and reworks efi_status_to_err() so that the two use a common
 | |
| list of errors.
 | |
| 
 | |
| Upstream Status: RHEL only
 | |
| Signed-off-by: Peter Jones <pjones@redhat.com>
 | |
| ---
 | |
|  drivers/firmware/efi/efi.c | 124 +++++++++++++++++++++++++++----------
 | |
|  include/linux/efi.h        |   3 +
 | |
|  2 files changed, 96 insertions(+), 31 deletions(-)
 | |
| 
 | |
| diff --git a/drivers/firmware/efi/efi.c b/drivers/firmware/efi/efi.c
 | |
| index fdd1db025dbf..8ef7d1df09dd 100644
 | |
| --- a/drivers/firmware/efi/efi.c
 | |
| +++ b/drivers/firmware/efi/efi.c
 | |
| @@ -31,6 +31,7 @@
 | |
|  #include <linux/ucs2_string.h>
 | |
|  #include <linux/memblock.h>
 | |
|  #include <linux/security.h>
 | |
| +#include <linux/bsearch.h>
 | |
| 
 | |
|  #include <asm/early_ioremap.h>
 | |
| 
 | |
| @@ -831,40 +832,101 @@ int efi_mem_type(unsigned long phys_addr)
 | |
|  }
 | |
|  #endif
 | |
| 
 | |
| +struct efi_error_code {
 | |
| +	efi_status_t status;
 | |
| +	int errno;
 | |
| +	const char *description;
 | |
| +};
 | |
| +
 | |
| +static const struct efi_error_code efi_error_codes[] = {
 | |
| +	{ EFI_SUCCESS, 0, "Success"},
 | |
| +#if 0
 | |
| +	{ EFI_LOAD_ERROR, -EPICK_AN_ERRNO, "Load Error"},
 | |
| +#endif
 | |
| +	{ EFI_INVALID_PARAMETER, -EINVAL, "Invalid Parameter"},
 | |
| +	{ EFI_UNSUPPORTED, -ENOSYS, "Unsupported"},
 | |
| +	{ EFI_BAD_BUFFER_SIZE, -ENOSPC, "Bad Buffer Size"},
 | |
| +	{ EFI_BUFFER_TOO_SMALL, -ENOSPC, "Buffer Too Small"},
 | |
| +	{ EFI_NOT_READY, -EAGAIN, "Not Ready"},
 | |
| +	{ EFI_DEVICE_ERROR, -EIO, "Device Error"},
 | |
| +	{ EFI_WRITE_PROTECTED, -EROFS, "Write Protected"},
 | |
| +	{ EFI_OUT_OF_RESOURCES, -ENOMEM, "Out of Resources"},
 | |
| +#if 0
 | |
| +	{ EFI_VOLUME_CORRUPTED, -EPICK_AN_ERRNO, "Volume Corrupt"},
 | |
| +	{ EFI_VOLUME_FULL, -EPICK_AN_ERRNO, "Volume Full"},
 | |
| +	{ EFI_NO_MEDIA, -EPICK_AN_ERRNO, "No Media"},
 | |
| +	{ EFI_MEDIA_CHANGED, -EPICK_AN_ERRNO, "Media changed"},
 | |
| +#endif
 | |
| +	{ EFI_NOT_FOUND, -ENOENT, "Not Found"},
 | |
| +#if 0
 | |
| +	{ EFI_ACCESS_DENIED, -EPICK_AN_ERRNO, "Access Denied"},
 | |
| +	{ EFI_NO_RESPONSE, -EPICK_AN_ERRNO, "No Response"},
 | |
| +	{ EFI_NO_MAPPING, -EPICK_AN_ERRNO, "No mapping"},
 | |
| +	{ EFI_TIMEOUT, -EPICK_AN_ERRNO, "Time out"},
 | |
| +	{ EFI_NOT_STARTED, -EPICK_AN_ERRNO, "Not started"},
 | |
| +	{ EFI_ALREADY_STARTED, -EPICK_AN_ERRNO, "Already started"},
 | |
| +#endif
 | |
| +	{ EFI_ABORTED, -EINTR, "Aborted"},
 | |
| +#if 0
 | |
| +	{ EFI_ICMP_ERROR, -EPICK_AN_ERRNO, "ICMP Error"},
 | |
| +	{ EFI_TFTP_ERROR, -EPICK_AN_ERRNO, "TFTP Error"},
 | |
| +	{ EFI_PROTOCOL_ERROR, -EPICK_AN_ERRNO, "Protocol Error"},
 | |
| +	{ EFI_INCOMPATIBLE_VERSION, -EPICK_AN_ERRNO, "Incompatible Version"},
 | |
| +#endif
 | |
| +	{ EFI_SECURITY_VIOLATION, -EACCES, "Security Policy Violation"},
 | |
| +#if 0
 | |
| +	{ EFI_CRC_ERROR, -EPICK_AN_ERRNO, "CRC Error"},
 | |
| +	{ EFI_END_OF_MEDIA, -EPICK_AN_ERRNO, "End of Media"},
 | |
| +	{ EFI_END_OF_FILE, -EPICK_AN_ERRNO, "End of File"},
 | |
| +	{ EFI_INVALID_LANGUAGE, -EPICK_AN_ERRNO, "Invalid Languages"},
 | |
| +	{ EFI_COMPROMISED_DATA, -EPICK_AN_ERRNO, "Compromised Data"},
 | |
| +
 | |
| +	// warnings
 | |
| +	{ EFI_WARN_UNKOWN_GLYPH, -EPICK_AN_ERRNO, "Warning Unknown Glyph"},
 | |
| +	{ EFI_WARN_DELETE_FAILURE, -EPICK_AN_ERRNO, "Warning Delete Failure"},
 | |
| +	{ EFI_WARN_WRITE_FAILURE, -EPICK_AN_ERRNO, "Warning Write Failure"},
 | |
| +	{ EFI_WARN_BUFFER_TOO_SMALL, -EPICK_AN_ERRNO, "Warning Buffer Too Small"},
 | |
| +#endif
 | |
| +};
 | |
| +
 | |
| +static int
 | |
| +efi_status_cmp_bsearch(const void *key, const void *item)
 | |
| +{
 | |
| +	u64 status = (u64)(uintptr_t)key;
 | |
| +	struct efi_error_code *code = (struct efi_error_code *)item;
 | |
| +
 | |
| +	if (status < code->status)
 | |
| +		return -1;
 | |
| +	if (status > code->status)
 | |
| +		return 1;
 | |
| +	return 0;
 | |
| +}
 | |
| +
 | |
|  int efi_status_to_err(efi_status_t status)
 | |
|  {
 | |
| -	int err;
 | |
| -
 | |
| -	switch (status) {
 | |
| -	case EFI_SUCCESS:
 | |
| -		err = 0;
 | |
| -		break;
 | |
| -	case EFI_INVALID_PARAMETER:
 | |
| -		err = -EINVAL;
 | |
| -		break;
 | |
| -	case EFI_OUT_OF_RESOURCES:
 | |
| -		err = -ENOSPC;
 | |
| -		break;
 | |
| -	case EFI_DEVICE_ERROR:
 | |
| -		err = -EIO;
 | |
| -		break;
 | |
| -	case EFI_WRITE_PROTECTED:
 | |
| -		err = -EROFS;
 | |
| -		break;
 | |
| -	case EFI_SECURITY_VIOLATION:
 | |
| -		err = -EACCES;
 | |
| -		break;
 | |
| -	case EFI_NOT_FOUND:
 | |
| -		err = -ENOENT;
 | |
| -		break;
 | |
| -	case EFI_ABORTED:
 | |
| -		err = -EINTR;
 | |
| -		break;
 | |
| -	default:
 | |
| -		err = -EINVAL;
 | |
| -	}
 | |
| +	struct efi_error_code *found;
 | |
| +	size_t num = sizeof(efi_error_codes) / sizeof(struct efi_error_code);
 | |
| 
 | |
| -	return err;
 | |
| +	found = bsearch((void *)(uintptr_t)status, efi_error_codes,
 | |
| +			sizeof(struct efi_error_code), num,
 | |
| +			efi_status_cmp_bsearch);
 | |
| +	if (!found)
 | |
| +		return -EINVAL;
 | |
| +	return found->errno;
 | |
| +}
 | |
| +
 | |
| +const char *
 | |
| +efi_status_to_str(efi_status_t status)
 | |
| +{
 | |
| +	struct efi_error_code *found;
 | |
| +	size_t num = sizeof(efi_error_codes) / sizeof(struct efi_error_code);
 | |
| +
 | |
| +	found = bsearch((void *)(uintptr_t)status, efi_error_codes,
 | |
| +			sizeof(struct efi_error_code), num,
 | |
| +			efi_status_cmp_bsearch);
 | |
| +	if (!found)
 | |
| +		return "Unknown error code";
 | |
| +	return found->description;
 | |
|  }
 | |
| 
 | |
|  static DEFINE_SPINLOCK(efi_mem_reserve_persistent_lock);
 | |
| diff --git a/include/linux/efi.h b/include/linux/efi.h
 | |
| index 73db1ae04cef..92aa4697f558 100644
 | |
| --- a/include/linux/efi.h
 | |
| +++ b/include/linux/efi.h
 | |
| @@ -43,6 +43,8 @@
 | |
|  #define EFI_ABORTED		(21 | (1UL << (BITS_PER_LONG-1)))
 | |
|  #define EFI_SECURITY_VIOLATION	(26 | (1UL << (BITS_PER_LONG-1)))
 | |
| 
 | |
| +#define EFI_IS_ERROR(x)		((x) & (1UL << (BITS_PER_LONG-1)))
 | |
| +
 | |
|  typedef unsigned long efi_status_t;
 | |
|  typedef u8 efi_bool_t;
 | |
|  typedef u16 efi_char16_t;		/* UNICODE character */
 | |
| @@ -832,6 +834,7 @@ static inline bool efi_rt_services_supported(unsigned int mask)
 | |
|  #endif
 | |
| 
 | |
|  extern int efi_status_to_err(efi_status_t status);
 | |
| +extern const char *efi_status_to_str(efi_status_t status);
 | |
| 
 | |
|  /*
 | |
|   * Variable Attributes
 | |
| -- 
 | |
| 2.26.2
 | |
| 
 |