Add a simple dissasembler to igen
[platform/upstream/binutils.git] / sim / igen / ChangeLog
1 Thu May 29 10:29:57 1997  Andrew Cagney  <cagney@b1.cygnus.com>
2
3         * lf.c (lf_write): New function write an N character buffer to the
4         file.
5
6         * igen.c (print_itrace): When available, use the assembler to
7         print the insn-trace.
8         (print_itrace_prefix): New function, print first part of call to
9         print_one_insn.
10         (print_itrace_format): New function, print fmt argument for
11         print_one_insn.
12         
13         * table.c (table_entry_read): Save any assembler lines instead of
14         discarding them.
15
16 Wed May 28 09:55:29 1997  Andrew Cagney  <cagney@b1.cygnus.com>
17
18         * gen-icache.c (print_icache_body): Process immeds.
19
20         * gen-semantics.c (print_semantic_body): When computing NIA, skip
21         any immed words that follow the instruction word.
22
23         * ld-insn.c (parse_insn_format): Parse immeds appended to an
24         instruction.
25
26         * igen.c (main): Allow any register to be specified as the zero
27         register.
28         (semantic_zero_reg): Global, index to zero register.
29
30         * gen-semantics.c (print_semantic_body): Zero selected register.
31
32 Tue May 27 14:12:32 1997  Andrew Cagney  <cagney@b1.cygnus.com>
33
34         * igen.h: Stop options and code gen type bit masks overlaping.
35
36 Fri May 23 12:01:08 1997  Andrew Cagney  <cagney@b1.cygnus.com>
37
38         * gen-semantics.c (print_semantic_body): Incorrect test for
39         zero-r0 code.
40
41 Fri May 16 14:32:31 1997  Andrew Cagney  <cagney@b1.cygnus.com>
42
43         * gen-semantics.c (print_semantic_body): Use common sim-engine
44         interface.
45
46 Fri May 16 11:48:30 1997  Andrew Cagney  <cagney@b1.cygnus.com>
47
48         * gen-semantics.c (print_semantic_body): Add code to clear r0.
49
50         * igen.c (main): Add new option zero-r0, which adds code to clear
51         GPR(0) each cycle.
52
53 Wed May  7 12:31:30 1997  Andrew Cagney  <cagney@b1.cygnus.com>
54
55         * igen.c (print_itrace): Fix so line-nr is passed to trace
56         function.
57
58         * gen-idecode.c (print_idecode_validate): Correct FP code.
59
60         * gen-support.c (gen_support_h): Always pass MY_INDEX to support
61         functions.
62         (print_support_function_name): Ditto.
63
64 Tue May  6 06:12:04 1997  Mike Meissner  <meissner@cygnus.com>
65
66         * igen.c (print_itrace): Call trace_one_insn to trace
67         instructions, rather than doing it directly.
68
69 Mon May  5 14:11:46 1997  Mike Meissner  <meissner@cygnus.com>
70
71         * gen-engine.c (engine_switch_leaf): Remove extra %s.
72         (print_engine_floating_point_unavailable): Wrap in #ifdef
73         UNUSED/#endif, until somebody uses it.
74
75         * gen-idecode.c (error_leaf_contains_multiple_insn): Remove unused
76         variable.
77         (print_jump_until_stop_body): Wrap in #ifdef UNUSED/#endif, until
78         somebody uses it.
79         (print_idecode_validate): Use long formats to print long values.
80
81         * gen-semantics.c (print_idecode_invalid): Set name to "unknown"
82         if we get an unexpected type.
83
84 Fri May  2 13:28:06 1997  Andrew Cagney  <cagney@b1.cygnus.com>
85
86         * igen.c (print_itrace): Pass SD as well as CPU to calls to
87         trace_printf.
88
89         * gen-support.c (gen_support_h): Always pass sim_cia cia to
90         support functions.
91         (print_support_function_name): Ditto.
92
93 Wed Apr 30 17:35:51 1997  Andrew Cagney  <cagney@b1.cygnus.com>
94
95         * gen-support.c (support_c_function): Remove unnecessary memset of
96         cia.
97         * gen-semantics.c (print_semantic_body): Wasn't closing
98         generated comment.
99
100 Tue Apr 29 11:11:12 1997  Andrew Cagney  <cagney@b1.cygnus.com>
101
102         * ld-insn.c (load_insn_table): Report instructions that do not
103         have at least a format and name.
104         (insn_table_find_opcode_field): Check progress is being made.
105
106         * gen-support.c (support_c_function): Report empty function body.
107
108 Thu Apr 24 11:43:45 1997  Andrew Cagney  <cagney@b1.cygnus.com>
109
110         * ld-insn.c (insn_table_expand_opcode): Allow reserved fields to
111         be broken up.
112         (insn_table_expand_insns): Allow special rules to apply to groups
113         of instructions when all members of the group match the special
114         mask/value.
115
116         * gen-semantics.c (print_c_semantic): Ditto.
117         * igen.c (print_semantic_function_formal): Ditto.
118         (print_semantic_function_type): Ditto.
119         * igen.c (print_icache_function_formal): Ditto.
120         * gen-idecode.c (print_idecode_issue_function_body): Ditto.
121
122         * gen-idecode.c (gen_idecode_h): Prepend the global_prefix to the
123         instruction_address type.
124
125         * gen-semantics.c (print_semantic_body): Call cpu_error when an
126         unimplemented instruction is encountered - gives the interpreter
127         the chance to stop correctly.
128
129 Wed Apr 23 20:06:36 1997  Andrew Cagney  <cagney@b1.cygnus.com>
130
131         * igen.c (print_function_name): Allow dot's in instruction names.
132
133 Tue Apr 22 21:46:28 1997  Andrew Cagney  <cagney@b1.cygnus.com>
134
135         * igen.c (main), igen.h: Support new option - delayed-branch -
136         generate code to drive a delayed branch processor.
137
138         * gen-idecode.c (gen_idecode_h): Define instruction_address type.
139
140         * igen.c (print_icache_function_formal): Replace address_word with
141         instruction_address.
142         (print_semantic_function_formal): Ditto.
143         (print_semantic_function_type): Ditto.
144         * gen-idecode.c (print_idecode_issue_function_body): Ditto.
145
146         * gen-semantics.c (print_semantic_body): Ditto.
147         (print_c_semantic): Ditto.
148
149         * gen-support.c (support_c_function): Return a zeroed CIA instead
150         of just zero - works with any cia type.
151
152         * igen.c (print_itrace): For delayed branch case, print just the
153         current instruction.
154         
155 Thu Apr 17 07:02:33 1997  Doug Evans  <dje@canuck.cygnus.com>
156
157         * igen.c (print_itrace): Use TRACE_FOO_P and trace_printf.
158
159 Tue Apr 15 15:20:31 1997  Ian Lance Taylor  <ian@cygnus.com>
160
161         * Makefile.in (INSTALL): Set to @INSTALL@.
162         (INSTALL_XFORM, INSTALL_XFORM1): Remove.
163
164 Mon Apr 14 16:29:34 1997  Ian Lance Taylor  <ian@cygnus.com>
165
166         * Makefile.in (INSTALL): Change install.sh to install-sh.
167
168 Wed Apr  2 18:51:20 1997  Doug Evans  <dje@canuck.cygnus.com>
169
170         * gen-support.c (gen_support_c): sim-state.h renamed to sim-main.h.
171         * gen-idecode.c (gen_idecode_c): Likewise.
172         * igen.c (gen_semantics_c): Likewise.
173
174 Mon Mar 24 10:10:08 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
175
176         * gen-icache.c (print_icache_body): No longer define cpu/sd,
177         support.h now defines CPU/SD globally.
178
179         * gen-model.c (gen_model_h): Ditto.
180
181         * gen-idecode.c (print_idecode_issue_function_body): Ditto.
182         (print_jump): Ditto.
183         (print_jump_until_stop_body): Ditto.
184         (print_idecode_validate): Ditto.
185
186         * gen-icache.c (print_icache_body): Ditto.
187
188         * gen-semantics.c (print_semantic_body): Ditto.
189
190         * igen.c (print_semantic_function_formal): Rename cpu to sim_cpu,
191         processor to cpu.
192         (print_icache_function_formal): Ditto.
193
194         * gen-support.c (print_support_function_name): Include sd/cpu arg
195         in support function argument list.
196         (support_c_function): Generate code to cpu/sd from sd/cpu.
197         (gen_support_h): Define _SD the argument prefix for all support
198         functions.  Define SD/CPU to determine sd/cpu from value of _SD
199         macro.
200
201 Tue Mar 18 15:52:24 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
202
203         * gen-support.c (gen_support_c): Update for renaming of engine to
204         sim-state.
205         
206         * igen.c: Ditto.
207         * gen-idecode.c (gen_idecode_c): Ditto.
208
209 Mon Mar 17 15:17:07 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
210
211         * ld-decode.c (load_decode_table): Rename slash to reserved.
212         (dump_decode_rule): Ditto.
213
214         * ld-insn.c (parse_insn_format): Differentiate between a `/' -
215         reserved bit - and a `*' - wild card.
216         (parse_insn_format): Change is_slash to more informative reserved.
217         (dump_insn_field): Ditto.
218         (insn_field_is_constant): Ditto.
219         (insn_table_expand_opcode): Ditto.
220
221         * gen-idecode.c (print_idecode_validate): Make check_mask and
222         check_val the correct integer size.
223         (print_idecode_validate): Fix reserved bit check for 64 bit
224         targets.
225
226 Fri Mar 14 11:24:06 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
227
228         * ld-insn.c (parse_insn_format): Accept '*' as an alternative of
229         `/' in bit fields.  `/' denotes a wild bit.
230
231 Fri Mar  7 18:20:38 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
232
233         * igen.h, igen.c (main): New options. Control generation of
234         conditional issue and slot verification code.
235
236 Fri Mar  7 18:17:25 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
237
238         * gen-support.c (print_support_function_name): Prepend the global
239         name prefix when applicable.  Provide #define to map the user
240         specified name the generated globaly unique one.
241
242 Fri Mar  7 18:07:45 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
243
244         * gen-idecode.c (print_idecode_validate): Wrap each of the checks
245         - reserved bits, floating point and slot validation - with a
246         #ifdef so that they are optional.
247         
248 Fri Mar  7 16:35:13 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
249
250         * gen-idecode.c (error_leaf_contains_multiple_insn): New function
251         - report the error of a leaf node in the decision tree containing
252         several instructions.
253         (print_idecode_table_leaf): Detect a leaf with multiple instructions.
254         (print_idecode_switch_leaf): Ditto.
255
256         * gen-semantics.h, gen-semantics.c (print_idecode_illegal,
257         print_idecode_invalid): Rename former to latter.  Add argument so
258         that one function can generate all invalid instruction cases -
259         illegal, fp-unavailable, wrong-slot.
260         * gen-engine.c: Update.
261
262         * gen-idecode.c: Use print_idecode_invalid to generate a function
263         call for cases when fp-unavailable and the slot is wrong.
264
265         * gen-idecode.c (print_idecode_validate): New check, generate code
266         to verify that the instruction slot is correct.
267         
268         * igen.c (main): Simplify options.
269
270 Wed Mar  5 09:55:55 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
271
272         * igen.c (print_itrace): Remove source line reference for trace
273         code - let the user see the generated file.
274         (print_itrace): Print the trace code rather than reference a
275         macro.
276
277 Tue Mar  4 17:31:55 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
278
279         * igen.c (print_semantic_function_actual): Pass either the
280         processor - smp - or the engine - mono - into semantic functions.
281         Don't pass in both.
282
283         * gen-icache.c (print_icache_body): Dependant on smp, derive
284         processor from engine or engine from processor, and hence ensuring
285         that both are defined in all semantic functions.
286
287 Mon Mar  3 17:11:21 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
288
289         * ld-insn.c (parse_insn_format): Make the width field optional.
290         If missing assume that the number of characters in the value
291         determines the number of bits in the field.
292         
293 Thu Feb 27 11:27:48 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
294
295         * ld-insn.c (insn_table_expand_opcode): Replace assertion with
296         more useful error message.
297
298 Tue Feb 25 16:43:27 1997  Andrew Cagney  <cagney@kremvax.cygnus.com>
299
300         * misc.c (error): Output errors on stderr.
301
302         * ld-insn.c (parse_insn_format): Skip any leading spaces.
303         Verify the width of instructions being parsed.
304
305         * table.c (table_entry_read): Parse CPP's convention for
306         specifying original file name/line-nr.
307
308 Wed Feb 19 12:30:28 1997  Andrew Cagney  <cagney@critters.cygnus.com>
309
310         * ld-insn.c (parse_insn_format): Allow trailing spaces in
311         instruction fields.
312
313         * Makefile.in: Create using ../ppc/Makefile.in as a starting
314         point.
315         * configure.in: Ditto vis ../ppc/configure.in
316         
317 Mon Feb 17 10:44:18 1997  Andrew Cagney  <cagney@critters.cygnus.com>
318
319         * gen-support.c (gen_support_c): Always include engine.h instead
320         of cpu.h
321         * gen-idecode.c (gen_idecode_c): Ditto.
322
323         * words.h (instruction_word): Remove instruction_word - now
324         generated by igen.
325         (address_word): New.  Used by igen.
326         
327         * lf.c (lf_print_function_type_function): New, pass a function to
328         print out the type instead of a constant string.
329         
330         * igen.h, igen.c (print_semantic_function_formal,
331         SEMANTIC_FUNCTION_FORMAL): Relace macro with function.
332         (print_semantic_function_actual, SEMANTIC_FUNCTION_ACTUAL): Ditto.
333         (print_semantic_function_type, SEMANTIC_FUNCTION_TYPE): Ditto.
334         (print_icache_function_type, ICACHE_FUNCTION_TYPE): Ditto.
335         (print_icache_function_formal, ICACHE_FUNCTION_FORMAL): Ditto.
336         (print_icache_function_actual, ICACHE_FUNCTION_ACTUAL): Ditto.
337         * gen-idecode.c (print_idecode_table): Update.
338         (idecode_switch_leaf): Update.
339         (print_idecode_switch_function_header): Ditto.
340         (print_idecode_floating_point_unavailable): Ditto.
341         (print_idecode_issue_function_header): Ditto.
342         * igen.c (gen_icache_h): Ditto.
343         * gen-engine.c (print_engine_table): Ditto.
344         (engine_switch_leaf): Ditto.
345         * gen-support.c (print_support_function_name): Ditto.
346         * gen-semantics.c (print_semantic_function_header): Update.
347         Update.
348         * gen-icache.c (print_icache_function_header): Update.
349         (print_icache_function): Update.
350         (print_icache_internal_function_declaration): Update.
351         (print_icache_internal_function_definition): Update.
352
353         * gen-idecode.c (gen_idecode_h): Drop including of idecode_*.h
354         files, will at some stage need to move it into support.
355
356         * igen.h, igen.c (main): New option -e <engine> - generate a full
357         simulation engine.  Previously this was the -d <idecode-file>
358         option.
359         * gen-engine.h, gen-engine.c: Copies of gen-idecode.*.  Will need
360         to clean these up so that that call upon the updated gen-idecode
361         code.
362         
363         * gen-idecode.h, gen-idecode.c: Prune out any code not relevant to
364         generating a decode table.
365         
366         * Makefile.in (igen): Add dependencies for new gen-engine.* files.
367
368         * igen.h, igen.c (main): New option -M - Control what is returned
369         by semantic functions - -1/NIA vs CIA+N/NIA.  Add
370         generate_semantic_returning_modified_nia_only to igen_code enum.
371         * gen-semantics.c (print_semantic_body): As an alternative, make
372         NIA == -1 instead of CIA+insn_size by default.
373         
374         * igen.h, igen.c (main, global_name_prefix, global_uname_prefix):
375         New option -P <prefix> - Prepend all generated functions with the
376         specified prefix.
377         (gen_idecode_c): Adjust.
378         * gen-icache.c (print_icache_struct): Ditto.
379         * gen-support.c (gen_support_c): Ditto.
380
381 Sun Feb 16 15:23:15 1997  Andrew Cagney  <cagney@critters.cygnus.com>
382
383         * igen.c (main): Correct usage. Missleading message about ucase
384         options dumping internal tables.  -F now includes rather then
385         excludes instructions.
386
387         * misc.h, misc.c (a2i): Make 64bit.
388
389         * ld-insn.h (max_insn_bit_size, default_insn_bit_size): Increase
390         max to 64bits, expect trouble.  Make the default 32 bits.
391         * gen-idecode.c (print_idecode_table): Change EXTRACTED*
392         et.al. macro's to use the insn_bit_size instead of assuming 32
393         bits.
394         * gen-icache.c (print_icache_extraction): Ditto.
395         * gen-idecode.c (idecode_switch_start): Ditto.
396         * gen-idecode.c (gen_idecode_c): Ditto
397
398         * igen.h (insn_specifying_widths), igen.c (main): New option -W.
399         Indicates that the instruction field of the table is specifying
400         bit widths instead of bit offsets.
401         * ld-insn.c (parse_insn_format): Parse instruction fields
402         specifying widths.
403
404         * misc.c (a2i): Allow binary numbers to be specified using the
405         syntax 0bNNNN.
406         * ld-insn.c: Allow such numbers to appear in the instruction
407         format.
408
409         * table.c (table_entry_read): Make // a valid comment character.
410         (table_entry_read): Skip lines containing a leading " - these may
411         eventually be used in a disasembler.
412
413 Fri Feb 14 15:23:15 1997  Andrew Cagney  <cagney@critters.cygnus.com>
414
415         * filter.c, filter.h, gen-engine.c, gen-engine.h, gen-icache.c,
416         gen-icache.h, gen-idecode.c, gen-idecode.h, gen-itable.c,
417         gen-itable.h, gen-model.c, gen-model.h, gen-semantics.c,
418         gen-semantics.h, gen-support.c, gen-support.h, igen.c, igen.h,
419         ld-cache.c, ld-cache.h, ld-decode.c, ld-decode.h, ld-insn.c,
420         ld-insn.h, lf.c, lf.h, misc.c, misc.h, table.c, table.h: Copy in
421         from the ../ppc directory.
422
423         * filter_host.c, filter_host.h: Copy in from the ../ppc directory
424         renaming from filter_filename.[hc]