> compile NEMU
ysyx_22040000 李心杨 Linux calcite 6.6.19 #1-NixOS SMP PREEMPT_DYNAMIC Fri Mar 1 12:35:11 UTC 2024 x86_64 GNU/Linux 14:34:22 up 1:40, 2 users, load average: 0.73, 0.75, 0.96
This commit is contained in:
parent
a2b9777ea4
commit
de4c8730af
6 changed files with 46 additions and 692 deletions
File diff suppressed because one or more lines are too long
|
@ -1,3 +0,0 @@
|
||||||
#ifndef __DIFFTEST_DEF_H__
|
|
||||||
#define __DIFFTEST_DEF_H__
|
|
||||||
#endif
|
|
15
nemu/include/func.h
Normal file
15
nemu/include/func.h
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#ifndef __FUNC_DEF_H__
|
||||||
|
#define __FUNC_DEF_H__
|
||||||
|
#include <common.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_FTRACE
|
||||||
|
typedef struct {
|
||||||
|
vaddr_t start;
|
||||||
|
vaddr_t len;
|
||||||
|
char * name;
|
||||||
|
} func_t;
|
||||||
|
|
||||||
|
func_t *func_table;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
|
@ -92,6 +92,8 @@
|
||||||
|
|
||||||
#define PG_ALIGN __attribute((aligned(4096)))
|
#define PG_ALIGN __attribute((aligned(4096)))
|
||||||
|
|
||||||
|
#define FAILED_GOTO(tag, exp) do {if((exp)) goto tag;} while(0)
|
||||||
|
|
||||||
#if !defined(likely)
|
#if !defined(likely)
|
||||||
#define likely(cond) __builtin_expect(cond, 1)
|
#define likely(cond) __builtin_expect(cond, 1)
|
||||||
#define unlikely(cond) __builtin_expect(cond, 0)
|
#define unlikely(cond) __builtin_expect(cond, 0)
|
||||||
|
|
|
@ -1,20 +1,26 @@
|
||||||
|
#include "macro.h"
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <elf.h>
|
#include <elf.h>
|
||||||
|
#include <func.h>
|
||||||
|
|
||||||
// Put this into another file
|
// Put this into another file
|
||||||
#ifdef CONFIG_FTRACE
|
#ifdef CONFIG_FTRACE
|
||||||
// static vaddr_t g_function_stack[CONFIG_FTRACE_STACK_SIZE] = {0};
|
// static vaddr_t g_function_stack[CONFIG_FTRACE_STACK_SIZE] = {0};
|
||||||
// static vaddr_t *g_function_start = NULL;
|
// static vaddr_t *g_function_start = NULL;
|
||||||
|
func_t *func_table = NULL;
|
||||||
|
int func_table_len = 0, func_table_size = 8;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define FAILED_GOTO(tag, exp) do {if((exp)) goto tag;} while(0)
|
|
||||||
|
|
||||||
void init_elf(const char *path) {
|
void init_elf(const char *path) {
|
||||||
bool success = false;
|
bool success = false;
|
||||||
FILE *elf_file = fopen(path, "rb");
|
FILE *elf_file = fopen(path, "rb");
|
||||||
Elf32_Ehdr header;
|
Elf32_Ehdr header;
|
||||||
Elf32_Shdr section_header[200], *psh;
|
Elf32_Shdr section_header[200], *psh;
|
||||||
|
|
||||||
|
func_table = (func_t *)malloc(func_table_size);
|
||||||
|
FAILED_GOTO(failed_nosym, func_table == NULL);
|
||||||
|
|
||||||
FAILED_GOTO(failed_nosym, fread(&header, sizeof(Elf32_Ehdr), 1, elf_file) <= 0);
|
FAILED_GOTO(failed_nosym, fread(&header, sizeof(Elf32_Ehdr), 1, elf_file) <= 0);
|
||||||
FAILED_GOTO(failed_nosym, fseek(elf_file, header.e_shoff, SEEK_SET) != 0);
|
FAILED_GOTO(failed_nosym, fseek(elf_file, header.e_shoff, SEEK_SET) != 0);
|
||||||
FAILED_GOTO(failed_nosym, fread(section_header, header.e_shentsize, header.e_shnum, elf_file) <= 0);
|
FAILED_GOTO(failed_nosym, fread(section_header, header.e_shentsize, header.e_shnum, elf_file) <= 0);
|
||||||
|
@ -38,19 +44,27 @@ void init_elf(const char *path) {
|
||||||
FAILED_GOTO(failed_nosym, sym == NULL);
|
FAILED_GOTO(failed_nosym, sym == NULL);
|
||||||
FAILED_GOTO(failed, fseek(elf_file, symtab->sh_offset, SEEK_SET) != 0);
|
FAILED_GOTO(failed, fseek(elf_file, symtab->sh_offset, SEEK_SET) != 0);
|
||||||
FAILED_GOTO(failed, fread(sym, sizeof(Elf32_Sym), sym_length, elf_file) <= 0);
|
FAILED_GOTO(failed, fread(sym, sizeof(Elf32_Sym), sym_length, elf_file) <= 0);
|
||||||
|
|
||||||
// Count how many function symbol in elf file
|
|
||||||
|
|
||||||
for(int j = 0; j < sym_length; j++) {
|
for(int j = 0; j < sym_length; j++) {
|
||||||
if(ELF32_ST_TYPE(sym[j].st_info) != STT_FUNC) continue;
|
if(ELF32_ST_TYPE(sym[j].st_info) != STT_FUNC) continue;
|
||||||
// Only read function type symbol
|
// Only read function type symbol
|
||||||
char func[30];
|
func_t *f = &func_table[func_table_len];
|
||||||
|
char *func = (char *)malloc(30);
|
||||||
FAILED_GOTO(failed, fseek(elf_file, strtab->sh_offset + sym[j].st_name, SEEK_SET) != 0);
|
FAILED_GOTO(failed, fseek(elf_file, strtab->sh_offset + sym[j].st_name, SEEK_SET) != 0);
|
||||||
FAILED_GOTO(failed, fgets(func, 30, elf_file) <= 0);
|
FAILED_GOTO(failed, fgets(func, 30, elf_file) <= 0);
|
||||||
|
f->start = sym[j].st_value;
|
||||||
|
f->len = sym[j].st_size;
|
||||||
|
f->name = func;
|
||||||
|
++func_table_len;
|
||||||
puts(func);
|
puts(func);
|
||||||
}
|
}
|
||||||
success = true;
|
success = true;
|
||||||
failed:
|
failed:
|
||||||
|
for(int i = 0; i < func_table_len; i++) {
|
||||||
|
func_t *f = &func_table[i];
|
||||||
|
if(f->name) { free(f->name); }
|
||||||
|
}
|
||||||
|
free(func_table);
|
||||||
free(sym);
|
free(sym);
|
||||||
failed_shstrtab:
|
failed_shstrtab:
|
||||||
free(shstrtab);
|
free(shstrtab);
|
||||||
|
|
9
nemu/src/utils/utils.c
Normal file
9
nemu/src/utils/utils.c
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <macro.h>
|
||||||
|
|
||||||
|
// void *realloc_and_copy(void *arr, size_t arr_len, size_t arr_size, size_t nmemb, size_t size)
|
||||||
|
// {
|
||||||
|
// Assert(2 * arr_size > arr_size, "Realloc array size exceed size_t limit");
|
||||||
|
// char *p = (char *)arr;
|
||||||
|
// realloc(arr, )
|
||||||
|
// }
|
Loading…
Reference in a new issue