From 2891de6ed6e954f8a368949463cb32807799a8a1 Mon Sep 17 00:00:00 2001 From: j8takagi Date: Wed, 27 Apr 2011 00:56:03 +0900 Subject: [PATCH] =?utf8?q?cmd.c=E3=82=92struct.c=E3=81=AB=E5=90=B8?= =?utf8?q?=E5=8F=8E=E5=90=88=E4=BD=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit --- src/Makefile | 2 +- src/cmd.c | 215 --------------------------------------------------- src/struct.c | 213 ++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 214 insertions(+), 216 deletions(-) delete mode 100644 src/cmd.c diff --git a/src/Makefile b/src/Makefile index a2c197f..01bec4f 100644 --- a/src/Makefile +++ b/src/Makefile @@ -4,7 +4,7 @@ CFLAGS := -g -Wall -Wextra -I $(INCLUDE) RM := rm -f COMMONSRC := word.c cmem.c cerr.c -CASL2SRC := struct.c cmd.c hash.c +CASL2SRC := struct.c hash.c ASSRC := assemble.c token.c label.c EXECSRC := exec.c dump.c diff --git a/src/cmd.c b/src/cmd.c deleted file mode 100644 index 7896d06..0000000 --- a/src/cmd.c +++ /dev/null @@ -1,215 +0,0 @@ -#include -#include -#include -#include "hash.h" -#include "struct.h" -#include "cmem.h" -#include "exec.h" - -/** - * システムCOMET IIの命令表 - */ -static COMET2CMD comet2cmd[] = { - { "NOP", NONE, 0x0, nop }, - { "LD", R_ADR_X, 0x1000, ld_r_adr_x }, - { "ST", R_ADR_X, 0x1100, st }, - { "LAD", R_ADR_X, 0x1200, lad }, - { "LD", R1_R2, 0x1400, ld_r1_r2 }, - { "ADDA", R_ADR_X, 0x2000, adda_r_adr_x }, - { "SUBA", R_ADR_X, 0x2100, suba_r_adr_x }, - { "ADDL", R_ADR_X, 0x2200, addl_r_adr_x }, - { "SUBL", R_ADR_X, 0x2300, subl_r_adr_x }, - { "ADDA", R1_R2, 0x2400, adda_r1_r2 }, - { "SUBA", R1_R2, 0x2500, suba_r1_r2 }, - { "ADDL", R1_R2, 0x2600, addl_r1_r2 }, - { "SUBL", R1_R2, 0x2700, subl_r1_r2 }, - { "AND", R_ADR_X, 0x3000, and_r_adr_x }, - { "OR", R_ADR_X, 0x3100, or_r_adr_x }, - { "XOR", R_ADR_X, 0x3200, xor_r_adr_x }, - { "AND", R1_R2, 0x3400, and_r1_r2 }, - { "OR", R1_R2, 0x3500, or_r1_r2 }, - { "XOR", R1_R2, 0x3600, xor_r1_r2 }, - { "CPA", R_ADR_X, 0x4000, cpa_r_adr_x }, - { "CPL", R_ADR_X, 0x4100, cpl_r_adr_x }, - { "CPA", R1_R2, 0x4400, cpa_r1_r2 }, - { "CPL", R1_R2, 0x4500, cpl_r1_r2 }, - { "SLA", R_ADR_X, 0x5000, sla }, - { "SRA", R_ADR_X, 0x5100, sra }, - { "SLL", R_ADR_X, 0x5200, sll }, - { "SRL", R_ADR_X, 0x5300, srl }, - { "JMI", ADR_X, 0x6100, jmi }, - { "JNZ", ADR_X, 0x6200, jnz }, - { "JZE", ADR_X, 0x6300, jze }, - { "JUMP", ADR_X, 0x6400, jump }, - { "JPL", ADR_X, 0x6500, jpl }, - { "JOV", ADR_X, 0x6600, jov }, - { "PUSH", ADR_X, 0x7000, push }, - { "POP", R_, 0x7100, pop }, - { "CALL", ADR_X, 0x8000, call }, - { "SVC", ADR_X, 0xF000, svc }, - { "RET", NONE, 0x8100, ret }, -}; - -/** - * 命令表のサイズ - */ -static int comet2cmdsize = ARRAYSIZE(comet2cmd); - -/** - * ハッシュ表のサイズ - */ -enum { - CMDTABSIZE = 39, -}; - -/** - * ハッシュ表 - */ -static CMDTAB *cmdtype_code[CMDTABSIZE], *code_type[CMDTABSIZE]; - -/** - * 命令の名前とタイプからハッシュ値を生成する - */ -unsigned hash_cmdtype(const char *cmd, CMDTYPE type) -{ - HKEY *keys[2]; - unsigned hashval; - - /* 命令名を設定 */ - keys[0] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[0]"); - keys[0]->type = CHARS; - keys[0]->val.s = strdup_chk(cmd, "keys[0].val.s"); - /* 命令タイプを設定 */ - keys[1] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[1]"); - keys[1]->type = INT; - keys[1]->val.i = (int)(type & 070); - /* ハッシュ値の計算 */ - hashval = hash(2, keys, CMDTABSIZE); - FREE(keys[0]->val.s); - FREE(keys[0]); - FREE(keys[1]); - /* ハッシュ値を返す */ - return hashval; -} - -/** - * 名前とタイプがキーの命令ハッシュ表を作成する - */ -bool create_cmdtype_code() -{ - CMDTAB *p; - unsigned hashval; - int i; - - for(i = 0; i < comet2cmdsize; i++) { - hashval = hash_cmdtype(comet2cmd[i].name, comet2cmd[i].type); /* ハッシュ値の生成 */ - p = malloc_chk(sizeof(CMDTAB), "cmdtype_code"); - p->cmd = &comet2cmd[i]; - p->next = cmdtype_code[hashval]; /* ハッシュ表に値を追加 */ - cmdtype_code[hashval] = p; - } - return true; -} - -/** - * 命令の名前とタイプから、命令コードを返す\n - * 無効な場合は0xFFFFを返す - */ -WORD getcmdcode(const char *cmd, CMDTYPE type) -{ - CMDTAB *p; - WORD w = 0xFFFF; - - assert(cmd != NULL); - for(p = cmdtype_code[hash_cmdtype(cmd, type)]; p != NULL; p = p->next) { - if(strcmp(cmd, p->cmd->name) == 0 && type == p->cmd->type) { - w = p->cmd->code; - break; - } - } - return w; -} - -/** - * 名前とタイプがキーの命令ハッシュ表を解放する - */ -void free_cmdtype_code() -{ - int i; - CMDTAB *p, *q; - - for(i = 0; i < CMDTABSIZE; i++) { - for(p = cmdtype_code[i]; p != NULL; p = q) { - q = p->next; - FREE(p); - } - } -} - -/** - * 命令コードからハッシュ値を生成する - */ -unsigned hash_code(WORD code) -{ - HKEY *keys[1]; - unsigned h; - - /* 命令コードを設定 */ - keys[0] = malloc_chk(sizeof(HKEY), "hash_code.key"); - keys[0]->type = INT; - keys[0]->val.i = (int)(code >> 8); - h = hash(1, keys, CMDTABSIZE); - FREE(keys[0]); - return h; -} - -/** - * コードがキーの命令ハッシュ表を作成する - */ -bool create_code_type() -{ - CMDTAB *p; - unsigned hashval; - int i; - - for(i = 0; i < comet2cmdsize; i++) { - hashval = hash_code((&comet2cmd[i])->code); /* ハッシュ値の生成 */ - p = malloc_chk(sizeof(CMDTAB), "code_type"); - p->cmd = &comet2cmd[i]; - p->next = code_type[hashval]; /* ハッシュ表に値を追加 */ - code_type[hashval] = p; - } - return true; -} - -/** - * 命令コードから命令の関数ポインタを返す - */ -const void (*getcmdptr(WORD code)) -{ - CMDTAB *t; - const void (*ptr); - - for(t = code_type[hash_code(code)]; t != NULL; t = t->next) { - if(code == t->cmd->code) { - ptr = t->cmd->ptr; - break; - } - } - return ptr; -} - -/** - * コードがキーの命令ハッシュ表を解放する - */ -void free_code_type() -{ - int i; - CMDTAB *p, *q; - for(i = 0; i < CMDTABSIZE; i++) { - for(p = code_type[i]; p != NULL; p = q) { - q = p->next; - FREE(p); - } - } -} diff --git a/src/struct.c b/src/struct.c index 2d3c67f..7102280 100644 --- a/src/struct.c +++ b/src/struct.c @@ -1,5 +1,10 @@ +#include +#include +#include +#include "hash.h" #include "struct.h" #include "cmem.h" +#include "exec.h" /** * COMET IIの仮想実行マシンシステム @@ -11,6 +16,214 @@ SYSTEM *sys; */ EXECPTR *execptr; +/** + * システムCOMET IIの命令表 + */ +static COMET2CMD comet2cmd[] = { + { "NOP", NONE, 0x0, nop }, + { "LD", R_ADR_X, 0x1000, ld_r_adr_x }, + { "ST", R_ADR_X, 0x1100, st }, + { "LAD", R_ADR_X, 0x1200, lad }, + { "LD", R1_R2, 0x1400, ld_r1_r2 }, + { "ADDA", R_ADR_X, 0x2000, adda_r_adr_x }, + { "SUBA", R_ADR_X, 0x2100, suba_r_adr_x }, + { "ADDL", R_ADR_X, 0x2200, addl_r_adr_x }, + { "SUBL", R_ADR_X, 0x2300, subl_r_adr_x }, + { "ADDA", R1_R2, 0x2400, adda_r1_r2 }, + { "SUBA", R1_R2, 0x2500, suba_r1_r2 }, + { "ADDL", R1_R2, 0x2600, addl_r1_r2 }, + { "SUBL", R1_R2, 0x2700, subl_r1_r2 }, + { "AND", R_ADR_X, 0x3000, and_r_adr_x }, + { "OR", R_ADR_X, 0x3100, or_r_adr_x }, + { "XOR", R_ADR_X, 0x3200, xor_r_adr_x }, + { "AND", R1_R2, 0x3400, and_r1_r2 }, + { "OR", R1_R2, 0x3500, or_r1_r2 }, + { "XOR", R1_R2, 0x3600, xor_r1_r2 }, + { "CPA", R_ADR_X, 0x4000, cpa_r_adr_x }, + { "CPL", R_ADR_X, 0x4100, cpl_r_adr_x }, + { "CPA", R1_R2, 0x4400, cpa_r1_r2 }, + { "CPL", R1_R2, 0x4500, cpl_r1_r2 }, + { "SLA", R_ADR_X, 0x5000, sla }, + { "SRA", R_ADR_X, 0x5100, sra }, + { "SLL", R_ADR_X, 0x5200, sll }, + { "SRL", R_ADR_X, 0x5300, srl }, + { "JMI", ADR_X, 0x6100, jmi }, + { "JNZ", ADR_X, 0x6200, jnz }, + { "JZE", ADR_X, 0x6300, jze }, + { "JUMP", ADR_X, 0x6400, jump }, + { "JPL", ADR_X, 0x6500, jpl }, + { "JOV", ADR_X, 0x6600, jov }, + { "PUSH", ADR_X, 0x7000, push }, + { "POP", R_, 0x7100, pop }, + { "CALL", ADR_X, 0x8000, call }, + { "SVC", ADR_X, 0xF000, svc }, + { "RET", NONE, 0x8100, ret }, +}; + +/** + * 命令表のサイズ + */ +static int comet2cmdsize = ARRAYSIZE(comet2cmd); + +/** + * ハッシュ表のサイズ + */ +enum { + CMDTABSIZE = 39, +}; + +/** + * ハッシュ表 + */ +static CMDTAB *cmdtype_code[CMDTABSIZE], *code_type[CMDTABSIZE]; + +/** + * 命令の名前とタイプからハッシュ値を生成する + */ +unsigned hash_cmdtype(const char *cmd, CMDTYPE type) +{ + HKEY *keys[2]; + unsigned hashval; + + /* 命令名を設定 */ + keys[0] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[0]"); + keys[0]->type = CHARS; + keys[0]->val.s = strdup_chk(cmd, "keys[0].val.s"); + /* 命令タイプを設定 */ + keys[1] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[1]"); + keys[1]->type = INT; + keys[1]->val.i = (int)(type & 070); + /* ハッシュ値の計算 */ + hashval = hash(2, keys, CMDTABSIZE); + FREE(keys[0]->val.s); + FREE(keys[0]); + FREE(keys[1]); + /* ハッシュ値を返す */ + return hashval; +} + +/** + * 名前とタイプがキーの命令ハッシュ表を作成する + */ +bool create_cmdtype_code() +{ + CMDTAB *p; + unsigned hashval; + int i; + + for(i = 0; i < comet2cmdsize; i++) { + hashval = hash_cmdtype(comet2cmd[i].name, comet2cmd[i].type); /* ハッシュ値の生成 */ + p = malloc_chk(sizeof(CMDTAB), "cmdtype_code"); + p->cmd = &comet2cmd[i]; + p->next = cmdtype_code[hashval]; /* ハッシュ表に値を追加 */ + cmdtype_code[hashval] = p; + } + return true; +} + +/** + * 命令の名前とタイプから、命令コードを返す\n + * 無効な場合は0xFFFFを返す + */ +WORD getcmdcode(const char *cmd, CMDTYPE type) +{ + CMDTAB *p; + WORD w = 0xFFFF; + + assert(cmd != NULL); + for(p = cmdtype_code[hash_cmdtype(cmd, type)]; p != NULL; p = p->next) { + if(strcmp(cmd, p->cmd->name) == 0 && type == p->cmd->type) { + w = p->cmd->code; + break; + } + } + return w; +} + +/** + * 名前とタイプがキーの命令ハッシュ表を解放する + */ +void free_cmdtype_code() +{ + int i; + CMDTAB *p, *q; + + for(i = 0; i < CMDTABSIZE; i++) { + for(p = cmdtype_code[i]; p != NULL; p = q) { + q = p->next; + FREE(p); + } + } +} + +/** + * 命令コードからハッシュ値を生成する + */ +unsigned hash_code(WORD code) +{ + HKEY *keys[1]; + unsigned h; + + /* 命令コードを設定 */ + keys[0] = malloc_chk(sizeof(HKEY), "hash_code.key"); + keys[0]->type = INT; + keys[0]->val.i = (int)(code >> 8); + h = hash(1, keys, CMDTABSIZE); + FREE(keys[0]); + return h; +} + +/** + * コードがキーの命令ハッシュ表を作成する + */ +bool create_code_type() +{ + CMDTAB *p; + unsigned hashval; + int i; + + for(i = 0; i < comet2cmdsize; i++) { + hashval = hash_code((&comet2cmd[i])->code); /* ハッシュ値の生成 */ + p = malloc_chk(sizeof(CMDTAB), "code_type"); + p->cmd = &comet2cmd[i]; + p->next = code_type[hashval]; /* ハッシュ表に値を追加 */ + code_type[hashval] = p; + } + return true; +} + +/** + * 命令コードから命令の関数ポインタを返す + */ +const void (*getcmdptr(WORD code)) +{ + CMDTAB *t; + const void (*ptr); + + for(t = code_type[hash_code(code)]; t != NULL; t = t->next) { + if(code == t->cmd->code) { + ptr = t->cmd->ptr; + break; + } + } + return ptr; +} + +/** + * コードがキーの命令ハッシュ表を解放する + */ +void free_code_type() +{ + int i; + CMDTAB *p, *q; + for(i = 0; i < CMDTABSIZE; i++) { + for(p = code_type[i]; p != NULL; p = q) { + q = p->next; + FREE(p); + } + } +} + /** * COMET II仮想マシンのリセット */ -- 2.18.0