10 * COMET IIの仮想実行マシンシステム
22 static COMET2CMD comet2cmd[] = {
23 { "NOP", NONE, 0x0, nop },
24 { "LD", R_ADR_X, 0x1000, ld_r_adr_x },
25 { "ST", R_ADR_X, 0x1100, st },
26 { "LAD", R_ADR_X, 0x1200, lad },
27 { "LD", R1_R2, 0x1400, ld_r1_r2 },
28 { "ADDA", R_ADR_X, 0x2000, adda_r_adr_x },
29 { "SUBA", R_ADR_X, 0x2100, suba_r_adr_x },
30 { "ADDL", R_ADR_X, 0x2200, addl_r_adr_x },
31 { "SUBL", R_ADR_X, 0x2300, subl_r_adr_x },
32 { "ADDA", R1_R2, 0x2400, adda_r1_r2 },
33 { "SUBA", R1_R2, 0x2500, suba_r1_r2 },
34 { "ADDL", R1_R2, 0x2600, addl_r1_r2 },
35 { "SUBL", R1_R2, 0x2700, subl_r1_r2 },
36 { "AND", R_ADR_X, 0x3000, and_r_adr_x },
37 { "OR", R_ADR_X, 0x3100, or_r_adr_x },
38 { "XOR", R_ADR_X, 0x3200, xor_r_adr_x },
39 { "AND", R1_R2, 0x3400, and_r1_r2 },
40 { "OR", R1_R2, 0x3500, or_r1_r2 },
41 { "XOR", R1_R2, 0x3600, xor_r1_r2 },
42 { "CPA", R_ADR_X, 0x4000, cpa_r_adr_x },
43 { "CPL", R_ADR_X, 0x4100, cpl_r_adr_x },
44 { "CPA", R1_R2, 0x4400, cpa_r1_r2 },
45 { "CPL", R1_R2, 0x4500, cpl_r1_r2 },
46 { "SLA", R_ADR_X, 0x5000, sla },
47 { "SRA", R_ADR_X, 0x5100, sra },
48 { "SLL", R_ADR_X, 0x5200, sll },
49 { "SRL", R_ADR_X, 0x5300, srl },
50 { "JMI", ADR_X, 0x6100, jmi },
51 { "JNZ", ADR_X, 0x6200, jnz },
52 { "JZE", ADR_X, 0x6300, jze },
53 { "JUMP", ADR_X, 0x6400, jump },
54 { "JPL", ADR_X, 0x6500, jpl },
55 { "JOV", ADR_X, 0x6600, jov },
56 { "PUSH", ADR_X, 0x7000, push },
57 { "POP", R_, 0x7100, pop },
58 { "CALL", ADR_X, 0x8000, call },
59 { "SVC", ADR_X, 0xF000, svc },
60 { "RET", NONE, 0x8100, ret },
66 static int comet2cmdsize = ARRAYSIZE(comet2cmd);
78 static CMDTAB *cmdtype_code[CMDTABSIZE], *code_type[CMDTABSIZE];
81 * 命令の名前とタイプからハッシュ値を生成する
83 unsigned hash_cmdtype(const char *cmd, CMDTYPE type)
89 keys[0] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[0]");
90 keys[0]->type = CHARS;
91 keys[0]->val.s = strdup_chk(cmd, "keys[0].val.s");
93 keys[1] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[1]");
95 keys[1]->val.i = (int)(type & 070);
97 hashval = hash(2, keys, CMDTABSIZE);
106 * 名前とタイプがキーの命令ハッシュ表を作成する
108 bool create_cmdtype_code()
114 for(i = 0; i < comet2cmdsize; i++) {
115 hashval = hash_cmdtype(comet2cmd[i].name, comet2cmd[i].type); /* ハッシュ値の生成 */
116 p = malloc_chk(sizeof(CMDTAB), "cmdtype_code");
117 p->cmd = &comet2cmd[i];
118 p->next = cmdtype_code[hashval]; /* ハッシュ表に値を追加 */
119 cmdtype_code[hashval] = p;
125 * 命令の名前とタイプから、命令コードを返す\n
128 WORD getcmdcode(const char *cmd, CMDTYPE type)
134 for(p = cmdtype_code[hash_cmdtype(cmd, type)]; p != NULL; p = p->next) {
135 if(strcmp(cmd, p->cmd->name) == 0 && type == p->cmd->type) {
144 * 名前とタイプがキーの命令ハッシュ表を解放する
146 void free_cmdtype_code()
151 for(i = 0; i < CMDTABSIZE; i++) {
152 for(p = cmdtype_code[i]; p != NULL; p = q) {
162 unsigned hash_code(WORD code)
168 keys[0] = malloc_chk(sizeof(HKEY), "hash_code.key");
170 keys[0]->val.i = (int)(code >> 8);
171 h = hash(1, keys, CMDTABSIZE);
177 * コードがキーの命令ハッシュ表を作成する
179 bool create_code_type()
185 for(i = 0; i < comet2cmdsize; i++) {
186 hashval = hash_code((&comet2cmd[i])->code); /* ハッシュ値の生成 */
187 p = malloc_chk(sizeof(CMDTAB), "code_type");
188 p->cmd = &comet2cmd[i];
189 p->next = code_type[hashval]; /* ハッシュ表に値を追加 */
190 code_type[hashval] = p;
196 * 命令コードから命令の関数ポインタを返す
198 const void (*getcmdptr(WORD code))
201 const void *ptr = NULL;
203 for(t = code_type[hash_code(code)]; t != NULL; t = t->next) {
204 if(code == t->cmd->code) {
213 * コードがキーの命令ハッシュ表を解放する
215 void free_code_type()
219 for(i = 0; i < CMDTABSIZE; i++) {
220 for(p = code_type[i]; p != NULL; p = q) {
230 void reset(int memsize, int clocks)
234 sys = malloc_chk(sizeof(SYSTEM), "sys");
236 sys->memsize = memsize;
238 sys->clocks = clocks;
240 sys->memory = calloc_chk(sys->memsize, sizeof(WORD), "memory");
242 sys->cpu = malloc_chk(sizeof(CPU), "cpu");
243 for(i = 0; i < GRSIZE; i++) { /* 汎用レジスタ */
244 sys->cpu->gr[i] = 0x0;
246 sys->cpu->sp = sys->memsize; /* スタックポインタ */
247 sys->cpu->pr = 0x0; /* プログラムレジスタ */
248 sys->cpu->fr = 0x0; /* フラグレジスタ */
249 /* CASL2プログラムの開始と終了のアドレスを初期化 */
250 execptr = malloc_chk(sizeof(EXECPTR), "execptr");
251 execptr->stop = false;
255 * COMET II仮想マシンのシャットダウン