diff options
author | Paul Oliver <contact@pauloliver.dev> | 2024-09-07 10:20:52 -0700 |
---|---|---|
committer | Paul Oliver <contact@pauloliver.dev> | 2024-09-07 10:20:52 -0700 |
commit | 7f56d951fe4ad6749e68ac860ea05f572b6d04ed (patch) | |
tree | 3346bdedd8cbaa93eb6ca1b75332bc73648d0ae8 /src | |
parent | 9779eecbee025d757df43b03a0dc27c5148245a5 (diff) |
Allow compiling ancestor at half of max address
Also makes code compatible with older versions of GCC.
Diffstat (limited to 'src')
-rw-r--r-- | src/arch/salis-v1.c | 10 | ||||
-rw-r--r-- | src/salis.c | 23 |
2 files changed, 31 insertions, 2 deletions
diff --git a/src/arch/salis-v1.c b/src/arch/salis-v1.c index 0e8f202..9268d50 100644 --- a/src/arch/salis-v1.c +++ b/src/arch/salis-v1.c @@ -200,7 +200,15 @@ void arch_on_proc_kill(Core *core) { void arch_anc_init(Core *core, u64 size) { assert(core); - proc_fetch(core, 0)->mb0s = size; + Proc *panc = proc_fetch(core, 0); + +#if ANC_HALF == 1 + panc->mb0a = U64_HALF; + panc->ip = U64_HALF; + panc->sp = U64_HALF; +#endif + + panc->mb0s = size; } #endif diff --git a/src/salis.c b/src/salis.c index c3de4f4..24f3966 100644 --- a/src/salis.c +++ b/src/salis.c @@ -27,6 +27,8 @@ #define INST_CAPS (0x80) #define INST_MASK (0x7f) +#define U64_HALF (0x8000000000000000) + typedef struct Core Core; typedef struct Ipcm Ipcm; typedef struct Proc Proc; @@ -296,7 +298,12 @@ u64 core_assemble_ancestor(int cix, const char *anc) { assert(f); - u64 addr = 0; +#if ANC_HALF == 1 + u64 addr = U64_HALF; +#else + u64 addr = 0; +#endif + char line[ASM_LINE_LEN] = {0}; Core *core = &g_cores[cix]; @@ -352,6 +359,10 @@ void core_init(int cix, u64 *seed, const char *anc) { u64 anc_size = core_assemble_ancestor(cix, anc); +#if ANC_HALF == 1 + anc_size -= U64_HALF; +#endif + arch_anc_init(core, anc_size); } #endif @@ -361,6 +372,8 @@ void core_load(FILE *f, Core *core) { assert(f); assert(core); +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wunused-result" fread(&core->mall, sizeof(u64), 1, f); fread( core->muta, sizeof(u64), 4, f); fread(&core->pnum, sizeof(u64), 1, f); @@ -371,6 +384,7 @@ void core_load(FILE *f, Core *core) { fread(&core->psli, sizeof(u64), 1, f); fread(&core->ncyc, sizeof(u64), 1, f); fread(&core->ivpt, sizeof(u64), 1, f); +#pragma GCC diagnostic pop core->iviv = calloc(SYNC_INTERVAL, sizeof(u8)); core->ivav = calloc(SYNC_INTERVAL, sizeof(u64)); @@ -380,10 +394,13 @@ void core_load(FILE *f, Core *core) { assert(core->ivav); assert(core->pvec); +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wunused-result" fread(core->iviv, sizeof(u8), SYNC_INTERVAL, f); fread(core->ivav, sizeof(u64), SYNC_INTERVAL, f); fread(core->pvec, sizeof(Proc), core->pcap, f); fread(core->mvec, sizeof(u8), MVEC_SIZE, f); +#pragma GCC diagnostic pop } #endif @@ -521,8 +538,12 @@ void salis_load() { core_load(f, &g_cores[i]); } +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wunused-result" fread(&g_steps, sizeof(u64), 1, f); fread(&g_syncs, sizeof(u64), 1, f); +#pragma GCC diagnostic pop + fclose(f); } #endif |