> 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:
tracer-ysyx 2024-03-20 14:34:22 +08:00 committed by xinyangli
parent a2b9777ea4
commit de4c8730af
6 changed files with 46 additions and 692 deletions

File diff suppressed because one or more lines are too long

View file

@ -1,3 +0,0 @@
#ifndef __DIFFTEST_DEF_H__
#define __DIFFTEST_DEF_H__
#endif

15
nemu/include/func.h Normal file
View 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

View file

@ -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)

View file

@ -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);
@ -39,18 +45,26 @@ void init_elf(const char *path) {
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
View 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, )
// }