|
|
a43681 |
From b6db7342f15a86f734445e83198dde024544e492 Mon Sep 17 00:00:00 2001
|
|
|
a43681 |
From: Peter Jones <pjones@redhat.com>
|
|
|
a43681 |
Date: Mon, 17 Jun 2019 14:25:21 -0400
|
|
|
a43681 |
Subject: [PATCH 30/63] Local header whitespace cleanup.
|
|
|
a43681 |
|
|
|
a43681 |
Signed-off-by: Peter Jones <pjones@redhat.com>
|
|
|
a43681 |
---
|
|
|
a43681 |
src/crc32.h | 2 +
|
|
|
a43681 |
src/disk.h | 4 +-
|
|
|
a43681 |
src/dp.h | 2 +
|
|
|
a43681 |
src/efiboot.h | 3 +-
|
|
|
a43681 |
src/efivar.h | 3 +-
|
|
|
a43681 |
src/efivar_endian.h | 2 +
|
|
|
a43681 |
src/fix_coverity.h | 28 ++-
|
|
|
a43681 |
src/generics.h | 2 +
|
|
|
a43681 |
src/gpt.h | 97 ++++----
|
|
|
a43681 |
src/guid.h | 20 +-
|
|
|
a43681 |
src/hexdump.h | 2 +
|
|
|
a43681 |
src/lib.h | 2 +
|
|
|
a43681 |
src/linux.h | 370 +++++++++++++++---------------
|
|
|
a43681 |
src/path-helpers.h | 37 +--
|
|
|
a43681 |
src/ucs2.h | 2 +
|
|
|
a43681 |
src/util.h | 532 ++++++++++++++++++++++----------------------
|
|
|
a43681 |
16 files changed, 572 insertions(+), 536 deletions(-)
|
|
|
a43681 |
|
|
|
a43681 |
diff --git a/src/crc32.h b/src/crc32.h
|
|
|
a43681 |
index 405d23c86ec..b5b975a5768 100644
|
|
|
a43681 |
--- a/src/crc32.h
|
|
|
a43681 |
+++ b/src/crc32.h
|
|
|
a43681 |
@@ -30,3 +30,5 @@
|
|
|
a43681 |
extern uint32_t crc32 (const void *buf, unsigned long len, uint32_t seed);
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* _CRC32_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/disk.h b/src/disk.h
|
|
|
a43681 |
index f0fa7f9f42d..8ba0f4602f4 100644
|
|
|
a43681 |
--- a/src/disk.h
|
|
|
a43681 |
+++ b/src/disk.h
|
|
|
a43681 |
@@ -24,6 +24,8 @@
|
|
|
a43681 |
extern bool HIDDEN is_partitioned(int fd);
|
|
|
a43681 |
|
|
|
a43681 |
extern HIDDEN ssize_t make_hd_dn(uint8_t *buf, ssize_t size, int fd,
|
|
|
a43681 |
- int32_t partition, uint32_t options);
|
|
|
a43681 |
+ int32_t partition, uint32_t options);
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* _EFIBOOT_DISK_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/dp.h b/src/dp.h
|
|
|
a43681 |
index 1f921d524aa..33a29db0d5d 100644
|
|
|
a43681 |
--- a/src/dp.h
|
|
|
a43681 |
+++ b/src/dp.h
|
|
|
a43681 |
@@ -187,3 +187,5 @@ extern ssize_t _format_bios_boot_dn(char *buf, size_t size, const_efidp dp);
|
|
|
a43681 |
format_helper_2(_format_bios_boot_dn, buf, size, off, dp)
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* _EFIVAR_INTERNAL_DP_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/efiboot.h b/src/efiboot.h
|
|
|
a43681 |
index f60f2cf5c2a..23275ed82bf 100644
|
|
|
a43681 |
--- a/src/efiboot.h
|
|
|
a43681 |
+++ b/src/efiboot.h
|
|
|
a43681 |
@@ -24,4 +24,5 @@
|
|
|
a43681 |
#include <efivar/efiboot.h>
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* !PRIVATE_EFIBOOT_H_ */
|
|
|
a43681 |
-// vim:fenc=utf-8:tw=75:et
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/efivar.h b/src/efivar.h
|
|
|
a43681 |
index ce6beb6850b..3d4b429631e 100644
|
|
|
a43681 |
--- a/src/efivar.h
|
|
|
a43681 |
+++ b/src/efivar.h
|
|
|
a43681 |
@@ -36,4 +36,5 @@
|
|
|
a43681 |
#include "path-helpers.h"
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* !PRIVATE_EFIVAR_H_ */
|
|
|
a43681 |
-// vim:fenc=utf-8:tw=75:et
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/efivar_endian.h b/src/efivar_endian.h
|
|
|
a43681 |
index b8e6a314838..bed4603ad71 100644
|
|
|
a43681 |
--- a/src/efivar_endian.h
|
|
|
a43681 |
+++ b/src/efivar_endian.h
|
|
|
a43681 |
@@ -51,3 +51,5 @@
|
|
|
a43681 |
#endif
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* _EFIVAR_ENDIAN_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/fix_coverity.h b/src/fix_coverity.h
|
|
|
a43681 |
index 95a5c9282c9..acb4cc65eff 100644
|
|
|
a43681 |
--- a/src/fix_coverity.h
|
|
|
a43681 |
+++ b/src/fix_coverity.h
|
|
|
a43681 |
@@ -22,8 +22,8 @@
|
|
|
a43681 |
*
|
|
|
a43681 |
* In glibc's headers, bits/floatn.h has:
|
|
|
a43681 |
*
|
|
|
a43681 |
- * #if (defined __x86_64__ \
|
|
|
a43681 |
- * ? __GNUC_PREREQ (4, 3) \
|
|
|
a43681 |
+ * #if (defined __x86_64__ \
|
|
|
a43681 |
+ * ? __GNUC_PREREQ (4, 3) \
|
|
|
a43681 |
* : (defined __GNU__ ? __GNUC_PREREQ (4, 5) : __GNUC_PREREQ (4, 4)))
|
|
|
a43681 |
* # define __HAVE_FLOAT128 1
|
|
|
a43681 |
* #else
|
|
|
a43681 |
@@ -35,24 +35,21 @@
|
|
|
a43681 |
* #if __HAVE_FLOAT128 && __GLIBC_USE (IEC_60559_TYPES_EXT)
|
|
|
a43681 |
* slash* Likewise for the '_Float128' format *slash
|
|
|
a43681 |
* extern _Float128 strtof128 (const char *__restrict __nptr,
|
|
|
a43681 |
- * char **__restrict __endptr)
|
|
|
a43681 |
- * __THROW __nonnull ((1));
|
|
|
a43681 |
+ * char **__restrict __endptr)
|
|
|
a43681 |
+ * __THROW __nonnull ((1));
|
|
|
a43681 |
* #endif
|
|
|
a43681 |
*
|
|
|
a43681 |
* Which then causes cov-emit to lose its shit:
|
|
|
a43681 |
*
|
|
|
a43681 |
- * "/usr/include/stdlib.h", line 133: error #20: identifier "_Float128" is
|
|
|
a43681 |
- * undefined
|
|
|
a43681 |
+ * "/usr/include/stdlib.h", line 133: error #20: identifier "_Float128" is undefined
|
|
|
a43681 |
* extern _Float128 strtof128 (const char *__restrict __nptr,
|
|
|
a43681 |
- * ^
|
|
|
a43681 |
- * "/usr/include/stdlib.h", line 190: error #20: identifier "_Float128" is
|
|
|
a43681 |
- * undefined
|
|
|
a43681 |
- * _Float128 __f)
|
|
|
a43681 |
- * ^
|
|
|
a43681 |
- * "/usr/include/stdlib.h", line 236: error #20: identifier "_Float128" is
|
|
|
a43681 |
- * undefined
|
|
|
a43681 |
+ * ^
|
|
|
a43681 |
+ * "/usr/include/stdlib.h", line 190: error #20: identifier "_Float128" is undefined
|
|
|
a43681 |
+ * _Float128 __f)
|
|
|
a43681 |
+ * ^
|
|
|
a43681 |
+ * "/usr/include/stdlib.h", line 236: error #20: identifier "_Float128" is undefined
|
|
|
a43681 |
* extern _Float128 strtof128_l (const char *__restrict __nptr,
|
|
|
a43681 |
- * ^
|
|
|
a43681 |
+ * ^
|
|
|
a43681 |
*
|
|
|
a43681 |
* And then you'll notice something like this later on:
|
|
|
a43681 |
* [WARNING] Emitted 0 C/C++ compilation units (0%) successfully
|
|
|
a43681 |
@@ -91,4 +88,5 @@ typedef _Complex float __cfloat128 __attribute__ ((__mode__ (__TC__)));
|
|
|
a43681 |
#endif
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* !FIX_COVERITY_H */
|
|
|
a43681 |
-// vim:fenc=utf-8:tw=75
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/generics.h b/src/generics.h
|
|
|
a43681 |
index 66be4bd76ab..8ade54ee96b 100644
|
|
|
a43681 |
--- a/src/generics.h
|
|
|
a43681 |
+++ b/src/generics.h
|
|
|
a43681 |
@@ -184,3 +184,5 @@ generic_append_variable(efi_guid_t guid, const char *name,
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* LIBEFIVAR_GENERIC_NEXT_VARIABLE_NAME_H */
|
|
|
a43681 |
#endif /* EFIVAR_BUILD_ENVIRONMENT */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/gpt.h b/src/gpt.h
|
|
|
a43681 |
index 0d7d5e8a649..66fbc21106c 100644
|
|
|
a43681 |
--- a/src/gpt.h
|
|
|
a43681 |
+++ b/src/gpt.h
|
|
|
a43681 |
@@ -38,27 +38,27 @@
|
|
|
a43681 |
#define GPT_HEADER_REVISION_V0_99 0x00009900
|
|
|
a43681 |
#define GPT_PRIMARY_PARTITION_TABLE_LBA 1
|
|
|
a43681 |
|
|
|
a43681 |
-#define PARTITION_SYSTEM_GUID \
|
|
|
a43681 |
- EFI_GUID(0xC12A7328, 0xF81F, 0x11d2, 0xBA4B, \
|
|
|
a43681 |
- 0x00, 0xA0, 0xC9, 0x3E, 0xC9, 0x3B)
|
|
|
a43681 |
-#define LEGACY_MBR_PARTITION_GUID \
|
|
|
a43681 |
- EFI_GUID(0x024DEE41, 0x33E7, 0x11d3, 0x9D69, \
|
|
|
a43681 |
- 0x00, 0x08, 0xC7, 0x81, 0xF3, 0x9F)
|
|
|
a43681 |
-#define PARTITION_MSFT_RESERVED_GUID \
|
|
|
a43681 |
- EFI_GUID(0xE3C9E316, 0x0B5C, 0x4DB8, 0x817D, \
|
|
|
a43681 |
- 0xF9, 0x2D, 0xF0, 0x02, 0x15, 0xAE)
|
|
|
a43681 |
-#define PARTITION_BASIC_DATA_GUID \
|
|
|
a43681 |
- EFI_GUID(0xEBD0A0A2, 0xB9E5, 0x4433, 0x87C0, \
|
|
|
a43681 |
- 0x68, 0xB6, 0xB7, 0x26, 0x99, 0xC7)
|
|
|
a43681 |
-#define PARTITION_LINUX_RAID_GUID \
|
|
|
a43681 |
- EFI_GUID(0xa19d880f, 0x05fc, 0x4d3b, 0xA006, \
|
|
|
a43681 |
- 0x74, 0x3f, 0x0f, 0x84, 0x91, 0x1e)
|
|
|
a43681 |
-#define PARTITION_LINUX_SWAP_GUID \
|
|
|
a43681 |
- EFI_GUID(0x0657fd6d, 0xa4ab, 0x43c4, 0x84E5, \
|
|
|
a43681 |
- 0x09, 0x33, 0xc8, 0x4b, 0x4f, 0x4f)
|
|
|
a43681 |
-#define PARTITION_LINUX_LVM_GUID \
|
|
|
a43681 |
- EFI_GUID(0xe6d6d379, 0xf507, 0x44c2, 0xa23c, \
|
|
|
a43681 |
- 0x23, 0x8f, 0x2a, 0x3d, 0xf9, 0x28)
|
|
|
a43681 |
+#define PARTITION_SYSTEM_GUID \
|
|
|
a43681 |
+ EFI_GUID(0xC12A7328, 0xF81F, 0x11d2, 0xBA4B, \
|
|
|
a43681 |
+ 0x00, 0xA0, 0xC9, 0x3E, 0xC9, 0x3B)
|
|
|
a43681 |
+#define LEGACY_MBR_PARTITION_GUID \
|
|
|
a43681 |
+ EFI_GUID(0x024DEE41, 0x33E7, 0x11d3, 0x9D69, \
|
|
|
a43681 |
+ 0x00, 0x08, 0xC7, 0x81, 0xF3, 0x9F)
|
|
|
a43681 |
+#define PARTITION_MSFT_RESERVED_GUID \
|
|
|
a43681 |
+ EFI_GUID(0xE3C9E316, 0x0B5C, 0x4DB8, 0x817D, \
|
|
|
a43681 |
+ 0xF9, 0x2D, 0xF0, 0x02, 0x15, 0xAE)
|
|
|
a43681 |
+#define PARTITION_BASIC_DATA_GUID \
|
|
|
a43681 |
+ EFI_GUID(0xEBD0A0A2, 0xB9E5, 0x4433, 0x87C0, \
|
|
|
a43681 |
+ 0x68, 0xB6, 0xB7, 0x26, 0x99, 0xC7)
|
|
|
a43681 |
+#define PARTITION_LINUX_RAID_GUID \
|
|
|
a43681 |
+ EFI_GUID(0xa19d880f, 0x05fc, 0x4d3b, 0xA006, \
|
|
|
a43681 |
+ 0x74, 0x3f, 0x0f, 0x84, 0x91, 0x1e)
|
|
|
a43681 |
+#define PARTITION_LINUX_SWAP_GUID \
|
|
|
a43681 |
+ EFI_GUID(0x0657fd6d, 0xa4ab, 0x43c4, 0x84E5, \
|
|
|
a43681 |
+ 0x09, 0x33, 0xc8, 0x4b, 0x4f, 0x4f)
|
|
|
a43681 |
+#define PARTITION_LINUX_LVM_GUID \
|
|
|
a43681 |
+ EFI_GUID(0xe6d6d379, 0xf507, 0x44c2, 0xa23c, \
|
|
|
a43681 |
+ 0x23, 0x8f, 0x2a, 0x3d, 0xf9, 0x28)
|
|
|
a43681 |
|
|
|
a43681 |
typedef struct _gpt_header {
|
|
|
a43681 |
uint64_t magic;
|
|
|
a43681 |
@@ -81,7 +81,7 @@ typedef struct _gpt_header {
|
|
|
a43681 |
typedef struct _gpt_entry_attributes {
|
|
|
a43681 |
uint64_t required_to_function:1;
|
|
|
a43681 |
uint64_t reserved:47;
|
|
|
a43681 |
- uint64_t type_guid_specific:16;
|
|
|
a43681 |
+ uint64_t type_guid_specific:16;
|
|
|
a43681 |
} PACKED gpt_entry_attributes;
|
|
|
a43681 |
|
|
|
a43681 |
typedef struct _gpt_entry {
|
|
|
a43681 |
@@ -103,25 +103,36 @@ typedef struct _gpt_entry {
|
|
|
a43681 |
* Number of actual partition entries should be calculated as:
|
|
|
a43681 |
*/
|
|
|
a43681 |
#define GPT_DEFAULT_RESERVED_PARTITION_ENTRIES \
|
|
|
a43681 |
- (GPT_DEFAULT_RESERVED_PARTITION_ENTRY_ARRAY_SIZE / \
|
|
|
a43681 |
- sizeof(gpt_entry))
|
|
|
a43681 |
+ (GPT_DEFAULT_RESERVED_PARTITION_ENTRY_ARRAY_SIZE / \
|
|
|
a43681 |
+ sizeof(gpt_entry))
|
|
|
a43681 |
|
|
|
a43681 |
typedef struct _partition_record {
|
|
|
a43681 |
- uint8_t boot_indicator; /* Not used by EFI firmware. Set to 0x80 to indicate that this
|
|
|
a43681 |
- is the bootable legacy partition. */
|
|
|
a43681 |
- uint8_t start_head; /* Start of partition in CHS address, not used by EFI firmware. */
|
|
|
a43681 |
- uint8_t start_sector; /* Start of partition in CHS address, not used by EFI firmware. */
|
|
|
a43681 |
- uint8_t start_track; /* Start of partition in CHS address, not used by EFI firmware. */
|
|
|
a43681 |
- uint8_t os_type; /* OS type. A value of 0xEF defines an EFI system partition.
|
|
|
a43681 |
- Other values are reserved for legacy operating systems, and
|
|
|
a43681 |
- allocated independently of the EFI specification. */
|
|
|
a43681 |
- uint8_t end_head; /* End of partition in CHS address, not used by EFI firmware. */
|
|
|
a43681 |
- uint8_t end_sector; /* End of partition in CHS address, not used by EFI firmware. */
|
|
|
a43681 |
- uint8_t end_track; /* End of partition in CHS address, not used by EFI firmware. */
|
|
|
a43681 |
- uint32_t starting_lba; /* Starting LBA address of the partition on the disk. Used by
|
|
|
a43681 |
- EFI firmware to define the start of the partition. */
|
|
|
a43681 |
- uint32_t size_in_lba; /* Size of partition in LBA. Used by EFI firmware to determine
|
|
|
a43681 |
- the size of the partition. */
|
|
|
a43681 |
+ uint8_t boot_indicator; /* Not used by EFI firmware. Set to 0x80 to
|
|
|
a43681 |
+ indicate that this is the bootable
|
|
|
a43681 |
+ legacy partition. */
|
|
|
a43681 |
+ uint8_t start_head; /* Start of partition in CHS address, not
|
|
|
a43681 |
+ used by EFI firmware. */
|
|
|
a43681 |
+ uint8_t start_sector; /* Start of partition in CHS address, not
|
|
|
a43681 |
+ used by EFI firmware. */
|
|
|
a43681 |
+ uint8_t start_track; /* Start of partition in CHS address, not
|
|
|
a43681 |
+ used by EFI firmware. */
|
|
|
a43681 |
+ uint8_t os_type; /* OS type. A value of 0xEF defines an EFI
|
|
|
a43681 |
+ system partition.
|
|
|
a43681 |
+ Other values are reserved for legacy
|
|
|
a43681 |
+ operating systems, and allocated
|
|
|
a43681 |
+ independently of the EFI specification. */
|
|
|
a43681 |
+ uint8_t end_head; /* End of partition in CHS address, not
|
|
|
a43681 |
+ used by EFI firmware. */
|
|
|
a43681 |
+ uint8_t end_sector; /* End of partition in CHS address, not
|
|
|
a43681 |
+ used by EFI firmware. */
|
|
|
a43681 |
+ uint8_t end_track; /* End of partition in CHS address, not
|
|
|
a43681 |
+ used by EFI firmware. */
|
|
|
a43681 |
+ uint32_t starting_lba; /* Starting LBA address of the partition on
|
|
|
a43681 |
+ the disk. Used by EFI firmware to define
|
|
|
a43681 |
+ the start of the partition. */
|
|
|
a43681 |
+ uint32_t size_in_lba; /* Size of partition in LBA. Used by EFI
|
|
|
a43681 |
+ firmware to determine the size of the
|
|
|
a43681 |
+ partition. */
|
|
|
a43681 |
} PACKED partition_record;
|
|
|
a43681 |
|
|
|
a43681 |
/*
|
|
|
a43681 |
@@ -141,8 +152,10 @@ typedef struct _legacy_mbr {
|
|
|
a43681 |
/* Functions */
|
|
|
a43681 |
extern int NONNULL(3, 4, 5, 6, 7) HIDDEN
|
|
|
a43681 |
gpt_disk_get_partition_info (int fd, uint32_t num, uint64_t *start,
|
|
|
a43681 |
- uint64_t *size, uint8_t *signature,
|
|
|
a43681 |
- uint8_t *mbr_type, uint8_t *signature_type,
|
|
|
a43681 |
- int ignore_pmbr_error, int logical_sector_size);
|
|
|
a43681 |
+ uint64_t *size, uint8_t *signature,
|
|
|
a43681 |
+ uint8_t *mbr_type, uint8_t *signature_type,
|
|
|
a43681 |
+ int ignore_pmbr_error, int logical_sector_size);
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* _EFIBOOT_GPT_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/guid.h b/src/guid.h
|
|
|
a43681 |
index d4a06f957a5..3229621a3f1 100644
|
|
|
a43681 |
--- a/src/guid.h
|
|
|
a43681 |
+++ b/src/guid.h
|
|
|
a43681 |
@@ -110,7 +110,7 @@ text_to_guid(const char *text, efi_guid_t *guid)
|
|
|
a43681 |
guid->a = cpu_to_le32(guid->a);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(fourbytes, text+9, 4);
|
|
|
a43681 |
if (check_segment_sanity(fourbytes, 4) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
@@ -118,7 +118,7 @@ text_to_guid(const char *text, efi_guid_t *guid)
|
|
|
a43681 |
guid->b = cpu_to_le16(guid->b);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(fourbytes, text+14, 4);
|
|
|
a43681 |
if (check_segment_sanity(fourbytes, 4) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
@@ -126,7 +126,7 @@ text_to_guid(const char *text, efi_guid_t *guid)
|
|
|
a43681 |
guid->c = cpu_to_le16(guid->c);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(fourbytes, text+19, 4);
|
|
|
a43681 |
if (check_segment_sanity(fourbytes, 4) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
@@ -134,42 +134,42 @@ text_to_guid(const char *text, efi_guid_t *guid)
|
|
|
a43681 |
guid->d = cpu_to_be16(guid->d);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(twobytes, text+24, 2);
|
|
|
a43681 |
if (check_segment_sanity(twobytes, 2) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
guid->e[0] = (uint8_t)strtoul(twobytes, NULL, 16);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(twobytes, text+26, 2);
|
|
|
a43681 |
if (check_segment_sanity(twobytes, 2) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
guid->e[1] = (uint8_t)strtoul(twobytes, NULL, 16);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(twobytes, text+28, 2);
|
|
|
a43681 |
if (check_segment_sanity(twobytes, 2) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
guid->e[2] = (uint8_t)strtoul(twobytes, NULL, 16);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(twobytes, text+30, 2);
|
|
|
a43681 |
if (check_segment_sanity(twobytes, 2) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
guid->e[3] = (uint8_t)strtoul(twobytes, NULL, 16);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(twobytes, text+32, 2);
|
|
|
a43681 |
if (check_segment_sanity(twobytes, 2) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
guid->e[4] = (uint8_t)strtoul(twobytes, NULL, 16);
|
|
|
a43681 |
|
|
|
a43681 |
/* 84be9c3e-8a32-42c0-891c-4cd3b072becc
|
|
|
a43681 |
- * ^ */
|
|
|
a43681 |
+ * ^ */
|
|
|
a43681 |
strncpy(twobytes, text+34, 2);
|
|
|
a43681 |
if (check_segment_sanity(twobytes, 2) < 0)
|
|
|
a43681 |
return -1;
|
|
|
a43681 |
@@ -185,3 +185,5 @@ struct guidname {
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* LIBEFIVAR_GUID */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/hexdump.h b/src/hexdump.h
|
|
|
a43681 |
index f8c32faa9e1..d88aa507b8d 100644
|
|
|
a43681 |
--- a/src/hexdump.h
|
|
|
a43681 |
+++ b/src/hexdump.h
|
|
|
a43681 |
@@ -114,3 +114,5 @@ hexdump(uint8_t *data, unsigned long size)
|
|
|
a43681 |
}
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* STATIC_HEXDUMP_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/lib.h b/src/lib.h
|
|
|
a43681 |
index 5024128c42c..3cc29a01fb4 100644
|
|
|
a43681 |
--- a/src/lib.h
|
|
|
a43681 |
+++ b/src/lib.h
|
|
|
a43681 |
@@ -51,3 +51,5 @@ extern struct efi_var_operations vars_ops;
|
|
|
a43681 |
extern struct efi_var_operations efivarfs_ops;
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* LIBEFIVAR_LIB_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/linux.h b/src/linux.h
|
|
|
a43681 |
index 43a9b7899f5..5ae64ffaacf 100644
|
|
|
a43681 |
--- a/src/linux.h
|
|
|
a43681 |
+++ b/src/linux.h
|
|
|
a43681 |
@@ -22,75 +22,75 @@
|
|
|
a43681 |
#define _EFIBOOT_LINUX_H
|
|
|
a43681 |
|
|
|
a43681 |
struct acpi_root_info {
|
|
|
a43681 |
- uint32_t acpi_hid;
|
|
|
a43681 |
- uint64_t acpi_uid;
|
|
|
a43681 |
- uint32_t acpi_cid;
|
|
|
a43681 |
- char *acpi_hid_str;
|
|
|
a43681 |
- char *acpi_uid_str;
|
|
|
a43681 |
- char *acpi_cid_str;
|
|
|
a43681 |
+ uint32_t acpi_hid;
|
|
|
a43681 |
+ uint64_t acpi_uid;
|
|
|
a43681 |
+ uint32_t acpi_cid;
|
|
|
a43681 |
+ char *acpi_hid_str;
|
|
|
a43681 |
+ char *acpi_uid_str;
|
|
|
a43681 |
+ char *acpi_cid_str;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct pci_root_info {
|
|
|
a43681 |
- uint16_t pci_domain;
|
|
|
a43681 |
- uint8_t pci_bus;
|
|
|
a43681 |
+ uint16_t pci_domain;
|
|
|
a43681 |
+ uint8_t pci_bus;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct pci_dev_info {
|
|
|
a43681 |
- uint16_t pci_domain;
|
|
|
a43681 |
- uint8_t pci_bus;
|
|
|
a43681 |
- uint8_t pci_device;
|
|
|
a43681 |
- uint8_t pci_function;
|
|
|
a43681 |
- char *driverlink;
|
|
|
a43681 |
+ uint16_t pci_domain;
|
|
|
a43681 |
+ uint8_t pci_bus;
|
|
|
a43681 |
+ uint8_t pci_device;
|
|
|
a43681 |
+ uint8_t pci_function;
|
|
|
a43681 |
+ char *driverlink;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct scsi_info {
|
|
|
a43681 |
- uint32_t scsi_bus;
|
|
|
a43681 |
- uint32_t scsi_device;
|
|
|
a43681 |
- uint32_t scsi_target;
|
|
|
a43681 |
- uint64_t scsi_lun;
|
|
|
a43681 |
+ uint32_t scsi_bus;
|
|
|
a43681 |
+ uint32_t scsi_device;
|
|
|
a43681 |
+ uint32_t scsi_target;
|
|
|
a43681 |
+ uint64_t scsi_lun;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct sas_info {
|
|
|
a43681 |
- uint32_t scsi_bus;
|
|
|
a43681 |
- uint32_t scsi_device;
|
|
|
a43681 |
- uint32_t scsi_target;
|
|
|
a43681 |
- uint64_t scsi_lun;
|
|
|
a43681 |
+ uint32_t scsi_bus;
|
|
|
a43681 |
+ uint32_t scsi_device;
|
|
|
a43681 |
+ uint32_t scsi_target;
|
|
|
a43681 |
+ uint64_t scsi_lun;
|
|
|
a43681 |
|
|
|
a43681 |
- uint64_t sas_address;
|
|
|
a43681 |
+ uint64_t sas_address;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct sata_info {
|
|
|
a43681 |
- uint32_t scsi_bus;
|
|
|
a43681 |
- uint32_t scsi_device;
|
|
|
a43681 |
- uint32_t scsi_target;
|
|
|
a43681 |
- uint64_t scsi_lun;
|
|
|
a43681 |
+ uint32_t scsi_bus;
|
|
|
a43681 |
+ uint32_t scsi_device;
|
|
|
a43681 |
+ uint32_t scsi_target;
|
|
|
a43681 |
+ uint64_t scsi_lun;
|
|
|
a43681 |
|
|
|
a43681 |
- uint32_t ata_devno;
|
|
|
a43681 |
- uint32_t ata_port;
|
|
|
a43681 |
- uint32_t ata_pmp;
|
|
|
a43681 |
+ uint32_t ata_devno;
|
|
|
a43681 |
+ uint32_t ata_port;
|
|
|
a43681 |
+ uint32_t ata_pmp;
|
|
|
a43681 |
|
|
|
a43681 |
- uint32_t ata_print_id;
|
|
|
a43681 |
+ uint32_t ata_print_id;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct ata_info {
|
|
|
a43681 |
- uint32_t scsi_bus;
|
|
|
a43681 |
- uint32_t scsi_device;
|
|
|
a43681 |
- uint32_t scsi_target;
|
|
|
a43681 |
- uint64_t scsi_lun;
|
|
|
a43681 |
+ uint32_t scsi_bus;
|
|
|
a43681 |
+ uint32_t scsi_device;
|
|
|
a43681 |
+ uint32_t scsi_target;
|
|
|
a43681 |
+ uint64_t scsi_lun;
|
|
|
a43681 |
|
|
|
a43681 |
- uint32_t scsi_host;
|
|
|
a43681 |
+ uint32_t scsi_host;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct nvme_info {
|
|
|
a43681 |
- int32_t ctrl_id;
|
|
|
a43681 |
- int32_t ns_id;
|
|
|
a43681 |
- int has_eui;
|
|
|
a43681 |
- uint8_t eui[8];
|
|
|
a43681 |
+ int32_t ctrl_id;
|
|
|
a43681 |
+ int32_t ns_id;
|
|
|
a43681 |
+ int has_eui;
|
|
|
a43681 |
+ uint8_t eui[8];
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct nvdimm_info {
|
|
|
a43681 |
- efi_guid_t namespace_label;
|
|
|
a43681 |
- efi_guid_t nvdimm_label;
|
|
|
a43681 |
+ efi_guid_t namespace_label;
|
|
|
a43681 |
+ efi_guid_t nvdimm_label;
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct emmc_info {
|
|
|
a43681 |
@@ -98,58 +98,58 @@ struct emmc_info {
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
enum interface_type {
|
|
|
a43681 |
- unknown,
|
|
|
a43681 |
- isa, acpi_root, pci_root, soc_root, pci, network,
|
|
|
a43681 |
- ata, atapi, scsi, sata, sas,
|
|
|
a43681 |
- usb, i1394, fibre, i2o,
|
|
|
a43681 |
- md, virtblk,
|
|
|
a43681 |
- nvme, nd_pmem,
|
|
|
a43681 |
- emmc,
|
|
|
a43681 |
+ unknown,
|
|
|
a43681 |
+ isa, acpi_root, pci_root, soc_root, pci, network,
|
|
|
a43681 |
+ ata, atapi, scsi, sata, sas,
|
|
|
a43681 |
+ usb, i1394, fibre, i2o,
|
|
|
a43681 |
+ md, virtblk,
|
|
|
a43681 |
+ nvme, nd_pmem,
|
|
|
a43681 |
+ emmc,
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
struct dev_probe;
|
|
|
a43681 |
|
|
|
a43681 |
struct device {
|
|
|
a43681 |
- enum interface_type interface_type;
|
|
|
a43681 |
- uint32_t flags;
|
|
|
a43681 |
- char *link;
|
|
|
a43681 |
- char *device;
|
|
|
a43681 |
- char *driver;
|
|
|
a43681 |
-
|
|
|
a43681 |
- struct dev_probe **probes;
|
|
|
a43681 |
- unsigned int n_probes;
|
|
|
a43681 |
-
|
|
|
a43681 |
- union {
|
|
|
a43681 |
- struct {
|
|
|
a43681 |
- struct stat stat;
|
|
|
a43681 |
-
|
|
|
a43681 |
- unsigned int controllernum;
|
|
|
a43681 |
- unsigned int disknum;
|
|
|
a43681 |
- int part;
|
|
|
a43681 |
- uint64_t major;
|
|
|
a43681 |
- uint32_t minor;
|
|
|
a43681 |
- uint32_t edd10_devicenum;
|
|
|
a43681 |
-
|
|
|
a43681 |
- char *disk_name;
|
|
|
a43681 |
- char *part_name;
|
|
|
a43681 |
-
|
|
|
a43681 |
- struct acpi_root_info acpi_root;
|
|
|
a43681 |
- struct pci_root_info pci_root;
|
|
|
a43681 |
- unsigned int n_pci_devs;
|
|
|
a43681 |
- struct pci_dev_info *pci_dev;
|
|
|
a43681 |
-
|
|
|
a43681 |
- union {
|
|
|
a43681 |
- struct scsi_info scsi_info;
|
|
|
a43681 |
- struct sas_info sas_info;
|
|
|
a43681 |
- struct sata_info sata_info;
|
|
|
a43681 |
- struct ata_info ata_info;
|
|
|
a43681 |
- struct nvme_info nvme_info;
|
|
|
a43681 |
- struct emmc_info emmc_info;
|
|
|
a43681 |
- struct nvdimm_info nvdimm_info;
|
|
|
a43681 |
- };
|
|
|
a43681 |
- };
|
|
|
a43681 |
- char *ifname;
|
|
|
a43681 |
- };
|
|
|
a43681 |
+ enum interface_type interface_type;
|
|
|
a43681 |
+ uint32_t flags;
|
|
|
a43681 |
+ char *link;
|
|
|
a43681 |
+ char *device;
|
|
|
a43681 |
+ char *driver;
|
|
|
a43681 |
+
|
|
|
a43681 |
+ struct dev_probe **probes;
|
|
|
a43681 |
+ unsigned int n_probes;
|
|
|
a43681 |
+
|
|
|
a43681 |
+ union {
|
|
|
a43681 |
+ struct {
|
|
|
a43681 |
+ struct stat stat;
|
|
|
a43681 |
+
|
|
|
a43681 |
+ unsigned int controllernum;
|
|
|
a43681 |
+ unsigned int disknum;
|
|
|
a43681 |
+ int part;
|
|
|
a43681 |
+ uint64_t major;
|
|
|
a43681 |
+ uint32_t minor;
|
|
|
a43681 |
+ uint32_t edd10_devicenum;
|
|
|
a43681 |
+
|
|
|
a43681 |
+ char *disk_name;
|
|
|
a43681 |
+ char *part_name;
|
|
|
a43681 |
+
|
|
|
a43681 |
+ struct acpi_root_info acpi_root;
|
|
|
a43681 |
+ struct pci_root_info pci_root;
|
|
|
a43681 |
+ unsigned int n_pci_devs;
|
|
|
a43681 |
+ struct pci_dev_info *pci_dev;
|
|
|
a43681 |
+
|
|
|
a43681 |
+ union {
|
|
|
a43681 |
+ struct scsi_info scsi_info;
|
|
|
a43681 |
+ struct sas_info sas_info;
|
|
|
a43681 |
+ struct sata_info sata_info;
|
|
|
a43681 |
+ struct ata_info ata_info;
|
|
|
a43681 |
+ struct nvme_info nvme_info;
|
|
|
a43681 |
+ struct emmc_info emmc_info;
|
|
|
a43681 |
+ struct nvdimm_info nvdimm_info;
|
|
|
a43681 |
+ };
|
|
|
a43681 |
+ };
|
|
|
a43681 |
+ char *ifname;
|
|
|
a43681 |
+ };
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
extern struct device HIDDEN *device_get(int fd, int partition);
|
|
|
a43681 |
@@ -160,117 +160,117 @@ extern int HIDDEN set_part_name(struct device *dev, const char * const fmt, ...)
|
|
|
a43681 |
extern int HIDDEN set_disk_name(struct device *dev, const char * const fmt, ...);
|
|
|
a43681 |
extern bool HIDDEN is_pata(struct device *dev);
|
|
|
a43681 |
extern int HIDDEN make_blockdev_path(uint8_t *buf, ssize_t size,
|
|
|
a43681 |
- struct device *dev);
|
|
|
a43681 |
+ struct device *dev);
|
|
|
a43681 |
extern int HIDDEN parse_acpi_hid_uid(struct device *dev, const char *fmt, ...);
|
|
|
a43681 |
extern int HIDDEN eb_nvme_ns_id(int fd, uint32_t *ns_id);
|
|
|
a43681 |
|
|
|
a43681 |
int HIDDEN get_sector_size(int filedes);
|
|
|
a43681 |
|
|
|
a43681 |
extern int HIDDEN find_parent_devpath(const char * const child,
|
|
|
a43681 |
- char **parent);
|
|
|
a43681 |
+ char **parent);
|
|
|
a43681 |
|
|
|
a43681 |
extern ssize_t HIDDEN make_mac_path(uint8_t *buf, ssize_t size,
|
|
|
a43681 |
- const char * const ifname);
|
|
|
a43681 |
-
|
|
|
a43681 |
-#define read_sysfs_file(buf, fmt, args...) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- uint8_t *buf_ = NULL; \
|
|
|
a43681 |
- ssize_t bufsize_ = -1; \
|
|
|
a43681 |
- int error_; \
|
|
|
a43681 |
- \
|
|
|
a43681 |
- bufsize_ = get_file(&buf_, "/sys/" fmt, ## args); \
|
|
|
a43681 |
- if (bufsize_ > 0) { \
|
|
|
a43681 |
- uint8_t *buf2_ = alloca(bufsize_); \
|
|
|
a43681 |
- error_ = errno; \
|
|
|
a43681 |
- if (buf2_) \
|
|
|
a43681 |
- memcpy(buf2_, buf_, bufsize_); \
|
|
|
a43681 |
- free(buf_); \
|
|
|
a43681 |
- *(buf) = (__typeof__(*(buf)))buf2_; \
|
|
|
a43681 |
- errno = error_; \
|
|
|
a43681 |
- } else if (buf_) { \
|
|
|
a43681 |
- /* covscan is _sure_ we leak buf_ if bufsize_ */\
|
|
|
a43681 |
- /* is <= 0, which is wrong, but appease it. */\
|
|
|
a43681 |
- free(buf_); \
|
|
|
a43681 |
- buf_ = NULL; \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- bufsize_; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
-
|
|
|
a43681 |
-#define sysfs_readlink(linkbuf, fmt, args...) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- char *_lb = alloca(PATH_MAX+1); \
|
|
|
a43681 |
- char *_pn; \
|
|
|
a43681 |
- int _rc; \
|
|
|
a43681 |
- \
|
|
|
a43681 |
- *(linkbuf) = NULL; \
|
|
|
a43681 |
- _rc = asprintfa(&_pn, "/sys/" fmt, ## args); \
|
|
|
a43681 |
- if (_rc >= 0) { \
|
|
|
a43681 |
- ssize_t _linksz; \
|
|
|
a43681 |
- _rc = _linksz = readlink(_pn, _lb, PATH_MAX); \
|
|
|
a43681 |
- if (_linksz >= 0) \
|
|
|
a43681 |
- _lb[_linksz] = '\0'; \
|
|
|
a43681 |
- else \
|
|
|
a43681 |
- efi_error("readlink of %s failed", _pn);\
|
|
|
a43681 |
- *(linkbuf) = _lb; \
|
|
|
a43681 |
- } else { \
|
|
|
a43681 |
- efi_error("could not allocate memory"); \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- _rc; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
-
|
|
|
a43681 |
-#define sysfs_stat(statbuf, fmt, args...) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- int rc_; \
|
|
|
a43681 |
- char *pn_; \
|
|
|
a43681 |
- \
|
|
|
a43681 |
- rc_ = asprintfa(&pn_, "/sys/" fmt, ## args); \
|
|
|
a43681 |
- if (rc_ >= 0) { \
|
|
|
a43681 |
- rc_ = stat(pn_, statbuf); \
|
|
|
a43681 |
- if (rc_ < 0) \
|
|
|
a43681 |
- efi_error("could not stat %s", pn_); \
|
|
|
a43681 |
- } else { \
|
|
|
a43681 |
- efi_error("could not allocate memory"); \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- rc_; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
-
|
|
|
a43681 |
-#define sysfs_opendir(fmt, args...) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- int rc_; \
|
|
|
a43681 |
- char *pn_; \
|
|
|
a43681 |
- DIR *dir_ = NULL; \
|
|
|
a43681 |
- \
|
|
|
a43681 |
- rc_ = asprintfa(&pn_, "/sys/" fmt, ## args); \
|
|
|
a43681 |
- if (rc_ >= 0) { \
|
|
|
a43681 |
- dir_ = opendir(pn_); \
|
|
|
a43681 |
- if (dir_ == NULL) \
|
|
|
a43681 |
- efi_error("could not open %s", pn_); \
|
|
|
a43681 |
- } else { \
|
|
|
a43681 |
- efi_error("could not allocate memory"); \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- dir_; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+ const char * const ifname);
|
|
|
a43681 |
+
|
|
|
a43681 |
+#define read_sysfs_file(buf, fmt, args...) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ uint8_t *buf_ = NULL; \
|
|
|
a43681 |
+ ssize_t bufsize_ = -1; \
|
|
|
a43681 |
+ int error_; \
|
|
|
a43681 |
+ \
|
|
|
a43681 |
+ bufsize_ = get_file(&buf_, "/sys/" fmt, ## args); \
|
|
|
a43681 |
+ if (bufsize_ > 0) { \
|
|
|
a43681 |
+ uint8_t *buf2_ = alloca(bufsize_); \
|
|
|
a43681 |
+ error_ = errno; \
|
|
|
a43681 |
+ if (buf2_) \
|
|
|
a43681 |
+ memcpy(buf2_, buf_, bufsize_); \
|
|
|
a43681 |
+ free(buf_); \
|
|
|
a43681 |
+ *(buf) = (__typeof__(*(buf)))buf2_; \
|
|
|
a43681 |
+ errno = error_; \
|
|
|
a43681 |
+ } else if (buf_) { \
|
|
|
a43681 |
+ /* covscan is _sure_ we leak buf_ if bufsize_ */\
|
|
|
a43681 |
+ /* is <= 0, which is wrong, but appease it. */\
|
|
|
a43681 |
+ free(buf_); \
|
|
|
a43681 |
+ buf_ = NULL; \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ bufsize_; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
+
|
|
|
a43681 |
+#define sysfs_readlink(linkbuf, fmt, args...) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ char *_lb = alloca(PATH_MAX+1); \
|
|
|
a43681 |
+ char *_pn; \
|
|
|
a43681 |
+ int _rc; \
|
|
|
a43681 |
+ \
|
|
|
a43681 |
+ *(linkbuf) = NULL; \
|
|
|
a43681 |
+ _rc = asprintfa(&_pn, "/sys/" fmt, ## args); \
|
|
|
a43681 |
+ if (_rc >= 0) { \
|
|
|
a43681 |
+ ssize_t _linksz; \
|
|
|
a43681 |
+ _rc = _linksz = readlink(_pn, _lb, PATH_MAX); \
|
|
|
a43681 |
+ if (_linksz >= 0) \
|
|
|
a43681 |
+ _lb[_linksz] = '\0'; \
|
|
|
a43681 |
+ else \
|
|
|
a43681 |
+ efi_error("readlink of %s failed", _pn);\
|
|
|
a43681 |
+ *(linkbuf) = _lb; \
|
|
|
a43681 |
+ } else { \
|
|
|
a43681 |
+ efi_error("could not allocate memory"); \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ _rc; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
+
|
|
|
a43681 |
+#define sysfs_stat(statbuf, fmt, args...) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ int rc_; \
|
|
|
a43681 |
+ char *pn_; \
|
|
|
a43681 |
+ \
|
|
|
a43681 |
+ rc_ = asprintfa(&pn_, "/sys/" fmt, ## args); \
|
|
|
a43681 |
+ if (rc_ >= 0) { \
|
|
|
a43681 |
+ rc_ = stat(pn_, statbuf); \
|
|
|
a43681 |
+ if (rc_ < 0) \
|
|
|
a43681 |
+ efi_error("could not stat %s", pn_); \
|
|
|
a43681 |
+ } else { \
|
|
|
a43681 |
+ efi_error("could not allocate memory"); \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ rc_; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
+
|
|
|
a43681 |
+#define sysfs_opendir(fmt, args...) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ int rc_; \
|
|
|
a43681 |
+ char *pn_; \
|
|
|
a43681 |
+ DIR *dir_ = NULL; \
|
|
|
a43681 |
+ \
|
|
|
a43681 |
+ rc_ = asprintfa(&pn_, "/sys/" fmt, ## args); \
|
|
|
a43681 |
+ if (rc_ >= 0) { \
|
|
|
a43681 |
+ dir_ = opendir(pn_); \
|
|
|
a43681 |
+ if (dir_ == NULL) \
|
|
|
a43681 |
+ efi_error("could not open %s", pn_); \
|
|
|
a43681 |
+ } else { \
|
|
|
a43681 |
+ efi_error("could not allocate memory"); \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ dir_; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
|
|
|
a43681 |
#define DEV_PROVIDES_ROOT 1
|
|
|
a43681 |
-#define DEV_PROVIDES_HD 2
|
|
|
a43681 |
-#define DEV_ABBREV_ONLY 4
|
|
|
a43681 |
+#define DEV_PROVIDES_HD 2
|
|
|
a43681 |
+#define DEV_ABBREV_ONLY 4
|
|
|
a43681 |
|
|
|
a43681 |
struct dev_probe {
|
|
|
a43681 |
- char *name;
|
|
|
a43681 |
- enum interface_type *iftypes;
|
|
|
a43681 |
- uint32_t flags;
|
|
|
a43681 |
- ssize_t (*parse)(struct device *dev,
|
|
|
a43681 |
- const char * const current, const char * const root);
|
|
|
a43681 |
- ssize_t (*create)(struct device *dev,
|
|
|
a43681 |
- uint8_t *buf, ssize_t size, ssize_t off);
|
|
|
a43681 |
- char *(*make_part_name)(struct device *dev);
|
|
|
a43681 |
+ char *name;
|
|
|
a43681 |
+ enum interface_type *iftypes;
|
|
|
a43681 |
+ uint32_t flags;
|
|
|
a43681 |
+ ssize_t (*parse)(struct device *dev,
|
|
|
a43681 |
+ const char * const current, const char * const root);
|
|
|
a43681 |
+ ssize_t (*create)(struct device *dev,
|
|
|
a43681 |
+ uint8_t *buf, ssize_t size, ssize_t off);
|
|
|
a43681 |
+ char *(*make_part_name)(struct device *dev);
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
extern ssize_t parse_scsi_link(const char *current, uint32_t *host,
|
|
|
a43681 |
- uint32_t *bus, uint32_t *device,
|
|
|
a43681 |
- uint32_t *target, uint64_t *lun,
|
|
|
a43681 |
- uint32_t *local_port_id, uint32_t *remote_port_id,
|
|
|
a43681 |
- uint32_t *remote_target_id);
|
|
|
a43681 |
+ uint32_t *bus, uint32_t *device,
|
|
|
a43681 |
+ uint32_t *target, uint64_t *lun,
|
|
|
a43681 |
+ uint32_t *local_port_id, uint32_t *remote_port_id,
|
|
|
a43681 |
+ uint32_t *remote_target_id);
|
|
|
a43681 |
|
|
|
a43681 |
/* device support implementations */
|
|
|
a43681 |
extern struct dev_probe pmem_parser;
|
|
|
a43681 |
@@ -288,3 +288,5 @@ extern struct dev_probe ata_parser;
|
|
|
a43681 |
extern struct dev_probe emmc_parser;
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* _EFIBOOT_LINUX_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/path-helpers.h b/src/path-helpers.h
|
|
|
a43681 |
index 355f4be56af..7dec05b6297 100644
|
|
|
a43681 |
--- a/src/path-helpers.h
|
|
|
a43681 |
+++ b/src/path-helpers.h
|
|
|
a43681 |
@@ -24,25 +24,26 @@ void HIDDEN fill_spans(const char *str, const char *reject, void *spanbuf);
|
|
|
a43681 |
unsigned int HIDDEN count_spans(const char *str, const char *reject, unsigned int *chars);
|
|
|
a43681 |
int HIDDEN find_path_segment(const char *path, int segment, const char **pos, size_t *len);
|
|
|
a43681 |
|
|
|
a43681 |
-#define pathseg(path, seg) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- const char *pos_ = NULL; \
|
|
|
a43681 |
- char *ret_ = NULL; \
|
|
|
a43681 |
- size_t len_ = 0; \
|
|
|
a43681 |
- int rc_; \
|
|
|
a43681 |
- \
|
|
|
a43681 |
- rc_ = find_path_segment(path, seg, &pos_, &len_); \
|
|
|
a43681 |
- if (rc_ >= 0) { \
|
|
|
a43681 |
- ret_ = alloca(len_ + 1); \
|
|
|
a43681 |
- if (ret_) { \
|
|
|
a43681 |
- memcpy(ret_, pos_, len_); \
|
|
|
a43681 |
- ret_[len_] = '\0'; \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- ret_; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define pathseg(path, seg) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ const char *pos_ = NULL; \
|
|
|
a43681 |
+ char *ret_ = NULL; \
|
|
|
a43681 |
+ size_t len_ = 0; \
|
|
|
a43681 |
+ int rc_; \
|
|
|
a43681 |
+ \
|
|
|
a43681 |
+ rc_ = find_path_segment(path, seg, &pos_, &len_); \
|
|
|
a43681 |
+ if (rc_ >= 0) { \
|
|
|
a43681 |
+ ret_ = alloca(len_ + 1); \
|
|
|
a43681 |
+ if (ret_) { \
|
|
|
a43681 |
+ memcpy(ret_, pos_, len_); \
|
|
|
a43681 |
+ ret_[len_] = '\0'; \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ ret_; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
|
|
|
a43681 |
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* !PATH_HELPER_H_ */
|
|
|
a43681 |
-// vim:fenc=utf-8:tw=75:et
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/ucs2.h b/src/ucs2.h
|
|
|
a43681 |
index fd8b056ad25..176f9ccac57 100644
|
|
|
a43681 |
--- a/src/ucs2.h
|
|
|
a43681 |
+++ b/src/ucs2.h
|
|
|
a43681 |
@@ -180,3 +180,5 @@ utf8_to_ucs2(void *ucs2void, ssize_t size, int terminate, uint8_t *utf8)
|
|
|
a43681 |
};
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* _EFIVAR_UCS2_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
diff --git a/src/util.h b/src/util.h
|
|
|
a43681 |
index ec1c5f1a69a..712abea2d42 100644
|
|
|
a43681 |
--- a/src/util.h
|
|
|
a43681 |
+++ b/src/util.h
|
|
|
a43681 |
@@ -75,322 +75,322 @@
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#ifndef int_add
|
|
|
a43681 |
-#define int_add(a, b, c) ({ \
|
|
|
a43681 |
- const int _limit = INT_MAX; \
|
|
|
a43681 |
- int _ret; \
|
|
|
a43681 |
- _ret = _limit - ((unsigned long long)a) > \
|
|
|
a43681 |
- ((unsigned long long)b); \
|
|
|
a43681 |
- if (!_ret) \
|
|
|
a43681 |
- *(c) = ((a) + (b)); \
|
|
|
a43681 |
- _ret; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define int_add(a, b, c) ({ \
|
|
|
a43681 |
+ const int _limit = INT_MAX; \
|
|
|
a43681 |
+ int _ret; \
|
|
|
a43681 |
+ _ret = _limit - ((unsigned long long)a) > \
|
|
|
a43681 |
+ ((unsigned long long)b); \
|
|
|
a43681 |
+ if (!_ret) \
|
|
|
a43681 |
+ *(c) = ((a) + (b)); \
|
|
|
a43681 |
+ _ret; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#ifndef long_add
|
|
|
a43681 |
-#define long_add(a, b, c) ({ \
|
|
|
a43681 |
- const long _limit = LONG_MAX; \
|
|
|
a43681 |
- int _ret; \
|
|
|
a43681 |
- _ret = _limit - ((unsigned long long)a) > \
|
|
|
a43681 |
- ((unsigned long long)b); \
|
|
|
a43681 |
- if (!_ret) \
|
|
|
a43681 |
- *(c) = ((a) + (b)); \
|
|
|
a43681 |
- _ret; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define long_add(a, b, c) ({ \
|
|
|
a43681 |
+ const long _limit = LONG_MAX; \
|
|
|
a43681 |
+ int _ret; \
|
|
|
a43681 |
+ _ret = _limit - ((unsigned long long)a) > \
|
|
|
a43681 |
+ ((unsigned long long)b); \
|
|
|
a43681 |
+ if (!_ret) \
|
|
|
a43681 |
+ *(c) = ((a) + (b)); \
|
|
|
a43681 |
+ _ret; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#ifndef long_mult
|
|
|
a43681 |
-#define long_mult(a, b, c) ({ \
|
|
|
a43681 |
- const long _limit = LONG_MAX; \
|
|
|
a43681 |
- int _ret = 1; \
|
|
|
a43681 |
- if ((a) == 0 || (b) == 0) \
|
|
|
a43681 |
- _ret = 0; \
|
|
|
a43681 |
- else \
|
|
|
a43681 |
- _ret = _limit / (a) < (b); \
|
|
|
a43681 |
- if (!_ret) \
|
|
|
a43681 |
- *(c) = ((a) * (b)); \
|
|
|
a43681 |
- _ret; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define long_mult(a, b, c) ({ \
|
|
|
a43681 |
+ const long _limit = LONG_MAX; \
|
|
|
a43681 |
+ int _ret = 1; \
|
|
|
a43681 |
+ if ((a) == 0 || (b) == 0) \
|
|
|
a43681 |
+ _ret = 0; \
|
|
|
a43681 |
+ else \
|
|
|
a43681 |
+ _ret = _limit / (a) < (b); \
|
|
|
a43681 |
+ if (!_ret) \
|
|
|
a43681 |
+ *(c) = ((a) * (b)); \
|
|
|
a43681 |
+ _ret; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#ifndef ulong_add
|
|
|
a43681 |
-#define ulong_add(a, b, c) ({ \
|
|
|
a43681 |
- const unsigned long _limit = ULONG_MAX; \
|
|
|
a43681 |
- int _ret; \
|
|
|
a43681 |
- _ret = _limit - ((unsigned long long)a) > \
|
|
|
a43681 |
- ((unsigned long long)b); \
|
|
|
a43681 |
- if (!_ret) \
|
|
|
a43681 |
- *(c) = ((a) + (b)); \
|
|
|
a43681 |
- _ret; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define ulong_add(a, b, c) ({ \
|
|
|
a43681 |
+ const unsigned long _limit = ULONG_MAX; \
|
|
|
a43681 |
+ int _ret; \
|
|
|
a43681 |
+ _ret = _limit - ((unsigned long long)a) > \
|
|
|
a43681 |
+ ((unsigned long long)b); \
|
|
|
a43681 |
+ if (!_ret) \
|
|
|
a43681 |
+ *(c) = ((a) + (b)); \
|
|
|
a43681 |
+ _ret; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#ifndef ulong_mult
|
|
|
a43681 |
-#define ulong_mult(a, b, c) ({ \
|
|
|
a43681 |
- const unsigned long _limit = ULONG_MAX; \
|
|
|
a43681 |
- int _ret = 1; \
|
|
|
a43681 |
- if ((a) == 0 || (b) == 0) \
|
|
|
a43681 |
- _ret = 0; \
|
|
|
a43681 |
- else \
|
|
|
a43681 |
- _ret = _limit / (a) < (b); \
|
|
|
a43681 |
- if (!_ret) \
|
|
|
a43681 |
- *(c) = ((a) * (b)); \
|
|
|
a43681 |
- _ret; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define ulong_mult(a, b, c) ({ \
|
|
|
a43681 |
+ const unsigned long _limit = ULONG_MAX; \
|
|
|
a43681 |
+ int _ret = 1; \
|
|
|
a43681 |
+ if ((a) == 0 || (b) == 0) \
|
|
|
a43681 |
+ _ret = 0; \
|
|
|
a43681 |
+ else \
|
|
|
a43681 |
+ _ret = _limit / (a) < (b); \
|
|
|
a43681 |
+ if (!_ret) \
|
|
|
a43681 |
+ *(c) = ((a) * (b)); \
|
|
|
a43681 |
+ _ret; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#endif
|
|
|
a43681 |
|
|
|
a43681 |
#if defined(__GNUC__) && defined(__GNUC_MINOR__)
|
|
|
a43681 |
#if __GNUC__ >= 5 && __GNUC_MINOR__ >= 1
|
|
|
a43681 |
-#define add(a, b, c) _Generic((c), \
|
|
|
a43681 |
- int *: int_add(a,b,c), \
|
|
|
a43681 |
- long *: long_add(a,b,c), \
|
|
|
a43681 |
- unsigned long *: ulong_add(a,b,c))
|
|
|
a43681 |
-#define mult(a, b, c) _Generic((c), \
|
|
|
a43681 |
- long *: long_mult(a,b,c), \
|
|
|
a43681 |
- unsigned long *: ulong_mult(a,b,c))
|
|
|
a43681 |
+#define add(a, b, c) _Generic((c), \
|
|
|
a43681 |
+ int *: int_add(a,b,c), \
|
|
|
a43681 |
+ long *: long_add(a,b,c), \
|
|
|
a43681 |
+ unsigned long *: ulong_add(a,b,c))
|
|
|
a43681 |
+#define mult(a, b, c) _Generic((c), \
|
|
|
a43681 |
+ long *: long_mult(a,b,c), \
|
|
|
a43681 |
+ unsigned long *: ulong_mult(a,b,c))
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#endif
|
|
|
a43681 |
|
|
|
a43681 |
#ifndef add
|
|
|
a43681 |
-#define add(a, b, c) ({ \
|
|
|
a43681 |
- (*(c)) = ((a) + (b)); \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define add(a, b, c) ({ \
|
|
|
a43681 |
+ (*(c)) = ((a) + (b)); \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#ifndef mult
|
|
|
a43681 |
-#define mult(a, b, c) ({ \
|
|
|
a43681 |
- (*(c)) = ((a) * (b)); \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define mult(a, b, c) ({ \
|
|
|
a43681 |
+ (*(c)) = ((a) * (b)); \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#endif
|
|
|
a43681 |
|
|
|
a43681 |
static inline int UNUSED
|
|
|
a43681 |
read_file(int fd, uint8_t **result, size_t *bufsize)
|
|
|
a43681 |
{
|
|
|
a43681 |
- uint8_t *p;
|
|
|
a43681 |
- size_t size = 4096;
|
|
|
a43681 |
- size_t filesize = 0;
|
|
|
a43681 |
- ssize_t s = 0;
|
|
|
a43681 |
- uint8_t *buf, *newbuf;
|
|
|
a43681 |
+ uint8_t *p;
|
|
|
a43681 |
+ size_t size = 4096;
|
|
|
a43681 |
+ size_t filesize = 0;
|
|
|
a43681 |
+ ssize_t s = 0;
|
|
|
a43681 |
+ uint8_t *buf, *newbuf;
|
|
|
a43681 |
|
|
|
a43681 |
- if (!(newbuf = calloc(size, sizeof (uint8_t)))) {
|
|
|
a43681 |
- efi_error("could not allocate memory");
|
|
|
a43681 |
- *result = buf = NULL;
|
|
|
a43681 |
- *bufsize = 0;
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
- buf = newbuf;
|
|
|
a43681 |
+ if (!(newbuf = calloc(size, sizeof (uint8_t)))) {
|
|
|
a43681 |
+ efi_error("could not allocate memory");
|
|
|
a43681 |
+ *result = buf = NULL;
|
|
|
a43681 |
+ *bufsize = 0;
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
+ buf = newbuf;
|
|
|
a43681 |
|
|
|
a43681 |
- do {
|
|
|
a43681 |
- p = buf + filesize;
|
|
|
a43681 |
- /* size - filesize shouldn't exceed SSIZE_MAX because we're
|
|
|
a43681 |
- * only allocating 4096 bytes at a time and we're checking that
|
|
|
a43681 |
- * before doing so. */
|
|
|
a43681 |
- s = read(fd, p, size - filesize);
|
|
|
a43681 |
- if (s < 0 && errno == EAGAIN) {
|
|
|
a43681 |
- /*
|
|
|
a43681 |
- * if we got EAGAIN, there's a good chance we've hit
|
|
|
a43681 |
- * the kernel rate limiter. Doing more reads is just
|
|
|
a43681 |
- * going to make it worse, so instead, give it a rest.
|
|
|
a43681 |
- */
|
|
|
a43681 |
- sched_yield();
|
|
|
a43681 |
- continue;
|
|
|
a43681 |
- } else if (s < 0) {
|
|
|
a43681 |
- int saved_errno = errno;
|
|
|
a43681 |
- free(buf);
|
|
|
a43681 |
- *result = buf = NULL;
|
|
|
a43681 |
- *bufsize = 0;
|
|
|
a43681 |
- errno = saved_errno;
|
|
|
a43681 |
- efi_error("could not read from file");
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
- filesize += s;
|
|
|
a43681 |
- /* only exit for empty reads */
|
|
|
a43681 |
- if (s == 0)
|
|
|
a43681 |
- break;
|
|
|
a43681 |
- if (filesize >= size) {
|
|
|
a43681 |
- /* See if we're going to overrun and return an error
|
|
|
a43681 |
- * instead. */
|
|
|
a43681 |
- if (size > (size_t)-1 - 4096) {
|
|
|
a43681 |
- free(buf);
|
|
|
a43681 |
- *result = buf = NULL;
|
|
|
a43681 |
- *bufsize = 0;
|
|
|
a43681 |
- errno = ENOMEM;
|
|
|
a43681 |
- efi_error("could not read from file");
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
- newbuf = realloc(buf, size + 4096);
|
|
|
a43681 |
- if (newbuf == NULL) {
|
|
|
a43681 |
- int saved_errno = errno;
|
|
|
a43681 |
- free(buf);
|
|
|
a43681 |
- *result = buf = NULL;
|
|
|
a43681 |
- *bufsize = 0;
|
|
|
a43681 |
- errno = saved_errno;
|
|
|
a43681 |
- efi_error("could not allocate memory");
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
- buf = newbuf;
|
|
|
a43681 |
- memset(buf + size, '\0', 4096);
|
|
|
a43681 |
- size += 4096;
|
|
|
a43681 |
- }
|
|
|
a43681 |
- } while (1);
|
|
|
a43681 |
+ do {
|
|
|
a43681 |
+ p = buf + filesize;
|
|
|
a43681 |
+ /* size - filesize shouldn't exceed SSIZE_MAX because we're
|
|
|
a43681 |
+ * only allocating 4096 bytes at a time and we're checking that
|
|
|
a43681 |
+ * before doing so. */
|
|
|
a43681 |
+ s = read(fd, p, size - filesize);
|
|
|
a43681 |
+ if (s < 0 && errno == EAGAIN) {
|
|
|
a43681 |
+ /*
|
|
|
a43681 |
+ * if we got EAGAIN, there's a good chance we've hit
|
|
|
a43681 |
+ * the kernel rate limiter. Doing more reads is just
|
|
|
a43681 |
+ * going to make it worse, so instead, give it a rest.
|
|
|
a43681 |
+ */
|
|
|
a43681 |
+ sched_yield();
|
|
|
a43681 |
+ continue;
|
|
|
a43681 |
+ } else if (s < 0) {
|
|
|
a43681 |
+ int saved_errno = errno;
|
|
|
a43681 |
+ free(buf);
|
|
|
a43681 |
+ *result = buf = NULL;
|
|
|
a43681 |
+ *bufsize = 0;
|
|
|
a43681 |
+ errno = saved_errno;
|
|
|
a43681 |
+ efi_error("could not read from file");
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
+ filesize += s;
|
|
|
a43681 |
+ /* only exit for empty reads */
|
|
|
a43681 |
+ if (s == 0)
|
|
|
a43681 |
+ break;
|
|
|
a43681 |
+ if (filesize >= size) {
|
|
|
a43681 |
+ /* See if we're going to overrun and return an error
|
|
|
a43681 |
+ * instead. */
|
|
|
a43681 |
+ if (size > (size_t)-1 - 4096) {
|
|
|
a43681 |
+ free(buf);
|
|
|
a43681 |
+ *result = buf = NULL;
|
|
|
a43681 |
+ *bufsize = 0;
|
|
|
a43681 |
+ errno = ENOMEM;
|
|
|
a43681 |
+ efi_error("could not read from file");
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
+ newbuf = realloc(buf, size + 4096);
|
|
|
a43681 |
+ if (newbuf == NULL) {
|
|
|
a43681 |
+ int saved_errno = errno;
|
|
|
a43681 |
+ free(buf);
|
|
|
a43681 |
+ *result = buf = NULL;
|
|
|
a43681 |
+ *bufsize = 0;
|
|
|
a43681 |
+ errno = saved_errno;
|
|
|
a43681 |
+ efi_error("could not allocate memory");
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
+ buf = newbuf;
|
|
|
a43681 |
+ memset(buf + size, '\0', 4096);
|
|
|
a43681 |
+ size += 4096;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
+ } while (1);
|
|
|
a43681 |
|
|
|
a43681 |
- newbuf = realloc(buf, filesize+1);
|
|
|
a43681 |
- if (!newbuf) {
|
|
|
a43681 |
- free(buf);
|
|
|
a43681 |
- *result = buf = NULL;
|
|
|
a43681 |
- efi_error("could not allocate memory");
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
- newbuf[filesize] = '\0';
|
|
|
a43681 |
- *result = newbuf;
|
|
|
a43681 |
- *bufsize = filesize+1;
|
|
|
a43681 |
- return 0;
|
|
|
a43681 |
+ newbuf = realloc(buf, filesize+1);
|
|
|
a43681 |
+ if (!newbuf) {
|
|
|
a43681 |
+ free(buf);
|
|
|
a43681 |
+ *result = buf = NULL;
|
|
|
a43681 |
+ efi_error("could not allocate memory");
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
+ newbuf[filesize] = '\0';
|
|
|
a43681 |
+ *result = newbuf;
|
|
|
a43681 |
+ *bufsize = filesize+1;
|
|
|
a43681 |
+ return 0;
|
|
|
a43681 |
}
|
|
|
a43681 |
|
|
|
a43681 |
static inline uint64_t UNUSED
|
|
|
a43681 |
lcm(uint64_t x, uint64_t y)
|
|
|
a43681 |
{
|
|
|
a43681 |
- uint64_t m = x, n = y, o;
|
|
|
a43681 |
- while ((o = m % n)) {
|
|
|
a43681 |
- m = n;
|
|
|
a43681 |
- n = o;
|
|
|
a43681 |
- }
|
|
|
a43681 |
- return (x / n) * y;
|
|
|
a43681 |
+ uint64_t m = x, n = y, o;
|
|
|
a43681 |
+ while ((o = m % n)) {
|
|
|
a43681 |
+ m = n;
|
|
|
a43681 |
+ n = o;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
+ return (x / n) * y;
|
|
|
a43681 |
}
|
|
|
a43681 |
|
|
|
a43681 |
#ifndef strdupa
|
|
|
a43681 |
-#define strdupa(s) \
|
|
|
a43681 |
- (__extension__ ({ \
|
|
|
a43681 |
- const char *__in = (s); \
|
|
|
a43681 |
- size_t __len = strlen (__in); \
|
|
|
a43681 |
- char *__out = (char *) alloca (__len + 1); \
|
|
|
a43681 |
- strcpy(__out, __in); \
|
|
|
a43681 |
- __out; \
|
|
|
a43681 |
- }))
|
|
|
a43681 |
+#define strdupa(s) \
|
|
|
a43681 |
+ (__extension__ ({ \
|
|
|
a43681 |
+ const char *__in = (s); \
|
|
|
a43681 |
+ size_t __len = strlen (__in); \
|
|
|
a43681 |
+ char *__out = (char *) alloca (__len + 1); \
|
|
|
a43681 |
+ strcpy(__out, __in); \
|
|
|
a43681 |
+ __out; \
|
|
|
a43681 |
+ }))
|
|
|
a43681 |
#endif
|
|
|
a43681 |
|
|
|
a43681 |
#ifndef strndupa
|
|
|
a43681 |
-#define strndupa(s, l) \
|
|
|
a43681 |
- (__extension__ ({ \
|
|
|
a43681 |
- const char *__in = (s); \
|
|
|
a43681 |
- size_t __len = strnlen (__in, (l)); \
|
|
|
a43681 |
- char *__out = (char *) alloca (__len + 1); \
|
|
|
a43681 |
- strncpy(__out, __in, __len); \
|
|
|
a43681 |
- __out[__len] = '\0'; \
|
|
|
a43681 |
- __out; \
|
|
|
a43681 |
- }))
|
|
|
a43681 |
+#define strndupa(s, l) \
|
|
|
a43681 |
+ (__extension__ ({ \
|
|
|
a43681 |
+ const char *__in = (s); \
|
|
|
a43681 |
+ size_t __len = strnlen (__in, (l)); \
|
|
|
a43681 |
+ char *__out = (char *) alloca (__len + 1); \
|
|
|
a43681 |
+ strncpy(__out, __in, __len); \
|
|
|
a43681 |
+ __out[__len] = '\0'; \
|
|
|
a43681 |
+ __out; \
|
|
|
a43681 |
+ }))
|
|
|
a43681 |
#endif
|
|
|
a43681 |
|
|
|
a43681 |
-#define asprintfa(str, fmt, args...) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- char *_tmp = NULL; \
|
|
|
a43681 |
- int _rc; \
|
|
|
a43681 |
- *(str) = NULL; \
|
|
|
a43681 |
- _rc = asprintf((str), (fmt), ## args); \
|
|
|
a43681 |
- if (_rc > 0) { \
|
|
|
a43681 |
- _tmp = strdupa(*(str)); \
|
|
|
a43681 |
- if (!_tmp) { \
|
|
|
a43681 |
- _rc = -1; \
|
|
|
a43681 |
- } else { \
|
|
|
a43681 |
- free(*(str)); \
|
|
|
a43681 |
- *(str) = _tmp; \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- } else { \
|
|
|
a43681 |
- _rc = -1; \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- _rc; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define asprintfa(str, fmt, args...) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ char *_tmp = NULL; \
|
|
|
a43681 |
+ int _rc; \
|
|
|
a43681 |
+ *(str) = NULL; \
|
|
|
a43681 |
+ _rc = asprintf((str), (fmt), ## args); \
|
|
|
a43681 |
+ if (_rc > 0) { \
|
|
|
a43681 |
+ _tmp = strdupa(*(str)); \
|
|
|
a43681 |
+ if (!_tmp) { \
|
|
|
a43681 |
+ _rc = -1; \
|
|
|
a43681 |
+ } else { \
|
|
|
a43681 |
+ free(*(str)); \
|
|
|
a43681 |
+ *(str) = _tmp; \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ } else { \
|
|
|
a43681 |
+ _rc = -1; \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ _rc; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
|
|
|
a43681 |
-#define vasprintfa(str, fmt, ap) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- char *_tmp = NULL; \
|
|
|
a43681 |
- int _rc; \
|
|
|
a43681 |
- *(str) = NULL; \
|
|
|
a43681 |
- _rc = vasprintf((str), (fmt), (ap)); \
|
|
|
a43681 |
- if (_rc > 0) { \
|
|
|
a43681 |
- _tmp = strdupa(*(str)); \
|
|
|
a43681 |
- if (!_tmp) { \
|
|
|
a43681 |
- _rc = -1; \
|
|
|
a43681 |
- } else { \
|
|
|
a43681 |
- free(*(str)); \
|
|
|
a43681 |
- *(str) = _tmp; \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- } else { \
|
|
|
a43681 |
- _rc = -1; \
|
|
|
a43681 |
- } \
|
|
|
a43681 |
- _rc; \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define vasprintfa(str, fmt, ap) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ char *_tmp = NULL; \
|
|
|
a43681 |
+ int _rc; \
|
|
|
a43681 |
+ *(str) = NULL; \
|
|
|
a43681 |
+ _rc = vasprintf((str), (fmt), (ap)); \
|
|
|
a43681 |
+ if (_rc > 0) { \
|
|
|
a43681 |
+ _tmp = strdupa(*(str)); \
|
|
|
a43681 |
+ if (!_tmp) { \
|
|
|
a43681 |
+ _rc = -1; \
|
|
|
a43681 |
+ } else { \
|
|
|
a43681 |
+ free(*(str)); \
|
|
|
a43681 |
+ *(str) = _tmp; \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ } else { \
|
|
|
a43681 |
+ _rc = -1; \
|
|
|
a43681 |
+ } \
|
|
|
a43681 |
+ _rc; \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
|
|
|
a43681 |
static inline ssize_t
|
|
|
a43681 |
get_file(uint8_t **result, const char * const fmt, ...)
|
|
|
a43681 |
{
|
|
|
a43681 |
- char *path;
|
|
|
a43681 |
- uint8_t *buf = NULL;
|
|
|
a43681 |
- size_t bufsize = 0;
|
|
|
a43681 |
- ssize_t rc;
|
|
|
a43681 |
- va_list ap;
|
|
|
a43681 |
- int error;
|
|
|
a43681 |
- int fd;
|
|
|
a43681 |
+ char *path;
|
|
|
a43681 |
+ uint8_t *buf = NULL;
|
|
|
a43681 |
+ size_t bufsize = 0;
|
|
|
a43681 |
+ ssize_t rc;
|
|
|
a43681 |
+ va_list ap;
|
|
|
a43681 |
+ int error;
|
|
|
a43681 |
+ int fd;
|
|
|
a43681 |
|
|
|
a43681 |
- if (result == NULL) {
|
|
|
a43681 |
- efi_error("invalid parameter 'result'");
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
+ if (result == NULL) {
|
|
|
a43681 |
+ efi_error("invalid parameter 'result'");
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
|
|
|
a43681 |
- va_start(ap, fmt);
|
|
|
a43681 |
- rc = vasprintfa(&path, fmt, ap);
|
|
|
a43681 |
- va_end(ap);
|
|
|
a43681 |
- if (rc < 0) {
|
|
|
a43681 |
- efi_error("could not allocate memory");
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
+ va_start(ap, fmt);
|
|
|
a43681 |
+ rc = vasprintfa(&path, fmt, ap);
|
|
|
a43681 |
+ va_end(ap);
|
|
|
a43681 |
+ if (rc < 0) {
|
|
|
a43681 |
+ efi_error("could not allocate memory");
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
|
|
|
a43681 |
- fd = open(path, O_RDONLY);
|
|
|
a43681 |
- if (fd < 0) {
|
|
|
a43681 |
- efi_error("could not open file \"%s\" for reading",
|
|
|
a43681 |
- path);
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
+ fd = open(path, O_RDONLY);
|
|
|
a43681 |
+ if (fd < 0) {
|
|
|
a43681 |
+ efi_error("could not open file \"%s\" for reading",
|
|
|
a43681 |
+ path);
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
|
|
|
a43681 |
- rc = read_file(fd, &buf, &bufsize);
|
|
|
a43681 |
- error = errno;
|
|
|
a43681 |
- close(fd);
|
|
|
a43681 |
- errno = error;
|
|
|
a43681 |
+ rc = read_file(fd, &buf, &bufsize);
|
|
|
a43681 |
+ error = errno;
|
|
|
a43681 |
+ close(fd);
|
|
|
a43681 |
+ errno = error;
|
|
|
a43681 |
|
|
|
a43681 |
- if (rc < 0 || bufsize < 1) {
|
|
|
a43681 |
- /*
|
|
|
a43681 |
- * I don't think this can happen, but I can't convince
|
|
|
a43681 |
- * cov-scan
|
|
|
a43681 |
- */
|
|
|
a43681 |
- if (buf)
|
|
|
a43681 |
- free(buf);
|
|
|
a43681 |
- *result = NULL;
|
|
|
a43681 |
- efi_error("could not read file \"%s\"", path);
|
|
|
a43681 |
- return -1;
|
|
|
a43681 |
- }
|
|
|
a43681 |
+ if (rc < 0 || bufsize < 1) {
|
|
|
a43681 |
+ /*
|
|
|
a43681 |
+ * I don't think this can happen, but I can't convince
|
|
|
a43681 |
+ * cov-scan
|
|
|
a43681 |
+ */
|
|
|
a43681 |
+ if (buf)
|
|
|
a43681 |
+ free(buf);
|
|
|
a43681 |
+ *result = NULL;
|
|
|
a43681 |
+ efi_error("could not read file \"%s\"", path);
|
|
|
a43681 |
+ return -1;
|
|
|
a43681 |
+ }
|
|
|
a43681 |
|
|
|
a43681 |
- *result = buf;
|
|
|
a43681 |
- return bufsize;
|
|
|
a43681 |
+ *result = buf;
|
|
|
a43681 |
+ return bufsize;
|
|
|
a43681 |
}
|
|
|
a43681 |
|
|
|
a43681 |
static inline void UNUSED
|
|
|
a43681 |
swizzle_guid_to_uuid(efi_guid_t *guid)
|
|
|
a43681 |
{
|
|
|
a43681 |
- uint32_t *u32;
|
|
|
a43681 |
- uint16_t *u16;
|
|
|
a43681 |
+ uint32_t *u32;
|
|
|
a43681 |
+ uint16_t *u16;
|
|
|
a43681 |
|
|
|
a43681 |
- u32 = (uint32_t *)guid;
|
|
|
a43681 |
- u32[0] = __builtin_bswap32(u32[0]);
|
|
|
a43681 |
- u16 = (uint16_t *)&u32[1];
|
|
|
a43681 |
- u16[0] = __builtin_bswap16(u16[0]);
|
|
|
a43681 |
- u16[1] = __builtin_bswap16(u16[1]);
|
|
|
a43681 |
+ u32 = (uint32_t *)guid;
|
|
|
a43681 |
+ u32[0] = __builtin_bswap32(u32[0]);
|
|
|
a43681 |
+ u16 = (uint16_t *)&u32[1];
|
|
|
a43681 |
+ u16[0] = __builtin_bswap16(u16[0]);
|
|
|
a43681 |
+ u16[1] = __builtin_bswap16(u16[1]);
|
|
|
a43681 |
}
|
|
|
a43681 |
|
|
|
a43681 |
-#define log_(file, line, func, level, fmt, args...) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- efi_set_loglevel(level); \
|
|
|
a43681 |
- FILE *logfile_ = efi_get_logfile(); \
|
|
|
a43681 |
- int len_ = strlen(fmt); \
|
|
|
a43681 |
- fprintf(logfile_, "%s:%d %s(): ", \
|
|
|
a43681 |
- file, line, func); \
|
|
|
a43681 |
- fprintf(logfile_, fmt, ## args); \
|
|
|
a43681 |
- if (!len_ || fmt[len_ - 1] != '\n') \
|
|
|
a43681 |
- fprintf(logfile_, "\n"); \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define log_(file, line, func, level, fmt, args...) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ efi_set_loglevel(level); \
|
|
|
a43681 |
+ FILE *logfile_ = efi_get_logfile(); \
|
|
|
a43681 |
+ int len_ = strlen(fmt); \
|
|
|
a43681 |
+ fprintf(logfile_, "%s:%d %s(): ", \
|
|
|
a43681 |
+ file, line, func); \
|
|
|
a43681 |
+ fprintf(logfile_, fmt, ## args); \
|
|
|
a43681 |
+ if (!len_ || fmt[len_ - 1] != '\n') \
|
|
|
a43681 |
+ fprintf(logfile_, "\n"); \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
|
|
|
a43681 |
#define LOG_VERBOSE 0
|
|
|
a43681 |
#define LOG_DEBUG 1
|
|
|
a43681 |
@@ -399,14 +399,16 @@ swizzle_guid_to_uuid(efi_guid_t *guid)
|
|
|
a43681 |
#endif
|
|
|
a43681 |
#define log(level, fmt, args...) log_(__FILE__, __LINE__, __func__, level, fmt, ## args)
|
|
|
a43681 |
#define debug(fmt, args...) log(LOG_DEBUG, fmt, ## args)
|
|
|
a43681 |
-#define log_hex_(file, line, func, level, buf, size) \
|
|
|
a43681 |
- ({ \
|
|
|
a43681 |
- efi_set_loglevel(level); \
|
|
|
a43681 |
- fhexdumpf(efi_get_logfile(), "%s:%d %s(): ", \
|
|
|
a43681 |
- (uint8_t *)buf, size, \
|
|
|
a43681 |
- file, line, func); \
|
|
|
a43681 |
- })
|
|
|
a43681 |
+#define log_hex_(file, line, func, level, buf, size) \
|
|
|
a43681 |
+ ({ \
|
|
|
a43681 |
+ efi_set_loglevel(level); \
|
|
|
a43681 |
+ fhexdumpf(efi_get_logfile(), "%s:%d %s(): ", \
|
|
|
a43681 |
+ (uint8_t *)buf, size, \
|
|
|
a43681 |
+ file, line, func); \
|
|
|
a43681 |
+ })
|
|
|
a43681 |
#define log_hex(level, buf, size) log_hex_(__FILE__, __LINE__, __func__, level, buf, size)
|
|
|
a43681 |
#define debug_hex(buf, size) log_hex(LOG_DEBUG, buf, size)
|
|
|
a43681 |
|
|
|
a43681 |
#endif /* EFIVAR_UTIL_H */
|
|
|
a43681 |
+
|
|
|
a43681 |
+// vim:fenc=utf-8:tw=75:noet
|
|
|
a43681 |
--
|
|
|
a43681 |
2.26.2
|
|
|
a43681 |
|