mirror of
https://github.com/systemd/systemd.git
synced 2024-10-30 06:25:37 +03:00
efi: use assert_se() instead of assert() to guard for OOM issues in EFI code
This commit is contained in:
parent
8890ec82f5
commit
1462d2451a
@ -27,16 +27,15 @@
|
||||
#define xnew_alloc(type, n, alloc) \
|
||||
({ \
|
||||
UINTN _alloc_size; \
|
||||
if (__builtin_mul_overflow(sizeof(type), (n), &_alloc_size)) \
|
||||
assert_not_reached(); \
|
||||
assert_se(!__builtin_mul_overflow(sizeof(type), (n), &_alloc_size)); \
|
||||
(type *) alloc(_alloc_size); \
|
||||
})
|
||||
|
||||
#define xallocate_pool(size) ASSERT_PTR(AllocatePool(size))
|
||||
#define xallocate_zero_pool(size) ASSERT_PTR(AllocateZeroPool(size))
|
||||
#define xreallocate_pool(p, old_size, new_size) ASSERT_PTR(ReallocatePool((p), (old_size), (new_size)))
|
||||
#define xpool_print(fmt, ...) ((CHAR16 *) ASSERT_PTR(PoolPrint((fmt), ##__VA_ARGS__)))
|
||||
#define xstrdup(str) ((CHAR16 *) ASSERT_PTR(StrDuplicate(str)))
|
||||
#define xallocate_pool(size) ASSERT_SE_PTR(AllocatePool(size))
|
||||
#define xallocate_zero_pool(size) ASSERT_SE_PTR(AllocateZeroPool(size))
|
||||
#define xreallocate_pool(p, old_size, new_size) ASSERT_SE_PTR(ReallocatePool((p), (old_size), (new_size)))
|
||||
#define xpool_print(fmt, ...) ((CHAR16 *) ASSERT_SE_PTR(PoolPrint((fmt), ##__VA_ARGS__)))
|
||||
#define xstrdup(str) ((CHAR16 *) ASSERT_SE_PTR(StrDuplicate(str)))
|
||||
#define xnew(type, n) xnew_alloc(type, (n), xallocate_pool)
|
||||
#define xnew0(type, n) xnew_alloc(type, (n), xallocate_zero_pool)
|
||||
|
||||
|
@ -226,7 +226,7 @@ static EFI_STATUS find_device(EFI_HANDLE *device, EFI_DEVICE_PATH **ret_device_p
|
||||
}
|
||||
|
||||
/* Patch in the data we found */
|
||||
EFI_DEVICE_PATH *xboot_path = ASSERT_PTR(DuplicateDevicePath(partition_path));
|
||||
EFI_DEVICE_PATH *xboot_path = ASSERT_SE_PTR(DuplicateDevicePath(partition_path));
|
||||
CopyMem((UINT8 *) xboot_path + ((UINT8 *) part_node - (UINT8 *) partition_path), &hd, sizeof(hd));
|
||||
*ret_device_path = xboot_path;
|
||||
return EFI_SUCCESS;
|
||||
|
Loading…
Reference in New Issue
Block a user