A.Olokhtonov
10 months ago
10 changed files with 228 additions and 182 deletions
@ -0,0 +1,44 @@ |
|||||||
|
let thread_id = null; |
||||||
|
let exports = null; |
||||||
|
|
||||||
|
async function init(tid, memory, heap_base) { |
||||||
|
thread_id = tid; |
||||||
|
|
||||||
|
const result = await WebAssembly.instantiateStreaming(fetch('wasm/lod.wasm'), { |
||||||
|
env: { 'memory': memory } |
||||||
|
}); |
||||||
|
|
||||||
|
exports = result.instance.exports; |
||||||
|
exports.set_sp(heap_base - thread_id * 16 * 4096); // 64K stack
|
||||||
|
|
||||||
|
postMessage({ 'type': 'init_done' }); |
||||||
|
} |
||||||
|
|
||||||
|
function work(indices_base, indices_count, zoom, offsets) { |
||||||
|
exports.do_lod( |
||||||
|
indices_base, indices_count, zoom, |
||||||
|
offsets['coords_from'], |
||||||
|
offsets['line_threshold'], |
||||||
|
offsets['xs'], |
||||||
|
offsets['ys'], |
||||||
|
offsets['pressures'], |
||||||
|
offsets['result_buffers'] + thread_id * 4, |
||||||
|
offsets['result_counts'] + thread_id * 4, |
||||||
|
); |
||||||
|
|
||||||
|
postMessage({ 'type': 'lod_done' }); |
||||||
|
} |
||||||
|
|
||||||
|
onmessage = (e) => { |
||||||
|
const d = e.data; |
||||||
|
|
||||||
|
if (d.type === 'init') { |
||||||
|
init(d.thread_id, d.memory, d.heap_base); |
||||||
|
} else if (d.type === 'lod') { |
||||||
|
work(d.indices_base, d.indices_count, d.zoom, d.offsets); |
||||||
|
} else { |
||||||
|
console.error('unexpected worker command:', d.type); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
@ -1 +1 @@ |
|||||||
clang -Oz --target=wasm32 -nostdlib -msimd128 -mbulk-memory -matomics -Wl,--no-entry,--import-memory,--shared-memory,--max-memory=$((1024 * 1024 * 1024)) -z stack-size=$((1024 * 1024)) multi.c -o multi.wasm |
clang -Oz --target=wasm32 -nostdlib -msimd128 -mbulk-memory -matomics -Wl,--no-entry,--import-memory,--shared-memory,--export-all,--max-memory=$((1024 * 1024 * 1024)) -z stack-size=$((1024 * 1024)) lod.c -o lod.wasm |
||||||
|
Binary file not shown.
@ -1,37 +0,0 @@ |
|||||||
#include <wasm_simd128.h> |
|
||||||
|
|
||||||
extern char __heap_base; |
|
||||||
|
|
||||||
static int allocated; |
|
||||||
|
|
||||||
void |
|
||||||
set_sp(char *sp) |
|
||||||
{ |
|
||||||
__asm__ __volatile__( |
|
||||||
".globaltype __stack_pointer, i32\n" |
|
||||||
"local.get %0\n" |
|
||||||
"global.set __stack_pointer\n" |
|
||||||
: : "r"(sp) |
|
||||||
); |
|
||||||
} |
|
||||||
|
|
||||||
void * |
|
||||||
alloc(int size) |
|
||||||
{ |
|
||||||
void *result = &__heap_base + allocated; |
|
||||||
allocated += size; |
|
||||||
return(result); |
|
||||||
} |
|
||||||
|
|
||||||
static void |
|
||||||
impl(int *buffer, int index, int number) |
|
||||||
{ |
|
||||||
buffer[index] = number; |
|
||||||
} |
|
||||||
|
|
||||||
void |
|
||||||
write_a_number(int *buffer, int index, int number) |
|
||||||
{ |
|
||||||
int n = number * 2; |
|
||||||
impl(buffer, index, n); |
|
||||||
} |
|
Binary file not shown.
@ -1,40 +0,0 @@ |
|||||||
let thread_id = null; |
|
||||||
let buf_offset = null; |
|
||||||
let exports = null; |
|
||||||
let flags = null; |
|
||||||
|
|
||||||
function done() { |
|
||||||
postMessage('done'); |
|
||||||
} |
|
||||||
|
|
||||||
async function init_wasm(tid, memory, offset, notify_flags, stack_base) { |
|
||||||
thread_id = tid; |
|
||||||
buf_offset = offset; |
|
||||||
|
|
||||||
const result = await WebAssembly.instantiateStreaming(fetch('wasm/multi.wasm'), { |
|
||||||
env: { 'memory': memory } |
|
||||||
}); |
|
||||||
|
|
||||||
exports = result.instance.exports; |
|
||||||
//console.log(tid, 'init');
|
|
||||||
exports.set_sp(stack_base - thread_id * 4096); |
|
||||||
|
|
||||||
flags = notify_flags; |
|
||||||
done(); |
|
||||||
} |
|
||||||
|
|
||||||
function do_work(num, callback) { |
|
||||||
//console.log(thread_id, 'work');
|
|
||||||
exports.write_a_number(buf_offset, thread_id, thread_id * num); |
|
||||||
done(); |
|
||||||
} |
|
||||||
|
|
||||||
onmessage = (e) => { |
|
||||||
if (e.data.type === 0) { |
|
||||||
init_wasm(e.data.thread_id, e.data.memory, e.data.buffer_offset, e.data.flags, e.data.stack_base); |
|
||||||
} else if (e.data.type === 1) { |
|
||||||
do_work(e.data.num); |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
|
|
Loading…
Reference in new issue