X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fstruct.c;h=9e3d256f9eb3f88b57937a76f25289a8c0c9c4bb;hp=45466485c9808de7a855b4b4dfd8f0715cba762f;hb=555c5e8b851becc08ba661a9cb19f617d5a00c12;hpb=712486afe58b10ef37c5fa915de889ab8d1dd6cd diff --git a/src/struct.c b/src/struct.c index 4546648..9e3d256 100644 --- a/src/struct.c +++ b/src/struct.c @@ -1,52 +1,38 @@ #include "casl2.h" -/* COMET IIのメモリ */ -WORD *memory; +/* COMET IIの仮装実行マシンシステム */ +SYSTEM *sys; -/* COMET IIのCPUレジスタ */ -WORD GR[REGSIZE], SP, PR, FR; +/* CASL IIプログラムのプロパティ */ +PROGPROP *prog; -CERRARRAY cerr[] = { - { 101, "label already defined" }, - { 102, "label table is full" }, - { 103, "label not found" }, - { 104, "label length is too long" }, - { 105, "no command in the line" }, - { 106, "operand count mismatch" }, - { 107, "no label in START" }, - { 108, "not command of operand \"r\"" }, - { 109, "not command of operand \"r1,r2\"" }, - { 110, "not command of operand \"r,adr[,x]\"" }, - { 111, "not command of operand \"adr[,x]\"" }, - { 112, "not command of no operand" }, - { 113, "command not defined" }, - { 114, "not integer" }, - { 115, "not hex" }, - { 116, "out of hex range" }, - { 117, "operand is too many" }, - { 118, "operand length is too long" }, - { 119, "out of COMET II memory" }, - { 120, "GR0 in operand x" }, - { 121, "cannot get operand token" }, - { 122, "cannot create hash table" }, - { 201, "execute - out of COMET II memory" }, - { 202, "SVC input - out of Input memory" }, - { 203, "SVC output - out of COMET II memory" }, - { 204, "Program Register (PR) - out of COMET II memory" }, - { 205, "Stack Pointer (SP) - cannot allocate stack buffer" }, - { 206, "Address - out of COMET II memory" }, - { 207, "Stack Pointer (SP) - out of COMET II memory" }, - { 0, NULL }, -}; +/* COMET II仮想マシンのリセット */ +void reset(int memsize, int clocks) +{ + int i; -/* メモリーサイズ */ -int memsize = DEFAULT_MEMSIZE; + sys = malloc_chk(sizeof(SYSTEM), "sys"); + /* メモリサイズの設定 */ + sys->memsize = memsize; + /* クロック周波数の設定 */ + sys->clocks = clocks; + /* メモリの初期化 */ + sys->memory = calloc_chk(sys->memsize, sizeof(WORD), "memory"); + /* CPUの初期化 */ + sys->cpu = malloc_chk(sizeof(CPU), "cpu"); + for(i = 0; i < GRSIZE; i++) { + sys->cpu->gr[i] = 0x0; + } + sys->cpu->sp = sys->cpu->pr = sys->cpu->fr = 0x0; + /* CASL2プログラムのプロパティ */ + prog = malloc_chk(sizeof(PROGPROP), "prog"); +} -/* クロック周波数 */ -int clocks = DEFAULT_CLOCKS; - -/* 実行開始番地 */ -WORD startptr = 0x0; - -/* 実行終了番地 */ -WORD endptr = 0x0; +/* COMET II仮想マシンのシャットダウン */ +void shutdown() +{ + free_chk(prog, "prog"); + free_chk(sys->memory, "sys.memory"); + free_chk(sys->cpu, "sys.cpu"); + free_chk(sys, "sys"); +}