[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 05/10] RISC-V: Add early startup code
From: |
Alexander Graf |
Subject: |
[PATCH v3 05/10] RISC-V: Add early startup code |
Date: |
Wed, 14 Nov 2018 18:27:34 +0100 |
On entry, we need to save the system table pointer as well as our image
handle. Add an early startup file that saves them and then brings us
into our main function.
Signed-off-by: Alexander Graf <address@hidden>
Reviewed-by: Alistair Francis <address@hidden>
---
grub-core/kern/riscv/efi/startup.S | 49 ++++++++++++++++++++++++++++++++++++++
1 file changed, 49 insertions(+)
create mode 100644 grub-core/kern/riscv/efi/startup.S
diff --git a/grub-core/kern/riscv/efi/startup.S
b/grub-core/kern/riscv/efi/startup.S
new file mode 100644
index 000000000..026f99bab
--- /dev/null
+++ b/grub-core/kern/riscv/efi/startup.S
@@ -0,0 +1,49 @@
+/*
+ * GRUB -- GRand Unified Bootloader
+ * Copyright (C) 2013 Free Software Foundation, Inc.
+ *
+ * GRUB is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GRUB is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with GRUB. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <grub/symbol.h>
+
+#if __riscv_xlen == 64
+#define sl sd
+#define ll ld
+#else
+#define sl sw
+#define ll lw
+#endif
+
+
+ .file "startup.S"
+ .text
+FUNCTION(_start)
+ /*
+ * EFI_SYSTEM_TABLE and EFI_HANDLE are passed in a1/a0.
+ */
+
+ ll a2, efi_image_handle_val
+ sl a0, 0(a2)
+ ll a2, efi_system_table_val
+ sl a1, 0(a2)
+ ll a2, grub_main_val
+ jr a2
+grub_main_val:
+ .quad EXT_C(grub_main)
+efi_system_table_val:
+ .quad EXT_C(grub_efi_system_table)
+efi_image_handle_val:
+ .quad EXT_C(grub_efi_image_handle)
+
--
2.12.3
- Re: [PATCH v3 09/10] RISC-V: Add to build system, (continued)
Re: [PATCH v3 09/10] RISC-V: Add to build system, Daniel Kiper, 2018/11/21
[PATCH v3 04/10] RISC-V: Add setjmp implementation, Alexander Graf, 2018/11/14
[PATCH v3 05/10] RISC-V: Add early startup code,
Alexander Graf <=
[PATCH v3 02/10] PE: Add RISC-V definitions, Alexander Graf, 2018/11/14
[PATCH v3 08/10] RISC-V: Add auxiliary files, Alexander Graf, 2018/11/14
Re: [PATCH v3 08/10] RISC-V: Add auxiliary files, Daniel Kiper, 2018/11/21