Mercurial > hg > Members > kono > os9 > sbc09
annotate v09.c @ 3:831ac057ea86
before mmu
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Wed, 04 Jul 2018 14:03:56 +0900 |
parents | 31d96e2b364e |
children | 6159cc57d44e |
rev | line source |
---|---|
0 | 1 /* 6809 Simulator V09. |
2 | |
3 Copyright 1994, L.C. Benschop, Eidnhoven The Netherlands. | |
4 This version of the program is distributed under the terms and conditions | |
5 of the GNU General Public License version 2. See the file COPYING. | |
6 THERE IS NO WARRANTY ON THIS PROGRAM!!! | |
7 | |
8 This program simulates a 6809 processor. | |
9 | |
10 System dependencies: short must be 16 bits. | |
11 char must be 8 bits. | |
12 long must be more than 16 bits. | |
13 arrays up to 65536 bytes must be supported. | |
14 machine must be twos complement. | |
15 Most Unix machines will work. For MSODS you need long pointers | |
16 and you may have to malloc() the mem array of 65536 bytes. | |
17 | |
18 Define BIG_ENDIAN if you have a big-endian machine (680x0 etc) | |
19 | |
20 Special instructions: | |
21 SWI2 writes char to stdout from register B. | |
22 SWI3 reads char from stdout to register B, sets carry at EOF. | |
23 (or when no key available when using term control). | |
24 SWI retains its normal function. | |
25 CWAI and SYNC stop simulator. | |
26 | |
27 */ | |
28 | |
29 | |
30 #include <stdio.h> | |
31 #include <stdlib.h> | |
32 #include <strings.h> | |
33 #include <sys/stat.h> | |
34 | |
35 #define engine extern | |
36 | |
37 #include "v09.h" | |
38 | |
39 FILE *tracefile; | |
40 | |
2
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
41 extern FILE *disk[]; |
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
42 extern FILE *fp; // for disasm |
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
43 extern char *prog; // for disasm |
0 | 44 extern void disasm(int,int); |
45 | |
46 void do_trace(FILE *tracefile) | |
47 { | |
48 Word pc=pcreg; | |
49 Byte ir; | |
50 // fprintf(tracefile,"pc=%04x ",pc); | |
51 // ir=mem[pc++]; | |
52 // fprintf(tracefile,"i=%02x ",ir); if((ir&0xfe)==0x10) fprintf(tracefile,"%02x ",mem[pc]);else | |
53 // fprintf(tracefile," "); | |
54 fprintf(tracefile,"x=%04x y=%04x u=%04x s=%04x a=%02x b=%02x cc=%02x pc=", | |
55 xreg,yreg,ureg,sreg,*areg,*breg,ccreg); | |
56 fp = tracefile; | |
57 prog = (char*)mem; | |
58 disasm(pc,pc); | |
59 } | |
60 | |
61 char *romfile = "v09.rom"; | |
62 int romstart = 0x8000; | |
63 | |
64 long | |
65 filesize(FILE *image) | |
66 { | |
67 struct stat buf; | |
68 fstat(fileno(image),&buf); | |
69 return buf.st_size; | |
70 } | |
71 | |
72 | |
73 void | |
74 read_image() | |
75 { | |
76 FILE *image; | |
77 if((image=fopen(romfile,"rb"))==NULL) | |
78 if((image=fopen("../v09.rom","rb"))==NULL) | |
79 if((image=fopen("..\\v09.rom","rb"))==NULL) { | |
80 perror("v09, image file"); | |
81 exit(2); | |
82 } | |
83 long len = filesize(image); | |
84 fread(mem+romstart,len,1,image); | |
85 fclose(image); | |
86 } | |
87 | |
88 void usage(void) | |
89 { | |
90 fprintf(stderr,"Usage: v09 [-l romstart] [-rom rom-image] [-t tracefile [-tl addr] [-nt]" | |
91 "[-th addr] ]\n[-e escchar] \n"); | |
92 exit(1); | |
93 } | |
94 | |
95 | |
96 #define CHECKARG if(i==argc)usage();else i++; | |
97 | |
98 int | |
99 main(int argc,char *argv[]) | |
100 { | |
101 char *imagename=0; | |
102 int i; | |
103 int setterm = 1; | |
104 escchar='\x1d'; | |
105 tracelo=0;tracehi=0xffff; | |
106 for(i=1;i<argc;i++) { | |
107 if (strcmp(argv[i],"-t")==0) { | |
108 i++; | |
109 if((tracefile=fopen(argv[i],"w"))==NULL) { | |
110 perror("v09, tracefile"); | |
111 exit(2); | |
112 } | |
113 tracing=1;attention=1; | |
114 } else if (strcmp(argv[i],"-rom")==0) { | |
115 i++; | |
1 | 116 timer = 0; // non standard rom image, don't start timer |
0 | 117 romfile = argv[i]; |
2
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
118 } else if (strcmp(argv[i],"-0")==0) { |
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
119 i++; |
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
120 disk[0] = fopen(argv[i],"r+"); |
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
121 } else if (strcmp(argv[i],"-1")==0) { |
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
122 i++; |
31d96e2b364e
add virtual hd option to v09
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1
diff
changeset
|
123 disk[1] = fopen(argv[i],"r+"); |
0 | 124 } else if (strcmp(argv[i],"-tl")==0) { |
125 i++; | |
126 tracelo=strtol(argv[i],(char**)0,0); | |
127 } else if (strcmp(argv[i],"-th")==0) { | |
128 i++; | |
129 tracehi=strtol(argv[i],(char**)0,0); | |
130 } else if (strcmp(argv[i],"-e")==0) { | |
131 i++; | |
132 escchar=strtol(argv[i],(char**)0,0); | |
133 } else if (strcmp(argv[i],"-l")==0) { | |
134 i++; | |
135 romstart=strtol(argv[i],(char**)0,0); | |
1 | 136 } else if (strcmp(argv[i],"-nt")==0) { // start debugger at the start |
0 | 137 attention = escape = 1; |
1 | 138 timer = 0; // no timer |
0 | 139 } else usage(); |
140 } | |
141 #ifdef MSDOS | |
142 if((mem=farmalloc(65535))==0) { | |
143 fprintf(stderr,"Not enough memory\n"); | |
144 exit(2); | |
145 } | |
146 #endif | |
147 read_image(); | |
148 if (setterm) set_term(escchar); | |
149 pcreg=(mem[0xfffe]<<8)+mem[0xffff]; | |
150 interpr(); | |
151 return 0; | |
152 } | |
153 |