aboutsummaryrefslogtreecommitdiff
path: root/saga/sthread.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'saga/sthread.cpp')
-rw-r--r--saga/sthread.cpp17
1 files changed, 9 insertions, 8 deletions
diff --git a/saga/sthread.cpp b/saga/sthread.cpp
index 5e9cc785bf..b80d58817e 100644
--- a/saga/sthread.cpp
+++ b/saga/sthread.cpp
@@ -37,7 +37,7 @@ namespace Saga {
void Script::setFramePtr(R_SCRIPT_THREAD *thread, int newPtr) {
thread->framePtr = newPtr;
- dataBuffer(3)->len = 2 * (ARRAYSIZE(thread->stackBuf) - thread->framePtr);
+ dataBuffer(3)->len = ARRAYSIZE(thread->stackBuf) - thread->framePtr;
dataBuffer(3)->data = (SDataWord_T *) &(thread->stackBuf[newPtr]);
}
@@ -54,17 +54,18 @@ R_SCRIPT_THREAD *Script::SThreadCreate() {
return NULL;
}
+ new_node = ys_dll_add_head(threadList(), new_thread, sizeof *new_thread);
+ free(new_thread);
+
+ new_thread = (R_SCRIPT_THREAD *)ys_dll_get_data(new_node);
+
new_thread->stackPtr = ARRAYSIZE(new_thread->stackBuf) - 1;
setFramePtr(new_thread, new_thread->stackPtr);
- dataBuffer(4)->len = sizeof(new_thread->threadVars);
+ dataBuffer(4)->len = ARRAYSIZE(new_thread->threadVars);
dataBuffer(4)->data = new_thread->threadVars;
- new_node = ys_dll_add_head(threadList(), new_thread, sizeof *new_thread);
-
- free(new_thread);
-
- return (R_SCRIPT_THREAD *)ys_dll_get_data(new_node);
+ return new_thread;
}
int Script::SThreadDestroy(R_SCRIPT_THREAD *thread) {
@@ -208,7 +209,7 @@ int Script::SThreadRun(R_SCRIPT_THREAD *thread, int instr_limit, int msec) {
MemoryReadStream scriptS(currentScript()->bytecode->bytecode_p, currentScript()->bytecode->bytecode_len);
- dataBuffer(2)->len = currentScript()->bytecode->bytecode_len;
+ dataBuffer(2)->len = currentScript()->bytecode->bytecode_len / sizeof(SDataWord_T);
dataBuffer(2)->data = (SDataWord_T *) currentScript()->bytecode->bytecode_p;
scriptS.seek(thread->i_offset);