repositories
/
mTask.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
small update
[mTask.git]
/
client
/
interpret.c
diff --git
a/client/interpret.c
b/client/interpret.c
index
b9d0c88
..
e5907cf
100644
(file)
--- a/
client/interpret.c
+++ b/
client/interpret.c
@@
-16,20
+16,16
@@
#define f16(p) program[pc]*265+program[pc+1]
#define f16(p) program[pc]*265+program[pc+1]
+uint16_t stack[STACKSIZE] = {0};
+
void run_task(struct task *t)
{
uint8_t *program = t->bc;
void run_task(struct task *t)
{
uint8_t *program = t->bc;
- int plen = t->t
len
;
+ int plen = t->t
asklength
;
int pc = 0;
int sp = 0;
int pc = 0;
int sp = 0;
- char stack[STACKSIZE] = {0};
debug("Running task with length: %d", plen);
while(pc < plen){
debug("Running task with length: %d", plen);
while(pc < plen){
-// debug("program: %d", program[pc]);
-// debug("stack: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x",
-// stack[0], stack[1], stack[2], stack[3], stack[4],
-// stack[5], stack[6], stack[7], stack[8], stack[9]);
-
switch(program[pc++]){
case BCNOP: trace("nop");
break;
switch(program[pc++]){
case BCNOP: trace("nop");
break;
@@
-166,6
+162,10
@@
void run_task(struct task *t)
sp--;
break;
#endif
sp--;
break;
#endif
+ case BCRETURN: trace("Return");
+ pc = plen;
+ t->value = (uint16_t) stack[sp-1];
+ break;
default:
trace("unrecognized");
die("Unrecognized command: %d", program[pc-1]);
default:
trace("unrecognized");
die("Unrecognized command: %d", program[pc-1]);