aboutsummaryrefslogtreecommitdiff
path: root/emlink.py
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2013-06-25 20:41:37 -0700
committerAlon Zakai <alonzakai@gmail.com>2013-07-03 15:31:03 -0700
commit5e01920010c51286010e0d59d5b7541aad0678e8 (patch)
tree47391361dc01e41dfee79fa9d3177f9db39f13db /emlink.py
parentb0e85bc8defe0e56c5baf4c1f510572b9f2d5196 (diff)
fix heap merging, add padding and offset adjustment, basic test passes in reverse as well
Diffstat (limited to 'emlink.py')
-rw-r--r--emlink.py7
1 files changed, 6 insertions, 1 deletions
diff --git a/emlink.py b/emlink.py
index 66dd54e4..83fe5d7e 100644
--- a/emlink.py
+++ b/emlink.py
@@ -45,6 +45,10 @@ class AsmModule():
self.mem_init_full_js = mem_init.group(0)
self.mem_init_js = mem_init.groups(0)[0][:-2]
self.mem_init_size = self.mem_init_js.count(',') + self.mem_init_js.count('concat') # XXX add testing for large and small ones
+ pad = 8 - (self.mem_init_size % 8)
+ if pad < 8:
+ self.mem_init_js += '.concat([' + ','.join(['0']*pad) + '])'
+ self.mem_init_size += pad
else:
self.mem_init_js = ''
self.mem_init_size = 0
@@ -80,6 +84,7 @@ class AsmModule():
if allocation:
full_allocation = '/* memory initializer */ allocate(' + allocation + ', "i8", ALLOC_NONE, Runtime.GLOBAL_BASE)'
main.pre_js = re.sub(shared.JS.memory_initializer_pattern if main.mem_init_js else shared.JS.no_memory_initializer_pattern, full_allocation, main.pre_js, count=1)
+ main.pre_js = re.sub('STATICTOP = STATIC_BASE \+ (\d+);', 'STATICTOP = STATIC_BASE + %d' % (main.mem_init_size + side.mem_init_size), main.pre_js, count=1)
# global initializers TODO
@@ -100,7 +105,7 @@ class AsmModule():
temp = shared.Building.js_optimizer(self.filename, ['asm', 'relocate'], extra_info={
'replacements': replacements,
'fBase': 0,
- 'hBase': shared.JS.align(main.mem_init_size, 8)
+ 'hBase': main.mem_init_size
})
#print >> sys.stderr, 'relocated side into', temp
relocated_funcs = AsmModule(temp)