[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 06/18] bsd-user: Add RISC-V ELF definitions and hardware capabili
From: |
Ajeet Singh |
Subject: |
[PATCH 06/18] bsd-user: Add RISC-V ELF definitions and hardware capability detection |
Date: |
Fri, 2 Aug 2024 18:34:11 +1000 |
From: Mark Corbin <mark.corbin@embecsom.com>
Introduced RISC-V specific ELF definitions and hardware capability
detection.
Additionally, a function to retrieve hardware capabilities
('get_elf_hwcap') is implemented, which returns the common bits set in
each CPU's ISA strings.
Signed-off-by: Mark Corbin <mark.corbin@embecsom.com>
Signed-off-by: Ajeet Singh <itachis@FreeBSD.org>
Co-authored-by: Kyle Evans <kevans@FreeBSD.org>
---
bsd-user/riscv/target_arch_elf.h | 48 ++++++++++++++++++++++++++++++++
1 file changed, 48 insertions(+)
create mode 100644 bsd-user/riscv/target_arch_elf.h
diff --git a/bsd-user/riscv/target_arch_elf.h b/bsd-user/riscv/target_arch_elf.h
new file mode 100644
index 0000000000..dfb2a3e32e
--- /dev/null
+++ b/bsd-user/riscv/target_arch_elf.h
@@ -0,0 +1,48 @@
+/*
+ * RISC-V ELF definitions
+ *
+ * Copyright (c) 2019 Mark Corbin
+ *
+ * This program 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 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program 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 this program; if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef TARGET_ARCH_ELF_H
+#define TARGET_ARCH_ELF_H
+
+#define elf_check_arch(x) ((x) == EM_RISCV)
+#define ELF_START_MMAP 0x80000000
+#define ELF_ET_DYN_LOAD_ADDR 0x100000
+#define ELF_CLASS ELFCLASS64
+
+#define ELF_DATA ELFDATA2LSB
+#define ELF_ARCH EM_RISCV
+
+/*
+ * Note: FreeBSD returns things a litle differently than this, but this is as
+ * close we have in the emulator. The FreeBSD/riscv64 kernel (in identcpu.c)
+ * returns the common bits set in each of the CPUs' ISA strings. Also, unlike
+ * linux, we don't mask out specific bits.
+ */
+#define ELF_HWCAP get_elf_hwcap()
+static uint32_t get_elf_hwcap(void)
+{
+ RISCVCPU *cpu = RISCV_CPU(thread_cpu);
+
+ return cpu->env.misa_ext_mask;
+}
+
+#define USE_ELF_CORE_DUMP
+#define ELF_EXEC_PAGESIZE 4096
+
+#endif /* TARGET_ARCH_ELF_H */
--
2.34.1
- [PATCH 01/18] bsd-user: Implement RISC-V CPU initialization and main loop, (continued)
- [PATCH 01/18] bsd-user: Implement RISC-V CPU initialization and main loop, Ajeet Singh, 2024/08/02
- [PATCH 02/18] bsd-user: Add RISC-V CPU execution loop and syscall handling, Ajeet Singh, 2024/08/02
- [PATCH 03/18] bsd-user: Implement RISC-V CPU register cloning and reset functions, Ajeet Singh, 2024/08/02
- [PATCH 04/18] bsd-user: Implement RISC-V TLS register setup, Ajeet Singh, 2024/08/02
- [PATCH 05/18] bsd-user: Add prototype for RISC-V TLS register setup, Ajeet Singh, 2024/08/02
- [PATCH 06/18] bsd-user: Add RISC-V ELF definitions and hardware capability detection,
Ajeet Singh <=
- [PATCH 07/18] bsd-user: Define RISC-V register structures and register copying, Ajeet Singh, 2024/08/02
- [PATCH 08/18] bsd-user: Add RISC-V signal trampoline setup function, Ajeet Singh, 2024/08/02
- [PATCH 09/18] bsd-user: Implement RISC-V sysarch system call emulation, Ajeet Singh, 2024/08/02
- [PATCH 10/18] bsd-user: Add RISC-V thread setup and initialization support, Ajeet Singh, 2024/08/02