projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
comet2monitorの追加と、モニター機能作成
[YACASL2.git]
/
include
/
struct.h
diff --git
a/include/struct.h
b/include/struct.h
index
dd69d21
..
e36c13f
100644
(file)
--- a/
include/struct.h
+++ b/
include/struct.h
@@
-1,20
+1,26
@@
#ifndef YACASL2_CASL2_INCLUDED
#define YACASL2_CASL2_INCLUDED
#ifndef YACASL2_CASL2_INCLUDED
#define YACASL2_CASL2_INCLUDED
+#include <stdio.h>
+#include <assert.h>
+#include <string.h>
+#include <time.h>
#include "word.h"
#include "word.h"
+#include "cmem.h"
+#include "hash.h"
/**
/**
- *
COMET IIの規格
+ *
@brief COMET IIの規格値
*/
enum {
CMDSIZE = 4, /**<命令の最大文字数 */
*/
enum {
CMDSIZE = 4, /**<命令の最大文字数 */
- GRSIZE = 8, /**<æ±
\8e
ç
\94
¨ã
\83
‹
\82
¸ã
\82
¹ã
\82
¿ã
\81
®æ
\95
°ã
\80
\82
COMET IIè¦
\8f
æ ¼ã
\81
«ã
\82
\88
ã
\82
\8a
0ã
\81
\8b
ã
\82
\89
7ã
\81
¾ã
\81
§ã
\81
®8ã
\81
¤
*/
+ GRSIZE = 8, /**<æ±
\8e
ç
\94
¨ã
\83
‹
\82
¸ã
\82
¹ã
\82
¿ã
\81
®æ
\95
°ã
\80
\82
COMET IIè¦
\8f
æ ¼ã
\81
§ã
\81
¯ã
\80
\81
8ï¼
\88
0ã
\81
\8b
ã
\82
\89
7ï¼
\89
*/
DEFAULT_MEMSIZE = 512, /**<デフォルトのメモリ容量。COMET II規格では、65535語(word) */
DEFAULT_CLOCKS = 5000000, /**<デフォルトのクロック周波数。COMET II規格では、未定義 */
};
/**
DEFAULT_MEMSIZE = 512, /**<デフォルトのメモリ容量。COMET II規格では、65535語(word) */
DEFAULT_CLOCKS = 5000000, /**<デフォルトのクロック周波数。COMET II規格では、未定義 */
};
/**
- * COMET II フラグのマスク値
+ *
@brief
COMET II フラグのマスク値
*/
enum {
OF = 0x4, /**<Overflow Flag */
*/
enum {
OF = 0x4, /**<Overflow Flag */
@@
-23,7
+29,7
@@
enum {
};
/**
};
/**
- *
COMET IIのCPU
+ *
@brief COMET IIのCPUを表すデータ型
*/
typedef struct {
WORD gr[GRSIZE]; /**<汎用レジスタ */
*/
typedef struct {
WORD gr[GRSIZE]; /**<汎用レジスタ */
@@
-33,85
+39,100
@@
typedef struct {
} CPU;
/**
} CPU;
/**
- *
COMET IIの仮想実行マシンシステム
+ *
@brief COMET IIの仮想実行マシンシステムを表すデータ型
*/
typedef struct {
CPU *cpu; /**<CPU */
WORD *memory; /**<メモリ */
int memsize; /**<メモリサイズ */
*/
typedef struct {
CPU *cpu; /**<CPU */
WORD *memory; /**<メモリ */
int memsize; /**<メモリサイズ */
-
int clocks;
/**<クロック周波数 */
+
clock_t clocks;
/**<クロック周波数 */
} SYSTEM;
} SYSTEM;
+/**
+ * @brief COMET IIの仮想実行マシンシステム
+ */
extern SYSTEM *sys;
/**
* COMET II 命令
extern SYSTEM *sys;
/**
* COMET II 命令
- * 命令タイプは、オペランドにより
6
種類に分類
+ * 命令タイプは、オペランドにより
5
種類に分類
*/
typedef enum {
/**
* オペランド数2または3
*/
typedef enum {
/**
* オペランド数2または3
- * 第1オペランド: 汎用レジスタ
- * 第2オペランド: アドレス
- * 第3オペランド: 指標レジスタ
- */
- R_ADR_X = 010,
- /**
- * オペランド数2または3
- * 第1オペランド: 汎用レジスタ、
- * 第2オペランド: アドレスに格納されている内容
- * 第3オペランド: 指標レジスタ
+ * - 第1オペランド: 汎用レジスタ。必須
+ * - 第2オペランド: アドレス。必須
+ * - 第3オペランド: 指標レジスタとして用いる汎用レジスタ。任意
*/
*/
- R_ADR_X
_ = 01
1,
+ R_ADR_X
= 0
1,
/**
* オペランド数2
/**
* オペランド数2
- *
第1オペランド: 汎用レジスタ
- *
第2オペランド: 汎用レジスタ
+ *
- 第1オペランド: 汎用レジスタ。必須
+ *
- 第2オペランド: 汎用レジスタ。必須
*/
*/
- R1_R2 = 02
0
,
+ R1_R2 = 02,
/**
* オペランド数1または2
/**
* オペランド数1または2
- *
第1オペランド: アドレス
- *
第2オペランド: 指標レジスタ
+ *
- 第1オペランド: アドレス。必須
+ *
- 第2オペランド: 指標レジスタとして用いる汎用レジスタ。任意
*/
*/
- ADR_X = 03
0
,
+ ADR_X = 03,
/**
/**
- *
オペランド数1
- *
第1オペランド: 汎用レジスタ
+ * オペランド数1
+ *
- 第1オペランド: 汎用レジスタ。必須
*/
*/
- R_ = 04
0
,
+ R_ = 04,
/**
/**
- *
オペランドなし
+ * オペランドなし
*/
NONE = 0,
} CMDTYPE;
/**
*/
NONE = 0,
} CMDTYPE;
/**
- * 命令コード
配列
+ * 命令コード
表の項目
*/
typedef struct {
*/
typedef struct {
- char *name;
- CMDTYPE type;
- WORD code;
+ char *name; /**<命令名 */
+ const void (*ptr); /**<命令の関数ポインタ */
} CMD;
} CMD;
+/**
+ * COMET II命令コード表の項目
+ */
+typedef struct {
+ char *name; /**<命令名 */
+ CMDTYPE type; /**<命令タイプ */
+ WORD code; /**<命令コード */
+ const void (*ptr); /**<命令の関数ポインタ */
+} COMET2CMD;
+
/**
* 命令コードのハッシュ表
*/
typedef struct _CMDTAB {
/**
* 命令コードのハッシュ表
*/
typedef struct _CMDTAB {
- struct _CMDTAB *next;
- C
MD *cmd;
+ struct _CMDTAB *next;
/**<リスト次項目へのポインタ */
+ C
OMET2CMD *cmd; /**<命令コード表の項目 */
} CMDTAB;
/**
} CMDTAB;
/**
- *
CASL2プログラムのプロパティ
+ *
プログラム実行時の開始と終了のアドレス
*/
typedef struct {
*/
typedef struct {
- WORD start; /**<プログラムの開始番地 */
- WORD end; /**<プログラムの終了番地 */
-} PROGPROP;
+ WORD start; /**<開始アドレス */
+ WORD end; /**<終了アドレス */
+ bool stop; /**<終了フラグ */
+} EXECPTR;
-extern PROGPROP *prog;
+extern EXECPTR *execptr;
+
+/**
+ * @brief 汎用レジスタの番号からレジスタを表す文字列を返す
+ *
+ * @return 汎用レジスタを表す文字列。「GR0」「GR1」・・・「GR7」のいずれか
+ *
+ * @param word レジスタ番号[0-7]を表すWORD値
+ */
+char *grstr(WORD word);
/**
* COMET II仮想マシンのリセット
/**
* COMET II仮想マシンのリセット
@@
-142,17
+163,26
@@
void free_cmdtype_code();
/**
* コードがキーの命令ハッシュ表を作成する
*/
/**
* コードがキーの命令ハッシュ表を作成する
*/
-bool create_code_type();
+bool create_code_
cmd
type();
/**
/**
- * 命令コードから命令タイプを返す
- * 無効な場合はNONEを返す
+ * 命令コードから命令の関数ポインタを返す
+ */
+const void (*getcmdptr(WORD code));
+
+/**
+ * 命令コードから命令のタイプを返す
*/
CMDTYPE getcmdtype(WORD code);
*/
CMDTYPE getcmdtype(WORD code);
+/**
+ * 命令コードから命令の名前を返す
+ */
+char *getcmdname(WORD code);
+
/**
* コードがキーの命令ハッシュ表を解放する
*/
/**
* コードがキーの命令ハッシュ表を解放する
*/
-void free_code_type();
+void free_code_
cmd
type();
#endif /* YACASL2_CASL2_INCLUDEDの終端 */
#endif /* YACASL2_CASL2_INCLUDEDの終端 */