バージョンアップ
[YACASL2.git] / src / dump.c
index d07c40f..858235b 100644 (file)
@@ -1,42 +1,32 @@
-#include "casl2.h"
+#include "exec.h"
 
-/* WORD値を2進数表記に変換 */
-char *word2bit(const WORD word)
+/* exec.hに定義された関数群 */
+void dumpmemory(WORD start, WORD end)
 {
-    WORD mask = 0x8000;
-    char *bit, *p;
-    bit = malloc(16 + 1);
-    p = bit;
-        while(mask > 0){
-            if((word & mask) == 0) {
-            *p++ = '0';
-        } else {
-            *p++ = '1';
-        }
-        mask = (mask >> 1);
-    }
-    *p = '\0';
-    return bit;
-}
-
-/* COMET IIのメモリを表示 */
-void dumpmemory()
-{
-    const int col = 16;
-    int i;
+    const WORD col = 0x10;
+    WORD i, j, mod = 0x0;
     /* Header */
-    fprintf(stdout, "#%04X: adr :", PR);
-    for(i = 0; i < col; i++) {
+    fprintf(stdout, "#%04X: adr :", sys->cpu->pr);
+    if(end > sys->memsize) {
+        end = sys->memsize;
+    }
+    for(i = 0; i < sys->memsize && i < col; i++) {
         fprintf(stdout, " %04X", i);
     }
     fprintf(stdout, "\n");
+    fprintf(stdout, "       -------------------------------------------------------------------------------------\n");
     /* Memory */
-    for(i = 0; i < memsize; i++) {
-        if(i % col == 0) {
-            fprintf(stdout, "#%04X: %04X: ", PR, i);
+    for(i = start; i < end; i++) {
+        if((mod = i % col) == 0 || i == start) {
+            fprintf(stdout, "#%04X: %04X: ", sys->cpu->pr, i);
+        }
+        if(i == start) {
+            for(j = 0; j < mod; j++) {
+                fprintf(stdout, "     ");
+            }
         }
-        fprintf(stdout, "%04X", memory[i]);
-        if(i > 0 && (i + 1) % col == 0) {
+        fprintf(stdout, "%04X", (sys->memory)[i]);
+        if((i > 0 && (i + 1) % col == 0) || (i + 1) == end) {
             fprintf(stdout, "\n");
         } else {
             fprintf(stdout, " ");
@@ -44,20 +34,24 @@ void dumpmemory()
     }
 }
 
-/* COMET IIのレジスタを表示 */
 void dspregister()
 {
-    int i;
-    for(i = 0; i < REGSIZE; i++ ) {
-        if(logicalmode == true) {
-            fprintf(stdout, "#%04X: GR%d: %6d = #%04X = %s\n",
-                    PR, i, GR[i], GR[i], word2bit(GR[i]));
-        } else {
-            fprintf(stdout, "#%04X: GR%d: %6d = #%04X = %s\n",
-                    PR, i, (short)GR[i], GR[i], word2bit(GR[i]));
-        }
+    char *sp = NULL;
+    char *pr = NULL;
+    char *fr = NULL;
+    for(int i = 0; i < GRSIZE; i++ ) {
+        fprintf(stdout, "#%04X: GR%d: ", sys->cpu->pr, i);
+        print_dumpword(sys->cpu->gr[i], execmode.logical);
+        fprintf(stdout, "\n");
     }
-    fprintf(stdout, "#%04X: SP:  %6d = #%04X = %s\n", PR, SP, SP, word2bit(SP));
-    fprintf(stdout, "#%04X: PR:  %6d = #%04X = %s\n", PR, PR, PR, word2bit(PR));
-    fprintf(stdout, "#%04X: FR (OF SF ZF): %s\n", PR, (word2bit(FR)+13));
+    fprintf(stdout, "#%04X: SP:  %6d = #%04X = %s\n",
+            sys->cpu->pr, sys->cpu->sp, sys->cpu->sp, sp = word2bit(sys->cpu->sp));
+    fprintf(stdout, "#%04X: PR:  %6d = #%04X = %s\n",
+            sys->cpu->pr, sys->cpu->pr, sys->cpu->pr, pr = word2bit(sys->cpu->pr));
+    fprintf(stdout, "#%04X: FR (OF SF ZF): %s\n",
+            sys->cpu->pr, ((fr = word2bit(sys->cpu->fr)) + 13)); /* FRは末尾3けたを表示 */
+
+    FREE(sp);
+    FREE(pr);
+    FREE(fr);
 }