Compare commits
No commits in common. "eef28a80588deba87d29461572971115cd43c624" and "863039eee208bb902d037d93b81c92625a1028a3" have entirely different histories.
eef28a8058
...
863039eee2
@ -1,495 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Peter Jones <pjones@redhat.com>
|
||||
Date: Thu, 29 Aug 2024 12:11:11 -0600
|
||||
Subject: [PATCH] efi/api.h: include missing __grub_efi_api macros on EFI
|
||||
functions
|
||||
|
||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||
Signed-off-by: Leo Sandoval <lsandova@redhat.com>
|
||||
---
|
||||
grub-core/loader/efi/chainloader.c | 2 +-
|
||||
include/grub/efi/api.h | 34 +++++++++++++-------------
|
||||
include/grub/efi/dhcp.h | 42 ++++++++++++++++----------------
|
||||
include/grub/efi/edid.h | 2 +-
|
||||
include/grub/efi/http.h | 12 ++++-----
|
||||
include/grub/efi/pci.h | 50 +++++++++++++++++++-------------------
|
||||
6 files changed, 71 insertions(+), 71 deletions(-)
|
||||
|
||||
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
||||
index 5cd6f6a59..460a44041 100644
|
||||
--- a/grub-core/loader/efi/chainloader.c
|
||||
+++ b/grub-core/loader/efi/chainloader.c
|
||||
@@ -555,7 +555,7 @@ handle_image (struct grub_secureboot_chainloader_context *load_context)
|
||||
grub_uint32_t buffer_size;
|
||||
int found_entry_point = 0;
|
||||
int rc;
|
||||
- grub_efi_status_t (*entry_point) (grub_efi_handle_t image_handle, grub_efi_system_table_t *system_table);
|
||||
+ grub_efi_status_t (__grub_efi_api *entry_point) (grub_efi_handle_t image_handle, grub_efi_system_table_t *system_table);
|
||||
|
||||
b = grub_efi_system_table->boot_services;
|
||||
|
||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||
index 2376182d7..5047ecf28 100644
|
||||
--- a/include/grub/efi/api.h
|
||||
+++ b/include/grub/efi/api.h
|
||||
@@ -1094,11 +1094,11 @@ typedef struct grub_efi_bios_device_path grub_efi_bios_device_path_t;
|
||||
struct grub_efi_service_binding;
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_service_binding_create_child) (struct grub_efi_service_binding *this,
|
||||
+(__grub_efi_api *grub_efi_service_binding_create_child) (struct grub_efi_service_binding *this,
|
||||
grub_efi_handle_t *child_handle);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_service_binding_destroy_child) (struct grub_efi_service_binding *this,
|
||||
+(__grub_efi_api *grub_efi_service_binding_destroy_child) (struct grub_efi_service_binding *this,
|
||||
grub_efi_handle_t *child_handle);
|
||||
|
||||
typedef struct grub_efi_service_binding
|
||||
@@ -1754,12 +1754,12 @@ typedef struct grub_efi_pxe_mode
|
||||
typedef struct grub_efi_pxe
|
||||
{
|
||||
grub_uint64_t rev;
|
||||
- grub_efi_status_t (*start) (struct grub_efi_pxe *this, grub_efi_boolean_t use_ipv6);
|
||||
+ grub_efi_status_t (__grub_efi_api *start) (struct grub_efi_pxe *this, grub_efi_boolean_t use_ipv6);
|
||||
void (*stop) (void);
|
||||
- grub_efi_status_t (*dhcp) (struct grub_efi_pxe *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *dhcp) (struct grub_efi_pxe *this,
|
||||
grub_efi_boolean_t sort_offers);
|
||||
void (*discover) (void);
|
||||
- grub_efi_status_t (*mtftp) (struct grub_efi_pxe *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *mtftp) (struct grub_efi_pxe *this,
|
||||
grub_efi_pxe_base_code_tftp_opcode_t operation,
|
||||
void *buffer_ptr,
|
||||
grub_efi_boolean_t overwrite,
|
||||
@@ -1775,7 +1775,7 @@ typedef struct grub_efi_pxe
|
||||
void (*setipfilter) (void);
|
||||
void (*arp) (void);
|
||||
void (*setparams) (void);
|
||||
- grub_efi_status_t (*set_station_ip) (struct grub_efi_pxe *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *set_station_ip) (struct grub_efi_pxe *this,
|
||||
grub_efi_pxe_ip_address_t *new_station_ip,
|
||||
grub_efi_pxe_ip_address_t *new_subnet_mask);
|
||||
void (*setpackets) (void);
|
||||
@@ -2054,21 +2054,21 @@ typedef enum grub_efi_ip4_config2_data_type grub_efi_ip4_config2_data_type_t;
|
||||
|
||||
struct grub_efi_ip4_config2_protocol
|
||||
{
|
||||
- grub_efi_status_t (*set_data) (struct grub_efi_ip4_config2_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *set_data) (struct grub_efi_ip4_config2_protocol *this,
|
||||
grub_efi_ip4_config2_data_type_t data_type,
|
||||
grub_efi_uintn_t data_size,
|
||||
void *data);
|
||||
|
||||
- grub_efi_status_t (*get_data) (struct grub_efi_ip4_config2_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *get_data) (struct grub_efi_ip4_config2_protocol *this,
|
||||
grub_efi_ip4_config2_data_type_t data_type,
|
||||
grub_efi_uintn_t *data_size,
|
||||
void *data);
|
||||
|
||||
- grub_efi_status_t (*register_data_notify) (struct grub_efi_ip4_config2_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *register_data_notify) (struct grub_efi_ip4_config2_protocol *this,
|
||||
grub_efi_ip4_config2_data_type_t data_type,
|
||||
grub_efi_event_t event);
|
||||
|
||||
- grub_efi_status_t (*unregister_datanotify) (struct grub_efi_ip4_config2_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *unregister_datanotify) (struct grub_efi_ip4_config2_protocol *this,
|
||||
grub_efi_ip4_config2_data_type_t data_type,
|
||||
grub_efi_event_t event);
|
||||
};
|
||||
@@ -2126,21 +2126,21 @@ typedef enum grub_efi_ip6_config_data_type grub_efi_ip6_config_data_type_t;
|
||||
|
||||
struct grub_efi_ip6_config_protocol
|
||||
{
|
||||
- grub_efi_status_t (*set_data) (struct grub_efi_ip6_config_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *set_data) (struct grub_efi_ip6_config_protocol *this,
|
||||
grub_efi_ip6_config_data_type_t data_type,
|
||||
grub_efi_uintn_t data_size,
|
||||
void *data);
|
||||
|
||||
- grub_efi_status_t (*get_data) (struct grub_efi_ip6_config_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *get_data) (struct grub_efi_ip6_config_protocol *this,
|
||||
grub_efi_ip6_config_data_type_t data_type,
|
||||
grub_efi_uintn_t *data_size,
|
||||
void *data);
|
||||
|
||||
- grub_efi_status_t (*register_data_notify) (struct grub_efi_ip6_config_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *register_data_notify) (struct grub_efi_ip6_config_protocol *this,
|
||||
grub_efi_ip6_config_data_type_t data_type,
|
||||
grub_efi_event_t event);
|
||||
|
||||
- grub_efi_status_t (*unregister_datanotify) (struct grub_efi_ip6_config_protocol *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *unregister_datanotify) (struct grub_efi_ip6_config_protocol *this,
|
||||
grub_efi_ip6_config_data_type_t data_type,
|
||||
grub_efi_event_t event);
|
||||
};
|
||||
@@ -2191,17 +2191,17 @@ typedef struct grub_efi_ip6_config_manual_address grub_efi_ip6_config_manual_add
|
||||
|
||||
struct grub_efi_memory_attribute_protocol
|
||||
{
|
||||
- grub_efi_status_t (*get_memory_attributes) (
|
||||
+ grub_efi_status_t (__grub_efi_api *get_memory_attributes) (
|
||||
struct grub_efi_memory_attribute_protocol *this,
|
||||
grub_efi_physical_address_t base_address,
|
||||
grub_efi_uint64_t length,
|
||||
grub_efi_uint64_t *attributes);
|
||||
- grub_efi_status_t (*set_memory_attributes) (
|
||||
+ grub_efi_status_t (__grub_efi_api *set_memory_attributes) (
|
||||
struct grub_efi_memory_attribute_protocol *this,
|
||||
grub_efi_physical_address_t base_address,
|
||||
grub_efi_uint64_t length,
|
||||
grub_efi_uint64_t attributes);
|
||||
- grub_efi_status_t (*clear_memory_attributes) (
|
||||
+ grub_efi_status_t (__grub_efi_api *clear_memory_attributes) (
|
||||
struct grub_efi_memory_attribute_protocol *this,
|
||||
grub_efi_physical_address_t base_address,
|
||||
grub_efi_uint64_t length,
|
||||
diff --git a/include/grub/efi/dhcp.h b/include/grub/efi/dhcp.h
|
||||
index fdb88eb81..d996716e4 100644
|
||||
--- a/include/grub/efi/dhcp.h
|
||||
+++ b/include/grub/efi/dhcp.h
|
||||
@@ -123,7 +123,7 @@ struct grub_efi_dhcp4_config_data {
|
||||
grub_efi_uint32_t request_try_count;
|
||||
grub_efi_uint32_t *request_timeout;
|
||||
grub_efi_ipv4_address_t client_address;
|
||||
- grub_efi_status_t (*dhcp4_callback) (
|
||||
+ grub_efi_status_t (__grub_efi_api *dhcp4_callback) (
|
||||
grub_efi_dhcp4_protocol_t *this,
|
||||
void *context,
|
||||
grub_efi_dhcp4_state_t current_state,
|
||||
@@ -153,27 +153,27 @@ struct grub_efi_dhcp4_mode_data {
|
||||
typedef struct grub_efi_dhcp4_mode_data grub_efi_dhcp4_mode_data_t;
|
||||
|
||||
struct grub_efi_dhcp4_protocol {
|
||||
- grub_efi_status_t (*get_mode_data) (grub_efi_dhcp4_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *get_mode_data) (grub_efi_dhcp4_protocol_t *this,
|
||||
grub_efi_dhcp4_mode_data_t *dhcp4_mode_data);
|
||||
- grub_efi_status_t (*configure) (grub_efi_dhcp4_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *configure) (grub_efi_dhcp4_protocol_t *this,
|
||||
grub_efi_dhcp4_config_data_t *dhcp4_cfg_data);
|
||||
- grub_efi_status_t (*start) (grub_efi_dhcp4_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *start) (grub_efi_dhcp4_protocol_t *this,
|
||||
grub_efi_event_t completion_event);
|
||||
- grub_efi_status_t (*renew_rebind) (grub_efi_dhcp4_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *renew_rebind) (grub_efi_dhcp4_protocol_t *this,
|
||||
grub_efi_boolean_t rebind_request,
|
||||
grub_efi_event_t completion_event);
|
||||
- grub_efi_status_t (*release) (grub_efi_dhcp4_protocol_t *this);
|
||||
- grub_efi_status_t (*stop) (grub_efi_dhcp4_protocol_t *this);
|
||||
- grub_efi_status_t (*build) (grub_efi_dhcp4_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *release) (grub_efi_dhcp4_protocol_t *this);
|
||||
+ grub_efi_status_t (__grub_efi_api *stop) (grub_efi_dhcp4_protocol_t *this);
|
||||
+ grub_efi_status_t (__grub_efi_api *build) (grub_efi_dhcp4_protocol_t *this,
|
||||
grub_efi_dhcp4_packet_t *seed_packet,
|
||||
grub_efi_uint32_t delete_count,
|
||||
grub_efi_uint8_t *delete_list,
|
||||
grub_efi_uint32_t append_count,
|
||||
grub_efi_dhcp4_packet_option_t *append_list[],
|
||||
grub_efi_dhcp4_packet_t **new_packet);
|
||||
- grub_efi_status_t (*transmit_receive) (grub_efi_dhcp4_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *transmit_receive) (grub_efi_dhcp4_protocol_t *this,
|
||||
grub_efi_dhcp4_transmit_receive_token_t *token);
|
||||
- grub_efi_status_t (*parse) (grub_efi_dhcp4_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *parse) (grub_efi_dhcp4_protocol_t *this,
|
||||
grub_efi_dhcp4_packet_t *packet,
|
||||
grub_efi_uint32_t *option_count,
|
||||
grub_efi_dhcp4_packet_option_t *packet_option_list[]);
|
||||
@@ -289,7 +289,7 @@ struct grub_efi_dhcp6_mode_data {
|
||||
typedef struct grub_efi_dhcp6_mode_data grub_efi_dhcp6_mode_data_t;
|
||||
|
||||
struct grub_efi_dhcp6_config_data {
|
||||
- grub_efi_status_t (*dhcp6_callback) (grub_efi_dhcp6_protocol_t this,
|
||||
+ grub_efi_status_t (__grub_efi_api *dhcp6_callback) (grub_efi_dhcp6_protocol_t this,
|
||||
void *context,
|
||||
grub_efi_dhcp6_state_t current_state,
|
||||
grub_efi_dhcp6_event_t dhcp6_event,
|
||||
@@ -308,33 +308,33 @@ struct grub_efi_dhcp6_config_data {
|
||||
typedef struct grub_efi_dhcp6_config_data grub_efi_dhcp6_config_data_t;
|
||||
|
||||
struct grub_efi_dhcp6_protocol {
|
||||
- grub_efi_status_t (*get_mode_data) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *get_mode_data) (grub_efi_dhcp6_protocol_t *this,
|
||||
grub_efi_dhcp6_mode_data_t *dhcp6_mode_data,
|
||||
grub_efi_dhcp6_config_data_t *dhcp6_config_data);
|
||||
- grub_efi_status_t (*configure) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *configure) (grub_efi_dhcp6_protocol_t *this,
|
||||
grub_efi_dhcp6_config_data_t *dhcp6_cfg_data);
|
||||
- grub_efi_status_t (*start) (grub_efi_dhcp6_protocol_t *this);
|
||||
- grub_efi_status_t (*info_request) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *start) (grub_efi_dhcp6_protocol_t *this);
|
||||
+ grub_efi_status_t (__grub_efi_api *info_request) (grub_efi_dhcp6_protocol_t *this,
|
||||
grub_efi_boolean_t send_client_id,
|
||||
grub_efi_dhcp6_packet_option_t *option_request,
|
||||
grub_efi_uint32_t option_count,
|
||||
grub_efi_dhcp6_packet_option_t *option_list[],
|
||||
grub_efi_dhcp6_retransmission_t *retransmission,
|
||||
grub_efi_event_t timeout_event,
|
||||
- grub_efi_status_t (*reply_callback) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *reply_callback) (grub_efi_dhcp6_protocol_t *this,
|
||||
void *context,
|
||||
grub_efi_dhcp6_packet_t *packet),
|
||||
void *callback_context);
|
||||
- grub_efi_status_t (*renew_rebind) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *renew_rebind) (grub_efi_dhcp6_protocol_t *this,
|
||||
grub_efi_boolean_t rebind_request);
|
||||
- grub_efi_status_t (*decline) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *decline) (grub_efi_dhcp6_protocol_t *this,
|
||||
grub_efi_uint32_t address_count,
|
||||
grub_efi_ipv6_address_t *addresses);
|
||||
- grub_efi_status_t (*release) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *release) (grub_efi_dhcp6_protocol_t *this,
|
||||
grub_efi_uint32_t address_count,
|
||||
grub_efi_ipv6_address_t *addresses);
|
||||
- grub_efi_status_t (*stop) (grub_efi_dhcp6_protocol_t *this);
|
||||
- grub_efi_status_t (*parse) (grub_efi_dhcp6_protocol_t *this,
|
||||
+ grub_efi_status_t (__grub_efi_api *stop) (grub_efi_dhcp6_protocol_t *this);
|
||||
+ grub_efi_status_t (__grub_efi_api *parse) (grub_efi_dhcp6_protocol_t *this,
|
||||
grub_efi_dhcp6_packet_t *packet,
|
||||
grub_efi_uint32_t *option_count,
|
||||
grub_efi_dhcp6_packet_option_t *packet_option_list[]);
|
||||
diff --git a/include/grub/efi/edid.h b/include/grub/efi/edid.h
|
||||
index 43c0c4372..ac1b8e2fd 100644
|
||||
--- a/include/grub/efi/edid.h
|
||||
+++ b/include/grub/efi/edid.h
|
||||
@@ -33,7 +33,7 @@
|
||||
struct grub_efi_edid_override;
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_edid_override_get_edid) (struct grub_efi_edid_override *this,
|
||||
+(__grub_efi_api *grub_efi_edid_override_get_edid) (struct grub_efi_edid_override *this,
|
||||
grub_efi_handle_t *childhandle,
|
||||
grub_efi_uint32_t *attributes,
|
||||
grub_efi_uintn_t *edidsize,
|
||||
diff --git a/include/grub/efi/http.h b/include/grub/efi/http.h
|
||||
index ad164ba19..242d001b6 100644
|
||||
--- a/include/grub/efi/http.h
|
||||
+++ b/include/grub/efi/http.h
|
||||
@@ -188,27 +188,27 @@ typedef struct {
|
||||
|
||||
struct grub_efi_http {
|
||||
grub_efi_status_t
|
||||
- (*get_mode_data) (struct grub_efi_http *this,
|
||||
+ (__grub_efi_api *get_mode_data) (struct grub_efi_http *this,
|
||||
grub_efi_http_config_data_t *http_config_data);
|
||||
|
||||
grub_efi_status_t
|
||||
- (*configure) (struct grub_efi_http *this,
|
||||
+ (__grub_efi_api *configure) (struct grub_efi_http *this,
|
||||
grub_efi_http_config_data_t *http_config_data);
|
||||
|
||||
grub_efi_status_t
|
||||
- (*request) (struct grub_efi_http *this,
|
||||
+ (__grub_efi_api *request) (struct grub_efi_http *this,
|
||||
grub_efi_http_token_t *token);
|
||||
|
||||
grub_efi_status_t
|
||||
- (*cancel) (struct grub_efi_http *this,
|
||||
+ (__grub_efi_api *cancel) (struct grub_efi_http *this,
|
||||
grub_efi_http_token_t *token);
|
||||
|
||||
grub_efi_status_t
|
||||
- (*response) (struct grub_efi_http *this,
|
||||
+ (__grub_efi_api *response) (struct grub_efi_http *this,
|
||||
grub_efi_http_token_t *token);
|
||||
|
||||
grub_efi_status_t
|
||||
- (*poll) (struct grub_efi_http *this);
|
||||
+ (__grub_efi_api *poll) (struct grub_efi_http *this);
|
||||
};
|
||||
typedef struct grub_efi_http grub_efi_http_t;
|
||||
|
||||
diff --git a/include/grub/efi/pci.h b/include/grub/efi/pci.h
|
||||
index b17245549..a90f61042 100644
|
||||
--- a/include/grub/efi/pci.h
|
||||
+++ b/include/grub/efi/pci.h
|
||||
@@ -48,7 +48,7 @@ typedef enum
|
||||
struct grub_efi_pci_io;
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_mem_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_mem_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint8_t bar_index,
|
||||
grub_efi_uint64_t offset,
|
||||
@@ -56,7 +56,7 @@ typedef grub_efi_status_t
|
||||
void *buffer);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_config_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_config_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint32_t offset,
|
||||
grub_efi_uintn_t count,
|
||||
@@ -113,7 +113,7 @@ typedef enum
|
||||
grub_efi_pci_io_attribute_operation_t;
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_poll_io_mem_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_poll_io_mem_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint8_t bar_ndex,
|
||||
grub_efi_uint64_t offset,
|
||||
@@ -123,7 +123,7 @@ typedef grub_efi_status_t
|
||||
grub_efi_uint64_t *result);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_copy_mem_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_copy_mem_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint8_t dest_bar_index,
|
||||
grub_efi_uint64_t dest_offset,
|
||||
@@ -132,7 +132,7 @@ typedef grub_efi_status_t
|
||||
grub_efi_uintn_t count);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_map_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_map_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_pci_io_operation_t operation,
|
||||
void *host_address,
|
||||
grub_efi_uintn_t *number_of_bytes,
|
||||
@@ -140,11 +140,11 @@ typedef grub_efi_status_t
|
||||
void **mapping);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_unmap_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_unmap_t) (struct grub_efi_pci_io *this,
|
||||
void *mapping);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_allocate_buffer_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_allocate_buffer_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_allocate_type_t type,
|
||||
grub_efi_memory_type_t memory_type,
|
||||
grub_efi_uintn_t pages,
|
||||
@@ -152,7 +152,7 @@ typedef grub_efi_status_t
|
||||
grub_efi_uint64_t attributes);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_free_buffer_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_free_buffer_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_allocate_type_t type,
|
||||
grub_efi_memory_type_t memory_type,
|
||||
grub_efi_uintn_t pages,
|
||||
@@ -160,29 +160,29 @@ typedef grub_efi_status_t
|
||||
grub_efi_uint64_t attributes);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_flush_t) (struct grub_efi_pci_io *this);
|
||||
+(__grub_efi_api *grub_efi_pci_io_flush_t) (struct grub_efi_pci_io *this);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_get_location_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_get_location_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_uintn_t *segment_number,
|
||||
grub_efi_uintn_t *bus_number,
|
||||
grub_efi_uintn_t *device_number,
|
||||
grub_efi_uintn_t *function_number);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_attributes_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_attributes_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_pci_io_attribute_operation_t operation,
|
||||
grub_efi_uint64_t attributes,
|
||||
grub_efi_uint64_t *result);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_get_bar_attributes_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_get_bar_attributes_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_uint8_t bar_index,
|
||||
grub_efi_uint64_t *supports,
|
||||
void **resources);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_io_set_bar_attributes_t) (struct grub_efi_pci_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_io_set_bar_attributes_t) (struct grub_efi_pci_io *this,
|
||||
grub_efi_uint64_t attributes,
|
||||
grub_efi_uint8_t bar_index,
|
||||
grub_efi_uint64_t *offset,
|
||||
@@ -212,12 +212,12 @@ struct grub_efi_pci_root_io;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
- grub_efi_status_t(*read) (struct grub_efi_pci_root_io *this,
|
||||
+ grub_efi_status_t(__grub_efi_api *read) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint64_t address,
|
||||
grub_efi_uintn_t count,
|
||||
void *buffer);
|
||||
- grub_efi_status_t(*write) (struct grub_efi_pci_root_io *this,
|
||||
+ grub_efi_status_t(__grub_efi_api *write) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint64_t address,
|
||||
grub_efi_uintn_t count,
|
||||
@@ -237,7 +237,7 @@ typedef enum
|
||||
grub_efi_pci_root_io_operation_t;
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_poll_io_mem_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_poll_io_mem_t) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint64_t address,
|
||||
grub_efi_uint64_t mask,
|
||||
@@ -246,7 +246,7 @@ typedef grub_efi_status_t
|
||||
grub_efi_uint64_t *result);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_copy_mem_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_copy_mem_t) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_pci_io_width_t width,
|
||||
grub_efi_uint64_t dest_offset,
|
||||
grub_efi_uint64_t src_offset,
|
||||
@@ -254,7 +254,7 @@ typedef grub_efi_status_t
|
||||
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_map_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_map_t) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_pci_root_io_operation_t operation,
|
||||
void *host_address,
|
||||
grub_efi_uintn_t *number_of_bytes,
|
||||
@@ -262,11 +262,11 @@ typedef grub_efi_status_t
|
||||
void **mapping);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_unmap_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_unmap_t) (struct grub_efi_pci_root_io *this,
|
||||
void *mapping);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_allocate_buffer_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_allocate_buffer_t) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_allocate_type_t type,
|
||||
grub_efi_memory_type_t memory_type,
|
||||
grub_efi_uintn_t pages,
|
||||
@@ -274,26 +274,26 @@ typedef grub_efi_status_t
|
||||
grub_efi_uint64_t attributes);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_free_buffer_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_free_buffer_t) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_uintn_t pages,
|
||||
void **host_address);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_flush_t) (struct grub_efi_pci_root_io *this);
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_flush_t) (struct grub_efi_pci_root_io *this);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_get_attributes_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_get_attributes_t) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_uint64_t *supports,
|
||||
void **resources);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_set_attributes_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_set_attributes_t) (struct grub_efi_pci_root_io *this,
|
||||
grub_efi_uint64_t attributes,
|
||||
grub_efi_uint64_t *offset,
|
||||
grub_efi_uint64_t *length);
|
||||
|
||||
typedef grub_efi_status_t
|
||||
-(*grub_efi_pci_root_io_configuration_t) (struct grub_efi_pci_root_io *this,
|
||||
+(__grub_efi_api *grub_efi_pci_root_io_configuration_t) (struct grub_efi_pci_root_io *this,
|
||||
void **resources);
|
||||
|
||||
struct grub_efi_pci_root_io {
|
@ -1,23 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Leo Sandoval <lsandova@redhat.com>
|
||||
Date: Wed, 28 Aug 2024 13:37:42 -0600
|
||||
Subject: [PATCH] grub-core/net/arp.c: fix variable name
|
||||
|
||||
Signed-off-by: Leo Sandoval <lsandova@redhat.com>
|
||||
---
|
||||
grub-core/net/arp.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/grub-core/net/arp.c b/grub-core/net/arp.c
|
||||
index 8bf0a06e1..7adeb7447 100644
|
||||
--- a/grub-core/net/arp.c
|
||||
+++ b/grub-core/net/arp.c
|
||||
@@ -159,7 +159,7 @@ grub_net_arp_receive (struct grub_net_buff *nb, struct grub_net_card *card,
|
||||
sender_addr.option = 0;
|
||||
target_addr.option = 0;
|
||||
|
||||
- grub_memcpy(&target_addr.ipv4, tmp_ptr, pln);
|
||||
+ grub_memcpy(&sender_addr.ipv4, tmp_ptr, pln);
|
||||
tmp_ptr += pln;
|
||||
|
||||
grub_net_link_layer_add_address (card, &sender_addr, &sender_mac_addr, 1);
|
@ -1,44 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Leo Sandoval <lsandova@redhat.com>
|
||||
Date: Wed, 4 Sep 2024 13:25:23 -0600
|
||||
Subject: [PATCH] load EFI commands inside test expressions
|
||||
|
||||
These two commands may fail interrumping the normal boot process,
|
||||
so placing these inside test expressions is a safer approach.
|
||||
|
||||
Resolves: #2305291
|
||||
Suggested-by: Kan-Ru Chen: <kanru@kanru.info>
|
||||
Signed-off-by: Leo Sandoval <lsandova@redhat.com>
|
||||
---
|
||||
util/grub.d/25_bli.in | 4 +++-
|
||||
util/grub.d/30_uefi-firmware.in | 3 +--
|
||||
2 files changed, 4 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/util/grub.d/25_bli.in b/util/grub.d/25_bli.in
|
||||
index 26e27a019..00a8d7159 100644
|
||||
--- a/util/grub.d/25_bli.in
|
||||
+++ b/util/grub.d/25_bli.in
|
||||
@@ -19,6 +19,8 @@ set -e
|
||||
|
||||
cat << EOF
|
||||
if [ "\$grub_platform" = "efi" ]; then
|
||||
- insmod bli
|
||||
+ if [ ! insmod bli ]; then
|
||||
+ echo "bli module not available"
|
||||
+ fi
|
||||
fi
|
||||
EOF
|
||||
diff --git a/util/grub.d/30_uefi-firmware.in b/util/grub.d/30_uefi-firmware.in
|
||||
index 1c2365ddb..1ef31e08f 100644
|
||||
--- a/util/grub.d/30_uefi-firmware.in
|
||||
+++ b/util/grub.d/30_uefi-firmware.in
|
||||
@@ -32,8 +32,7 @@ gettext_printf "Adding boot menu entry for UEFI Firmware Settings ...\n" >&2
|
||||
|
||||
cat << EOF
|
||||
if [ "\$grub_platform" = "efi" ]; then
|
||||
- fwsetup --is-supported
|
||||
- if [ "\$?" = 0 ]; then
|
||||
+ if [ fwsetup --is-supported ]; then
|
||||
menuentry '$LABEL' \$menuentry_id_option 'uefi-firmware' {
|
||||
fwsetup
|
||||
}
|
@ -1,25 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Nicolas Frayer <nfrayer@redhat.com>
|
||||
Date: Wed, 25 Sep 2024 17:23:33 +0200
|
||||
Subject: [PATCH] efi/loader: Check if NX is required in grub_efi_linux_boot()
|
||||
|
||||
Call grub_efi_check_nx_required() passing it nx_required to
|
||||
assign the correct value
|
||||
|
||||
Signed-off-by: Nicolas Frayer <nfrayer@redhat.com>
|
||||
---
|
||||
grub-core/loader/efi/linux.c | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
||||
index 0d1804b602da..5889e3f36f89 100644
|
||||
--- a/grub-core/loader/efi/linux.c
|
||||
+++ b/grub-core/loader/efi/linux.c
|
||||
@@ -236,6 +236,7 @@ grub_efi_linux_boot (grub_addr_t k_address, grub_size_t k_size,
|
||||
grub_dprintf ("linux", "kernel_address: %p handover_offset: %p params: %p\n",
|
||||
(void *)k_address, (void *)h_offset, k_params);
|
||||
|
||||
+ grub_efi_check_nx_required(&nx_required);
|
||||
|
||||
if (nx_required && !nx_supported)
|
||||
return grub_error (GRUB_ERR_BAD_OS, N_("kernel does not support NX loading required by policy"));
|
@ -1,80 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Hans de Goede <hdegoede@redhat.com>
|
||||
Date: Thu, 3 Oct 2024 12:26:07 +0200
|
||||
Subject: [PATCH] Stop grub.efi from always printing "dynamic_load_symbols
|
||||
%p\n" during boot
|
||||
|
||||
Commit 972aa68d2bf5 ("Make a "gdb" dprintf that tells us load addresses.")
|
||||
added some debug prints to help with running gdb against grub.
|
||||
|
||||
Besides adding a new grub_dl_print_gdb_info () function which uses
|
||||
`grub_qdprintf ("gdb", ...);` it also adds a new grub_efi_print_gdb_info ()
|
||||
call to grub_efi_init ().
|
||||
|
||||
grub_efi_print_gdb_info () is intended for the gdbinfo command and uses
|
||||
a non debug grub_printf () call leading to grub now always printing this
|
||||
message during boot breaking flicker-free boot.
|
||||
|
||||
Add a new "debug" parameter to grub_efi_print_gdb_info () and use
|
||||
`grub_qdprintf ("gdb", ...);` when this is set to silence the printing
|
||||
done from grub_efi_init () when debugging is not enabled.
|
||||
|
||||
Fixes: 972aa68d2bf5 ("Make a "gdb" dprintf that tells us load addresses.")
|
||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
||||
---
|
||||
grub-core/kern/efi/debug.c | 2 +-
|
||||
grub-core/kern/efi/init.c | 2 +-
|
||||
include/grub/efi/debug.h | 7 +++++--
|
||||
3 files changed, 7 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/grub-core/kern/efi/debug.c b/grub-core/kern/efi/debug.c
|
||||
index 5d2ab1a36ff4..5ac194fc8f46 100644
|
||||
--- a/grub-core/kern/efi/debug.c
|
||||
+++ b/grub-core/kern/efi/debug.c
|
||||
@@ -26,7 +26,7 @@ grub_cmd_gdbinfo (struct grub_command *cmd __attribute__ ((unused)),
|
||||
int argc __attribute__ ((unused)),
|
||||
char **args __attribute__ ((unused)))
|
||||
{
|
||||
- grub_efi_print_gdb_info ();
|
||||
+ grub_efi_print_gdb_info (false);
|
||||
return 0;
|
||||
}
|
||||
|
||||
diff --git a/grub-core/kern/efi/init.c b/grub-core/kern/efi/init.c
|
||||
index d35d69747342..ce8a7fe7122f 100644
|
||||
--- a/grub-core/kern/efi/init.c
|
||||
+++ b/grub-core/kern/efi/init.c
|
||||
@@ -157,7 +157,7 @@ grub_efi_init (void)
|
||||
grub_efi_system_table->boot_services->set_watchdog_timer (0, 0, 0, NULL);
|
||||
|
||||
grub_efi_env_init ();
|
||||
- grub_efi_print_gdb_info ();
|
||||
+ grub_efi_print_gdb_info (true);
|
||||
grub_efidisk_init ();
|
||||
|
||||
grub_efi_register_debug_commands ();
|
||||
diff --git a/include/grub/efi/debug.h b/include/grub/efi/debug.h
|
||||
index c2d2a03b06f1..961e591afa3e 100644
|
||||
--- a/include/grub/efi/debug.h
|
||||
+++ b/include/grub/efi/debug.h
|
||||
@@ -27,7 +27,7 @@
|
||||
void grub_efi_register_debug_commands (void);
|
||||
|
||||
static inline void
|
||||
-grub_efi_print_gdb_info (void)
|
||||
+grub_efi_print_gdb_info (bool debug)
|
||||
{
|
||||
grub_addr_t text;
|
||||
|
||||
@@ -35,7 +35,10 @@ grub_efi_print_gdb_info (void)
|
||||
if (!text)
|
||||
return;
|
||||
|
||||
- grub_printf ("dynamic_load_symbols %p\n", (void *)text);
|
||||
+ if (debug)
|
||||
+ grub_qdprintf ("gdb", "dynamic_load_symbols %p\n", (void *)text);
|
||||
+ else
|
||||
+ grub_printf ("dynamic_load_symbols %p\n", (void *)text);
|
||||
}
|
||||
|
||||
#endif /* ! GRUB_EFI_DEBUG_HEADER */
|
@ -1,34 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Benjamin Herrenschmidt <benh@kernel.crashing.org>
|
||||
Date: Wed, 16 Oct 2024 16:20:24 +1100
|
||||
Subject: [PATCH] acpi: Fix out of bounds access in grub_acpi_xsdt_find_table()
|
||||
|
||||
The calculation of the size of the table was incorrect (copy/pasta from
|
||||
grub_acpi_rsdt_find_table() I assume...). The entries are 64-bit long.
|
||||
|
||||
This causes us to access beyond the end of the table which is causing
|
||||
crashes during boot on some systems. Typically this is causing a crash
|
||||
on VMWare when using UEFI and enabling serial autodetection, as
|
||||
|
||||
grub_acpi_find_table (GRUB_ACPI_SPCR_SIGNATURE);
|
||||
|
||||
Will goes past the end of the table (the SPCR table doesn't exits)
|
||||
|
||||
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
|
||||
---
|
||||
grub-core/kern/acpi.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/grub-core/kern/acpi.c b/grub-core/kern/acpi.c
|
||||
index 48ded4e2ea6e..8ff0835d501f 100644
|
||||
--- a/grub-core/kern/acpi.c
|
||||
+++ b/grub-core/kern/acpi.c
|
||||
@@ -75,7 +75,7 @@ grub_acpi_xsdt_find_table (struct grub_acpi_table_header *xsdt, const char *sig)
|
||||
return 0;
|
||||
|
||||
ptr = (grub_unaligned_uint64_t *) (xsdt + 1);
|
||||
- s = (xsdt->length - sizeof (*xsdt)) / sizeof (grub_uint32_t);
|
||||
+ s = (xsdt->length - sizeof (*xsdt)) / sizeof (grub_uint64_t);
|
||||
for (; s; s--, ptr++)
|
||||
{
|
||||
struct grub_acpi_table_header *tbl;
|
@ -1,59 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Nicolas Frayer <nfrayer@redhat.com>
|
||||
Date: Wed, 16 Oct 2024 15:50:32 +0200
|
||||
Subject: [PATCH] cmd/search: Fix a possible NULL ptr dereference
|
||||
|
||||
When querying about a partition UUID, we're not checking
|
||||
for get_device_uuid() return value, which can possibly
|
||||
result in dereferencing a NULL pointer.
|
||||
|
||||
Signed-off-by: Nicolas Frayer <nfrayer@redhat.com>
|
||||
Co-authored-by: Chuong Tran <anhchuong89@gmail.com>
|
||||
---
|
||||
grub-core/commands/search.c | 28 +++++++++++++++-------------
|
||||
1 file changed, 15 insertions(+), 13 deletions(-)
|
||||
|
||||
diff --git a/grub-core/commands/search.c b/grub-core/commands/search.c
|
||||
index 9dd937e6df4e..d538b36219fb 100644
|
||||
--- a/grub-core/commands/search.c
|
||||
+++ b/grub-core/commands/search.c
|
||||
@@ -212,24 +212,26 @@ iterate_device (const char *name, void *data)
|
||||
struct uuid_context uuid_ctx;
|
||||
int ret = 0;
|
||||
|
||||
- get_device_uuid(name, &quid_name);
|
||||
- if (!grub_strcmp(quid_name, ctx->key))
|
||||
+ if (get_device_uuid(name, &quid_name))
|
||||
{
|
||||
- uuid_ctx.name = name;
|
||||
- uuid_ctx.uuid = quid_name;
|
||||
+ if (!grub_strcmp(quid_name, ctx->key))
|
||||
+ {
|
||||
+ uuid_ctx.name = name;
|
||||
+ uuid_ctx.uuid = quid_name;
|
||||
|
||||
- ret = grub_device_iterate (check_for_duplicate, &uuid_ctx);
|
||||
+ ret = grub_device_iterate (check_for_duplicate, &uuid_ctx);
|
||||
|
||||
- if (ret)
|
||||
- {
|
||||
- grub_printf("Duplicated media UUID found, rebooting ...\n");
|
||||
- grub_sleep(10);
|
||||
- grub_reboot();
|
||||
- }
|
||||
- }
|
||||
+ if (ret)
|
||||
+ {
|
||||
+ grub_printf("Duplicated media UUID found, rebooting ...\n");
|
||||
+ grub_sleep(10);
|
||||
+ grub_reboot();
|
||||
+ }
|
||||
+ }
|
||||
|
||||
- if (quid_name) grub_free (quid_name);
|
||||
+ if (quid_name) grub_free (quid_name);
|
||||
|
||||
+ }
|
||||
}
|
||||
}
|
||||
}
|
@ -1,44 +0,0 @@
|
||||
From c5ae124e11f28f637cbd38cb4d6c1b9817baa135 Mon Sep 17 00:00:00 2001
|
||||
From: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
|
||||
Date: Mon, 12 Aug 2024 16:13:18 +0200
|
||||
Subject: [PATCH] kern/riscv/efi/init: Use time register in
|
||||
grub_efi_get_time_ms()
|
||||
|
||||
The cycle register is not guaranteed to count at constant frequency.
|
||||
If it is counting at all depends on the state the performance monitoring
|
||||
unit. Use the time register to measure time.
|
||||
|
||||
Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
|
||||
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
|
||||
---
|
||||
grub-core/kern/riscv/efi/init.c | 15 +++++++--------
|
||||
1 file changed, 7 insertions(+), 8 deletions(-)
|
||||
|
||||
diff --git a/grub-core/kern/riscv/efi/init.c b/grub-core/kern/riscv/efi/init.c
|
||||
index 38795fe67..0d7de4f54 100644
|
||||
--- a/grub-core/kern/riscv/efi/init.c
|
||||
+++ b/grub-core/kern/riscv/efi/init.c
|
||||
@@ -33,16 +33,15 @@ grub_efi_get_time_ms (void)
|
||||
grub_uint64_t tmr;
|
||||
|
||||
#if __riscv_xlen == 64
|
||||
- asm volatile ("rdcycle %0" : "=r" (tmr));
|
||||
+ asm volatile ("rdtime %0" : "=r"(tmr));
|
||||
#else
|
||||
grub_uint32_t lo, hi, tmp;
|
||||
- asm volatile (
|
||||
- "1:\n"
|
||||
- "rdcycleh %0\n"
|
||||
- "rdcycle %1\n"
|
||||
- "rdcycleh %2\n"
|
||||
- "bne %0, %2, 1b"
|
||||
- : "=&r" (hi), "=&r" (lo), "=&r" (tmp));
|
||||
+ asm volatile ("1:\n"
|
||||
+ "rdtimeh %0\n"
|
||||
+ "rdtime %1\n"
|
||||
+ "rdtimeh %2\n"
|
||||
+ "bne %0, %2, 1b"
|
||||
+ : "=&r" (hi), "=&r" (lo), "=&r" (tmp));
|
||||
tmr = ((grub_uint64_t)hi << 32) | lo;
|
||||
#endif
|
||||
|
@ -1,36 +0,0 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Jason Montleon <jason@montleon.com>
|
||||
Date: Fri, 3 May 2024 13:18:37 -0400
|
||||
Subject: [PATCH] Use medany instead of large model for RISCV
|
||||
|
||||
Signed-off-by: Jason Montleon <jason@montleon.com>
|
||||
---
|
||||
configure.ac | 6 ++++--
|
||||
1 file changed, 4 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/configure.ac b/configure.ac
|
||||
index d223fe3ef6e..6a6688e362a 100644
|
||||
--- a/configure.ac
|
||||
+++ b/configure.ac
|
||||
@@ -1313,7 +1313,7 @@ AC_SUBST(TARGET_LDFLAGS_OLDMAGIC)
|
||||
|
||||
LDFLAGS="$TARGET_LDFLAGS"
|
||||
|
||||
-if test "$target_cpu" = x86_64 || test "$target_cpu" = sparc64 || test "$target_cpu" = riscv64 ; then
|
||||
+if test "$target_cpu" = x86_64 || test "$target_cpu" = sparc64 ; then
|
||||
# Use large model to support 4G memory
|
||||
AC_CACHE_CHECK([whether option -mcmodel=large works], grub_cv_cc_mcmodel, [
|
||||
CFLAGS="$TARGET_CFLAGS -mcmodel=large"
|
||||
@@ -1323,9 +1323,11 @@ if test "$target_cpu" = x86_64 || test "$target_cpu" = sparc64 || test "$target_
|
||||
])
|
||||
if test "x$grub_cv_cc_mcmodel" = xyes; then
|
||||
TARGET_CFLAGS="$TARGET_CFLAGS -mcmodel=large"
|
||||
- elif test "$target_cpu" = sparc64 || test "$target_cpu" = riscv64; then
|
||||
+ elif test "$target_cpu" = sparc64; then
|
||||
TARGET_CFLAGS="$TARGET_CFLAGS -mcmodel=medany"
|
||||
fi
|
||||
+elif test "$target_cpu" = riscv64 ; then
|
||||
+ TARGET_CFLAGS="$TARGET_CFLAGS -mcmodel=medany"
|
||||
fi
|
||||
|
||||
if test "$target_cpu"-"$platform" = x86_64-efi; then
|
@ -15,12 +15,7 @@
|
||||
%endif
|
||||
|
||||
# gnulib actively ignores CFLAGS because it's terrible
|
||||
# build aarch64 gnulib with branch protection
|
||||
%ifarch aarch64
|
||||
%global cc_equals "CC=%{ccpath} -fPIE -Wl,-z,noexecstack -Wl,--no-warn-rwx-segments -mbranch-protection=standard"
|
||||
%else
|
||||
%global cc_equals "CC=%{ccpath} -fPIE -Wl,-z,noexecstack -Wl,--no-warn-rwx-segments"
|
||||
%endif
|
||||
|
||||
%global cflags_sed \\\
|
||||
sed \\\
|
||||
|
17
grub.patches
17
grub.patches
@ -250,40 +250,23 @@ Patch0249: 0249-grub-set-bootflag-Conservative-partial-fix-for-CVE-2.patch
|
||||
Patch0250: 0250-grub-set-bootflag-More-complete-fix-for-CVE-2024-104.patch
|
||||
Patch0251: 0251-grub-set-bootflag-Exit-calmly-when-not-running-as-ro.patch
|
||||
Patch0252: 0252-Makefile.core.def-fix-linux-module.patch
|
||||
%ifnarch riscv64
|
||||
Patch0253: 0253-Add-support-for-Linux-EFI-stub-loading-on-arm-archit.patch
|
||||
Patch0254: 0254-arm-arm64-loader-Better-memory-allocation-and-error-.patch
|
||||
Patch0255: 0255-arm64-Fix-EFI-loader-kernel-image-allocation.patch
|
||||
%endif
|
||||
Patch0256: 0256-pe-add-the-DOS-header-struct-and-fix-some-bad-naming.patch
|
||||
%ifnarch riscv64
|
||||
Patch0257: 0257-Correct-BSS-zeroing-on-aarch64.patch
|
||||
Patch0258: 0258-arm64-Use-proper-memory-type-for-kernel-allocation.patch
|
||||
%endif
|
||||
Patch0259: 0259-normal-Remove-grub_env_set-prefix-in-grub_try_normal.patch
|
||||
Patch0260: 0260-fs-xfs-Handle-non-continuous-data-blocks-in-director.patch
|
||||
Patch0261: 0261-Ignore-warnings-for-incompatible-types.patch
|
||||
Patch0262: 0262-cmd-search-Rework-of-CVE-2023-4001-fix.patch
|
||||
%ifnarch riscv64
|
||||
Patch0263: 0263-loader-efi-linux.c-read-the-kernel-image-before-head.patch
|
||||
Patch0264: 0264-nx-set-attrs-in-our-kernel-loaders.patch
|
||||
Patch0265: 0265-efi-Provide-wrappers-for-load_image-start_image.patch
|
||||
Patch0266: 0266-efi-Disallow-fallback-to-legacy-Linux-loader-when-sh.patch
|
||||
%endif
|
||||
Patch0267: 0267-Set-non-executable-stack-sections-on-EFI-assembly-fi.patch
|
||||
Patch0268: 0268-grub-mkconfig.in-turn-off-executable-owner-bit.patch
|
||||
Patch0269: 0269-kern-ieee1275-init-Add-IEEE-1275-Radix-support-for-K.patch
|
||||
Patch0270: 0270-grub2-mkconfig-Ensure-grub-cfg-stub-is-not-overwritt.patch
|
||||
Patch0271: 0271-grub2-mkconfig-Simplify-os_name-detection.patch
|
||||
Patch0272: 0272-grub-mkconfig-Remove-check-for-mount-point-for-grub-.patch
|
||||
Patch0273: 0273-efi-api.h-include-missing-__grub_efi_api-macros-on-E.patch
|
||||
Patch0274: 0274-grub-core-net-arp.c-fix-variable-name.patch
|
||||
Patch0275: 0275-load-EFI-commands-inside-test-expressions.patch
|
||||
%ifnarch riscv64
|
||||
Patch0276: 0276-efi-loader-Check-if-NX-is-required-in-grub_efi_linux.patch
|
||||
%endif
|
||||
Patch0277: 0277-Stop-grub.efi-from-always-printing-dynamic_load_symb.patch
|
||||
Patch0278: 0278-acpi-Fix-out-of-bounds-access-in-grub_acpi_xsdt_find.patch
|
||||
Patch0279: 0279-cmd-search-Fix-a-possible-NULL-ptr-dereference.patch
|
||||
Patch0280: 0280-kern-riscv-efi-init-Use-time-register-in-grub_efi_ge.patch
|
||||
Patch0281: 0281-Use-medany-instead-of-large-model-for-RISCV.patch
|
||||
|
31
grub2.spec
31
grub2.spec
@ -17,7 +17,7 @@
|
||||
Name: grub2
|
||||
Epoch: 1
|
||||
Version: 2.12
|
||||
Release: 11.0.riscv64%{?dist}
|
||||
Release: 4%{?dist}
|
||||
Summary: Bootloader with support for Linux, Multiboot and more
|
||||
License: GPL-3.0-or-later
|
||||
URL: http://www.gnu.org/software/grub/
|
||||
@ -560,35 +560,6 @@ mv ${EFI_HOME}/grub.cfg.stb ${EFI_HOME}/grub.cfg
|
||||
%endif
|
||||
|
||||
%changelog
|
||||
* Fri Nov 08 2024 Jason Montleon <jmontleo@redhat.com> - 2.12-11.0.riscv64
|
||||
- Add RISC-V specific patches
|
||||
- Disable ARM patches on RISC-V that break builds
|
||||
|
||||
* Wed Oct 23 2024 Nicolas Frayer <nfrayer@redhat.com> 2.12-11
|
||||
- cmd/search: Fix a possible NULL ptr dereference
|
||||
|
||||
* Thu Oct 17 2024 Nicolas Frayer <nfrayer@redhat.com> 2.12-10
|
||||
- acpi: Fix out of bounds access in grub_acpi_xsdt_find_table()
|
||||
- Resolves: #2317048
|
||||
|
||||
* Thu Oct 3 2024 Nicolas Frayer <nfrayer@redhat.com> 2.12-9
|
||||
- Stop grub.efi from always printing "dynamic_load_symbols %p\n" during boot
|
||||
- Resolves: #2316279
|
||||
|
||||
* Wed Sep 25 2024 Nicolas Frayer <nfrayer@redhat.com> 2.12-8
|
||||
- NX: efi/loader, add a call to grub_efi_check_nx_required()
|
||||
|
||||
* Tue Sep 17 2024 Nicolas Frayer <nfrayer@redhat.com> - 2.12-7
|
||||
- aarch64/macros: Build gnulib with -mbranch-protection=standard
|
||||
|
||||
* Thu Sep 5 2024 Leo Sandoval <lsandova@redhat.com> - 2.12-6
|
||||
- load EFI commands inside test expressions
|
||||
- Resolves: #2305291
|
||||
|
||||
* Thu Aug 29 2024 Leo Sandoval <lsandova@redhat.com> - 2.12-5
|
||||
- Fix netbooting regressions introduced at 2.12-1
|
||||
- Resolves: #2303727
|
||||
|
||||
* Thu Aug 08 2024 Peter Robinson <pbrobinson@fedoraproject.org> 2.12-4
|
||||
- Build using fuse3
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user