1 #ifndef YACASL2_CASL2_INCLUDED
2 #define YACASL2_CASL2_INCLUDED
16 CMDSIZE = 4, /**<命令の最大文字数 */
17 GRSIZE = 8, /**<汎用レジスタの数。COMET II規格では、8(0から7) */
18 DEFAULT_MEMSIZE = 512, /**<デフォルトのメモリ容量。COMET II規格では、65535語(word) */
19 DEFAULT_CLOCKS = 5000000, /**<デフォルトのクロック周波数。COMET II規格では、未定義 */
23 * @brief COMET II フラグのマスク値
26 OF = 0x4, /**<Overflow Flag */
27 SF = 0x2, /**<Sign Flag */
28 ZF = 0x1, /**<Zero Flag */
32 * @brief COMET IIのCPUを表すデータ型
35 WORD gr[GRSIZE]; /**<汎用レジスタ */
36 WORD sp; /**<スタックポインタ */
37 WORD pr; /**<プログラムレジスタ */
38 WORD fr; /**<フラグレジスタ */
42 * @brief COMET IIの仮想実行マシンシステムを表すデータ型
46 WORD *memory; /**<メモリ */
47 int memsize; /**<メモリサイズ */
48 clock_t clocks; /**<クロック周波数 */
52 * @brief COMET IIの仮想実行マシンシステム
66 * 命令タイプは、オペランドにより5種類に分類
71 * - 第1オペランド: 汎用レジスタ。必須
73 * - 第3オペランド: 指標レジスタとして用いる汎用レジスタ。任意
78 * - 第1オペランド: 汎用レジスタ。必須
79 * - 第2オペランド: 汎用レジスタ。必須
85 * - 第2オペランド: 指標レジスタとして用いる汎用レジスタ。任意
90 * - 第1オペランド: 汎用レジスタ。必須
103 char *name; /**<命令名 */
104 const void (*ptr); /**<命令の関数ポインタ */
111 char *name; /**<命令名 */
112 CMDTYPE type; /**<命令タイプ */
113 WORD code; /**<命令コード */
114 const void (*ptr); /**<命令の関数ポインタ */
120 typedef struct _CMDTAB {
121 struct _CMDTAB *next; /**<リスト次項目へのポインタ */
122 const COMET2CMD *cmd; /**<命令コード表の項目 */
126 * プログラム実行時の開始と終了のアドレス
129 WORD start; /**<開始アドレス */
130 WORD end; /**<終了アドレス */
131 bool stop; /**<終了フラグ */
134 extern EXECPTR *execptr;
137 * @brief 汎用レジスタの番号からレジスタを表す文字列を返す
139 * @return 汎用レジスタを表す文字列。「GR0」「GR1」・・・「GR7」のいずれか
141 * @param word レジスタ番号[0-7]を表すWORD値
143 char *grstr(WORD word);
148 void reset(int memsize, int clocks);
151 * COMET II仮想マシンのシャットダウン
156 * @brief 命令ハッシュ表を作成する
162 bool create_cmdtable(CMDTAB_HASH hash);
165 * 命令の名前とタイプから、命令コードを返す
168 WORD getcmdcode(const char *cmd, CMDTYPE type);
173 void free_cmdtable();
176 * コードがキーの命令ハッシュ表を作成する
178 bool create_code_cmdtype();
181 * 命令コードから命令の関数ポインタを返す
183 const void (*getcmdptr(WORD code));
188 CMDTYPE getcmdtype(WORD code);
193 char *getcmdname(WORD code);
195 #endif /* YACASL2_CASL2_INCLUDEDの終端 */