# HG changeset patch # User tobaru # Date 1580716399 -32400 # Node ID 1696f9c2ad0d50bb2595519c3628bdbf58003816 # Parent 875ad11af59621a9f2454d2e2ab65aa1fc6d77fe call interface switchuvm diff -r 875ad11af596 -r 1696f9c2ad0d src/gearsTools/generate_stub.pl --- a/src/gearsTools/generate_stub.pl Sun Feb 02 13:31:03 2020 +0900 +++ b/src/gearsTools/generate_stub.pl Mon Feb 03 16:53:19 2020 +0900 @@ -3,6 +3,7 @@ use strict; use Getopt::Std; use File::Path qw(make_path); +use Data::Dumper; # interface.h # typedef struct Worker { @@ -144,6 +145,7 @@ } } + print Dumper \%var; } sub getCodeGear { diff -r 875ad11af596 -r 1696f9c2ad0d src/proc.cbc --- a/src/proc.cbc Sun Feb 02 13:31:03 2020 +0900 +++ b/src/proc.cbc Mon Feb 03 16:53:19 2020 +0900 @@ -174,6 +174,19 @@ p->state = RUNNABLE; } + +void switchuvm_dummy(struct proc* proc) +{ + goto cbc_switchuvm_dummy(&proc->cbc_context, proc); +} + +__ncode cbc_switchuvm_dummy(struct Context* cbc_context, struct proc* proc){ + + struct vm* vm = createvm_impl(cbc_context); + Gearef(cbc_context, vm)->vm = (union Data*) vm; + goto meta(cbc_context, vm->switchuvm); +} + // Grow current process's memory by n bytes. // Return 0 on success, -1 on failure. int growproc(int n) @@ -194,7 +207,8 @@ } proc->sz = sz; - switchuvm(proc); + // switchuvm(proc); + switchuvm_dummy(proc); return 0; }