stack allocation now fixed

This commit is contained in:
Anton Lydike 2021-04-18 12:55:57 +02:00
parent 2b87bbe270
commit cb48d66400
5 changed files with 19 additions and 16 deletions

0
docs/stack.md Normal file
View File

View File

View File

@ -1,3 +1,4 @@
.stack 0xFFFF
.data 0x200
fibs: .space 56

View File

@ -221,8 +221,9 @@ class LoadedMemorySection:
print(FMT_BOLD + FMT_MAGENTA + "..." + FMT_NONE)
def __repr__(self):
return "{} at 0x{:08X} (size={}bytes, flags={}, owner={})".format(
return "{}[{}] at 0x{:08X} (size={}bytes, flags={}, owner={})".format(
self.__class__.__name__,
self.name,
self.base,
self.size,
self.flags,
@ -258,20 +259,6 @@ class LoadedExecutable:
self.exported_symbols = dict()
self.global_symbol_table = dict()
# stack/heap if wanted
if exe.stack_pref is not None:
self.sections.append(LoadedMemorySection(
'stack',
base_addr,
exe.stack_pref,
bytearray(exe.stack_pref),
MemoryFlags(read_only=False, executable=False),
self.name
))
self.stack_heap = (self.base_addr, self.base_addr + exe.stack_pref)
else:
self.stack_heap = (0, 0)
curr = base_addr
for sec in exe.sections.values():
loaded_sec = LoadedMemorySection(
@ -286,6 +273,21 @@ class LoadedExecutable:
self.sections_by_name[loaded_sec.name] = loaded_sec
curr = align_addr(loaded_sec.size + curr)
# stack/heap if wanted
if exe.stack_pref is not None:
self.sections.append(LoadedMemorySection(
'stack',
curr,
exe.stack_pref,
bytearray(exe.stack_pref),
MemoryFlags(read_only=False, executable=False),
self.name
))
self.stack_heap = (curr, curr + exe.stack_pref)
else:
self.stack_heap = (0, 0)
for name, (sec_name, offset) in exe.symbols.items():
if sec_name == '_static_':
self.symbols[name] = offset

View File

@ -98,7 +98,7 @@ class ExecutableParser:
def op_stack(self, op: 'RiscVPseudoOpToken'):
ASSERT_LEN(op.args, 1)
size = parse_numeric_argument(op.args)
size = parse_numeric_argument(op.args[0])
self.stack_pref = size
def op_global(self, op: 'RiscVPseudoOpToken'):