annotate src/list.c @ 0:57495da01900

Initial checking of LWASM
author lost
date Fri, 03 Oct 2008 02:44:20 +0000
parents
children 34568fab6058
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
1 /*
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
2 * list.c
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
3 *
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
4 * code for displaying a program listing in lwasm
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
5 */
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
6
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
7 //#include <ctype.h>
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
8 #include <errno.h>
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
9 #include <stdio.h>
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
10 //#include <stdlib.h>
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
11 #include <string.h>
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
12 #define __list_c_seen__
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
13 //#include "instab.h"
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
14 #include "lwasm.h"
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
15
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
16 const char *errlist[] =
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
17 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
18 "No error",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
19 "Bad opcode",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
20 "Illegal Symbol",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
21 "Multiply defined symbol",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
22 "Symbol required but not present",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
23 "Forward references not permitted",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
24 "Byte overflow",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
25 "Phase error",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
26 "Bad operand",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
27 "Symbol not permitted here",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
28 "Undefined symbol",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
29 "Bit number out of range",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
30 "Invalid expression",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
31 "Invalid register",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
32 "Bad file name",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
33 "ENDM without MACRO",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
34 "Redefined macro",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
35 "Nested namespace",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
36 "Bad condition",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
37 "User error",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
38 "Bad pragma",
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
39 ""
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
40 };
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
41
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
42 void list_code(asmstate_t *as)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
43 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
44 FILE *lf;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
45 sourceline_t *cl;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
46 int bn;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
47 int c;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
48 char *t;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
49
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
50 if (as -> listfile && strcmp(as -> listfile, "-"))
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
51 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
52 lf = fopen(as -> listfile, "w");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
53 if (!lf)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
54 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
55 perror("Cannot open list file");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
56 return;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
57 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
58 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
59 else
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
60 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
61 lf = stdout;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
62 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
63
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
64 for (cl = as -> source_head; cl; cl = cl -> next)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
65 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
66 bn = 0;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
67 if (cl -> errors)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
68 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
69 errortab_t *e;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
70 for (e = cl -> errors; e; e = e -> next)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
71 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
72 if (e -> errnum < ERR_MAXERR && e -> errnum != ERR_USER)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
73 fprintf(lf, "*****ERROR: %s\n", errlist[e -> errnum]);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
74 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
75 if (cl -> user_error)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
76 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
77 fprintf(lf, "*****ERROR: %s\n", cl -> user_error);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
78 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
79 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
80 if (cl -> skipped)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
81 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
82 fprintf(lf, "%-15.15s", "<skipped>");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
83 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
84 else if (cl -> macrodef)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
85 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
86 fprintf(lf, "%-15.15s", "<macrodef>");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
87 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
88 else if (cl -> opcode >= 0 && cl -> numcodebytes > 0)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
89 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
90 fprintf(lf, "%04X ", cl -> addr);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
91 while (bn < 5 && bn < cl -> numcodebytes)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
92 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
93 fprintf(lf, "%02X", cl -> codebytes[bn]);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
94 bn++;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
95 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
96 while (bn < 5)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
97 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
98 fprintf(lf, " ");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
99 bn++;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
100 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
101 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
102 else if (cl -> addrset || (cl -> len && cl -> numcodebytes == 0))
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
103 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
104 fprintf(lf, "%04X %10s", cl -> addr, "");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
105 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
106 else if (cl -> isequ)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
107 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
108 fprintf(lf, " %04X ", cl -> symaddr);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
109 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
110 else if (cl -> issetdp)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
111 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
112 fprintf(lf, " %02X ", cl -> dpval);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
113 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
114 else
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
115 fprintf(lf, " ");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
116 fprintf(lf, " %15.15s:%06d ", cl -> sourcefile, cl -> lineno);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
117 // actually display the line from the file
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
118 for (c = 0, t = cl -> line; *t; t++)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
119 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
120 if (*t == '\n' || *t == '\r')
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
121 break;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
122 if (*t == '\t')
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
123 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
124 do
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
125 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
126 fprintf(lf, " ");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
127 c++;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
128 } while (c % 8);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
129 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
130 else
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
131 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
132 c++;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
133 fprintf(lf, "%c", *t);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
134 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
135 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
136 // fprintf(lf, "\n");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
137
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
138 while (bn < cl -> numcodebytes)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
139 {
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
140 if (bn % 5 == 0)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
141 fprintf(lf, "\n%04X ", (cl -> addr + bn) & 0xFFFF);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
142 fprintf(lf, "%02X", cl -> codebytes[bn]);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
143 bn++;
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
144 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
145 fprintf(lf, "\n");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
146 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
147
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
148 fprintf(lf, "\n");
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
149 list_symbols(as, lf);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
150
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
151 if (lf != stdout)
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
152 fclose(lf);
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
153 }
57495da01900 Initial checking of LWASM
lost
parents:
diff changeset
154