]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - sim/common/ChangeLog
2003-02-20 Andrew Cagney <ac131313@redhat.com>
[thirdparty/binutils-gdb.git] / sim / common / ChangeLog
CommitLineData
45a15d6f
KH
12003-01-08 Kazu Hirata <kazu@cs.umass.edu>
2
3 * run.c (usage): Fix typos.
4
127a77fe
CD
52002-11-27 Richard Sandiford <rsandifo@redhat.com>
6
7 * sim-fpu.c (sim_fpu_inv): Use sim_fpu_div.
8
b85e4829
AC
92002-11-22 Andrew Cagney <ac131313@redhat.com>
10
11 * dv-core.c: Update copyright. sim/common contributed to the FSF.
12 * dv-glue.c, dv-pal.c, hw-base.c, hw-base.h, hw-device.c: Ditto.
13 * hw-device.h, hw-handles.c, hw-handles.h: Ditto.
14 * hw-instances.c, hw-instances.h, hw-properties.c: Ditto.
15 * hw-properties.h, hw-tree.c, hw-tree.h, sim-alu.h: Ditto.
16 * sim-basics.h, sim-bits.c, sim-bits.h, sim-config.c: Ditto.
17 * sim-config.h, sim-core.c, sim-core.h, sim-endian.c: Ditto.
18 * sim-endian.h, sim-events.c, sim-events.h, sim-inline.c: Ditto.
19 * sim-inline.h, sim-io.c, sim-io.h, sim-n-bits.h: Ditto.
20 * sim-n-core.h, sim-n-endian.h, sim-types.h: Ditto.
21
d25b1553
AC
222002-11-13 Andrew Cagney <cagney@redhat.com>
23
24 * run.c (main): Remove SIM_HAVE_ENVIRONMENT from #endif.
25
d690312f
CD
262002-11-06 Richard Sandiford <rsandifo@redhat.com>
27
28 * Make-common.in (SIM_EXTRA_DISTCLEAN): New macro.
29 (distclean): Depend on it.
30
7c3e3b33
AM
312002-10-14 Alan Modra <amodra@bigpond.net.au>
32
33 * cgen-trace.h: Test __BFD_H_SEEN__ rather than BFD_VERSION.
34
7ede505a
DB
352002-08-29 Dave Brolley <brolley@redhat.com>
36
37 * Make-common.in (CGEN_READ_SCM): Remove ../../cgen/stamp-cgen.
38
75c4388a
AC
392002-07-17 Andrew Cagney <cagney@redhat.com>
40
41 * run-sim.h: Add #ifdef RUN_SIM_H wrapper.
42 (sim_set_callbacks, sim_size, sim_trace)
43 (sim_set_trace, sim_set_profile_size, sim_kill): Declare. Moved
44 to here from "gdb/remote-sim.h".
45
7a3085c1 462002-07-16 Andrew Cagney <ac131313@redhat.com>
39248af8
AC
47
48 * sim-resume.c (sim_resume): Add local variable sig_to_deliver to
49 avoid possible longjmp problems with automatic variable siggnal.
50
076043f2
AC
512002-07-14 Andrew Cagney <ac131313@redhat.com>
52
53 From 2002-07-11 Momchil Velikov <velco@fadata.bg>:
54 * Make-common.in (installdirs): Make $(libdir) too, needed when
55 installing libsim.a.
56
3fbeef0b
AC
572002-07-13 Andrew Cagney <ac131313@redhat.com>
58
59 * gennltvals.sh (dir): Mark d30v as obsolete.
60 * nltvals.def: Remove d30v.
61
bf962092
AC
622002-06-17 Andrew Cagney <cagney@redhat.com>
63
27961795
AC
64 * hw-events.c (hw_event_queue_schedule): Initialize `dummy'.
65
bf962092
AC
66 * sim-memopt.c: Include <unistd.h>.
67 (do_memopt_add): Fix printf format.
68 * sim-events.c (sim_events_schedule): Initialize ``dummy''.
69
c8cca39f
AC
702002-06-16 Andrew Cagney <ac131313@redhat.com>
71
72 * aclocal.m4 (SIM_AC_OPTION_WARNINGS): Update to match GDB's
73 --enable-gdb-build-warnings.
74 * configure: Regenerated to track ../common/aclocal.m4 changes.
75
307041b7 762002-06-09 Aldy Hernandez <aldyh@redhat.com>
7d7d930f
AH
77
78 * sim-fpu.c (unpack_fpu): Initialize exponent for
79 sim_fpu_class_zero.
80 (i2fpu): Same.
81 (sim_fpu_sqrt): Same.
82
3c25f8c7
AC
832002-06-08 Andrew Cagney <cagney@redhat.com>
84
85 * gentmap.c (gen_targ_map_c): Generate "gdb/callback.h".
86 * sim-basics.h: Include "gdb/callback.h" and "gdb/remote-sim.h".
87 * run.c: Ditto.
88 * sim-load.c: Ditto.
89 * callback.c: Ditto.
90 * syscall.c: Ditto.
91 * Make-common.in (callback_h): Define.
92 (remote_sim_h): Define.
93 (run.o): Update.
94 (callback.o): Update.
95 (syscall.o): Update.
96 (sim-load.o):
97 (nrun.o): Update.
98 (sim-hload.o): Update.
99 (sim-io.o): Update.
100 (sim-reason.o): Update.
101 (sim-reg.o): Update.
102 (sim-resume.o): Update.
103
dbec3bef
KH
1042002-05-30 Kazu Hirata <kazu@cs.umass.edu>
105
106 * run.c: Fix formatting.
107
de4112fa
NC
1082002-05-20 Nick Clifton <nickc@cambridge.redhat.com>
109
110 * run-sim.h: New header. Provide prototypes for functions used
111 between run() and libsim.a which are not used by GDB.
112 * run.c: Include run-sim.h.
113 (main): If SIM_TARGET_SWITCHES is defined call
114 sim_target_parse_command_line.
115 (usage): If SIM_TARGET_SWITCHES is defined call
116 sim_target_display_usage.
117
a8cdafbd
AV
1182002-05-17 Andrey Volkov <avolkov@transas.com>
119
120 * run.c: Made h8300s as new target, not h8300h alias.
121 Added new option -S (h8300s target)
122 * sim-options.c: Ditto.
123
5accf1ff
CD
1242002-05-01 Chris Demetriou <cgd@broadcom.com>
125
126 * callback.c: Use 'deprecated' rather than 'depreciated.'
127
080fe24b
AC
1282002-02-24 Andrew Cagney <ac131313@redhat.com>
129
130 From wiz at danbala:
131 * sim-fpu.h: Fix grammar and typos.
132 Fix PR gdb/287.
133
6439295f
CD
1342002-02-10 Chris Demetriou <cgd@broadcom.com>
135
136 * callback.c: Fix some spelling errors.
137 * hw-device.h: Likewise.
138 * hw-tree.c: Likewise.
139 * sim-abort.c: Likewise.
140 * sim-alu.h: Likewise.
141 * sim-core.h: Likewise.
142 * sim-events.c: Likewise.
143 * sim-events.h: Likewise.
144 * sim-fpu.h: Likewise.
145 * sim-profile.h: Likewise.
146 * sim-utils.c: Likewise.
147
dea03d4e
HPN
1482002-01-31 Hans-Peter Nilsson <hp@axis.com>
149
150 * cgen-ops.h (ADDCQI, ADDCFQI, ADDOFQI, SUBCQI, SUBCFQI, SUBOFQI):
151 New functions.
152
1636f0bb
BE
1532002-01-20 Ben Elliston <bje@redhat.com>
154
155 * sim-fpu.h (SIM_FPU_IS_QNAN): Replace "Quite" with "Quiet" in
156 the comment for this enumerator.
157
b59d44de
BE
1582002-01-14 Ben Elliston <bje@redhat.com>
159
160 * sim-fpu.h: Fix comment about sim_fpu_* constants.
161
280b26c0
KH
1622001-12-20 Kazu Hirata <kazu@hxi.com>
163
164 * run.c (usage): Fix a typo.
165
e3e473da
BE
1662001-07-05 Ben Elliston <bje@redhat.com>
167
168 * Make-common.in (srccgen): Remove.
169 (CGEN_CPU_DIR): Define.
170 (CGEN_READ_SCM): Redefine without $(srccgen).
171 (CGEN_ARCH_SCM): Ditto.
172 (CGEN_CPU_SCM): Ditto.
173 (CGEN_DECODE_SCM): Ditto.
174 (CGEN_DESC_SCM): Ditto.
175
2836ee25
FCE
1762001-04-25 Frank Ch. Eigler <fche@redhat.com>
177
178 * sim-load.c (sim_load_file): Put it back: external now.
179 * sim-utils.c (sim_analyze_program): Ditto. Nyuk nyuk nyuk.
180
5b778125
AC
1812001-04-21 Andrew Cagney <ac131313@redhat.com>
182
183 * sim-load.c (sim_load_file): Delete call bfd_cache_close. BFD
184 internal interface.
185 * sim-utils.c (sim_analyze_program): Ditto.
186
6ec9f4a9
FCE
1872001-04-19 Frank Ch. Eigler <fche@redhat.com>
188
189 * sim-utils.c (sim_analyze_program): Call bfd_cache_close after
190 we're finished with its immediate use.
191 * sim-load.c (sim_load_file): Ditto.
192
764f1408
FCE
1932001-03-16 Frank Ch. Eigler <fche@redhat.com>
194
195 Add support for mmap-based memory regions.
196 * sim-memopt.c (mmap_next_fd): New global.
197 (sim_memory_init): Reinitialize it.
198 (OPTION_MEMORY_MAPFILE, memory_option_handler): Support new
199 "--memory-mapfile FILE" option. Check for some errors.
200 (do_memopt_add): Conditionally do mmap instead of malloc for
201 backing store of simulated memory. Check for more errors.
202 (do_simopt_delete, sim_memory_uninstall): Corresponding cleanup.
203 * sim-memopt.h (munmap_length): New member of _sim_memopt.
204 * configure.in: Look for mmap/fstat related functions and headers.
205 * config.in, configure: Regenerated.
206
35c20992
FCE
2072001-03-15 Frank Ch. Eigler <fche@redhat.com>
208
209 * sim-core.c (sim_core_map_attach): Correct overlap-related
210 error messages.
211
f6bb7a3b
MM
2122001-03-07 Michael Meissner <meissner@redhat.com>
213
214 * run.c (alloca-conf.h): Delete, no longer provided.
215
01816cd8
BE
2162001-02-22 Ben Elliston <bje@redhat.com>
217
218 * sim-trace.h (TRACE_VPU_IDX): Add.
219 (TRACE_vpu): Define.
220 (WITH_TRACE_VPU_P): Likewise.
221 (TRACE_VPU_P): Likewise.
222 * sim-trace.c (OPTION_TRACE_VPU): Define.
223 (trace_options): Add --trace-vpu.
224 (trace_option_handler): Handle OPTION_TRACE_VPU.
225 (trace_option_handler): Include VPU tracing in --trace-semantics.
226 (trace_idx_to_str): Handle TRACE_VPU_IDX.
227
44a9331c
BE
2282001-02-21 Ben Elliston <bje@redhat.com>
229
230 * sim-trace.h (TRACE_BRANCH_INPUT1): New macro.
231 (TRACE_BRANCH_INPUT2): Likewise.
232
c43ad8eb
BE
2332001-02-09 Ben Elliston <bje@redhat.com>
234
235 * (profile_print_pc): Write header out in target byte order.
236
2372001-02-09 Ben Elliston <bje@redhat.com>
238
239 * sim-profile.c (profile_pc_init): Correct bug in loop logic when
240 adjusting the pc shift value.
241
9397fcbf
FCE
2422001-01-12 Chris Demetriou <cgd@sibyte.com>
243
badd2b1e
BE
244 * aclocal.m4 (SIM_AC_OPTION_SCACHE): Properly handle the case
245 where a numeric value is supplied.
9397fcbf 246
63fe1038
BE
2472001-01-06 Ben Elliston <bje@redhat.com>
248
249 * cgen.sh: Allow extrafiles to include the semantics files when
250 generating an ISA-specific decoder.
251
b6f6b44d
AO
2522000-12-27 Alexandre Oliva <aoliva@redhat.com>
253
254 * Make-common.in (sim-io.o): Depend on targ-vals.h.
255
ad8707b5
BE
2562000-12-23 Ben Elliston <bje@redhat.com>
257
258 * cgen-trace.c (trace_result): Handle 'f' type operands; output
259 them to the trace stream using sim_fpu_printn_fpu. Include
260 "sim-fpu.h".
261
b94c0966
BE
2622000-12-15 Ben Elliston <bje@redhat.com>
263
264 * sim-fpu.h (sim_fpu_printn_fpu): Declare.
265 * sim-fpu.c (print_bits): Add digits parameter. Print only as many
266 trailing digits as specified (-1 to print all digits).
267 (sim_fpu_print_fpu): New wrapper around sim_fpu_printn_fpu.
268 (sim_fpu_printn_fpu): Rename from sim_fpu_print_fpu; update calls
269 to print_bits ().
270
fd5d712e
BE
2712000-12-13 Ben Elliston <bje@redhat.com>
272
273 * cgen.sh: Set prefix/PREFIX (append ISA if applicable). Factor
274 sed expressions into $sedscript, substituting @prefix@/@PREFIX@.
275 (defs): New action.
276
4c15ccf7
GK
2772000-12-12 Geoffrey Keating <geoffk@redhat.com>
278
279 * sim-endian.h: Don't have parameters on macro definitions which
280 are simply renaming functions, to permit use of XCONCAT2 in both
281 the macro name and the arguments in a use of such a definition.
282
0d277f51
BE
2832000-12-11 Ben Elliston <bje@redhat.com>
284
285 * cgen-ops.h (SUBWORDDFDI): New function.
286
bb4e03e5
BE
2872000-12-05 Ben Elliston <bje@redhat.com>
288
c79688eb
BE
289 * Make-common.in (cgen-defs): New target.
290 (cgen-decode): Pass $(EXTRAFILES).
291
bb4e03e5
BE
292 * genmloop.sh: Use @prefix@, not @cpu@ throughout. Add -prefix and
293 -outfile-suffix options.
294
76440e4b
BE
2952000-12-04 Ben Elliston <bje@redhat.com>
296
6227bc85
BE
297 * cgen-ops.h (SUBWORDSIQI): Mask off top bits.
298 (SUBWORDSIUQI): Likewise.
299 (SUBWORDDIHI): Likewise.
300 (SUBWORDDIQI): New function.
301
76440e4b
BE
302 * cgen-trace.c (disassemble_insn): Remove unused declaration.
303 * cgen-scache.c (scache_option_handler): Remove unused local var.
304
cdc2a5c3
BE
3052000-12-03 Ben Elliston <bje@redhat.com>
306
307 * sim-profile.c (profile_option_handler): Remove unused prof_nr.
308
4e73b9c1
SC
3092000-11-26 Stephane Carrez <Stephane.Carrez@worldnet.fr>
310
311 * hw-events.c (delete_hw_event_data): Remove the scheduled events.
312
ce9bc8d1
SC
3132000-11-26 Stephane Carrez <Stephane.Carrez@worldnet.fr>
314
315 * dv-core.c (dv_core_attach_address_callback): Don't abort if
316 space is not zero.
317
ce13044d
SC
3182000-11-24 Stephane Carrez <Stephane.Carrez@worldnet.fr>
319
320 * hw-base.c (hw_delete): Don't free base_of_hw since it's freed.
321 (set_hw_delete): Moved the macro as a function.
322 * hw-base.h (set_hw_delete): Declare as external function.
323 * hw-alloc.c (delete_hw_alloc_data): Allow to free the memory
324 allocated using hw_malloc.
325
7c070881
SC
3262000-11-24 Stephane Carrez <Stephane.Carrez@worldnet.fr>
327
328 * sim-options.c (sim_parse_args): Free the memory used for
329 long_options, short_options, handlers, opt_cpu, orig_val.
330
4f49fa1b
BE
3312000-11-20 Ben Elliston <bje@redhat.com>
332
333 * cgen-ops.h (SUBBI): New macro.
334 (SUBWORDSIQI, SUBWORDSIHI, SUBWORDSIUQI): New functions.
335 (SUBWORDDIHI, SUBWORDDIUQI, SUBWORDDIDF): Likewise.
336
2d84da1b
BE
3372000-11-16 Ben Elliston <bje@redhat.com>
338
339 * cgen-types.h (VOID): New type.
340
dbc168af
BE
3412000-11-09 Ben Elliston <bje@redhat.com>
342
343 * sim-fpu.c (sim_fpu_one): Set exponent to 0.
344 (sim_fpu_two): Set exponent to 1.
345
e4f5c43e
EZ
3462000-10-26 Ben Elliston <bje@redhat.com>
347
348 * cgen.sh: Handle an isa argument between cpu and mach. Default to
349 `all'. Pass `-i' options to cgen applications.
350 * Make-common.in (cgen-arch, cgen-cpu, cgen-decode, cgen-cpu-decode,
351 cgen-desc): Pass $(isa) to cgen.sh.
352
a8d894af
BE
3532000-10-08 Ben Elliston <bje@redhat.com>
354
355 * cgen-utils.c (cgen_rtx_error): New function.
356
3572000-10-07 Ben Elliston <bje@redhat.com>
358
359 * cgen-trace.c (sim_cgen_disassemble_insn): Handle failure
360 conditions for sim_core_read_buffer().
361
6d4c43bf
DB
3622000-09-26 Dave Brolley <brolley@redhat.com>
363
364 * cgen-utils.c (RORQI): New function.
365 (ROLQI): New function.
366 (RORHI): New function.
367 (ROLHI): New function.
368
0e266e5c
DB
3692000-08-28 Dave Brolley <brolley@redhat.com>
370
371 * cgen-trace.c (sim_cgen_disassemble_insn): Make sure entire insn is
372 in insn_value if it will fit.
373
604259a0
FCE
3742000-08-21 Frank Ch. Eigler <fche@redhat.com>
375
376 * Make-common.in, cgen.sh: Contribute CGEN-related build targets/rules.
377
4193618c
DB
3782000-08-15 Dave Brolley <brolley@redhat.com>
379
380 * sim-profile.c (profile_print_speed): Print cpu frequency if not zero.
381
3822000-08-15 Dave Brolley <brolley@redhat.com>
383
384 * sim-profile.h (PROFILE_DATA): Add cpu_freq.
385 (PROFILE_CPU_FREQ): New macro.
386 * sim-profile.c (OPTION_PROFILE_CPU_FREQUENCY): New enumerator.
387 (profile-options): Add profile-cpu-frequency.
388 (parse_frequency): New function.
389 (profile_option_handler): Handle OPTION_PROFILE_CPU_FREQUENCY.
390 (profile_print_speed): Print cpu frequency and simulated execution time.
391 Re-indent other items to match.
392
548a3e15
AC
3932000-08-09 Andrew Cagney <cagney@lulu.cygnus.com>
394
395 * dv-sockser.c (dv_sockser_init): Eliminate MIN macro.
396
fab307a2
FCE
3972000-07-27 Frank Ch. Eigler <fche@redhat.com>
398
399 From Maciej W. Rozycki <macro@ds2.pg.gda.pl>
400 * Makefile.in (install): Install run.1 man page.
401
46a19b74
AC
402Thu Jul 27 21:56:08 2000 Andrew Cagney <cagney@b1.cygnus.com>
403
404 From 2000-06-23 Doug Evans <dje@casey.transmeta.com>:
405 * Makefile.in (headers,nltvals.def): Merge.
406
3c765a54
AC
407Thu Jul 27 20:37:47 2000 Andrew Cagney <cagney@b1.cygnus.com>
408
f9cbceb6
AC
409 From 2000-06-25 Stephane Carrez <Stephane.Carrez@worldnet.fr>:
410 * nrun.c (main): Print the simulator statistics only in
411 verbose mode.
412 * hw-properties.h (hw_find_integer_array_property): Fix
413 prototype (use signed_cell).
414
38e64f35
AC
415 From 2000-06-25 Stephane Carrez <Stephane.Carrez@worldnet.fr>:
416 * sim-events.c (sim_events_remain_time): New function returning
417 the time that remains before the event is raised.
418 * hw-events.c (hw_event_remain_time): Likewise.
419 * sim-events.h (sim_events_remain_time): Declare.
420 * hw-events.h (hw_event_remain_time): Declare.
421
0802cc40
AC
422 From 2000-06-25 Stephane Carrez <Stephane.Carrez@worldnet.fr>:
423 * sim-hw.c: Use <errno.h> instead of <sys/errno.h>
424 (OPTION_HW_LIST): New option --hw-list to list the devices.
425 (hw_option_handler): List the device tree with 'sim_hw_print'.
426
3c765a54
AC
427 From 2000-06-25 Stephane Carrez <Stephane.Carrez@worldnet.fr>:
428 * sim-bits.h (_MSB_16, _LSB_16): Define for 16-bit targets.
429 (MASK, LSBIT, MSBIT): Likewise and use _MSB_16 and _LSB_16.
430 (EXTENDED): Define for 16-bit word size.
431 * sim-bits.c (LSEXTRACTED, MSEXTRACTED, LSINSERTED,
432 MSINSERTED, LSSEXT, MSSEXT): Implement for 16-bit word size.
433 * sim-types.h: Added support for 16-bit targets.
434
7fb283bc
FCE
4352000-06-23 Frank Ch. Eigler <fche@redhat.com>
436
437 * cgen-trace.h (TRACE_USEFUL_MASK): Remove TRACE_EVENTS_IDX.
438
ab42ee12
FCE
4392000-06-24 Frank Ch. Eigler <fche@redhat.com>
440
441 From Maciej W. Rozycki <macro@ds2.pg.gda.pl>:
442 * Makefile.in (distclean): Clean cconfig.h also.
443
eb2d80b4
AC
444Tue May 23 21:39:23 2000 Andrew Cagney <cagney@b1.cygnus.com>
445
446 * configure: Regenerated to track ../common/aclocal.m4 changes.
447
448Tue May 23 21:35:53 2000 Andrew Cagney <cagney@b1.cygnus.com>
449
450 * aclocal.m4 (sim-profile): Enable the profiler by default.
451
781c552e
AC
452Tue May 23 20:30:12 2000 Andrew Cagney <cagney@amy.cygnus.com>
453
454 * run.c (main): Initialize sigrc.
455
5eb1a8fa
AC
456Wed Apr 26 16:18:44 2000 Andrew Cagney <cagney@b1.cygnus.com>
457
458 * sim-events.c (update_time_from_event): Add more detailed event
459 tracing.
460
b2ac51e4
DB
4612000-03-30 Dave Brolley <brolley@redhat.com>
462
463 * aclocal.m4 (cgen): Use guile to run cgen.
464
f8603f2f
DB
4652000-03-23 Dave Brolley <brolley@redhat.com>
466
467 * cgen-fpu.h: Rename extsfdf to fextsfdf. Rename truncdfsf to
468 ftruncdfsf.
469 * cgen-accfp.c (fextsfdf): New function.
470 (ftruncdfsf): New function.
471 (cgen_init_accurate_fpu): Initialize fextsfdf and ftruncdfsf.
472
0f831eb3
JJ
4732000-03-13 Jeff Johnston <jjohnstn@cygnus.com>
474
475 * cgen-ops.h: Added TRUNCSISI.
476
e88acae7
FCE
4772000-03-08 Dave Brolley <brolley@redhat.com>
478
479 * cgen-par.h (cgen_write_queue_kind): Add CGEN_FN_SF_WRITE.
480 (CGEN_WRITE_QUEUE_ELEMENT): Add fn_sf_write.
481 (sim_queue_fn_si_write): Last argument is has type USI.
482 (sim_queue_fn_sf_write): New function.
483 * cgen-par.c (sim_queue_fn_si_write): Declare 'value' as USI.
484 (sim_queue_fn_sf_write): New function.
485 (cgen_write_queue_element_execute): Handle CGEN_FN_SF_WRITE.
486
baa7ae6f
AC
487Tue Feb 22 16:45:09 2000 Andrew Cagney <cagney@b1.cygnus.com>
488
489 * run.c (main): When SIM_HAVE_ENVIRONMENT enable tracing with
490 sim_set_trace and run simulator using sim_resume.
491 (main): Add option ``-o'' - operating environment. Only continue
492 after a signal when operating environment.
493 (main): Always set REASON and SIGRC using sim_stop_reason.
494 (sim_trace): Delete extern declaration.
495
6d358e86
NC
4962000-02-08 Nick Clifton <nickc@cygnus.com>
497
498 * callback.c: Fix compile time warning messages.
499 * run.c: Fix compile time warning messages.
500
ed9a39eb
JM
5011999-12-17 Dave Brolley <brolley@cygnus.com>
502
503 * sim-profile.h: (set_profile_option_mask): Add prototype.
504 * sim-profile.c (set_profile_option_mask): No longer static.
505
c4093a6a
JM
506Wed Dec 8 21:47:13 1999 Andrew Cagney <cagney@b1.cygnus.com>
507
508 * sim-arange.c: Include <string.h>
509
de57eccd
JM
5101999-12-07 Dave Brolley <brolley@cygnus.com>
511
c4093a6a 512 * sim-options.c (print_help): '=' required before optional argument.
de57eccd
JM
513 * cgen-par.h (CGEN_FN_MEM_QI_WRITE): New enumerator.
514 (CGEN_FN_MEM_HI_WRITE): New enumerator.
515 (CGEN_FN_MEM_SI_WRITE): New enumerator.
516 (CGEN_FN_MEM_DI_WRITE): New enumerator.
517 (CGEN_FN_MEM_DF_WRITE): New enumerator.
518 (CGEN_FN_MEM_XI_WRITE): New enumerator.
519 (fn_mem_qi_write): New union members.
520 (fn_mem_hi_write): New union members.
521 (fn_mem_si_write): New union members.
522 (fn_mem_di_write): New union members.
523 (fn_mem_df_write): New union members.
524 (fn_mem_xi_write): New union members.
525 (sim_queue_fn_mem_qi_write): New function.
526 (sim_queue_fn_mem_hi_write): New function.
527 (sim_queue_fn_mem_si_write): New function.
528 (sim_queue_fn_mem_di_write): New function.
529 (sim_queue_fn_mem_df_write): New function.
530 (sim_queue_fn_mem_xi_write): New function.
531 * cgen-par.c (sim_queue_fn_mem_qi_write): New function.
532 (sim_queue_fn_mem_hi_write): New function.
533 (sim_queue_fn_mem_si_write): New function.
534 (sim_queue_fn_mem_di_write): New function.
535 (sim_queue_fn_mem_df_write): New function.
536 (sim_queue_fn_mem_xi_write): New function.
537 (cgen_write_queue_element_execute): Handle CGEN_FN_MEM_QI_WRITE,
538 CGEN_FN_MEM_HI_WRITE, CGEN_FN_MEM_SI_WRITE, CGEN_FN_MEM_DI_WRITE,
539 CGEN_FN_MEM_DF_WRITE, CGEN_FN_MEM_XI_WRITE.
540
c2d11a7d
JM
5411999-12-01 Dave Brolley <brolley@cygnus.com>
542
543 * cgen-accfp.c (subsf): Check status code.
544 (mulsf): Ditto.
545 (negsf): Ditto.
546 (abssf): Ditto.
547 (sqrtsf): Ditto.
548 (invsf): Ditto.
549 (minsf): Ditto.
550 (maxsf): Ditto.
551 (subdf): Ditto.
552 (muldf): Ditto.
553 (divdf): Ditto.
554 (negdf): Ditto.
555 (absdf): Ditto.
556 (sqrtdf): Ditto.
557 (invdf): Ditto.
558 (mindf): Ditto.
559 (maxdf): Ditto.
560
5611999-11-26 Dave Brolley <brolley@cygnus.com>
562
563 * cgen-par.h (fn_df_write): Mode of data is DF.
564 (sim_queue_fn_df_write): Mode of data is DF.
565 * cgen-par.c (sim_queue_fn_df_write): Mode of data is DF.
566
5671999-11-22 Dave Brolley <brolley@cygnus.com>
568
569 * cgen-trace.c (SIZE_TRACE_BUF): Inxrease size of trace buffer.
570 * cgen-par.h (CGEN_WRITE_QUEUE_SIZE): Increase size of queue.
571
11cf8741
JM
5721999-11-04 Dave Brolley <brolley@cygnus.com>
573
574 * cgen-par.h (cgen_write_queue_kind): Add CGEN_FN_XI_WRITE and
575 CGEN_MEM_XI_WRITE members.
576 (CGEN_WRITE_QUEUE_ELEMENT): Add fn_xi_write and mem_xi_write members.
577 (sim_queue_fn_xi_write): New function.
578 (sim_queue_mem_xi_write): New function.
579
580 * cgen-par.c (sim_queue_fn_xi_write): New function.
581 (sim_queue_mem_xi_write): New function.
582 (cgen_write_queue_element_execute): Handle CGEN_FN_XI_WRITE and
583 CGEN_MEM_XI_WRITE.
584
e514a9d6
JM
5851999-10-22 Dave Brolley <brolley@cygnus.com>
586
587 * cgen-par.h (insn_address): New field in CGEN_WRITE_QUEUE_ELEMENT.
588 (CGEN_WRITE_QUEUE_ELEMENT_IADDR): New macro.
589 * cgen-par.c: Set insn_address for each queued write. Get pc from
590 cpu when executing queued writes.
591
5921999-10-19 Dave Brolley <brolley@cygnus.com>
593
594 * cgen-par.h (sim_queue_fn_pc_write): New function.
595 (CGEN_FN_PC_WRITE): New enumerator.
596 (fn_pc_write): New union member.
597 * cgen-par.c (sim_queue_fn_pc_write): New function.
598 (cgen_write_queue_element_execute): Handle CGEN_FN_PC_WRITE.
599
917317f4
JM
6001999-10-18 Dave Brolley <brolley@cygnus.com>
601
602 * cgen-par.h (CGEN_MEM_DI_WRITE): New enumerator.
603 (CGEN_MEM_DF_WRITE): New enumerator.
604 (mem_di_write): New union member.
605 (mem_df_write): New union member.
606 * cgen-par.c (sim_queue_mem_di_write): New function.
607 (sim_queue_mem_df_write): New function.
608 (cgen_write_queue_element_execute): Handle CGEN_MEM_DI_WRITE and
609 CGEN_MEM_DF_WRITE.
610 * cgen-accfp.c (divsf): Check for division errors.
611
6121999-10-14 Doug Evans <devans@casey.cygnus.com>
613
614 * cgen-engine.h (EXTRACT_INT,EXTRACT_UINT): Delete.
615
2df3850c
JM
6161999-10-07 Dave Brolley <brolley@cygnus.com>
617
618 * cgen-par.h (CGEN_FN_HI_WRITE): New enumerator.
619 (fn_hi_write): New union member.
620 (sim_queue_fn_hi_write): New function.
621 * cgen-par.c (sim_queue_fn_hi_write): New function.
622 (cgen_write_queue_element_execute): Handle CGEN_FN_HI_WRITE.
623
2acceee2
JM
6241999-09-29 Doug Evans <devans@casey.cygnus.com>
625
626 * cgen-defs.h (sim_engine_invalid_insn): New arg `vpc'.
627 Change type of result to SEM_PC.
628
629Wed Sep 29 14:43:57 1999 Dave Brolley <brolley@cygnus.com>
630
631 * cgen-defs.h (sim_engine_invalid_insn): Now returns PC.
632
6426a772
JM
6331999-09-25 Doug Evans <devans@casey.cygnus.com>
634
635 * cgen-ops.h (SUBWORD*): Delete cpu arg.
636 (JOIN*): Delete cpu arg.
637
638Tue Sep 21 17:14:16 1999 Dave Brolley <brolley@cygnus.com>
639
640 * genmloop.sh (@cpu@_scache_lookup): No longer takes last_insn_p
641 parameter.
642 (SET_LAST_INSN_P): Set last_insn_p flag in the scache element.
643
c2c6d25f
JM
644Mon Sep 20 21:44:06 1999 Geoffrey Keating <geoffk@cygnus.com>
645
646 * sim-fpu.c (i2fpu): Keep the guard bits sticky when converting
647 large values.
648
7fc5b5ad
AC
649Tue Feb 8 16:33:48 2000 Andrew Cagney <cagney@b1.cygnus.com>
650
651 * run.c (main): Check the sim_stop_reason and only halt simulation
652 when a valid stop condition is identified.
653
c2c6d25f
JM
654Wed Sep 15 14:12:37 1999 Andrew Cagney <cagney@b1.cygnus.com>
655
656 * hw-tree.c, hw-properties.c, hw-instances.c: Include "sim-io.h".
657
658Tue Sep 14 14:15:47 1999 Dave Brolley <brolley@cygnus.com>
659
660 * cgen-par.h (CGEN_BI_WRITE): New enumerator.
661 (bi_write): New union element.
662 (sim_queue_bi_write): New function.
663 * cgen-par.c (sim_queue_bi_write): New function.
664 (cgen_write_queue_element_execute): Handle CGEN_BI_WRITE.
665
d4f3574e
SS
666Thu Sep 2 18:15:53 1999 Andrew Cagney <cagney@b1.cygnus.com>
667
668 * configure: Regenerated to track ../common/aclocal.m4 changes.
669
670 * aclocal.m4 (WERROR_CFLAGS, WARN_CFLAGS): Merge from
671 ../gdb/configure.in.
672 * Make-common.in (WERROR_CFLAGS, WARN_CFLAGS): Define.
673 (SIM_WERROR_CFLAGS, SIM_WARN_CFLAGS): Define.
674 (SIM_WARNINGS): Delete
675 (CONFIG_CFLAGS): Update.
676
677Tue Aug 31 16:01:42 1999 Dave Brolley <brolley@cygnus.com>
678
679 * cgen-par.c: New file.
680 * cgen-par.h: New file.
681 * cgen-sim.h (cgen-par.h): #include it.
682 * cgen-cpu.h (write_queue): New field.
683 (CPU_WRITE_QUEUE): New access macro.
684 * Make-common.in (CGEN_MAIN_CPU_DEPS): Add cgen-par.h.
685 (cgen-par.o): New target.
686
104c1213
JM
6871999-08-28 Doug Evans <devans@casey.cygnus.com>
688
689 * cgen-types.h (mode_type,MODE_VOID): Renamed from MODE_VM.
690 * cgen-utils.c (mode_names): Update.
691
53a5351d
JM
6921999-08-20 Doug Evans <devans@casey.cygnus.com>
693
694 * genmloop.sh: New args -parallel-generic-write, -parallel-only.
695 * cgen-engine.h (SEMANTIC_FN): Don't use version with PAREXEC
696 buffer arg if WITH_PARALLEL_GENWRITE.
697 (struct insn_sem): Handle WITH_PARALLEL_GENWRITE.
698 (struct idesc): Ditto.
699
700Wed Aug 18 18:17:28 1999 Doug Evans <devans@canuck.cygnus.com>
701
702 * sim-model.c (model_option_handler): Add \n to error message.
703
96baa820
JM
7041999-08-08 Doug Evans <devans@casey.cygnus.com>
705
706 * cgen-engine.h (SEM_FN_NAME,SEMF_FN_NAME): Delete.
707 (insn_sem): Rewrite.
708 (sem_fn_desc): New struct.
709 (idesc): Rewrite.
710 * genmloop.sh (scache case,@cpu@_scache_lookup): Profile scache hit,
711 misses if ! FAST_P.
712 (scache case): Split into non-parallel/parallel versions.
713 (@cpu@_engine_run_{full,fast}): Call @cpu@_{sem,semf}_init_idesc_table
714 if not use semantic switch version.
715
7161999-08-04 Doug Evans <devans@casey.cygnus.com>
717
718 * cgen-defs.h (SEM_BRANCH_TYPE): New enum.
719 * cgen-engine.h (SEM_BRANCH_UNTAKEN,SEM_BRANCH_UNCACHEABLE): Delete.
720 (SEM_BRANCH_INIT_EXTRACT): Delete.
721 (SEM_BRANCH_INIT): Replace npc_ptr with br_type.
722 (SEM_BRANCH_FINI): Ditto.
723 (SEM_BRANCH_VIA_ADDR): Ditto.
724 (SEM_BRANCH_VIA_CACHE): Ditto. Delete cachvarptr arg.
725 (SEM_BRANCH_ADDR_CACHE): Delete.
726 (SEM_SKIP_COMPILE,SEM_SKIP_INSN): New macros.
727 * cgen-scache.h (cpu_scache): Replace member pbb_pr_npc_ptr with
728 pbb_br_type.
729 * genmloop.sh (eng.hin): Update prototype of ${cpu}_pbb_cti_chain.
730 (@cpu@_pbb_begin): Initialize branch_target.
731 (@cpu@_pbb_cti_chain): Replace arg new_vpc_ptr with br_type.
732 (@cpu@_engine_run_full): Replace local pbb_br_npc_ptr with
733 pbb_br_type.
734 (@cpu@_engine_run_fast): Ditto.
735
adf40b2e
JM
736Fri Jul 16 14:47:53 1999 Dave Brolley <brolley@cygnus.com>
737
738 * cgen-utils.c (RORSI): New function.
739 (ROLSI): New function.
740
7411999-07-14 Doug Evans <devans@casey.cygnus.com>
742
743 * Makefile.in (TAGS): Tweak TAGS regex.
744 * cgen-mem.h (*): Add TAGS markers.
745
43e526b9
JM
746Sun Jul 11 23:47:20 1999 Andrew Cagney <cagney@b1.cygnus.com>
747
748 * sim-resume.c (sim_resume): Ensure that the siggnal [sic] is only
749 passed in when sim_resume is first entered - don't re-pass it
750 after a restart.
751
752Sun Jul 11 23:34:44 1999 Andrew Cagney <cagney@b1.cygnus.com>
753
754 * sim-options.c (standard_option_handler): Add OPTION_LOAD_VMA and
755 OPTION_LOAD_LMA but only when is defined.
756 (standard_options): When SIM_HANDLES_LMA is defined include
757 options --load-lma and --load-vma.
758 (standard_install): Initialize STATE_LOAD_AT_LMA_P.
759
760 * sim-base.h (STATE_LOAD_AT_LMA_P): Define.
761 (struct sim_state_base): Add load_at_lma_p.
762 * sim-hload.c (sim_load): Replace SIM_HANDLES_LMA with
763 STATE_LOAD_AT_LMA_P.
764
765Sun Jul 11 12:03:36 1999 Andrew Cagney <cagney@b1.cygnus.com>
766
767 * nrun.c (main): Re-format loop gnu style.
768
9846de1b
JM
769Wed Jul 7 19:56:03 1999 Andrew Cagney <cagney@b1.cygnus.com>
770
771 * dv-sockser.c (connected_p): Initialize addrlen.
772
7731999-07-06 Dave Brolley <brolley@cygnus.com>
774
775 * cgen-accfp.c (floatsidf): New function.
776 (fixdfsi): New function.
777
7781999-07-06 Doug Evans <devans@casey.cygnus.com>
779
780 * sim-model.c (sim_model_init): Issue error if machine is unsupported.
781
43ff13b4
JM
7821999-07-05 Doug Evans <devans@casey.cygnus.com>
783
784 * Make-common.in (CGEN_MAIN_CPU_DEPS): Add cgen-fpu.h.
785 (cgen-fpu.o,cgen-accfp.o): Add rules for.
786 * cgen-fpu.c: New file.
787 * cgen-fpu.h: New file.
788 * cgen-accfp.c: New file.
789 * cgen-cpu.h (CGEN_CPU): New member fpu.
790 * cgen-mem.h: Redo fp support.
791 * cgen-ops.h: Delete k&r support. Redo fp support.
792 * cgen-sim.h: Include cgen-fpu.h.
793 * cgen-types.h (SF,DF,XF,TF): Moved to cgen-fpu.h.
794
085dd6e6
JM
7951999-06-23 Doug Evans <devans@casey.cygnus.com>
796
797 * cgen-engine.h (TARGET_SEM_BRANCH_FINI): Remove cruft at end of
798 ifndef.
799 * genmloop.sh (@cpu@_scache_lookup): Delete unused local var.
800 (@cpu@_pbb_cti_chain): Minor clean up.
801
cd0fc7c3
SS
8021999-05-08 Felix Lee <flee@cygnus.com>
803
804 * aclocal.m4: Use AC_EXEEXT instead of AM_EXEEXT. Delete defn of
805 AM_CYGWIN32 and AM_EXEEXT.
806 * configure: Regenerate.
807
7a292a7a
SS
808Fri Apr 16 16:43:22 1999 Doug Evans <devans@charmed.cygnus.com>
809
810 * sim-core.c (device_error,device_io_read_buffer,
811 device_io_write_buffer): Delete decls.
812 * sim-core.h: Put them here.
813
814 * sim-core.c (sim_core_read_buffer): Pass sd to device_io_read_buffer.
815 (sim_core_write_buffer): Pass sd to device_io_write_buffer.
816 * sim-n-core.h (sim_core_read_aligned_N): Ditto.
817 (sim_core_write_aligned_N): Ditto.
818
8191999-04-14 Stephane Carrez <stcarrez@worldnet.fr>
820
821 * sim-memopt.c (sim_memory_uninstall): Don't look into
822 free()d memory.
823
8241999-04-14 Doug Evans <devans@casey.cygnus.com>
825
826 * cgen-utils.scm (virtual_insn_entries): Update attribute definition.
827
8281999-04-13 Doug Evans <devans@casey.cygnus.com>
829
830 * sim-core.c (sim_core_read_buffer): Handle NULL cpu when WITH_DEVICES.
831 (sim_core_write_buffer): Ditto.
832
8331999-04-02 Keith Seitz <keiths@cygnus.com>
834
835 * sim-io.c (sim_io_poll_quit): Only call the poll_quit callback
836 after the interval counter has expired.
837 (POLL_QUIT_INTERVAL): Define. Used to tweak the frequency of
838 poll_quit callbacks. May be overridden by Makefile.
839 (poll_quit_counter): New global.
840 * sim-events.c: Remove all mentions of ui_loop_hook. The
841 host callback "poll_quit" will serve the purpose.
842 * run.c: Add definition of ui_loop_hook when NEED_UI_LOOP_HOOK
843 is defined.
844 * nrun.c: Remove declaration of ui_loop_hook.
845
846Wed Mar 31 18:55:41 1999 Doug Evans <devans@canuck.cygnus.com>
847
848 * cgen-run.c (sim_resume): Don't tell main loop to run "forever"
849 if being used by gdb.
850
8511999-03-22 Doug Evans <devans@casey.cygnus.com>
852
853 * cgen-types.h (XF,TF): Tweak.
854 * cgen-ops.h: Redo inline support. Delete DI_FN_SUPPORT,
855 in cgen-types.h.
856 (SUBWORD*,JOIN*): Define.
857 * cgen-trace.c (sim_cgen_disassemble_insn): Update, base_insn_bitsize
858 moved into cpu descriptor.
859 * sim-model.h (MACH): New member `num'.
860
c906108c
SS
8611999-02-09 Doug Evans <devans@casey.cygnus.com>
862
c906108c
SS
863 * cgen-cpu.h (CGEN_DISASSEMBLER): New type.
864 (CGEN_CPU): Member opcode renamed to cpu_desc.
865 New members get_idata,disassembler.
866 * cgen-defs.h (CGEN_INSN_VIRTUAL_P): CGEN_INSN_ATTR renamed to
867 CGEN_INSN_ATTR_VALUE.
868 (CGEN_STATE): Delete member opcode_table.
869 (sim_disassemble_insn): Delete decl.
870 * cgen-engine.h (struct insn_sem): Moved to here from <cpu>-decode.c.
871 (struct idesc): Moved to here from <cpu>-decode.h.
872 * cgen-run.c (prime_cpu): Call prepare_run callback.
873 * cgen-trace.h (SFILE): New type.
874 (sim_disasm_sprintf): Declare.
875 (sim_disasm_read_memory,sim_disasm_perror_memory): Declare.
876 (sim_cgen_disassemble_insn): Declare.
877 * cgen-trace.c: Include errno.h,dis-asm.h. Don't include cpu-opc.h.
878 (insn_fields): Delete.
879 (trace_insn_fini): STATE_OPCODE_TABLE (sd) replaced with
880 CPU_CPU_DESC (cpu).
881 (trace_insn): Call CPU_DISASSEMBLER hook.
882 (sim_disasm_sprintf): New function.
883 (sim_disasm_read_memory): New function.
884 (sim_disasm_perror_memory): New function.
885 (sim_cgen_disassemble_insn): New function.
886 * cgen-utils.c: Don't include cpu-opc.h.
887 (virtual_insn_entries): New static local.
888 (cgen_virtual_insn_table): Renamed from cgen_virtual_opcode_table.
889 (cgen_insn_name): Rewrite.
890 (disasm_sprintf,sim_disassemble_insn): Moved to cgen-trace.c.
891 * cgen.sh (desc): New file generator handler.
892 * genmloop.sh: -parallel changed to -parallel-read/-parallel-write.
893 Define WITH_PARALLEL_READ/WITH_PARALLEL_WRITE appropriately.
894 Don't include cpu-opc.h,cpu-sim.h.
895 * sim-model.c (model_set): Delete SIM_DESC arg.
896 (sim_model_set): Update.
897 * sim-model.h (MACH): New member prepare_run.
898
8991999-01-28 Frank Ch. Eigler <fche@cygnus.com>
900
901 * sim-memopt.c (memory_option_handler): Avoid memset() calls
902 if redundant with allocator functions.
903
904Wed Jan 27 17:19:09 1999 Doug Evans <devans@canuck.cygnus.com>
905
906 * cgen-engine.h (EXTRACT_LSB0_{INT,UINT}): Fix.
907
908 * sim-profile.h: Make like sim-trace.h.
909 (PROFILE_USEFUL_MASK): New macro.
910 * sim-profile.c (profile_options): Make like trace_options, allow
911 optional on|off arg where applicable.
912 (set_profile_option_mask): New function.
913 (sim_profile_set_option): New function.
914 (profile_option_handler): Simplify.
915 Have -p only enable selected things, not everything.
916 Add missing break to OPTION_PROFILE_PC_RANGE.
917 * cgen-scache.c (scache_options): Allow optional on|off arg to
918 --profile-scache.
919 (scache_option_handler): Use sim_profile_set_option.
920
9211999-01-26 Frank Ch. Eigler <fche@cygnus.com>
922
923 * sim-memopt.c (memory_options): Add MEMORY_FILL option.
924 (memory_option_handler): Implement MEMORY_FILL option. Make
925 MEMORY_CLEAR an alias for MEMORY_FILL=0.
926 (parse_ulong_value): New function.
927 (do_memopt_add): Allocate all buffers. Optionally fill them.
928
9291999-01-15 Richard Henderson <rth@cygnus.com>
930
931 * hw-events.c (hw_event_queue_schedule): _vtracef takes a
932 va_list, not an integer.
933 * sim-events.c (sim_events_schedule): Likewise.
934
935 * sim-types.h (UNSIGNED32, UNSIGNED64): Properly cast to
936 the appropriate type.
937
9381999-01-14 Doug Evans <devans@casey.cygnus.com>
939
940 * cgen-defs.h (PCADDR,CIA): Define in terms of IADDR.
941 (sim_disassemble_insn): Update prototype.
942 (sim_engine_invalid_insn): Ditto.
943 * cgen-engine.h (SEMANTIC_FN): Add !WITH_SCACHE version.
944 (SEM_BRANCH_INIT): PCADDR->IADDR.
945 (SEM_NBRANCH_FINI): New macro for !WITH_SCACHE case.
946 * cgen-scache.c (scache_lookup,scache_lookup_or_alloc): PCADDR->IADDR.
947 * cgen-scache.h (*): Ditto.
948 * cgen-trace.c (*): Ditto.
949 * cgen-trace.h (*): Ditto.
950 * cgen-utils.c (*): Ditto.
951 * cgen-types.h (integer modes): Use signedNN/unsignedNN types.
952 (insn_t): Delete.
953 * genmloop.sh (@cpu@_fill_argbuf): Add !WITH_SCACHE support.
954 (simple engine framework): Rewrite.
955 * sim-module.c (modules): Install model module sooner (and in
956 particular before the profile module).
957
9581999-01-12 Doug Evans <devans@casey.cygnus.com>
959
960 * sim-model.h (sim_mach_lookup_bfd_name): Add prototype.
961 * sim-model.c (sim_mach_lookup_bfd_name): New function.
962 (sim_model_init): Call it.
963
964 * cgen-trace.c (trace_insn): Pass pc to trace_prefix for virtual insns.
965
9661999-01-05 Doug Evans <devans@casey.cygnus.com>
967
968 * Make-common.in (CGEN_INCLUDE_DEPS): Add cgen-defs.h, cgen-engine.h.
c906108c
SS
969 * cgen-engine.h (SEM_BRANCH_FINI): New arg pcvar, all uses updated.
970 (SEM_BRANCH_INIT_EXTRACT): New macro.
971 (SEM_BRANCH_INIT): Add taken_p.
972 (TARGET_SEM_BRANCH_FINI): Provide default definition.
973 (SEM_BRANCH_FINI): Use it.
974 (SEM_INSN): Update.
975 * cgen-run.c (sim_resume): Handle tracing of last insn.
976 * cgen-scache.h (WITH_SCACHE): Define as 0 if not defined.
977 * cgen-trace.c (current_abuf): New static global.
978 (trace_insn_init): Initialize it.
979 (trace_insn_fini): Use it.
980 (trace_insn): Set it.
981 * cgen.sh (arch case): Pass -m ${mach} to cgen.
982 * genmloop.sh (@cpu@_emit_before): Only define if WITH_SCACHE_PBB.
983 (@cpu@_emit_after): Ditto.
984 (simple @cpu@_engine_run_full): New local `pc'. Initialize semantic
985 labels if WITH_SEM_SWITCH_FULL.
986 * sim-model.c: Include bfd.h.
987 (sim_model_init): New function.
988 (sim_model_install): Record init fn.
989 * sim-model.h (MACH): New member bfd_name.
990 * sim-module.c (modules): Initialize model before scache.
991
9921998-12-24 Frank Ch. Eigler <fche@cygnus.com>
993
994 * dv-sockser.c (DEFAULT_TIMEOUT): Increase to 1 ms.
995
996 * nrun.c (main): Remain in simulation loop for traps and
997 exceptions when in operating environment mode.
998 (ui_loop_hook): New stub hook for standalone use.
999 * sim-events.c (sim_events_process): Call ui_loop_hook
1000 periodically on CYGWIN host.
1001
1002 * sim-reason.c (sim_stop_reason): Return host signal numbers
1003 to gdb on sim_stopped and sim_signalled cases.
1004 * sim-engine.c (sim_engine_halt): Call SIM_CPU_EXCEPTION_SUSPEND
1005 hook just before longjmp.
1006 * sim-resume.c (sim_resume): Call SIM_CPU_EXCEPTION_RESUME
1007 hook just before sim_engine_run.
1008
1009 * sim-n-core.h (sim_core_trace_M): Allay const warning.
1010 * sim-trace.h (trace_generic): Ditto.
1011 * sim-trace.c (trace_generic): Ditto.
1012
10131998-12-14 Doug Evans <devans@casey.cygnus.com>
1014
1015 * Make-common.in (SIM_MAIN_DEPS): New var.
1016 (CGEN_MAIN_CPU_DEPS): New var.
1017 * aclocal.m4: Add --enable-cgen-maint option.
1018 * cgen-mem.h (GETMEM*): New arg `pc'. Pass to sim_core routine.
1019 (SETMEM*): Ditto.
1020 (GETIMEM*): Pass pc value to sim_core routine.
1021
1022Fri Dec 11 16:58:36 1998 Andrew Cagney <cagney@b1.cygnus.com>
1023
1024 * hw-handles.c (hw_handle_add_ihandle, hw_handle_add_phandle):
1025 Compare with ZERO not NULL.
1026
1027Thu Dec 10 14:14:39 1998 Andrew Cagney <cagney@b1.cygnus.com>
1028
1029 * hw-properties.c, hw-instances.c, hw-tree.c: Include
1030 "sim-assert.h".
1031
10321998-12-09 Doug Evans <devans@casey.cygnus.com>
1033
1034 * sim-arange.c: Include libiberty.h, and stdlib.h if present.
1035 * sim-trace.c: Include stdlib.h if present.
1036 * dv-sockser.c: Include unistd.h if present.
1037 (dv_sockser_init): Add missing arg to call to sim_io_eprintf.
1038 * cgen-scache.c (scache_flush): Delete unused locals i,sc.
1039
10401998-12-08 James E Wilson <wilson@wilson-pc.cygnus.com>
1041
1042 * gennltvals.sh: Add i960.
1043 * nltvals.def: Rebuild.
1044
10451998-12-04 Doug Evans <devans@casey.cygnus.com>
1046
1047 * cgen-defs.h: New file, old cgen-sim.h.
1048 * cgen-sim.h: Simple header that includes others.
1049 * sim-arange.c: New file.
1050 * sim-arange.h: New file.
1051 * sim-basics.h: Include it.
1052 * Make-common.in (SIM_NEW_COMMON_OBJS): Add sim-arange.o.
1053 (sim-arange.o): Add rule for.
1054 * sim-cpu.h (sim_cpu_msg_prefix): Add prototype.
1055 (sim_io_eprintf_cpu): Add prototype.
1056 * sim-inline.h (HAVE_INLINE): Define if GNUC.
1057 (INLINE2): New macro.
1058 (EXTERN_INLINE): New macro.
1059 * sim-module.c (sim_post_argv_init): Initialize cpu backlink
1060 before calling module init fns.
1061 * sim-profile.c (OPTION_PROFILE_*): Move into enum.
1062 (profile_init): New function.
1063 (profile_options): New option --profile-range.
1064 (profile_option_handler): Handle --profile-range.
1065 (profile_print_insn): Qualify address range specific section titles.
1066 (profile_print_addr_ranges): New function.
1067 (profile_info): Print address ranges if specified.
1068 (profile_install): Set profile_init init fn.
1069 * sim-profile.h (PROFILE_DATA): New member `range'.
1070 * sim-trace.c (trace_init): New function.
1071 (trace_options): New option --trace-range.
1072 (trace_option_handler): Handle --trace-range.
1073 (trace_install): Set trace_init init fn.
1074 * sim-trace.h (TRACE_DATA): New member `range'.
1075 * sim-utils.c (sim_cpu_msg_prefix): New function.
1076 (sim_io_eprintf_cpu): New function.
1077 * cgen-engine.h (PC_IN_TRACE_RANGE_P): New macro.
1078 (PC_IN_PROFILE_RANGE_P): New macro.
1079 * cgen-trace.c (trace_insn_init): Set current_insn to NULL.
1080 (trace_insn_fini): New arg abuf. All callers updated.
1081 Exit early if trace_insn not called. Check ARGBUF_PROFILE_P before
1082 printing cycle counts.
1083 * cgen-trace.h (trace_insn_fini): Update prototype.
1084 (TRACE_RESULT_P): New macro.
1085 (TRACE_INSN_INIT,TRACE_INSN_FINI): New arg abuf. All callers updated.
1086 (TRACE_INSN): Check ARGBUF_TRACE_P.
1087 (TRACE_EXTRACT,TRACE_RESULT): New arg abuf. All callers updated.
1088 * cgen-types.h (SIM_INLINE): Delete.
1089 (SIM_HAVE_MODEL,SIM_HAVE_ADDR_RANGE): Define.
1090 * cgen-utils.c: Don't include cgen-engine.h
1091 * genmloop.sh (@cpu@_fill_argbuf): New function.
1092 (@cpu@_fill_argbuf_tp): New function.
1093 (@cpu@_emit_before,@cpu@_emit_after): New functions.
1094 (@cpu@_pbb_begin): Prefix cti_sc,insn_count with '_'.
1095 (SET_CTI_VPC,SET_INSN_COUNT): Update.
1096 (@cpu@_pbb_before): Check ARGBUF_PROFILE_P before calling
1097 doing profiling. Update call to TRACE_INSN_INIT,TRACE_INSN_FINI.
1098 (@cpu@_pbb_after): Check ARGBUF_PROFILE_P before calling
1099 doing profiling. Update call to TRACE_INSN_FINI.
1100
1101 * sim-memopt.c (sim_memory_uninstall): Result type is `void'.
1102
11031998-12-03 Frank Ch. Eigler <fche@cygnus.com>
1104
1105 * sim-memopt.c (sim_memory_uninstall): Deallocate all memory
1106 regions.
1107
11081998-12-01 Doug Evans <devans@casey.cygnus.com>
1109
1110 * sim-inline.c (SIM_INLINE_P): Fix typo.
1111
11121998-11-30 Doug Evans <devans@casey.cygnus.com>
1113
1114 * cgen-utils.c (cgen_virtual_opcode_table): Update.
1115
1116Tue Nov 24 18:40:03 1998 Andrew Cagney <cagney@b1.cygnus.com>
1117
1118 * gennltvals.sh: Add v850 and d10v. Sort alphabetically.
1119 * nltvals.def: Re-generate.
1120
1121Mon Nov 23 13:28:38 1998 Andrew Cagney <cagney@b1.cygnus.com>
1122
1123 * sim-core.c (reverse_n, sim_core_uninstall, sim_core_init,
1124 sim_core_map_attach, sim_core_map_detach, next_event_queue,
1125 new_sim_core_mapping): Only define when EXTERN_SIM_CORE_P, pacify
1126 GCC.
1127 * sim-events.c (sim_events_uninstall, sim_events_suspend,
1128 sim_events_resume, sim_events_zalloc, insert_sim_event): Ditto.
1129
11301998-11-22 Doug Evans <devans@tobor.to.cygnus.com>
1131
1132 * genmloop.sh (${cpu}_pbb_chain): Watch for Ctrl-C's.
1133 (${cpu}_pbb_cti_chain): Ditto.
1134
11351998-11-18 Doug Evans <devans@casey.cygnus.com>
1136
1137 * Make-common.in (cgen-utils.o): Depend on cgen-engine.h.
c906108c
SS
1138 * cgen-engine.h (EXTRACT_[ML]SB0_{INT,UINT}): New macros.
1139 (EXTRACT_INT,EXTRACT_UINT): New macros.
1140 (SEM_SEM_ARG): New macro.
1141 (SEM_NEXT_VPC): New arg `pc'.
1142 * cgen-sim.h (EXTRACT_SIGNED,EXTRACT_UNSIGNED): Delete.
1143 (sim_disassemble_insn): Update prototype.
1144 * cgen-trace.c (current_insn,insn_fields): New static locals.
1145 (trace_insn): Set them.
b83266a0 1146 * cgen-utils.c: #include cgen-engine.h.
c906108c
SS
1147 (sim_disassemble_insn): New arg insn_fields.
1148 Handle variable length insns.
1149 * genmloop.sh: Only emit pbb decls if -pbb.
1150 (${cpu}_scache_lookup): New arg `vpc'.
1151 (scache support): Fetch pc before entering loop.
1152
1153 * gennltvals.sh: Add fr30 support.
1154 * nltvals.def: Rebuild.
1155
1156Wed Nov 18 10:22:22 1998 Andrew Cagney <cagney@b1.cygnus.com>
1157
1158 * sim-types.h: Re-do type system so that GCC's attribute and mode
1159 are used to specify types. Handle case of ALPHA.
1160
11611998-11-13 Frank Ch. Eigler <fche@elastic.org>
1162
1163 * aclocal.m4: Add tests for dlopen family.
1164 * config.in: Regenerated.
1165
1166Wed Nov 11 14:02:25 1998 Doug Evans <devans@canuck.cygnus.com>
1167
1168 * sim-hload.c (sim_load): Pass `prog_name' to sim_load_file, not NULL.
1169
1170Wed Nov 4 23:51:19 1998 Doug Evans <devans@seba.cygnus.com>
1171
1172 * genmloop.sh (eng.hin): Rename HAVE_PARALLEL_EXEC to
1173 HAVE_PARALLEL_INSNS, define as 0 or 1. Emit decls of fns in mloop.cin.
1174 * cgen-engine.h: Typedefs of IADDR,CIA,SEM_ARG,SEM_PC moved ...
1175 * cgen-sim.h: ... to here.
1176
1177Wed Oct 28 12:00:57 1998 Andrew Cagney <cagney@b1.cygnus.com>
1178
1179 * aclocal.m4 (enable-build-warnings): Replace
1180 enable-sim-warnings. Extend =LIST syntax so that prepend and
1181 append of options is possible. Drop -Werror, add
1182 -Wstrict-prototypes for GDB compatibility.
1183 * Make-common.in (SIM_WARNINGS): Update.
1184
1185Mon Oct 19 13:56:32 1998 Doug Evans <devans@seba.cygnus.com>
1186
1187 * Make-common.in (CGEN_INCLUDE_DEPS): Define.
1188 (sim-core.o): Delete duplicate dependence on $(SIM_EXTRA_DEPS).
1189 (sim-cpu.o,sim-endian.o,sim-hw.o): Ditto.
1190 (cgen-run.o,cgen-scache.o,cgen-trace.o,cgen-utils.o): Delete
1191 explicit cgen header dependencies, require SIM_EXTRA_DEPS to include
1192 CGEN_INCLUDE_DEPS.
1193 * cgen-cpu.h: New file.
1194 * cgen-engine.h: New file.
1195 * cgen-scache.h: New file.
1196 * cgen-sim.h: Delete portions moved to new files.
1197 * genmloop.sh: Generate two files eng.hin,mloop.cin explicitly,
1198 rather than sending result to stdout.
1199
1200Fri Oct 9 14:20:22 1998 Doug Evans <devans@seba.cygnus.com>
1201
1202 * Make-common.in (sim-reg.o): New rule.
1203 (cgen-run.o): New rule.
1204 * cgen-ops.h: Delete many BI macros. Change all UBI -> BI.
1205 * cgen-run.c (prime_cpu): New function.
1206 * cgen-scache.c: Add pseudo-basic-block (pbb) scaching support.
1207 (scache_option_handler, case OPTION_PROFILE_SCACHE): Handle explicitly
1208 mentioned cpu.
1209 (scache_flush_cpu,scache_lookup,scache_lookup_or_alloc): New fns.
1210 * cgen-sim.h (CGEN_INSN_VIRTUAL_TYPE): New enum.
1211 (CGEN_INSN_VIRTUAL_P): New macro.
1212 (SEM_PC): New typedef.
1213 (SEMANTIC_FN): Change type of result to SEM_PC.
1214 (SEM_SET_FULL_CODE,SEM_SET_FAST_CODE,SEM_SET_CODE): New macros.
1215 (IDESC_CTI_P,IDESC_SKIP_P): New macros.
1216 (SCACHE_MAP): New typedef.
1217 (CPU_SCACHE): Add pbb support.
1218 (scace_lookup,scache_lookup_or_alloc,scache_flush_cpu): Declare.
1219 (SEM_BRANCH_INIT_EXTRACT,SEM_BRANCH_INIT,SEM_BRANCH_FINI): New macros.
1220 (CGEN_CPU): New members running_p,insn_count,{fast,full}_engine_fn,
1221 max_slice_insns.
1222 (INSN_NAME): Delete.
1223 (cgen_insn_name): Declare.
1224 (sim_engine_invalid_insn): Renamed from sim_engine_illegal_insn.
1225 * cgen-trace.c (trace_buf): Shrink from 1024 to 256 bytes.
1226 (first_insn_p): Make static.
1227 (trace_insn): Handle virtual insns specially.
1228 (cgen_trace_printf): Ensure we haven't overflowed the buffer.
1229 * cgen-types.h (UBI): Delete.
1230 (MODE_TYPE): New enum.
1231 (HOSTINT,HOSTUINT,HOSTPTR): Delete.
1232 * cgen-utils.c (mode_names): Delete UBI. Add INT,UINT,PTR.
1233 (cgen_virtual_opcode_table): New global.
1234 (cgen_insn_name): New function.
1235 (sim_disassemble_insn): Ignore virtual insns.
1236 * genmloop.sh: Delete top level loop generation. Add pbb support.
1237 * sim-cpu.h (CPU_INSN_NAME_FN): New typedef.
1238 (sim_cpu_base): New members max_insns,insn_name,model_data.
1239 (CPU_PC_GET,CPU_PC_SET): New macros.
1240 (sim_pc_get,sim_pc_set): Declare.
1241 * sim-model.c (model_set): Call model init fn.
1242 * sim-model.h (MODEL_FN): New typedef.
1243 (INSN_TIMING): New member model_fn.
1244 (MODEL): New members num,init.
1245 * sim-profile.c (sim_profile_print_bar): Renamed from print_bar.
1246 All callers updated.
1247 (profile_insn_init): New fn.
1248 (profile_print_insn): Update, INSN_NAME -> CPU_INSN_NAME.
1249 Exit early if insn profiling not supported.
1250 (profile_print_memory): Update, MAX_MODES -> MODE_TARGET_MAX.
1251 (profile_install): Record profile_insn_init as init fn.
1252 (profile_uninstall): Free PROFILE_INSN_COUNT if non-null.
1253 * sim-profile.h: Update, MAX_MODES -> MODE_TARGET_MAX.
1254 (PROFILE_DATA): Delete member exec_time.
1255 Change insn_count to pointer to array, rather than the array.
1256 (sim_profile_print_bar): Declare.
1257
1258Wed Oct 7 16:56:42 1998 Doug Evans <devans@seba.cygnus.com>
1259
1260 * cgen-run.c: New file.
1261 * sim-reg.c: New file.
1262
1263Mon Sep 14 10:58:19 1998 Frank Ch. Eigler <fche@cygnus.com>
1264
1265 * aclocal.m4: Add checks for -lsocket and -lnsl.
1266
1267 * dv-sockser.c (dv_sockser_init): Use SO_REUSEADDR to
1268 allow local port reuse on listening socket.
1269
1270Tue Sep 1 15:36:52 1998 Frank Ch. Eigler <fche@cygnus.com>
1271
1272 * sim-config.h: Remove reference to linux kernel header.
1273
1274Tue Aug 25 12:45:27 1998 Frank Ch. Eigler <fche@cygnus.com>
1275
1276 * dv-sockser.c (sockser_addr): Make variable non-static.
1277
1278Mon Aug 24 11:47:37 1998 Joyce Janczyn <janczyn@cygnus.com>
1279
1280 * sim-hw.{c,h} (sim_hw_parse): Return struct hw pointer.
1281
1282Tue Aug 11 18:12:19 1998 Doug Evans <devans@canuck.cygnus.com>
1283
1284 * sim-events.c (sim_events_elapsed_time): Fix calculation.
1285
1286Tue Aug 4 20:36:46 1998 Jeff Holcomb <jeffh@cygnus.com>
1287
1288 * Make-common.in (install-common): Add $(EXEEXT) when installing
1289 run.
1290
1291Mon Aug 3 11:46:01 1998 Doug Evans <devans@seba.cygnus.com>
1292
1293 * cgen-sim.h (cgen_state): New member opcode_table.
1294 * cgen-utils.c (sim_disassemble_insn): Use it.
1295
1296Fri Jul 24 10:14:18 1998 Doug Evans <devans@canuck.cygnus.com>
1297
1298 * cgen-mem.h (DECLARE_SETT): Fix return type.
1299 * cgen-sim.h (sim_engine_illegal_insn): Declare.
1300 * cgen-scache.c: Include stdlib.h.
1301 * cgen-trace.c (trace_extract): Use %lx for PCADDR.
1302 * sim-model.c (model_option_handler): Remove unused variable `n'.
1303
1304Tue Jul 21 16:27:43 1998 Doug Evans <devans@seba.cygnus.com>
1305
1306 * cgen-utils.c: Include bfd.h.
1307 (sim_disassemble_insn): Update call to CGEN_EXTRACT_FN.
1308
1309Wed Jul 8 18:24:10 1998 Jeffrey A Law (law@cygnus.com)
1310
1311 * sim-bits.h (EXTEND24): Fix typo.
1312
1313Wed Jul 8 17:41:47 1998 Andrew Cagney <cagney@b1.cygnus.com>
1314
1315 * sim-events.c (ETRACE_P): New macro.
1316 (struct _sim_event): Add member trace.
1317 (sim_events_free): Reclaim trace message.
1318
1319 * sim-events.c, sim-events.h (sim_events_schedule_vtracef,
1320 sim_events_schedule_tracef): New functions, include printf trace
1321 information in argument list. If tracing, store asprintf'd trace
1322 message in sim_event.
1323
1324 * hw-events.c, hw-events.h (hw_event_queue_schedule_tracef,
1325 hw_event_queue_schedule_vtracef): New functions, mimic
1326 sim_event_tracef.
1327
1328Mon Jul 6 15:51:14 1998 Jeffrey A Law (law@cygnus.com)
1329
1330 * sim-bits.h (EXTEND24): Define.
1331
1332Thu Jul 2 17:13:25 1998 Doug Evans <devans@seba.cygnus.com>
1333
1334 * cgen-sim.h (CPU_SCACHE): Make size unsigned.
1335 (CPU_SCACHE_HASH_MASK): New macro.
1336 (SCACHE_HASH_PC): Rewrite.
1337 * genmloop.sh (engine_resume_{full,fast}): Move some of hash
1338 computation out of main loop.
1339
1340Wed Jul 1 16:44:12 1998 Doug Evans <devans@seba.cygnus.com>
1341
c906108c
SS
1342 * cgen-sim.h (RECORD_IADDR): Delete.
1343 * cgen-types.h (HOSTINT,HOSTUINT,HOSTPTR): New types.
1344 * genmloop.sh (engine_resume_{full,fast}): Delete icount.
1345
1346Wed Jun 17 12:25:08 1998 Mark Alexander <marka@cygnus.com>
1347
1348 * gennltvals.def (mn10200): Add entry.
1349 * nltvals.def: Regenerate with MN10200 additions.
1350
1351Wed Jun 17 13:18:28 1998 Andrew Cagney <cagney@b1.cygnus.com>
1352
1353 * sim-inline.h (EXTERN_*): Replace with EXTERN_*_P. Correct
1354 documentation on how it works.
1355
1356 * sim-core.h, sim-core.c (sim_core_install, sim_core_attach,
1357 sim_core_detach, sim_core_read_buffer, sim_core_write_buffer,
1358 sim_core_set_xor, sim_core_xor_read_buffer,
1359 sim_core_xor_write_buffer): Update.
1360
1361 * sim-events.h, sim-events.c (sim_events_install,
1362 sim_events_watch_clock, sim_events_schedule_after_signal,
1363 sim_events_schedule, sim_events_watch_sim, sim_events_watch_core,
1364 sim_events_deschedule): Update.
1365
1366 * sim-fpu.h, sim-fpu.c (sim_fpu_zero, sim_fpu_one, sim_fpu_two,
1367 sim_fpu_max32, sim_fpu_max64): Update.
1368
1369Sat Jun 13 07:45:38 1998 Doug Evans <devans@fallis.cygnus.com>
1370
1371 * cgen-trace.c (trace_insn_fini): Redo cycle handling.
1372 * sim-profile.h (PROFILE_DATA): Rename cycle handling members.
1373 * sim-profile.c (profile_print_model): Update.
1374
1375Fri Jun 12 18:35:07 1998 Doug Evans <devans@seba.cygnus.com>
1376
1377 * gennltvals.def (m32r): Use common syscall.h now.
1378 (mn10300): Add entry.
1379 * nltvals.def: Regenerate.
1380
1381 * sim-engine.c (sim_engine_get_run_state): New function.
1382 * sim-engine.h (sim_engine_get_run_state): Declare it.
1383
1384Thu Jun 11 00:50:03 1998 Doug Evans <devans@seba.cygnus.com>
1385
1386 * sim-core.h (SIM_CORE_SIGNAL_FN): New typedef.
1387 * sim-core.c (sim_core_signal): Make extern, always define.
1388
1389Wed Jun 10 16:02:29 1998 Doug Evans <devans@seba.cygnus.com>
1390
1391 * Make-common.in (CGEN_FLAGS_TO_PASS): New variable.
1392 * cgen-ops.h (ANDIF): New macro.
1393 (ANDIF[BQHSD]I): Delete.
1394
1395Thu Jun 4 13:53:54 1998 Andrew Cagney <cagney@b1.cygnus.com>
1396
1397 * hw-events.c (create_hw_event, delete_hw_event): Delete.
1398 (hw_event_queue_schedule, hw_event_queue_deschedule,
1399 bounce_hw_event): Fix hw-event memory corruptions found by Joyce
1400 Janczyn.
1401
1402 * hw-alloc.h (HW_NZALLOC): Define.
1403
1404 * Make-common.in (test-hw-events): Add target for testing the
1405 hw-event code.
1406
1407Mon May 25 21:11:26 1998 Andrew Cagney <cagney@b1.cygnus.com>
1408
1409 * Make-common.in (SIM_COMMON_HW_OBJS): Add hw-handles.o and
1410 hw-instances.o.
1411 hw-handles.c, hw-instances.c, hw-handles.h, hw-instances.h: New
1412 files.
1413 * hw-main.h: Include hw-handles.h, hw-instances.h.
1414 * hw-base.h ({create,delete}_hw_{handles,instances}_data): Declare
1415 * hw-base.c (hw_create, hw_delete): Call same.
1416
1417Mon May 25 18:55:35 1998 Andrew Cagney <cagney@b1.cygnus.com>
1418
1419 * dv-core.c: Include hw-main.h and sim-main.h.
1420 * dv-pal.c: Include hw-main.h and sim-io.h.
1421 * dv-glue.c: Include hw-main.h.
1422
1423 * hw-main.h: New file. Move list of includes to here.
1424 * hw-base.h: From here.
1425 * Make-common.in (hw_base_headers): Rename to hw_main_headers.
1426 (hw-*.o, dv-*.o): Update.
1427 * hw-tree.c, hw-base.c, hw-properties.c, hw-ports.c, hw-device.c,
1428 hw-events.c, hw-alloc.c, sim-hw.c: Include hw-main.h instead of
1429 sim-main.h.
1430
1431 * hw-base.h (do_hw_attach_regs, do_hw_poll_read_method,
1432 do_hw_poll_read): Move declarations from here.
1433 * hw-main.h: To here.
1434
1435 * hw-base.h (struct hw_device_descriptor, hw_finish_callback):
1436 Move from here.
1437 * hw-main.h (struct hw_descriptor, hw_finish_method): To here,
1438 rename.
1439 * Make-common.in (hw-config.h): Update
1440 * hw-base.c, dv-pal.c, dv-glue.c: Update
1441
1442 * dv-glue.c, hw-device.h, hw-base.h, hw-ports.c: Rename
1443 `*_callback' to `*_method.
1444
1445Mon May 25 18:41:18 1998 Andrew Cagney <cagney@b1.cygnus.com>
1446
1447 * hw-base.h (set_*): Move set method macros from here.
1448 * hw-device.h: To here.
1449
1450Mon May 25 18:21:38 1998 Andrew Cagney <cagney@b1.cygnus.com>
1451
1452 * hw-base.h (create_hw_property_data, delete_hw_property_data):
1453 Declare.
1454
1455 * hw-base.c (hw_create, hw_delete): Call
1456 * hw-properties.c (create_hw_property_data,
1457 delete_hw_property_data): Define.
1458
1459Mon May 25 17:40:46 1998 Andrew Cagney <cagney@b1.cygnus.com>
1460
1461 * hw-device.c, hw-properties.c: Include hw-base.h
1462
1463 * hw-alloc.h, hw-alloc.c: New files. Move alloc code to here.
1464 * hw-device.c: From here.
1465 * hw-base.h: Include "hw-events.h".
1466
1467 * hw-base.h (create_hw_alloc_data, delete_hw_alloc_data): Declare.
1468 * hw-base.c (hw_create, hw_delete): Call.
1469 * hw-alloc.c (create_hw_alloc_data, delete_hw_alloc_data): Define.
1470
1471 * Make-common.in (SIM_NEW_COMMON_OBJS): Add hw-alloc.o.
1472 (hw-alloc.o): New target.
1473
1474Mon May 25 17:14:27 1998 Andrew Cagney <cagney@b1.cygnus.com>
1475
1476 * hw-events.h, hw-events.c: New files. Move event code to here.
1477 * sim-hw.c: From here.
1478 * hw-base.h: Include "hw-events.h".
1479 * Make-common.in (SIM_NEW_COMMON_OBJS): Add hw-events.o.
1480 (hw-events.o): New target.
1481
1482 * hw-device.h (struct hw): Add struct hw_event_data events_of_hw.
1483 * hw-events.h (struct hw_event): Replace typedef hw_event.
1484
1485 * hw-base.h (create_hw_event_data, delete_hw_event_data): Declare.
1486 * hw-base.c (hw_create, hw_delete): Call.
1487 * hw-events.c (create_hw_event_data, delete_hw_event_data): Define.
1488
1489 * dv-pal.c: Update.
1490
1491Mon May 25 16:55:16 1998 Andrew Cagney <cagney@b1.cygnus.com>
1492
1493 * hw-base.c (panic_hw_port_event, empty_hw_ports): Move from here.
1494 * hw-ports.c: To here.
1495
1496 * hw-base.h, hw-ports.c (create_hw_port_data,
1497 delete_hw_port_data): New functions.
1498 * hw-base.c (hw_delete, hw_create): Call same.
1499
1500 * hw-base.h (set_hw_ports, set_hw_port_event): Move set functions
1501 from here.
1502 * hw-ports.h: To here.
1503
1504Mon May 25 16:42:48 1998 Andrew Cagney <cagney@b1.cygnus.com>
1505
1506 * hw-device.c (hw_ioctl), hw-device.h (hw_ioctl_callback): Drop
1507 PROCESSOR and CIA arguments.
1508
1509Fri May 22 12:16:27 1998 Andrew Cagney <cagney@b1.cygnus.com>
1510
1511 * aclocal.m4 (SIM_AC_OPTION_HW): Add enable / disable argument.
1512 Move common object files from here.
1513 * Make-common.in (SIM_COMMON_HW_OBJS): To here.
1514
1515Thu May 21 17:57:16 1998 Andrew Cagney <cagney@b1.cygnus.com>
1516
1517 * sim-hw.c: Include ctype.h.
1518 (do_hw_poll_read): Do not assume EAGAIN.
1519
1520Wed May 20 04:37:57 1998 Doug Evans <devans@seba.cygnus.com>
1521
1522 * cgen-trace.c (first_insn_p): New static local.
1523 (trace_insn_init): Set it.
1524 (trace_insn_fini): Use TRACE_PREFIX.
1525 (trace_insn): Rewrite to use trace_prefix.
1526 * sim-trace.c (trace_prefix): Don't print filename arg if NULL.
1527 Adjust width accordingly.
1528
1529 * sim-profile.h (PROFILE_DATA): New member profile_any_p.
1530 (PROFILE_ANY_P,PROFILE_INSN_P,PROFILE_MEMORY): New macros.
1531 (PROFILE_SCACHE_P,PROFILE_PC_P,PROFILE_CORE_P): New macros.
1532 (PROFILE_COUNT_INSN,PROFILE_COUNT_READ,PROFILE_COUNT_WRITE): Simplify.
1533 (PROFILE_COUNT_CORE): Simplify.
1534 * sim-profile.c (profile_option_handler): Compute profile_any_p.
1535
1536Tue May 19 23:55:30 1998 Doug Evans <devans@seba.cygnus.com>
1537
1538 * cgen-ops.h (ADDCFSI): Fix typo.
1539
1540Sat May 16 12:44:52 1998 Doug Evans <devans@seba.cygnus.com>
1541
1542 * cgen-sim.h (CGEN_CPU): New members idesc_{read,sem}_init_p.
1543 * genmloop.sh: Use them rather than static locals.
1544
1545 * sim-engine.c (sim_engine_set_run_state): New function.
1546 * sim-engine.h (sim_engine_set_run_state): Declare.
1547 * genmloop.sh (pending_reason,pending_sigrc): New static locals.
1548 (@cpu@_engine_stop): New args reason,sigrc. All callers updated.
1549 (engine_resume): Reorganize. Allow synchronous exit from main loop.
1550
1551Fri May 15 16:06:05 1998 Doug Evans <devans@seba.cygnus.com>
1552
1553 * cgen-trace.c (trace_insn_init): New arg first_p.
1554 All callers updated.
1555 (trace_insn_fini): New arg last_p. All callers updated.
1556 * cgen-trace.h (trace_insn_init,trace_insn_fini): Update.
1557 (TRACE_INSN_INIT,TRACE_INSN_FINI): Update.
1558 * genmloop.sh (engine_resume): Update.
1559
1560Fri May 15 15:59:00 1998 Joyce Janczyn <janczyn@cygnus.com>
1561
1562 * Make-common.in (install-common): Run ranlib on installed copy of
1563 libsim.a.
1564
1565Fri May 15 15:03:00 1998 Joyce Janczyn <janczyn@cygnus.com>
1566
1567 * Make-common.in (install-common): Rename and install libsim.a.
1568
1569Tue May 12 15:23:57 1998 Andrew Cagney <cagney@b1.cygnus.com>
1570
1571 * sim-io.c (unistd.h): Include.
1572
1573Wed May 6 16:04:18 1998 Doug Evans <devans@seba.cygnus.com>
1574
1575 * Make-common (sim_main_headers): Sort.
1576 (cgen-*.o): Add cgen-sim.h dependency.
1577
1578 * cgen-scache.c (scache_init): Only allocate space if scache element
1579 size is non-zero.
1580 (scache_flush,scache_print_profile): Check if scache in use first.
1581
1582 * cgen-sim.h (IDESC): Provide forward declaration.
1583 (DECODE): Delete.
1584 (CGEN_CPU): Always define scache member. New members idesc,opcode.
1585 (cgen_cpu_max_extra_bytes): Declare.
1586 * cgen-utils.c (cgen_cpu_max_extra_bytes): New function.
1587
c906108c
SS
1588 * sim-cpu.h: New file. sim_cpu_base moved here.
1589 Move sim_cpu_lookup decl here.
1590 * sim-base.h: #include "sim-cpu.h".
1591 * sim-cpu.c: New file.
1592 * Make-common (sim_main_headers): Add sim-cpu.h.
1593 (sim-cpu.o): Add rule for.
1594
1595 * sim-model.c (set_model): Delete.
1596 (sim_model_set,model_set): New functions.
1597 (sim_model_install): Renamed from model_install.
1598 Don't set default model here.
1599 (model_option_handler): Rewrite --model processing.
1600 (sim_model_lookup,sim_mach_lookup): New functions.
1601 * sim-model.h (MAX_MODELS,MAX_INSNS): Delete.
1602 (insn_timing): Delete.
1603 (INSN_TIMING): New member `num'.
1604 (IMP_PROPERTIES): Always define scache_elm_size member.
1605 (MACH): New member init_cpu.
1606 (sim_machs): Renamed from machs.
1607 (sim_model_install): Renamed from model_install.
1608 (sim_model_set,sim_model_lookup,sim_mach_lookup): Declare.
1609 * sim-module.c (modules): Update.
1610
1611 * sim-profile.c (profile_print_insn): Add cpu arg to INSN_NAME macro.
1612
1613 * sim-io.c: #include <errno.h>.
1614
1615Wed May 6 12:39:15 1998 Andrew Cagney <cagney@b1.cygnus.com>
1616
1617 * dv-pal.c (struct hw_pal_device): Add reader.
1618 (hw_pal_finish): Initialize reader.
1619 (scan_hw_pal): Use reader.
1620
1621 * hw-base.h, sim-hw.c (do_hw_poll_read): New function.
1622 (HW_IO_EOF, HW_IO_NOT_READY): Define.
1623 * dv-pal.c: Use.
1624
1625 * sim-io.h, sim-io.c (sim_io_poll_read): New function. Copy from
1626 ../ppc/main.c sim_io_read_stdin.
1627
1628Fri May 1 12:11:02 1998 Andrew Cagney <cagney@b1.cygnus.com>
1629
1630 * hw-tree.h (hw_tree_print): Paramaterize with print and file
1631 arguments.
1632 * hw-tree.c: Update.
1633
1634 * hw-base.h (hw_port_event_callback): Delete CPU/CIA args.
1635 * hw-device.h (hw_io_read_buffer, hw_io_write_buffer): Delete
1636 CPU/CIA args.
1637 * hw-ports.h (hw_port_event): Ditto.
1638 * hw-ports.c (hw_port_event): Update.
1639 * hw-base.c (panic_hw_io_read_buffer, panic_hw_io_write_buffer):
1640 Update.
1641 * dv-pal.c (hw_pal_io_read_buffer, hw_pal_io_write_buffer):
1642 Update.
1643 (hw_pal_io_write_buffer): Call hw_halt not sim_engine_halt.
1644 (do_counter_event): Update.
1645 * dv-glue.c (hw_glue_io_read_buffer): Update.
1646 (hw_glue_port_event): Update.
1647
1648 * hw-device.h (SIM_DESC): Replace with struct sim_state.
1649 * hw-base.h (hw_create): Ditto.
1650 * hw-base.c (hw_create): Ditto.
1651
1652 * hw-device.c (hw_abort, hw_trace, hw_hw_event_queue_schedule,
1653 hw_event_queue_deschedule, hw_event_queue_time): Delete, moved
1654 from here to.
1655 * sim-hw.c: Here.
1656 * hw-device.h (hw_system_cpu): Declare.
1657 * sim-hw.c (hw_system_cpu): New function.
1658
1659 * sim-core.c (sim_core_map_attach, sim_core_attach): Call
1660 sim_hw_abort not hw_abort.
1661 (sim-hw.h): Include.
1662 (sim_core_read_buffer, sim_core_write_buffer): Call
1663 sim_hw_io_read_buffer and sim_hw_io_write_buffer. Do not pass CPU
1664 argument.
1665 (sim_core_set_xor): Do not pass CPU when aborting.
1666
1667 * sim-n-core.h (sim_core_read_aligned_N,
1668 sim_core_write_aligned_N): Call sim_hw_abort not hw_abort.
1669 (sim_core_read_aligned_N, sim_core_write_aligned_N): Call
1670 sim_cpu_hw_io_read_buffer and sim_cpu_hw_io_write_buffer. Does not
1671 return length.
1672
1673 * sim-hw.h: Declare sim_hw_io_{read,write}_buffer. Declare
1674 sim_hw_print.
1675 * sim-hw.c (sim_hw_io_read_buffer, sim_hw_io_write_buffer,
1676 sim_cpu_hw_io_read_buffer, sim_cpu_hw_io_write_buffer): New
1677 functions.
1678 (sim_hw_print): New function.
1679
1680 * sim-engine.h (sim_engine_vabort): Declare.
1681 * sim-engine.c (sim_engine_vabort): New function.
1682
1683Wed Apr 29 23:58:52 1998 Andrew Cagney <cagney@b1.cygnus.com>
1684
1685 * sim-trace.c (print_data): For floating-point numbers trace raw
1686 hex value.
1687 (trace_result_fp2): New function.
1688 * sim-trace.h (trace_result_fp2): New declaration.
1689 (TRACE_FP_RESULT2): New macro.
1690
1691Tue Apr 28 18:28:58 1998 Geoffrey Noer <noer@cygnus.com>
1692
1693 * common/aclocal.m4: call AM_EXEEXT in SIM_AC_COMMON, define
1694 AM_CYGWIN32 and AM_EXEEXT.
1695 * common/Make-common.in: set EXEEXT, add missing EXEEXTs
1696 to run and install-common rules.
1697 * common/configure: regenerate
1698
1699Sat Apr 25 17:45:01 1998 Andrew Cagney <cagney@b1.cygnus.com>
1700
1701 * sim-types.h (cell_word): New type.
1702 (natural_cell): Delete type.
1703
1704Sun Apr 26 15:31:55 1998 Tom Tromey <tromey@creche>
1705
1706 * configure: Regenerated to track ../common/aclocal.m4 changes.
1707 * config.in: Ditto.
1708
1709Sun Apr 26 15:25:07 1998 Tom Tromey <tromey@cygnus.com>
1710
1711 * acconfig.h (NEED_DECLARATION_PRINTF): Removed.
1712
1713Fri Apr 24 14:16:40 1998 Tom Tromey <tromey@creche>
1714
1715 * configure: Regenerated to track ../common/aclocal.m4 changes.
1716 * config.in: Ditto.
1717
1718Fri Apr 24 11:38:08 1998 Tom Tromey <tromey@cygnus.com>
1719
1720 * acconfig.h: New file.
1721 * Make-common.in (top_builddir): New macro.
1722 (INTL_LIB): Removed.
1723 (INTLLIBS): New macro.
1724 (INTLDEPS): Likewise.
1725 (LIBDEPS): Use INTLDEPS.
1726 (EXTRA_LIBS): Use INTLLIBS.
1727 * aclocal.m4 (SIM_AC_COMMON): Call CY_GNU_GETTEXT.
1728 (CY_WITH_NLS, CY_GNU_GETTEXT, AM_PATH_PROG_WITH_TEST,
1729 AM_LC_MESSAGES): New macros from GNU gettext.
1730
1731Fri Apr 24 19:57:59 1998 Andrew Cagney <cagney@b1.cygnus.com>
1732
1733 * sim-config.h: Discard leading _ from macros.
1734 * sim-types.h: Ditto.
1735
1736Wed Apr 22 14:14:19 1998 Michael Meissner <meissner@cygnus.com>
1737
1738 * Make-common.in (CSEARCH): Add -I to intl directories.
1739 (INTL_LIB): Point to libintl.a.
1740 (LIBDEPS): Add $(INTL_LIB).
1741 (EXTRA_LIBS): Ditto.
1742
1743Tue Apr 21 12:44:27 1998 Doug Evans <devans@canuck.cygnus.com>
1744
1745 * cgen-types.h (GETHIDI,MAKEDI): Tweak.
1746
1747 * cgen-ops.h (ADDCFSI): Fix.
1748 (SUBCFSI): Tweak.
1749
1750Tue Apr 21 13:18:41 1998 Andrew Cagney <cagney@b1.cygnus.com>
1751
1752 * sim-types.h (signed_address, unsigned_address): Define.
1753
1754Mon Apr 20 21:47:54 1998 Andrew Cagney <cagney@b1.cygnus.com>
1755
1756 * sim-fpu.c (sim_fpu_2d): Don't return an SNaN, convert it into a
1757 QNaN.
1758
1759Thu Apr 16 10:30:14 1998 Andrew Cagney <cagney@b1.cygnus.com>
1760
1761 * sim-fpu.c, sim-fpu.h (sim_fpu_fractionto, sim_fpu_tofraction):
1762 New functions, pack / unpack sim_fpu struct using raw values.
1763 (sim_fpu_is): Differentiate between negative and positive
1764 infinity.
1765
1766Tue Apr 14 18:49:31 1998 Andrew Cagney <cagney@b1.cygnus.com>
1767
1768 * sim-bits.h (EXTEND4): Define.
1769 (EXTEND4, EXTEND15, EXTEND11): Ditto.
1770
1771Tue Apr 14 16:31:35 1998 John Metzler <jmetzler@cygnus.com>
1772
1773 * sim-memopt.c (parse_addr): Sunos 4.5 does not have strtol
1774 declared so we need this cast to prevent long long addresses
1775 from being misconfigures. Results in access to unmapped memory.
1776
1777Tue Apr 14 13:19:14 1998 Doug Evans <devans@canuck.cygnus.com>
1778
1779 * Make-common.in (RUNTESTFLAGS): Define.
1780 (check): Pass RUNTESTFLAGS to recursive make.
1781
1782Tue Apr 14 15:09:19 1998 Andrew Cagney <cagney@b1.cygnus.com>
1783
1784 * sim-info.c (sim_info): Be verbose when either VERBOSE or
1785 STATE_VERBOSE_P.
1786
1787Sat Apr 4 23:24:17 1998 Andrew Cagney <cagney@b1.cygnus.com>
1788
1789 * aclocal.m4 (sim-inline): By default, disable sim-inline when
1790 cross compiling.
1791
1792Sat Apr 4 20:36:25 1998 Andrew Cagney <cagney@b1.cygnus.com>
1793
1794 * aclocal.m4 (sim-cflags): Add -fomit-frame-pointer to defaults.
1795 (sim-inline): Update to match sim-inline.[hc]
1796 * configure: Regenerated to track ../common/aclocal.m4 changes.
1797
1798 * Make-common.in (sim_main_headers): Add sim-inline.h
1799
1800 * sim-bits.h (sim-bits.c): Include when H_REVEALS_MODULE_P.
1801 selected.
1802 * sim-endian.h (sim-endian.c): Ditto.
1803
1804 * sim-events.h (_SIM_EVENTS_H_): Replace with SIM_EVENTS_H.
1805 (sim_events_set_trace): Delete unused prototype.
1806
1807 * sim-core.h (_SIM_CORE_H_): Replace with SIM_CORE_H.
1808 * sim-core.c (_SIM_CORE_C_): Ditto for SIM_CORE_C.
1809
1810 * sim-fpu.h (sim-fpu.c): Include when H_REVEALS_MODULE_P.
1811 (sim_fpu_to232i, sim_fpu_to232u, sim_fpu_i232to, sim_fpu_u232to):
1812 Comment out, not yet implemented in sim-fpu.c.
1813 (sim_fpu_zero, sim_fpu_one, sim_fpu_two, sim_fpu_qnan,
1814 sim_fpu_max32, sim_fpu_max64): Mark as EXTERN_SIM_FPU.
1815
1816 * sim-inline.h: Rewrite description.
1817 (H_REVEALS_MODULE_P, C_REVEALS_MODULE_P): Define.
1818 (SIM_MAIN_INLINE): Add inline option.
1819
1820 * sim-inline.c (semantics.c, idecode.c, engine.c, ...): Do not
1821 include generated files. Handled by generator directly.
1822
1823Sat Apr 4 01:07:06 1998 Andrew Cagney <cagney@b1.cygnus.com>
1824
1825 * sim-trace.c (set_trace_option_mask): Keep TRACE_ANY_P
1826 up-to-date.
1827
1828 * sim-trace.h (TRACE_ANY_P): Define.
1829 (struct _trace_data): Add trace_any_p.
1830
1831Mon Mar 30 17:11:55 1998 Andrew Cagney <cagney@b1.cygnus.com>
1832
1833 * run.c (main): Handle all alternatives of enum sim_stop.
1834 (main): Delete unused `asection *s'.
1835
1836Fri Mar 27 16:15:52 1998 Andrew Cagney <cagney@b1.cygnus.com>
1837
1838 * hw-tree.h, hw-tree.c (hw_tree_vparse): New function
1839
1840 * configure: Regenerated to track ../common/aclocal.m4 changes.
1841
1842 * sim-hw.c: New file.
1843 * sim-hw.h (sim_hw_parse): Declare function.
1844 (hw-tree.h): Do not include.
1845
1846 * sim-base.h (STATE_HW): Define.
1847 (struct sim_state_base): Add member struct *hw.
1848
1849 * sim-module.c (sim-hw.h): Include.
1850 (modules): Add sim_hw_install.
1851
1852 * aclocal.m4 (sim_hw_obj): Add sim-hw.o
1853
1854Fri Mar 27 14:55:06 1998 Andrew Cagney <cagney@b1.cygnus.com>
1855
1856 * sim-base.h (CPU_INDEX): Define.
1857
1858 * sim-utils.c (sim_state_alloc): Initialize.
1859 * sim-module.c (sim_post_argv_init): Ditto.
1860
1861Thu Mar 26 10:07:57 1998 Stu Grossman <grossman@bhuna.cygnus.co.uk>
1862
1863 * aclocal.m4 (sim_hw_obj): Fix sed expression to generate
1864 properly formatted lists.
1865
1866Thu Mar 26 10:37:22 1998 Andrew Cagney <cagney@b1.cygnus.com>
1867
1868 * dv-pal.c (enum hw_pal_address_mask): From Stu Grossman, was
1869 0x2f needs to be 0x3f.
1870
1871Thu Mar 26 09:10:56 1998 Andrew Cagney <cagney@b1.cygnus.com>
1872
1873 * hw-tree.c (hw_tree_find_property): Return NULL when device is
1874 not found.
1875 (hw_tree_find_*_property): Clean up error message when property is
1876 not found.
1877
1878 * dv-pal.c (hw_pal_io_read_buffer): Check the smp property is
1879 present before looking for it.
1880
1881Wed Mar 25 16:17:38 1998 Ian Carmichael <iancarm@cygnus.com>
1882
1883 * aclocal.m4 (AC_CHECK_HEADERS): Add check for fpu_control.h.
1884 (AC_CHECK_FUNCS): Add check for __setfpucw.
1885 * configure: Regenerated.
1886
1887Wed Mar 25 09:18:34 1998 Andrew Cagney <cagney@b1.cygnus.com>
1888
1889 * dv-pal.c (hw_pal_countdown, hw_pal_countdown_value,
1890 hw_pal_timer, hw_pal_timer_value): Define.
1891 (hw_pal_io_read_buffer, hw_pal_io_write_buffer): Add timer support
1892 (do_counter_event, do_counter_read, do_counter_value,
1893 do_counter_write): new functions.
1894
1895Tue Mar 24 12:24:24 1998 Andrew Cagney <cagney@b1.cygnus.com>
1896
1897 * hw-tree.c (hw_printf): Send tree dump to stderr, same as other
1898 trace output.
1899
1900 * hw-base.c (hw_create): Stop searching for a device when one is
1901 found.
1902
1903Wed Mar 25 12:35:29 1998 Andrew Cagney <cagney@b1.cygnus.com>
1904
1905 * configure: Regenerated to track ../common/aclocal.m4 changes.
1906
1907Mon Mar 23 10:25:08 1998 Andrew Cagney <cagney@b1.cygnus.com>
1908
1909 * aclocal.m4 (SIM_AC_OPTION_HARDWARE): Add second argument,
1910 appends extra devices.
1911 (SIM_AC_OPTION_HARDWARE): Substute sim_hw, a non-duplicate list of
1912 the device names.
1913
1914 * Make-common.in (hw-config.h): New target, create hw-config.h
1915 file.
1916 (SIM_HW): Definition from @sim_hw@.
1917 (hw-base.o): Depend on hw-config.h
1918
1919Tue Mar 24 17:41:35 1998 Stu Grossman <grossman@bhuna.cygnus.co.uk>
1920
1921 * Make-common.in: Get SHELL from configure.
1922 * (stamp-tvals sim-inline.c): Use $(SHELL) when invoking
1923 move-if-change. Fixes NT native build problem.
1924 * Makefile.in (nltvals.def): Use $(SHELL) when invoking
1925 move-if-change. Fixes NT native build problem.
1926 * configure: Regenerate with autoconf 2.12.1 to fix shell issues for
1927 NT native builds.
1928
1929Sun Mar 22 16:54:40 1998 Andrew Cagney <cagney@b1.cygnus.com>
1930
1931 * hw-device.h, hw-device.c (hw_strdup): New function.
1932
1933 * hw-base.c (hw_create): Use hw_strdup when saving a copy of the
1934 strings name, family and args.
1935 (full_name_of_hw): Use hw_strdup when returning the full path.
1936
1937 * hw-properties.c: Clean up property not found / wrong type error
1938 messages.
1939
1940 * hw-tree.c (hw_tree_parse): Finish a devices initialization
1941 before attaching any ports.
1942
1943 * hw-base.c (hw-config.): Include. Replace hardwired table.
1944
1945 * dv-glue.c: Copy over ../ppc/hw_glue.c. Update to new framework.
1946
1947 * Make-common.in: Add rule for dv-glue.o.
1948
1949Sun Mar 22 16:45:54 1998 Andrew Cagney <cagney@b1.cygnus.com>
1950
1951 * hw-base.c (hw_finish): Move setting of trace level to here.
1952 (hw_create): From here.
1953
1954 * hw-base.h, hw-base.c (do_hw_attach_regs): Copy function from
1955 ../ppc/device_table.c.
1956
1957 * dv-pal.c (hw_pal_finish): Attach PAL device to parent bus.
1958
1959 * hw-tree.c (print_properties): Supress path when printing
1960 properties of root node.
1961
1962Sun Mar 22 16:21:15 1998 Andrew Cagney <cagney@b1.cygnus.com>
1963
1964 * hw-device.h (HW_TRACE): Define.
1965 (hw_trace): Declare.
1966 * hw-device.c (hw_trace): Implement function.
1967
1968 * hw-base.c (hw_create): Set hw trace level from "trace?"
1969 property.
1970
1971 * dv-core.c (dv_core_attach_address_callback): Add trace.
1972
1973 * dv-pal.c: Replace DTRACE with HW_TRACE.
1974
1975Sun Mar 22 15:23:35 1998 Andrew Cagney <cagney@b1.cygnus.com>
1976
1977 * hw-device.h (HW_ZALLOC, HW_MALLOC): New macros.
1978 (hw_alloc_data): Delcare.
1979 (struct hw): Add member alloc_of_hw.
1980
1981 * hw-device.c (hw_zalloc, hw_malloc, hw_free, hw_free_all): New
1982 functions. Assocate memory with a device.
1983 (stdlib.h): Include.
1984
1985 * hw-base.h (set_hw_delete): Define.
1986 (hw_delete_callback): Declare.
1987 (hw_delete): Declare.
1988
1989 * hw-base.c (hw_delete): Implement function.
1990 (struct hw_base_data): Add member to_delete.
1991 (ignore_hw_delete): New function, does nothing.
1992 (hw_create): Set the hw_delete method.
1993 (hw_create): Allocate the base type using HW_ZALLOC before setting
1994 any methods.
1995
1996 * hw-tree.h, hw-tree.c (hw_tree_delete): New function.
1997
1998 * hw-properties.c: Replace zalloc/zfree with hw_zalloc/hw_free.
1999
2000 * hw-ports.c: Replace zalloc/zfree with hw_zalloc/hw_free.
2001 (attach_hw_port_edge): Add struct hw argument
2002
2003 * dv-pal.c (hw_pal_finish): Replace zalloc/zfree with
2004 hw_zalloc/hw_free.
2005
2006Sun Mar 22 15:09:52 1998 Andrew Cagney <cagney@b1.cygnus.com>
2007
2008 * hw-device.h (hw_attach_address_callback,
2009 hw_detach_address_callback): Attach to a single space not a space
2010 mask. Clarify interpretation of SPACE:ADDR parameters.
2011
2012 * hw-base.c (passthrough_hw_attach_address,
2013 passthrough_hw_detach_address): Update.
2014 * dv-core.c (dv_core_attach_address_callback): Ditto.
2015 * dv-pal.c (hw_pal_attach_address): Ditto.
2016
2017Thu Mar 19 00:41:00 1998 Andrew Cagney <cagney@b1.cygnus.com>
2018
2019 * sim-options.h: Document additional CPU arg to OPTION_HANDLER.
2020
2021Wed Mar 18 14:13:02 1998 Andrew Cagney <cagney@b1.cygnus.com>
2022
2023 * Make-common.in (SIM_HW_OBJS, SIM_HW_SRC, SIM_DV_OBJS): Define.
2024 (hw-base_h, hw-device_h, hw-handles_h, hw-instances_h, hw_ports_h,
2025 hw-properties_h, hw-tree_h): Define, point at corresponding
2026 header.
2027 (hw_base_headers): Define list of headers included by hw-base.h
2028 (hw-base.o, hw-device.o, hw-instances.o, hw-handles.o, hw-ports.o,
2029 hw-properties.o, hw-tree.o): Specify dependencies.
2030 (dv-core.o, dv-pal.o): Ditto.
2031
2032 * sim-hw.h: New file.
2033
2034 * hw-device.h, hw-device.c, hw-properties.h, hw-properties.c,
2035 hw-ports.h, hw-ports.c: New files. Copied from ../ppc/device.[ch].
2036
2037 * hw-tree.h, hw-tree.c: New files. Copied from ../ppc/tree.[hc].
2038
2039 * hw-base.h, hw-base.c: new files. Copied from
2040 ../ppc/device_table.[hc].
2041
2042 * dv-core.c, dv-pal.c: New files. Copied from
2043 ../ppc/hw_{core,pal}.c
2044
2045 * sim-basics.h (struct hw): Declare.
2046 (enum port_direction, enum object_disposition): Declare.
2047
2048Wed Mar 18 12:38:12 1998 Andrew Cagney <cagney@b1.cygnus.com>
2049
2050 * aclocal.m4 (SIM_AC_OPTION_HARDWARE): Set sim_hw_obj, sim_dv_obj,
2051 sim_dv_src in Makefile. Take list of devices as parameter to m4
2052 macro..
2053
2054 * configure: Regenerated to track ../common/aclocal.m4 changes.
2055
2056Mon Mar 16 12:37:33 1998 Andrew Cagney <cagney@b1.cygnus.com>
2057
2058 * sim-trace.h, sim-trace.c (trace_prefix): Pass in sim_cia so that
2059 trace_prefix can abort cleanly.
2060
2061Sat Mar 14 18:36:12 1998 Doug Evans <devans@seba.cygnus.com>
2062
2063 * dv-sockser.c, dv-sockser.h: New files.
2064 * Make-common.in (dv-sockser.o): Add rule for.
2065 * aclocal.m4: Check for fcntl.h.
2066 * config.h: Add HAVE_FCNTL_H.
2067
2068 * sim-break.c (remove_breakpoint): Fix thinko.
2069
2070 * sim-hload.c (sim_load): Provide default value of SIM_HANDLES_LMA.
2071 Use SIM_HANDLES_LMA for lma_p arg to sim_load_file.
2072
20731998-03-13 Fred Fish <fnf@cygnus.com>
2074
2075 * sim-base.h (struct sim_state_base): Add prog_syms and
2076 define macro STATE_PROG_SYMS.
2077 * sim-trace.c (trace_prefix): Add variables abfd, symsize,
2078 symbol_count, and asymbols. Call bfd_get_symtab_upper_bound
2079 and bfd_canonicalize_symtab, to get symbol table on first use
2080 and preserve it via STATE_PROG_SYMS for future calls to
2081 bfd_find_nearest_line.
2082
2083Wed Mar 11 14:02:47 1998 Andrew Cagney <cagney@b1.cygnus.com>
2084
2085 * sim-core.h, sim-core.c (sim_core_map_to_str): Delete.
2086
2087 * sim-core.c (sim_core_attach): Handle a generic number of maps -
2088 up to nr_maps, not just access_* maps.
2089
2090 * sim-profile.h (struct PROFILE_DATA): Track nr_maps different
2091 maps.
2092
2093 * sim-profile.c (profile_print_core): Make map unsigned. Iterate
2094 over nr_maps not sim_core_nr_maps.
2095
2096 * sim-events.h, sim-events.c (sim_events_watch_core): Change
2097 core_map argument to unsigned.
2098 (struct _sim_core): Ditto for struct member core_map.
2099
2100 * sim-core.h (nr_sim_core_maps, sim_core_*_map): Delete
2101
2102 * sim-basics.h (access_io, access_*_io): Define.
2103 (map_read, map_write, map_exec, map_io): Define.
2104
2105 * sim-core.c, sim-core.h (sim_core_attach): Replace argument
2106 attach with more generic mapmask.
2107 (sim_core_{read,write}_*): Change map argument to unsigned.
2108
2109 * sim-core.c (sim_core_uninstall, sim_core_attach,
2110 sim_core_detach): Iterate over nr_maps instead of
2111 sim_core_nr_maps.
2112
2113 * sim-break.c (insert_breakpoint): Write breakpoints to exec_map
2114 instead of the write_map.
2115 (remove_breakpoint): Ditto.
2116
2117 * genmloop.sh (engine_resume_full): Replace sim_core_*_map
2118 with read_map, write_map, exec_map resp.
2119
2120 * cgen-mem.h (DECLARE_GETMEM, DECLARE_SETMEM, DECLARE_GETIMEM):
2121 Ditto.
2122
2123 * cgen-utils.c (sim_disassemble_insn): Ditto.
2124
2125 * sim-hrw.c (sim_write, sim_write): Ditto.
2126
2127 * sim-utils.h, sim-utils.c (access_to_str, map_to_str,
2128 transfer_to_str): New functions.
2129
2130Mon Mar 9 12:50:59 1998 Doug Evans <devans@seba.cygnus.com>
2131
2132 * sim-base.h (sim_state_base): New member environment.
2133 (STATE_ENVIRONMENT): New macro.
2134 * sim-config.c (current_environment): Delete.
2135 (sim_config_default): New function.
2136 (sim_config): Set STATE_ENVIRONMENT, not current_environment.
2137 * sim-config.h (current_environment,CURRENT_ENVIRONMENT): Delete.
2138 (sim_config_default): Add prototype.
2139 * sim-module.c (sim_pre_argv_init): Call sim_config_default.
2140 * sim-options.c (standard_option_handler, case OPTION_ENVIRONMENT):
2141 Set STATE_ENVIRONMENT, not current_environment.
2142
2143Mon Mar 9 11:59:03 1998 Jim Wilson <wilson@cygnus.com>
2144
2145 * sim-fpu.c (NR_GUARDS64): Change NR_PAD32 to NR_PAD64.
2146
2147Tue Mar 3 10:53:05 1998 Andrew Cagney <cagney@b1.cygnus.com>
2148
2149 * sim-types.h (SIGNED32, SIGNED64): Pacify GCC.
2150
2151 * sim-alu.h (ALU64_BEGIN): Make alu64_r unsigned.
2152
2153Mon Mar 2 10:20:06 1998 Doug Evans <devans@seba.cygnus.com>
2154
2155 * Make-common.in (TAGS): Make smarter.
2156 * Makefile.in (TAGS): Ditto.
2157
2158Fri Feb 27 19:09:57 1998 Doug Evans <devans@canuck.cygnus.com>
2159
2160 * sim-module.c (*): Fix typos in assertion tests.
2161
2162Sat Feb 28 13:54:10 1998 Andrew Cagney <cagney@b1.cygnus.com>
2163
2164 * sim-module.c (sim_pre_argv_init): String passed to asprintf
2165 can't be constant.
2166
2167 * sim-options.c (sim_parse_args): Ditto.
2168 (sim_args_command): Return OK, instead of nothing, for an empty
2169 command.
2170
2171Fri Feb 27 13:29:13 1998 Andrew Cagney <cagney@b1.cygnus.com>
2172
2173 * sim-profile.c (profile_info): Rename from profile_print. Drop
2174 misc and misc_cpu callback arguments. Use
2175 PROFILE_INFO_CPU_CALLBACK and STATE_PROFILE_INFO_CALLBACK instead.
2176 (profile_install): Install profile_info function.
2177
2178 * sim-profile.h (PROFILE_INFO_CPU_CALLBACK,
2179 STATE_PROFILE_INFO_CALLBACK): Define.
2180 (struct PROFILE_DATA): Add field info_cpu_callback.
2181 (profile_print): Delete function.
2182
2183 * sim-base.h (STATE_MODULES): Define. Replace individual
2184 STATE_*_LIST with single struct module_list.
2185
2186 * sim-module.h (MODULE_INFO_FN, MODULE_INFO_LIST): Declare.
2187 (struct module_list): Declare.
2188
2189 * sim-module.h, sim-module.c (sim_module_add_info_fn,
2190 sim_module_info): New functions.
2191 (sim_module_install): Clean up module data structures.
2192
2193 * sim-info.c (sim_info): New file. New function. Call
2194 sim_module_info.
2195
2196 * Make-common.in (sim-info.o): Define rule.
2197 (SIM_NEW_COMMON_OBJS): Add sim-info.o.
2198
2199
2200Fri Feb 27 18:26:16 1998 Doug Evans <devans@canuck.cygnus.com>
2201
2202 * sim-base.h (sim_cpu_base): New members name, options.
2203 (sim_cpu_lookup): Add prototype.
2204 * sim-module.c (sim_pre_argv_init): Provide default names for cpus.
2205 * sim-options.h (DECLARE_OPTION_HANDLER): New argument `cpu'.
2206 (sim_add_option_table): Update prototype.
2207 * sim-options.c (sim_add_option_table): New argument `cpu'.
2208 (standard_option_handler,standard_install): Update.
2209 (sim_parse_args): Handle cpu specific options.
2210 (print_help): New static function.
2211 (sim_print_help): Call it. Print cpu specific options.
2212 (find_match): New static function.
2213 (sim_args_command): Call it. Handle cpu specific options.
2214 * sim-utils.c (sim_cpu_lookup): New function.
2215 * sim-memopt.c (memory_option_handler): Update.
2216 (sim_memopt_install): Update.
2217 * sim-model.c (model_option_handler): Update.
2218 (model_install): Update.
2219 * sim-profile.c (profile_option_handler): Update.
2220 (profile_install): Update.
2221 * sim-trace.c (trace_option_handler): Update.
2222 (trace_install): Update.
2223 * sim-watch.c (watchpoint_option_handler): Update.
2224 (sim_watchpoint_install): Update.
2225 * cgen-scache.c (scache_option_handler): Update.
2226 (scache_install): Update.
2227
2228Wed Feb 25 11:00:26 1998 Doug Evans <devans@canuck.cygnus.com>
2229
2230 * Make-common.in (check): Run `make check' in testsuite dir.
2231
2232Wed Feb 25 14:40:24 1998 Andrew Cagney <cagney@b1.cygnus.com>
2233
2234 * sim-trace.c (trace_result0): New function.
2235
2236 * sim-trace.h (TRACE_FP_*, TRACE_FPU_*): Rename TRACE_FPU_*
2237 macro's to TRACE_FP_*. TRACE_FPU_* should be defined and used when
2238 tracing sim_fpu variables.
2239 (TRACE_ALU_RESULT0): Define.
2240 (TRACE_FP_RESULT_WORD): Define.
2241 (TRACE_FP_INPUT_WORD1): Define.
2242
2243 * sim-fpu.c, sim-fpu.h (sim_fpu_max32, sim_fpu_max64, sim_fpu_one,
2244 sim_fpu_two): New constants.
2245 (sim_fpu_op1, sim_fpu_op2): New types.
2246 (struct _sim_fpu): Delete member result. Re-order other members.
2247 (sim_fpu_sign, sim_fpu_exp): New functions.
2248 (sim_fpu_max, sim_fpu_min): new functions.
2249 (EXPMAX32, EXPMAX64, NR_PAD32, NR_PAD64, NR_GUARDS32, NR_GUARDS64,
2250 NORMAL_EXPMAX32, NORMAL_EXPMAX64): Define.
2251
2252Tue Feb 24 22:45:39 1998 Doug Evans <devans@seba.cygnus.com>
2253
2254 * sim-profile.c (profile_print): Delete duplicate test of
2255 PROFILE_INSN_IDX.
2256 (profile_print_pc): Exit early if data collection not set up.
2257 (profile_print_core): Simplify by calling sim_core_map_to_str.
2258 * sim-core.h (sim_core_map_to_str): Declare.
2259 * sim-core.c (sim_core_map_to_str): Make non-static.
2260
2261 * genmloop.sh (engine_resume): Update insn_count before exiting.
2262 (engine_resume_full): Keep accurate core profile data.
2263
2264 * cgen-utils.c (sim_disassemble_insn): Don't use
2265 sim_core_read_aligned_N, it messes up profiling results.
2266
2267Mon Feb 23 20:45:57 1998 Mark Alexander <marka@cygnus.com>
2268
2269 * nltvals.def: Regenerate with MN10300 additions.
2270
2271Tue Feb 24 13:18:42 1998 Andrew Cagney <cagney@b1.cygnus.com>
2272
2273 * sim-trace.h (TRACE_ALU_RESULT2): Define.
2274
2275 * sim-trace.h, sim-trace.c (trace_result_word2,
2276 trace_input_word4, trace_result_word4): New function.
2277
2278Mon Feb 23 13:08:35 1998 Doug Evans <devans@canuck.cygnus.com>
2279
2280 * cgen-sim.h (SEM_NEXT_PC): New arg `len'.
2281
2282 * sim-xcat.h: Delete.
2283 * cgen-mem.h: Delete inclusion of sim-xcat.h.
2284 * cgen-sim.h: Ditto.
2285 * sim-alu.h: Replace sim-xcat.h with symcat.h.
2286 * sim-n-bits.h: Ditto.
2287 * sim-n-core.h: Ditto.
2288 * sim-n-endian.h: Ditto.
2289
2290Mon Feb 23 13:19:58 1998 Michael Meissner <meissner@cygnus.com>
2291
2292 * syscall.c (cb_syscall): Handle short reads, and EOF.
2293
2294Tue Feb 24 00:29:57 1998 Andrew Cagney <cagney@b1.cygnus.com>
2295
2296 * sim-trace.c (print_data): case trace_fmt_fp missing break. Use
2297 sim_fpu to safely print fp_word values.
2298 (print_data): Add trace_fmt_bool and trace_fmt_addr.
2299 (trace_result_bool1, trace_result_addr1): New functions.
2300 (trace_input_bool1, trace_input_addr1): New functions.
2301
2302 * sim-trace.h (TRACE_FPU_*): Define.
2303
2304Mon Feb 23 13:24:54 1998 Andrew Cagney <cagney@b1.cygnus.com>
2305
2306 * sim-fpu.h (enum sim_fpu_class): Add sim_fpu_class_denorm.
2307 (sim_fpu_fpto, sim_fpu_tofp): Define.
2308
2309Fri Feb 20 18:08:51 1998 Andrew Cagney <cagney@b1.cygnus.com>
2310
2311 * sim-fpu.c (sim_fpu_cmp): New function.
2312
2313Wed Feb 18 16:29:21 1998 Doug Evans <devans@canuck.cygnus.com>
2314
2315 * cgen-utils.h (sim_disassemble_insn): Use CGEN_INSN_BITSIZE
2316 instead of abuf->length.
2317 * sim-trace.c (trace_options): Have -t only trace a few useful things.
2318 (set_trace_option_mask): Renamed from set_trace_options.
2319 (set_trace_option): New function.
2320 (trace_option_handler): Update calls to set_trace_option{,_mask}.
2321 * sim-trace.h (TRACE_USEFUL_MASK): New macro.
2322
2323Wed Feb 18 12:42:15 1998 Andrew Cagney <cagney@b1.cygnus.com>
2324
2325 * sim-basics.h: Declare struct _sim_fpu.
2326
2327Tue Feb 17 16:27:46 1998 Andrew Cagney <cagney@b1.cygnus.com>
2328
2329 * sim-trace.h (TRACE_ALU_INPUT*, TRACE_ALU_RESULT): Define.
2330 (trace_prefix, trace_input*, trace_result*): Declare.
2331 (trace_one_insn): Change declaration, assume trace_prefix called.
2332 (trace_generic): Like trace_one_insn.
2333 (TRACE_ALU_IDX, TRACE_*_IDX): Change #define's to enum.
2334 (TRACE_alu, TRACE_[a-z]*): Update.
2335
2336 * sim-trace.c (trace_prefix, trace_input*, trace_result*,
2337 trace_insn, save_data, trace_idx_to_str, print_data): New
2338 functions.
2339 (trace_one_insn): Rewrite.
2340 (trace_generic): New function.
2341
2342Tue Feb 17 17:27:30 1998 Doug Evans <devans@seba.cygnus.com>
2343
c906108c
SS
2344 * aclocal.m4 (USE_MAINTAINER_MODE): New variable.
2345
2346 * cgen-sim.h (SEMANTIC_CACHE_FN): Delete.
2347 (SEMANTIC_FN): Rewrite declaration.
2348 (DECODE): Update type of semantic_fast member.
2349 ({EX,SEM}_FN_NAME): Have only one version.
c906108c
SS
2350 * sim-base.h (sim_state_base): Delete conditionals surrounding
2351 member scache_size.
2352
2353Tue Feb 10 18:31:49 1998 Andrew Cagney <cagney@b1.cygnus.com>
2354
2355 * sim-load.c (sim_load_file): Print LMA/VMA according to value
2356 used.
2357
2358Tue Feb 10 14:56:23 1998 Ian Carmichael <iancarm@cygnus.com>
2359
2360 * sim-core.c: Add missing prototypes for WITH_DEVICES.
2361 Add missing parameters to device_io calls.
2362 * sim-core.h: Add missing parameters to device_io calls.
2363
2364Mon Feb 9 14:48:37 1998 Doug Evans <devans@canuck.cygnus.com>
2365
2366 * cgen-sim.h (DECODE): Always use switch for `read' for now.
2367 (PAREXEC): Renamed from PARALLEL_EXEC. All uses updated.
2368 (SEMANTIC{,_CACHE}_FN): Fix return type.
c906108c
SS
2369 * genmloop.sh (@cpu@_engine_run): Delete `current_state'.
2370 (engine_resume): Likewise. Make `engine' volatile. Save copy
2371 of cpu pointer in volatile object. Initialize read switch if
2372 -parallel.
2373
2374Thu Feb 5 13:27:04 1998 Doug Evans <devans@seba.cygnus.com>
2375
2376 * cgen-sim.h (EX_FN_NAME): _exc_ -> _ex_.
2377 (SEM_INSN): New macro.
2378
2379Tue Feb 3 16:31:56 1998 Andrew Cagney <cagney@b1.cygnus.com>
2380
2381 * sim-run.c (sim_engine_run): Assume IMEM is 32 bit.
2382
2383Sun Feb 1 16:47:51 1998 Andrew Cagney <cagney@b1.cygnus.com>
2384
2385 * configure: Regenerated to track ../common/aclocal.m4 changes.
2386
2387Sun Feb 1 16:16:57 1998 Andrew Cagney <cagney@b1.cygnus.com>
2388
2389 * sim-types.h (fp_word): New type, define according to
2390 WITH_TARGET_FLOATING_POINT_BITSIZE.
2391
2392 * aclocal.m4 (default_sim_floating_point_bitsize): Add
2393 configuration of size of floating point registers.
2394
2395Sun Feb 1 14:02:31 1998 Andrew Cagney <cagney@b1.cygnus.com>
2396
2397 * sim-profile.c (profile_print): Only print CPU <N> if other
2398 output is going to appear.
2399
2400Sat Jan 31 18:15:41 1998 Andrew Cagney <cagney@b1.cygnus.com>
2401
2402 * configure: Regenerated to track ../common/aclocal.m4 changes.
2403
2404Sat Jan 31 18:03:55 1998 Andrew Cagney <cagney@b1.cygnus.com>
2405
2406 * sim-types.h (address_word): Typedef according to
2407 WITH_TARGET_ADDRESS_BITSIZE.
2408 (signed_cell, unsigned_cell, natural_cell): Ditto using
2409 WITH_TARGET_CELL_BITSIZE.
2410
2411 * sim-config.h (WITH_TARGET_ADDRESS_BITSIZE): Define.
2412 (WITH_TARGET_CELL_BITSIZE): Define.
2413 (WITH_HOST_WORD_BITSIZE): Delete.
2414
2415 * sim-config.c (print_sim_config): Update.
2416
2417 * aclocal.m4 (SIM_AC_OPTION_BITSIZE): Add support for
2418 configuration of address and OpenFirmware cell sizes.
2419
2420Fri Jan 30 09:36:33 1998 Andrew Cagney <cagney@b1.cygnus.com>
2421
2422 * sim-engine.h (sim_engine_run): Add argument nr_cpus.
2423 * sim-run.c (sim_engine_run): Update.
2424
2425 * sim-engine.h (SIM_ENGINE_HALT_HOOK): Use SET_CPU_CIA instead of
2426 CPU_CIA.
2427 * sim-run.c (sim_engine_run): Ditto.
2428
2429 * sim-resume.c (sim_resume): Obtain nr_cpus from sim_engine.
2430 (sim_resume): Pass nr_cpus to sim_engine_run.
2431
2432 * sim-engine.h (struct _sim_engine): Add member nr_cpus.
2433
2434 * sim-engine.c (sim_engine_init): Hardwire nr_cpus to
2435 MAX_NR_PROCESSORS.
2436 (sim_engine_nr_cpus) sim-engine.c, sim-engine.h: New function
2437
c906108c
SS
2438Fri Jan 23 14:20:54 1998 Doug Evans <devans@seba.cygnus.com>
2439
2440 * Make-common.in (stamp-tvals): New rule.
2441 (targ-vals.h,targ-map.c): Depend on it.
2442 (clean): Remove stamp-tvals.
2443
2444Tue Jan 20 21:35:13 1998 Michael Meissner <meissner@cygnus.com>
2445
2446 * sim-utils.c (sim_state_alloc): #if 0 variable that is only used
2447 in code also #if 0'ed.
2448
2449Mon Jan 19 22:26:29 1998 Doug Evans <devans@seba>
2450
2451 * configure: Regenerated to track ../common/aclocal.m4 changes.
2452 * aclocal.m4: Recognize --enable-maintainer-mode.
2453
2454Mon Jan 19 12:45:45 1998 Doug Evans <devans@seba.cygnus.com>
2455
2456 * cgen-scache.h: Deleted.
2457 * Make-common.in (cgen-run.o,cgen-scache.o): Delete cgen-scache.h dep.
c906108c
SS
2458 * cgen-scache.c: Only compile contents if WITH_SCACHE.
2459 (scache_init): Use runtime computed size of SCACHE.
2460 (scache_flush): Likewise.
2461 * cgen-mem.h (GETIMEMU[QHSD]I): Declare.
2462 ([GS]ETT{QI,UQI,HI,UHI,SI,USI,DI,UDI}): Declare.
2463 * cgen-sim.h: Scache support moved here.
2464 (PC): Redo definition.
2465 (ARGBUF,SCACHE,PARALLEL_EXEC): Provide forward decls.
2466 (DECODE): Add parallel execution support.
2467 Only include semantic label members if using switch.
2468 (SWITCH,CASE,BREAK,DEFAULT,ENDSWITCH): Portable computed goto support.
2469 (CGEN_CPU): Delete members exec_state, halt_sigrc, halt_jmp_buf.
2470 (IADDR,CIA,SEM_ARG,EX_FN_NAME,SEM_FN_NAME,RECORD_IADDR,SEM_ARGBUF,
2471 SEM_NEXT_PC,SEM_BRANCH_VIA_{CACHE,ADDR},SEM_NEW_PC_ADDR): Moved here
2472 from cgen-types.h.
2473 (engine_{stop,run,resume,halt,signal}): Delete decls.
2474 * cgen-types.h (CGEN_{XCAT3,CAT3}): Delete.
2475 (argbuf,scache): Delete forward decls.
2476 (STATE): Delete decl.
2477 * cgen-utils.c: Don't include decode.h, mem-ops.h, sem-ops.h.
2478 Include cgen-mem.h, cgen-ops.h.
2479 (engine_halt,engine_signal): Delete.
2480 ({ex,exc,sem,semc}_illegal): Delete.
2481 (sim_disassemble_insn): Result of extract fn is in bits.
2482 * genmloop.sh: Rewrite.
2483
2484 * cgen-trace.c (trace_insn): Set printed_result_p=0 if not tracing
2485 line numbers.
2486
2487 * sim-base.h (sim_state_base): Delete member `model'.
2488 (sim_cpu_base): Add member `model'.
2489 * sim-model.h (IMP_PROPERTIES): New type.
2490 (MACH): New members imp_props, models.
2491 (models): Delete decl.
2492 * sim-model.c (set_model): Update.
2493 * sim-profile.c (profile_print_model): Update.
2494
2495 * sim-utils.c (sim_state_alloc): Delete setting of cpu backlink here.
2496
2497Fri Jan 16 12:33:09 1998 Nick Clifton <nickc@cygnus.com>
2498
2499 * cgen-trace.c (trace_insn): Call CGEN_INSN_MNEMONIC() rather than
2500 CGEN_INSN_SYNTAX().
2501
2502Mon Dec 15 23:17:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
2503
2504 * configure: Regenerated to track ../common/aclocal.m4 changes.
2505 * config.in: Ditto.
2506
2507Mon Dec 15 23:16:03 1997 Andrew Cagney <cagney@b1.cygnus.com>
2508
2509 * aclocal.m4 (AR): Check for sigaction.
2510
2511Thu Dec 4 09:21:05 1997 Doug Evans <devans@canuck.cygnus.com>
2512
2513 * Make-common.in (sim-core.o): Depend on $(sim_main_headers).
2514
2515 * sim-config.h (WITH_TREE_PROPERTIES): Define as 0.
2516 * sim-config.c (sim_config): Replace WITH_DEVICES with
2517 WITH_TREE_PROPERTIES.
2518
2519 * configure: Regenerated to track ../common/aclocal.m4 changes.
2520
2521Wed Dec 3 17:56:02 1997 Doug Evans <devans@canuck.cygnus.com>
2522
2523 * Make-common.in (SIM_ENVIRONMENT): New variable.
2524 (CONFIG_CFLAGS): Add it.
2525 * aclocal.m4 (SIM_AC_OPTION_ENVIRONMENT): Handle
2526 --enable-sim-environment option.
2527 * configure: Regenerated.
2528 * sim-config.h (environment support): Rewrite.
2529 * sim-config.c (current_environment): Define as enum, unconditionally.
2530 (current_alignment): Define unconditionally.
2531 (config_environment_to_a): Update.
2532 (config_alignment_to_a): Fix type of argument. Define unconditionally.
2533 (sim_config): Handle environment and alignment determination
2534 unconditionally. Delete sanity checks of current_environment,
2535 unnecessary.
2536 (print_sim_config): Update.
2537 * sim-options.c (STANDARD_OPTIONS enum): Add OPTION_ENVIRONMENT.
2538 (standard_options): Add --environment.
2539 (standard_option_handler): Likewise.
2540
2541Fri Nov 28 12:21:25 1997 Andrew Cagney <cagney@b1.cygnus.com>
2542
2543 * sim-alu.h: Add notes on carry vs borrow for subtraction.
2544 (ALU{,8,16,32,64}ADD): Redefine ADD macro as add overflowing.
2545 (ALU{,8,16,32,64}ADDC): Define - add carrying.
2546 (ALU{,8,16,32,64}SUB): Redefine SUB macro as subtract overflowing.
2547 (ALU{,8,16,32,64}SUBB): Define - subtract borrowing.
2548 (ALU{,8,16,32,64}SUBC): Define - tract carrying.
2549 (ALU{,8,16,32,64}ADD_CA, ALU{,8,16,32,64}ADDC_C): Replace single
2550 argument ADD_CA macro with two argument ADDC_C - add carrying with
2551 carry in.
2552 (ALU{,8,16,32,64}SUB_CA, ALU{,8,16,32,64}SUBC_X): Replace single
2553 argument SUB_CA macro with two argument SUBC_X - subtract
2554 carrying, extended.
2555 (ALU{,8,16,32,64}SUBB_B): Define - subtract borrowing with
2556 borrow-in.
2557 (ALU{,8,16,32,64}NEGC, ALU{,8,16,32,64}NEGB): Define.
2558
2559Sun Nov 30 17:40:57 1997 Michael Meissner <meissner@cygnus.com>
2560
2561 * sim-io.c (sim_io_{syscalls,getstring}): Delete. No longer used.
2562 * sim-io.h (sim_io_syscalls): Delete.
2563
2564Fri Nov 28 20:10:09 1997 Michael Meissner <meissner@cygnus.com>
2565
2566 * syscall.c (cb_syscall): Add missing else, so write to stdout
2567 isn't doubled.
2568
2569 * sim-alu.h (ALU{,8,16,32,64}_SET_CARRY): Provide macros to import
2570 the carry bit from the CPU's psw.
2571
2572Fri Nov 28 11:15:05 1997 Doug Evans <devans@canuck.cygnus.com>
2573
2574 * gennltvals.sh: Redo syscall support.
2575 * nltvals.def: Regenerated.
2576
2577Wed Nov 26 16:49:38 1997 Michael Meissner <meissner@cygnus.com>
2578
2579 * syscall.c (cb_syscall): If writing to stdout or stderr, flush
2580 the stream immediately.
2581
2582Wed Nov 26 12:32:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
2583
2584 * sim-io.c (sim_io_getstring): Delete unused len2.
2585 (sim_io_syscalls): Ditto for sys_errno.
2586
2587Wed Nov 26 11:18:40 1997 Doug Evans <devans@canuck.cygnus.com>
2588
2589 * syscall.c (cb_syscall): Test CB_SYSCALL struct magic number.
2590
2591 * Make-common.in (run.o): Depend on remote-sim.h.
2592 (nrun.o,sim-hload.o,sim-hrw.o): Likewise.
2593 (sim-io.o,sim-reason.o,sim-resume.o): Likewise.
2594
2595Tue Nov 25 20:12:46 1997 Michael Meissner <meissner@cygnus.com>
2596
2597 * sim-io.c (sim_io_syscalls): Disable lseek.
2598
2599Tue Nov 25 00:12:38 1997 Doug Evans <devans@seba.cygnus.com>
2600
2601 * gennltvals.sh: Generate syscall values for d30v.
2602
2603 * gennltvals.sh: Use libgloss/syscall.h for sparc.
2604 * nltvals.def: Regenerate.
2605
2606 * callback.c (os_stat): Make 3rd arg a host struct stat ptr.
2607 (os_fstat): Likewise. Validate fd argument.
2608 (cb_host_to_target_stat): Delete big_p arg. If HS arg is NULL,
2609 just compute target stat struct length.
2610 * syscall.c: #include "libiberty.h", <sys/types.h>, <sys/stat.h>.
2611 (ENOSYS,ENAMETOOLONG): Provide definitions if missing.
2612 (get_string): Return host errno values so they can be properly
2613 translated later.
2614 (cb_syscall): Likewise.
2615 (cb_syscall, cases open,unlink): Use get_path instead of get_string.
2616 (cb_syscall, case read): Use read_stdin for file descriptor 0.
2617 (cb_syscall, case write): Use write_stderr for file descriptor 2.
2618 (cb_syscall): Add cases for lseek, unlink, stat, fstat, time.
2619 (get_path): New function.
2620
2621Mon Nov 24 18:56:07 1997 Michael Meissner <meissner@cygnus.com>
2622
2623 * sim-io.c (sim_io_syscalls): New function to provide system call
2624 emulation. Provide exit, open, close, read, write, lseek, and
2625 unlink.
2626 (sim_io_getstring): New function to return a string from a
2627 simulated memory location.
2628
2629 * sim-io.h (sim_io_syscalls): Add declaration.
2630
2631Mon Nov 24 12:09:59 1997 Doug Evans <devans@seba.cygnus.com>
2632
2633 * sim-core.c (sim_core_signal): Fix spelling error in message.
2634
2635 * sim-hrw.c (sim_read): Use read map, not write map.
2636
2637 * Make-common.in (all): Add .gdbinit.
2638 * gdbinit.in: Add dump command.
2639
2640 * sim-model.c (model_options): Use '\0' for `shortopt'.
2641
2642 * sim-trace.c (trace_option_handler): Set state trace file
2643 for --trace-file in addition to cpu's values.
2644 (trace_vprintf): If cpu == NULL, try state's trace file.
2645 (trace_options): Reorganize table, reword some descriptions.
2646
2647Sun Nov 23 10:57:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
2648
2649 * sim-fpu.c (sim_fpu_abs, sim_fpu_neg, sim_fpu_inv), sim-fpu.h:
2650 New functions.
2651
2652Sat Nov 22 19:16:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
2653
2654 * sim-reason.c (sim_stop_reason): For sim_signalled, return the
2655 signal untranslated, document problem with this.
2656
2657 * nrun.c (main): Check for a prog name of `*step'. If present,
2658 step the simulator instead of allowing it to run free.
2659
2660 * sim-signal.c (SIGQUIT): Define on _MSC_VER hosts.
2661
2662 * Make-common.in (sim_main_headers): Add sim-signal.h.
2663
2664Fri Nov 21 09:32:32 1997 Andrew Cagney <cagney@b1.cygnus.com>
2665
2666 * sim-signal.c (sim_signal_to_host): Return 0 for SIM_SIGNONE.
2667
2668Thu Nov 20 20:35:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
2669
2670 * sim-signal.h: Start simulator signals at 64 so that host signal
2671 numbers can be detected and reported.
2672
2673 * sim-signal.h (SIM_SIGFPE), sim-signal.h: Add signal.
2674
2675Wed Nov 19 12:02:41 1997 Doug Evans <devans@seba.cygnus.com>
2676
2677 * callback.c (cb_host_to_target_stat): Fix return values.
2678
2679 * cgen-sim.h (enum_signal_type): Delete.
2680 (engine_signal): Update prototype.
2681 * cgen-utils.c: Don't include <signal.h>.
2682 (sim_signal_to_host): Delete, lives in sim-signal.c now.
2683 (engine_signal): Update.
2684
2685 * sim-utils.c (sim_state_alloc): Call SIM_STATE_ALLOC if defined.
2686 (sim_state_free): Call SIM_STATE_FREE if defined.
2687
2688 * sim-module.c (sim_module_install): Don't leave any modules
2689 installed if one fails to install.
2690
2691Wed Nov 19 13:25:48 1997 Michael Meissner <meissner@cygnus.com>
2692
2693 * sim-options.c: Don't include ../libiberty/alloca-conf.h any
2694 more, since alloca is not used in this file.
2695
2696 * sim-alu.h (ALU{32,64}_*): Rewrite 32 and 64 bit ALU support to
2697 correctly set the carry and overflow bits for those types.
2698 (ALU{8,16,32,64}_{ADD,SUB}_CA): Take VAL argument to add along
2699 with carry, so carry is correct after doing both adds.
2700 (ALU*): Space out '\' to make it easier to read.
2701
2702Tue Nov 18 15:53:45 1997 Doug Evans <devans@canuck.cygnus.com>
2703
2704 * sim-core.c (sim_core_signal): Use sim_stopped instead of
2705 sim_signalled.
2706
2707 * sim-signal.c, sim-signal.h: New files.
2708 * Make-common.in (sim-signal.o): Add rule for.
2709 (SIM_NEW_COMMON_OBJS): Add sim-signal.o.
2710 * sim-abort.c: Don't include <signal.h>.
2711 * sim-basics.h: #include "sim-signal.h".
2712 * sim-break.c: Don't include <signal.h>.
2713 (sim_handle_breakpoint): Replace SIGTRAP with SIM_SIGTRAP.
2714 * sim-core.c: Don't include <signal.h>.
2715 (SIGBUS): Delete definition.
2716 (sim_core_signal): Replace SIGSEGV,SIGBUS with SIM_SIGSEGV,SIM_SIGBUS.
2717 * sim-engine.c: Don't include <signal.h>.
2718 (sim_engine_abort): Replace SIGABRT with SIM_SIGABRT.
2719 * sim-reason.c (sim_stop_reason): Call sim_signal_to_host.
2720 * sim-resume.c: Don't include <signal.h>.
2721 (SIGTRAP): Delete definition.
2722 (has_stepped): Replace SIGTRAP with SIM_SIGTRAP.
2723 * sim-stop.c: Don't include <signal.h>.
2724 (control_c_simulation): Replace SIGINT with SIM_SIGINT.
2725 * sim-watch.c: Don't include <signal.h>.
2726 (handle_watchpoint): Replace SIGINT with SIM_SIGINT.
2727
2728 * Make-common.in (SIM_NEW_COMMON_OBJS): New variable.
2729
2730 * sim-base.h (CIA_ADDR): Provide default definition.
2731 * sim-core.c (sim_core_signal): Use CIA_ADDR to fetch value.
2732 * sim-break.c (sim_handle_breakpoint): Likewise.
2733
2734Mon Nov 17 14:15:31 1997 Doug Evans <devans@seba.cygnus.com>
2735
2736 * Make-common.in (srccom): New variable.
2737
2738 * Make-common.in (DEP, COMMON_DEP_CFLAGS): Define.
2739 (LIB_OBJS): Add syscall.o.
2740 (gentmap): Pass $(NL_TARGET) to $(CC).
2741 (syscall.o): Add rule for.
2742 (sim_main_headers): Add $(SIM_EXTRA_DEPS).
2743 (sim-bits.o): Depend on $(sim-n-bits_h).
2744 (sim-load.o): Depend on callback.h.
2745
2746 * Make-common.in (cgen-*.o): Update dependencies, mem-ops.h renamed to
2747 cgen-mem.h, sem-ops.h renamed to cgen-ops.h.
2748 * cgen-mem.h, cgen-ops.h: New files.
2749
2750 * aclocal.m4 (--enable-sim-scache): Pass -DWITH_SCACHE=0 for "=no".
2751
2752 * Makefile.in (nltvals.def): Depend on gennltvals.sh.
2753 Rewrite build rule.
2754 * callback.c: #include string.h or strings.h.
2755 #include sys/types.h and sys/stat.h.
2756 (cb_init_syscall_map,cb_init_errno_map,cb_init_open_map): Declare.
2757 (os_get_errno,os_open): Update.
2758 (os_stat,os_fstat): New functions.
2759 (os_init): Initialize syscall_map, errno_map, open_map.
2760 (default_callback): Add entries for os_stat, os_fstat, syscall_map,
2761 errno_map, open_map, signal_map, stat_map.
2762 (cb_read_target_syscall_maps): New function.
2763 (cb_target_to_host_syscall): New function.
2764 (cb_host_to_target_errno): Renamed from host_to_target_errno.
2765 (cb_target_to_host_open): Renamed from target_to_host_open.
2766 (store): New function.
2767 (cb_host_to_target_stat): New function.
2768 * syscall.c: New file.
2769 * gentmap.c (sys_tdefs): New global.
2770 (gen_targ_vals_h): Output target syscall numbers.
2771 (gen_targ_map_c): Update. Output target syscall translation map.
2772 * gentvals.sh: New first argument `target'. Preface table with
2773 #ifdef NL_TARGET_$target if non-null target passed.
2774 * gennltvals.sh: New file.
2775 * nltvals.def: Regenerated.
2776
2777Fri Nov 14 11:33:34 1997 Andrew Cagney <cagney@b1.cygnus.com>
2778
2779 * sim-n-core.h (sim_core_read_unaligned_N): Return static
2780 sim_core_dummy_M.
2781 (sim_core_dummy_M): Declare.
2782
2783Wed Nov 12 18:16:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
2784
2785 * sim-core.c (sim_core_signal): Print the address of the
2786 instruction.
2787
2788Thu Nov 13 11:49:41 1997 Doug Evans <devans@seba.cygnus.com>
2789
2790 * sim-base.h (sim_state_base): Move `magic' to end of struct.
2791
2792 * sim-base.h (sim_state_base): Add member trace_data.
2793 (STATE_TRACE_DATA): New macro.
2794 * sim-trace.h (TRACE_DEBUG_IDX,TRACE_debug): New macros.
2795 ({WITH_,}TRACE_DEBUG_P): New macros.
2796 (STATE_TRACE_FLAGS,STRACE_P,STRACE_DEBUG_P): New macros.
2797 (_sim_cpu): Delete forward reference.
2798 (debug_printf): Update.
2799 * sim-trace.c (OPTION_TRACE_DEBUG): Define.
2800 (trace_options): Add --trace-debug.
2801 (set_trace_options): Handle it.
2802 (trace_option_handler): Likewise.
2803 (trace_install): Init state trace_data struct.
2804 (trace_uninstall): Close state trace file.
2805 * sim-events.c (ETRACE): Only print source file and line number if
2806 --trace-debug.
2807 * sim-n-core.h (sim_core_trace_M): Likewise.
2808
2809 * sim-core.c (sim_core_signal): Add missing "\n" in message.
2810
28111997-11-13 Felix Lee <flee@cygnus.com>
2812
2813 * sim-n-core.h (sim_core_read_unaligned_N): illegal empty
2814 initializer.
2815 * sim-types.h (unsigned128,signed128): fix typo for MSVC.
2816
2817Wed Nov 12 12:18:08 1997 Doug Evans <devans@canuck.cygnus.com>
2818
2819 * aclocal.m4 (SIM_AC_OPTION_SCACHE): Fix typo.
2820
2821 * Make-common.in (BUILT_SRC_FROM_COMMON): Remove files no longer
2822 built this way.
2823 (sim-config.o): Remove non-existent $(sim-nconfig_h) dependency.
2824 (clean): Don't delete $(BUILT_SRC_FROM_COMMON) if building in
2825 source tree.
2826
2827Tue Nov 11 13:28:02 1997 Andrew Cagney <cagney@b1.cygnus.com>
2828
2829 * sim-events.c (sim_events_process): Re-compute the time -
2830 update_time_from_event - as each event is processed. Reverses
2831 previous change.
2832
2833Fri Nov 7 00:37:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
2834
2835 * callback.c (os_poll_quit): Replace _WIN32 with _MSC_VER.
2836
2837Fri Nov 7 00:37:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
2838
2839 * sim-events.c (sim_events_process): Delete redundant call to
2840 update_time_from_event.
2841 (sim_events_slip): Always decrement time_from_event.
2842 (sim_events_tick, sim_events_deschedule, update_time_from_event):
2843 Delete assertion that time_from_event >=0 when work in queue, no
2844 longer applicable.
2845
2846Thu Nov 6 12:06:46 1997 Andrew Cagney <cagney@b1.cygnus.com>
2847
2848 * sim-options.c (STANDARD_OPTIONS): Change OPTION_* to an enum.
2849 (standard_option_handler): Update.
2850
2851 * sim-options.h: Clarify documentation.
2852 (OPTION_LONG_ONLY_P): Delete definition.
2853 (OPTION_VALID_P): Define.
2854
2855 * sim-options.c (sim_print_help): Allow short only options.
2856 (sim_parse_args): Ditto.
2857 (sim_args_command): Skip short only options.
2858 (sim_parse_args): Allocate space for NUM_OPTS not just 256. Make
2859 separate entries for short and long options in the HANDLERS and
2860 ORIG_VAL tables.
2861 (sim_parse_args): Disable argument permutation.
2862
2863Wed Nov 5 13:40:31 1997 Andrew Cagney <cagney@b1.cygnus.com>
2864
2865 * sim-core.h (DECLARE_SIM_CORE_WRITE_N. DECLARE_SIM_CORE_READ_N):
2866 Add argument M, size of data type.
2867 (sim_core_read_misaligned_3, sim_core_write_misaligned_3):
2868 Declare, ditto for 5, 6 & 7 byte transfers.
2869 (sim_core_write_unaligned_1, sim_core_write_unaligned_1): Define
2870 as aligned variant.
2871
2872 * sim-n-core.h (sim_core_trace_M): Rename from
2873 sim_core_trace_N. Add nr_bytes argument. Replace transfer argument
2874 with transfer type. Print transfer direction. Handle 1 and 2 byte
2875 transfers.
2876 (sim_core_read_unaligned_N, sim_core_write_unaligned_N): Trace
2877 unaligned accesses.
2878 (unsigned_M, T2H_M, H2T_M): Rename from unsigned_N, T2H_N, H2T_N.
2879 Update all functions.
2880
2881 * sim-core.c: Generate functions starting with 16 not 1.
2882 (sim_core_read_unaligned_3): Generate. Ditto for 3 byte write and
2883 all 5, 6 & 7 byte transfers.
2884
2885 * sim-n-core.h (sim_core_read_misaligned_N,
2886 sim_core_write_misaligned_N): Implement.
2887
2888Mon Nov 3 15:03:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
2889
2890 * sim-endian.h (U16_8): Implement
2891
2892 * sim-endian.c (sim_endian_split_16, sim_endian_join_16): New functions
2893
2894 * sim-endian.h (VL8_16, VH8_16): Implement.
2895
2896 * sim-memopt.c (memory_option_handler): Typecast 64bit value to
2897 long in printf.
2898 (memory_option_handler): Only zalloc modulo bytes when non-zero.
2899 (memory_option_handler): Skip comma in alias address list
2900
2901Fri Oct 31 13:03:33 1997 Andrew Cagney <cagney@b1.cygnus.com>
2902
2903 * sim-memopt.c (do_memopt_add, do_memopt_delete): Add level and
2904 space params.
2905 (parse_size, parse_addr): New functions
2906 (memory_option_handler, memory_options): Parse address & size
2907 using new functions. Pass level, space, modulo to do_memopt_add &
2908 do_memopt_del.
2909
2910 * sim-memopt.h (struct _sim_memopt): Add level & space fields.
2911
2912 * sim-core.h (sim_core_arrach, sim_core_detach): Replace
2913 `attach_type attach' argument with `unsigned level' argument.
2914 Document.
2915
2916 * sim-core.c (new_sim_core_mapping, sim_core_map_attach,
2917 sim_core_attach): Replace argument attach with level. Update
2918 verification of arguments.
2919 (sim_core_map_detach, sim_core_detach): Replace argument attach
2920 with level.
2921
2922 * sim-basics.h (enum _attach_type): Delete.
2923
2924Thu Oct 30 13:45:00 1997 Doug Evans <devans@seba.cygnus.com>
2925
2926 * sim-core.h (sim_core_write_8): Define.
2927
2928Tue Oct 28 12:29:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
2929
2930 * sim-bits.h: Document ROTn macro.
2931
2932 * sim-endian.h (H2T): Handle 16 byte variables.
2933
2934 * sim-n-core.h (sim_core_read_unaligned_N): Return a dummy when an
2935 error.
2936
2937 * sim-core.c: Do not generate sim_core_*_word.
2938
2939 * sim-n-core.h (sim_core_trace_N): Add line_nr argument.
2940 (sim_core_write_aligned_N, sim_core_read_aligned_N): Update.
2941
2942 * sim-core.h (sim_core_read_unaligned_word,
2943 sim_core_read_aligned_word, sim_core_read_word,
2944 sim_core_write_unaligned_word, sim_core_write_aligned_word,
2945 sim_core_write_word): Change to macros that map onto sim_core_*_N.
2946
2947Mon Oct 27 11:25:10 1997 Doug Evans <devans@canuck.cygnus.com>
2948
2949 * sim-n-endian.h: Add TAGS entrys for 16 byte versions.
2950
2951 * sim-endian.h: Disable 16 byte support.
2952
2953Mon Oct 27 12:00:48 1997 Andrew Cagney <cagney@b1.cygnus.com>
2954
2955 * sim-endian.c (_SWAP_16): Define. Generate 126 bit swap code.
2956
2957 * sim-n-core.h (sim_core_trace_N): New function.
2958 (sim_core_read_aligned_N, sim_core_write_aligned_N): Use,
2959 (sim_core_read_unaligned_N): Do not retyrn bogus value wden error.
2960
2961 * sim-endian.h: Add 128 bit variant.
2962
2963 * sim-core.h, sim-core.c: Add 128 bit variant.
2964
2965 * sim-types.h: Add signed128 and unsigned128 types using a struct.
2966
2967Fri Oct 24 11:33:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
2968
2969 * sim-events.c (sim_events_process): Clear events->work_pending.
2970 (sim_events_tickn, sim_events_tick): Accumulate, instead of
2971 setting, nr_ticks_to_process.
2972 (sim_events_preprocess): Allow nr_ticks_to_process to be non-zero
2973 when the event queue isn't next.
2974
2975 * sim-events.h, sim-events.c (sim_events_slip): New function.
2976
2977Wed Oct 22 14:18:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
2978
2979 * sim-hload.c (sim_load): Pass lma_p==0 and do_load=sim_load.
2980
2981 * sim-utils.h, sim-load.c (sim_load_file): Add lma_p and do_load
2982 arguments.
2983
2984Tue Oct 21 18:37:57 1997 Doug Evans <devans@canuck.cygnus.com>
2985
2986 * nrun.c (main): Remove useless test of name != NULL.
2987 Exit if bfd_openr fails. Call bfd_check_format after bfd_openr.
2988
2989Tue Oct 21 10:42:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
2990
2991 * sim-fpu.c (EXPMAX): Type is unsigned.
2992 (MIN_INT, MAX_INT): Type is signed64.
2993 (i2fpu): Type of val is signed64.
2994
2995Tue Oct 21 10:42:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
2996
2997 * sim-profile.h (PROFILE_PC_BUCKET_SIZE): Treat a shift of zero as
2998 a bucket size of zero.
2999
3000 * sim-profile.c (OPTION_PROFILE_PC_GRANULARITY,
3001 OPTION_PROFILE_PC): Define.
3002 (profile_option_handler): Add support for --profile-pc and
3003 --profile-pc-granularity options.
3004 (profile_pc_init): When possible, compute nr buckets from bucket
3005 size.
3006
3007 * sim-profile.c (profile_pc_init): Align the profile-pc end
3008 address with the profile-pc bucket size.
3009
3010 * sim-profile.h (PROFILE_PC_NR_BUCKETS): Rename PROFILE_PC_SIZE to
3011 something less ambiguous.
3012 (PROFILE_PC_BUCKET_SIZE): Ditto for PROFILE_PC_SAMPLE_SIZE.
3013
3014 * sim-profile.c (profile_pc_cleanup): New function. Move
3015 profile_pc_uninstall code to here.
3016 (profile_pc_uninstall): Call.
3017 (profile_pc_init): Call.
3018
3019Mon Oct 20 17:23:58 1997 Andrew Cagney <cagney@b1.cygnus.com>
3020
3021 * sim-profile.c (profile_print_pc): Dump pc profile to dmon.out
3022 file using BSD gprof format.
3023
3024 * sim-bits.h (LSBIT, MSBIT, BIT): Force result to type
3025 unsigned_word.
3026 (LSBIT8, LSBIT16, LSBIT32, LSBIT64, MSBIT8, MSBIT16, MSBIT32,
3027 MSBIT64): Force result to unsignedN.
3028
3029Thu Oct 16 11:38:56 1997 Andrew Cagney <cagney@b1.cygnus.com>
3030
3031 * sim-alu.h (ALU16_BEGIN, ALU32_BEGIN, ALU64_BEGIN): Drop opening
3032 brace from macro.
3033 (ALU8_BEGIN, ALU8_SET, ALU8_ADD, ALU8_SUB, ALU8_NEGATE): Define.
3034 (ALU16_ADD, ALU16_SUB, ALU16_NEGATE): Simplify arrithmetic.
3035 (ALU32_ADD, ALU32_SUB, ALU32_NEGATE): Simplify arrithmetic.
3036 (ALU64_ADD, ALU64_SUB, ALU64_NEGATE): Simplify arrithmetic.
3037
3038Wed Oct 15 09:24:19 1997 Andrew Cagney <cagney@b1.cygnus.com>
3039
3040 * sim-core.h (struct _sim_core_mapping): Change free_buffer to
3041 type void*.
3042
3043 * sim-core.c (sim_core_uninstall, new_sim_core_mapping,
3044 sim_core_map_attach, sim_core_map_detach): Change free_buffer to
3045 type void*.
3046 (sim_core_attach): Rename buffer_freed to free_buffer, type
3047 void*. Ensure that allocated buffer is alligned according to
3048 region's address.
3049
3050Mon Oct 13 11:34:50 1997 Andrew Cagney <cagney@b1.cygnus.com>
3051
3052 * sim-alu.h (ALU64_HAD_OVERFLOW): Define.
3053 (ALU64_SUB): Define.
3054
3055 * Make-common.in (all): Build SIM_EXTRA_ALL first.
3056 (.gdbinit): Remove dependencies, generate once per build.
3057
3058Tue Oct 14 19:20:09 1997 Andrew Cagney <cagney@b1.cygnus.com>
3059
3060 * sim-n-core.h (sim_core_read_aligned_N,
3061 sim_core_write_aligned_N): Make xaddr param type address_word not
3062 unsigned_word.
3063
3064Fri Oct 3 09:49:18 1997 Andrew Cagney <cagney@b1.cygnus.com>
3065
3066 * sim-fpu.h, sim-fpu.c: Rewrite. Change sim_fpu object to an
3067 unpacked floating point struct. Pass sim_fpu object by reference.
3068 Add preliminary support for rounding modes.
3069
3070Fri Oct 3 09:28:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
3071
3072 * configure: Regenerated to track ../common/aclocal.m4 changes.
3073
3074Thu Oct 2 19:43:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
3075
3076 * aclocal.m4 (sim-bitsize): Fix typo, WITH_TARGET_WORD_BITSIZE not
3077 WITH_TARGET_BITSIZE.
3078
3079Thu Sep 25 23:20:20 1997 Felix Lee <flee@yin.cygnus.com>
3080
3081 * sim-profile.c (profile_print_core): label needs empty statement.
3082
3083Thu Sep 25 11:20:47 1997 Stu Grossman <grossman@babylon-5.cygnus.com>
3084
3085 * sim-break.c (sim_set_breakpoint sim_clear_breakpoint): Use ZALLOC
3086 and zfree instead of xmalloc and free. Prevents warnings.
3087
3088Wed Sep 24 17:38:57 1997 Andrew Cagney <cagney@b1.cygnus.com>
3089
3090 * configure: Regenerated to track ../common/aclocal.m4 changes.
3091
3092Wed Sep 24 17:23:31 1997 Andrew Cagney <cagney@b1.cygnus.com>
3093
3094 * Make-common.in (SIM_BITSIZE): Assign from configured value.
3095 (CONFIG_CFLAGS): Add SIM_BITSIZE.
3096
3097 * aclocal.m4 (--enable-sim-bitsize): Developer option for
3098 controling the bitsize/msb of the target.
3099
3100Wed Sep 24 17:41:40 1997 Stu Grossman <grossman@babylon-5.cygnus.com>
3101
3102 * Make-common.in: New files sim-break.c, sim-break.h.
3103 * sim-base.h: Add point to breakpoint list to sim_state_base.
3104 * sim-break.c sim-break.h: New modules that implement intrinsic
3105 breakpoint support.
3106 * sim-module.c: Add breakpoint module.
3107
3108Tue Sep 23 00:26:39 1997 Felix Lee <flee@yin.cygnus.com>
3109
3110 * sim-events.c (SIM_EVENTS_POLL_RATE): poll more often than once
3111 an hour.
3112 * sim-n-core.h (WITH_XOR_ENDIAN): MSVC barfs on
3113 if (0) { 1 % 0; }
3114 * sim-core.c (sim_core_xor_write_buffer): WITH_XOR_ENDIAN + 1.
3115 (SIGBUS) define for Windows.
3116 * sim-trace.c (trace_printf,debug_printf): added ALMOST_STDC.
3117 * sim-resume.c: define SIGTRAP for windows.
3118 * sim-xcat.h: use token pasting if ALMOST_STDC.
3119
3120Tue Sep 23 11:04:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
3121
3122 * Make-common.in (SIM_SCACHE, SIM_DEFAULT_MODEL): Assign
3123 configured values.
3124 (CONFIG_CFLAGS): Add same.
3125
3126Mon Sep 22 17:20:27 1997 Felix Lee <flee@cygnus.com>
3127
3128 * sim-types.h (SIGNED64): ##i64 when _MSC_VER, not _WIN32.
3129 (SIGNED32): use ##i32.
3130
3131Tue Sep 23 11:04:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
3132
3133 * configure: Regenerated to track ../common/aclocal.m4 changes.
3134
3135Tue Sep 23 10:07:47 1997 Andrew Cagney <cagney@b1.cygnus.com>
3136
3137 * aclocal.m4 (sim-endian): Simplify logic determining [default]
3138 endian of target.
3139
3140 * Make-common.in (SIM_WARNINGS, SIM_ALIGNMENT, SIM_ENDIAN,
3141 SIM_HOSTENDIAN, SIM_RESERVED_BITS, SIM_ASSERT, SIM_FLOAT,
3142 SIM_HARDWARE, SIM_INLINE, SIM_PACKAGES, SIM_REGPARM, SIM_SMP,
3143 SIM_STDCALL, SIM_XOR_ENDIAN): Assign configured values.
3144 (CONFIG_CFLAGS): Add same.
3145
3146 * aclocal.m4: Perform AC_SUBST on optional options.
3147
3148Mon Sep 22 11:46:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
3149
3150 * sim-config.h (WITH_DEFAULT_ALIGNMENT): Don't hardwire any alignment.
3151
3152 * sim-options.c (standard_option_handler): Typo in warning message.
3153
3154 * sim-base.h (STATE_MODEL): Make conditional on SIM_HAVE_MODEL.
3155
3156 * sim-profile.c (profile_print_insn): Check 0 .. MAX_INSN for any
3157 insn count. Make count conditional on there being a valid
3158 INSN_NAME.
3159 (profile_pc_init): Make default PC profile frequency an arbitrary
3160 256.
3161
3162 * sim-base.h: Ditto.
3163
3164 * sim-profile.h (WITH_PROFILE_MODEL_P): Only enable modeling when
3165 SIM_HAVE_MODEL.
3166
3167 * sim-model.h (struct MACH): Depreciate, to be replaced by bfd
3168 archure struct.
3169
3170Mon Sep 22 11:46:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
3171
3172 * configure: Regenerated to track ../common/aclocal.m4 changes.
3173
3174Mon Sep 22 11:45:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
3175
3176 * aclocal.m4 (sim_alignment): Simplify logic for selecting the
3177 configured alignment.
3178
3179Fri Sep 19 17:45:25 1997 Andrew Cagney <cagney@b1.cygnus.com>
3180
3181 * configure: Regenerated to track ../common/aclocal.m4 changes.
3182
3183Fri Sep 19 17:26:14 1997 Andrew Cagney <cagney@b1.cygnus.com>
3184
3185 * sim-config.c (sim_config): Check for default alignment.
3186
3187 * sim-options.c (standard_option_handler): Add alignment option.
3188
3189 * aclocal.m4 (sim_alignment): Allow configuration of hardwired and
3190 default alignment requirements on memory accesses.
3191
3192Fri Sep 19 11:51:35 1997 Jeffrey A Law (law@cygnus.com)
3193
3194 * sim-load.c (sim_load_file): Return failure if the executable
3195 had no loadable sections.
3196
3197Wed Sep 17 13:33:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
3198
3199 * sim-events.c (ETRACE): Use trace_printf not sim_io_printf for
3200 trace output.
3201
3202 * sim-core.c (sim_core_signal): When bad access halt simulator
3203 SIGSEGV / SIGBUS instead of aborting.
3204 (signal.h): Include.
3205
3206 * sim-watch.c (sim_watchpoint_install): Handler for watchpoint
3207 options was missing.
3208
3209 * sim-bits.h (MOVED): Define
3210
3211Wed Sep 17 10:33:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
3212
3213 * sim-alu.h (ALU32_HAD_OVERFLOW): Pacify GCC, Use MSBIT instead of
3214 BIT.
3215
3216 * sim-bits.h (LSBIT, MSBIT): Check for overflow of shift value.
3217
3218 * sim-bits.c: Add 8 bit versions of bit macros.
3219
3220 * sim-bits.h: Ditto.
3221
3222Tue Sep 16 16:15:16 1997 Andrew Cagney <cagney@b1.cygnus.com>
3223
3224 * sim-bits.c (LSSEXT, MSSEXT): Replace SEXT.
3225 (LSINSERTED, MSINSERTED): Ditto for INSERTED.
3226
3227 * sim-n-bits.h (MSSEXTn, LSSEXTn): Replace SEXTn.
3228 (LSINSERTDn, MSINSERTEDN): Ditto for INSERTEDn.
3229
3230 * sim-bits.h (SEXT*): Define as MSEXT/LSEXT.
3231 (INSERTED*): Ditto for LSINSERTED/MSINSERTED.
3232
3233Mon Sep 15 17:36:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
3234
3235 * aclocal.m4 (SIM_AC_COMMON): Add optional config.h file argument.
3236 configure.in: Output to cconfig.h instead of config.h.
3237
3238 * configure: Regenerated to track ../common/aclocal.m4 changes.
3239
3240Mon Sep 15 15:39:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
3241
3242 * sim-utils.c (sim_analyze_program): Set STATE_ARCHITECTURE from
3243 BFD if known.
3244
3245Tue Sep 9 21:46:46 1997 Felix Lee <flee@cygnus.com>
3246
3247 * callback.c (os_write): divert stdout and stderr to their
3248 respective hooks.
3249
3250Thu Sep 11 10:08:48 1997 Andrew Cagney <cagney@b1.cygnus.com>
3251
3252 * sim-profile.c (profile_print_speed): Call
3253 sim_events_elapsed_time instead of PROFILE_EXEC_TIME for moment.
3254
3255 * sim-events.c (sim_events_elapsed_time): New function return nr
3256 host MS consumed by the simulator.
3257 (sim_watch_valid): Use.
3258
3259 * sim-module.c (modules): Install sim_events very very early.
3260
3261 * sim-profile.c (profile_print): Call profile_print_pc.
3262 (print_bar):
3263 (profile_pc_init): New function, set up processor for PC
3264 profiling.
3265 (profile_print_pc): New function, print a PC profile.
3266 (profile_pc_event): New function, sample PC.
3267
3268 * sim-profile.h (PROFILE_PC_COUNT, PROFILE_PC_START,
3269 PROFILE_PC_END, PROFILE_PC_SHIFT, PROFILE_PC_SAMPLE_SIZE): Add to
3270 profile struct.
3271
3272 * sim-options.c (sim_print_help): Pacify GCC.
3273
3274 * sim-n-core.h (sim_core_read_aligned_N,
3275 sim_core_write_aligned_N): Add un-conditional profile call.
3276 (sim_core_read_unaligned_N, sim_core_write_unaligned_N): Add
3277 profile call when aligned read/write isn't used.
3278
3279 * sim-base.h: Include sim-profile, sim-model after sim-core &
3280 sim-events allow sim-core to define useful values.
3281
3282 * sim-profile.c (OPTION_PROFILE_CORE): Define.
3283 (profile_option_handler, profile_options): Add support for
3284 --profile-core option.
3285 (print_bar): Include when core profiling.
3286 (profile_print_core): New function, print core profile.
3287
3288 * sim-config.c (print_sim_config): Print profile status.
3289
3290 * sim-profile.h (PROFILE_NEXT_IDX, PROFILE_core,
3291 WITH_PROFILE_PC_P): Define.
3292 (PROFILE_CORE_COUNT): Count each core-map/size separatly.
3293 (PROFILE_COUNT_CORE): Define.
3294
3295Thu Sep 11 08:44:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
3296
3297 * sim-watch.c (handle_watchpoint): Pass a char** index into the
3298 interrupt_names array as the data.
3299 (sim-watch.h): Document.
3300
3301Wed Sep 10 16:15:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
3302
3303 * sim-options.c (sim_print_help): When the doc string is to long
3304 word wrap it.
3305
3306 * sim-watch.c (sim_watchpoint_install): Use option.doc_name so
3307 that only the first few the watch options are listed. Generate
3308 meanginful usage messages.
3309
3310 * sim-options.h (struct OPTION): Clarify use of doc_name field
3311
3312Wed Sep 10 13:23:24 1997 Andrew Cagney <cagney@b1.cygnus.com>
3313
3314 * sim-options.c (OPTION_ARCHITECTURE_INFO): New option.
3315 (standard_option_handler): Handle --architecture-info.
3316
3317Tue Sep 9 21:46:46 1997 Felix Lee <flee@cygnus.com>
3318
3319 * sim-core.h (sim_cpu_core): [WITH_XOR_ENDIAN + 1], to avoid
3320 illegal zero-sized array.
3321 * sim-core.c (sim_core_xor_read_buffer): same.
3322
3323Tue Sep 9 11:20:35 1997 Doug Evans <dje@canuck.cygnus.com>
3324
3325 * nltvals.def: Regenerate.
3326
3327Tue Sep 9 02:10:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
3328
3329 * sim-fpu.c (DP_FRACHIGH2): Define LL using SIGNED64.
3330
3331Mon Sep 8 12:22:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
3332
3333 * sim-bits.c (MASKED): Delete.
3334 (EXTRACTED): Delete.
3335 (LSEXTRACTED, MSEXTRACTED): New functions.
3336
3337 * sim-n-bits.h (MASKEDn): Delete, define as MSMASKED or LSMASKED.
3338 (MSMASKEDn, LSMASKEDn): Add last argument.
3339 (MSMASK*): Ditto.
3340
3341 * sim-bits.h (EXTEND8, EXTEND16): Define.
3342 (EXTRACTED64): Define as 64 bit extract, not 32 bit.
3343
3344 * sim-run.c (sim_engine_run): Use CPU_CIA macro.
3345
3346 * sim-engine.h (SIM_ENGINE_HALT_HOOK): Use CPU_CIA to get at
3347 current instruction address.
3348
3349 * sim-inline.h (*_ENGINE): Define.
3350
3351Fri Sep 5 08:39:02 1997 Andrew Cagney <cagney@b1.cygnus.com>
3352
3353 * sim-core.c (sim_core_attach): Fix checks of modulo/mask.
3354
3355 * sim-watch.c (delete_watchpoint): Delete by ident and type.
3356 (watch_option_handler): Call delete_watchpoint with ident or type.
3357 (sim_watchpoint_install): Create interrupt specific watchpoint
3358 commands on the fly.
3359 (do_watchpoint_create): New function, create a watch point using
3360 type/int-nr info encoded in the option nr.
3361 (do_watchpoint_info): New function. List active watchpoints.
3362
3363 * sim-watch.h: Change data structure to a list.
3364
3365 * sim-memopt.c (memory_option_handler): Require explicit "all"
3366 before deleting all memory regions.
3367
3368 * sim-utils.c (sim_do_commandf): New function, printf version of
3369 sim_do_command.
3370
3371 * sim-basics.h (asprintf, vasprintf): Hack, define for CYGWIN32.
3372
3373 * sim-alu.h (ALU64_ADD): Use explicit MSEXTRACTED64, do not assume
3374 bit endianness.
3375 (SIGNED64, UNSIGNED64): Delete.
3376 (ALU64_ADD): Don't rely on bit endianness.
3377 (ALU64_BEGIN): Define.
3378
3379 * sim-n-bits.h (MSEXTRACTEDn, LSEXTRACTED): New functions.
3380 (EXTRACTEDn): Delete, define as either LSEXTRACTED or MSEXTRACTED.
3381
3382 * sim-types.h (SIGNED64, UNSIGNED64): New macros, attach relevant
3383 suffix - u64, LL - to 64 bit constants.
3384
3385Thu Sep 4 09:27:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
3386
3387 * sim-config.c (sim_config): Add assert for SIM_MAGIC_NUMBER.
3388
3389 * sim-utils.h (NZALLOC): Define - zalloc * N.
3390
3391 * sim-hrw.c (sim_read, sim_write): New file. Provide generic
3392 implementation of read/write functions.
3393
3394 * Make-common.in (sim-hrw.o): New target.
3395
3396 * sim-base.h (STATE_MEMOPT_P): Delete, simulators _always_ add
3397 memory.
3398
3399 * sim-memopt.c (memory_option_handler): Implement memory-size
3400 command. Implement memory-alias command. Let memory-delete delete
3401 all memory regions.
3402 (add_memopt): New function. Add a memory region.
3403 (do_memopt_delete): New function. Delete a memory region.
3404
3405 * sim-utils.c (sim_elapsed_time_get): Never return zero.
3406
3407 * sim-core.c (sim_core_detach): New function.
3408 (sim_core_map_detach): New function. Perform the actual detach.
3409 (sim_core_init): Move initialization code from here.
3410 (sim_core_install): To here.
3411 (sim_core_uninstall): And here.
3412
3413 * sim-module.c: Add memopt module.
3414
3415 * sim-base.h (STATE_MEMOPT, STATE_MEMOPT_P): Add memopt to
3416 simulator base type.
3417
3418 * Make-common.in (sim_main_headers): Add sim-memopt.h
3419 (sim-memopt.o): New target.
3420
3421 * sim-core.c (sim_core_install): Add core_options to the option
3422 table.
3423
3424 * sim-watch.c (watch_options): Make --delete-watch a synonym for
3425 --watch-delete.
3426
3427 * sim-config.h (WITH_MODULO_MEMORY): Define as 0. Update
3428 comments.
3429
3430 * sim-core.h (struct _sim_core_mapping): Change nr_bytes to type
3431 address_word, add mask member.
3432
3433 * sim-core.h, sim-core.c (sim_core_attach): Make nr_bytes of type
3434 address_word, allow for 64bit targets in 32bit host. Add modulo
3435 argument.
3436 (sim_core_map_attach): Ditto.
3437 (new_sim_core_mapping): Ditto.
3438 (sim_core_translate): Mask address when modulo memory.
3439
3440Wed Sep 3 17:32:54 1997 Doug Evans <dje@seba.cygnus.com>
3441
3442 * sim-hload.c (sim_load): Add assert for SIM_MAGIC_NUMBER.
3443
3444 * gdbinit.in: New file.
3445 * aclocal.m4 (SIM_AC_OUTPUT): Build .gdbinit.
3446 * Make-common.in (distclean): Delete .gdbinit.
3447 (.gdbinit): Add rule for.
3448 * configure: Regenerated to track ../common/aclocal.m4 changes.
3449
3450 * Make-common.in (cgen-run.o): Add rule for.
3451
3452Wed Sep 3 10:08:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
3453
3454 * sim-resume.c (sim_resume): Suspend/resume the simulator.
3455
3456 * sim-events.c (sim_watch_valid): Compute total elapsed time from
3457 both resumed and previous elapsed time.
3458 (sim_events_init): Set initial_wallclock and current_wallclock to
3459 zero.
3460 (sim_events_install): Install sim_events_suspend and
3461 sim_events_resume.
3462 (sim_events_watch_clock): Allow for suspended simulator when
3463 computing the time of the clock event.
3464
3465 * sim-events.h (struct _sim_event): Add resume_wallclock, rename
3466 initial_wallclock to elapsed_wallclock, set both to zero.
3467 (sim_events_init, sim_events_uninstall): Delete prototypes.
3468
3469 * sim-module.h (MODULE_SUSPEND_FN, MODULE_RESUME_FN): Define types.
3470
3471 * sim-module.c(sim_module_resume, sim_module_suspend): New
3472 functions.
3473
3474Wed Sep 3 10:08:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
3475
3476 * sim-core.c (sim_core_map_attach): Clarify memory overlap error
3477 message.
3478
3479Tue Sep 2 14:57:06 1997 Doug Evans <dje@canuck.cygnus.com>
3480
3481 * Makefile.in (TAGS): Add support for "/* TAGS: foo */" marker.
3482 * Make-common.in (TAGS): Likewise.
3483 * sim-n-bits.h: Add TAGS comments for all functions.
3484 * sim-n-core.h: Likewise.
3485 * sim-n-endian.h: Likewise.
3486
3487Mon Sep 1 10:50:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
3488
3489 * sim-utils.c (sim_state_alloc): Set CPU backlinks, callback and
3490 kind.
3491
3492 * sim-base.h (sim_state_alloc): Add callback and kind arguments.
3493
3494 * sim-base.h (INVALID_INSTRUCTION_ADDRESS): Add default
3495 definition.
3496
3497Sat Aug 30 09:47:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
3498
3499 * sim-fpu.c (DP_GARDMSB, ...): Make unsigned.
3500 (DP_FRACHIGH, DP_FRACHIGH2, ..): Use MSMASK to avoid LL.
3501
3502Fri Aug 29 13:37:44 1997 Andrew Cagney <cagney@b1.cygnus.com>
3503
3504 * sim-core.c (sim_core_map_attach): Cast attach enum to int.
3505 (sim_core_xor_read_buffer, sim_core_xor_write_buffer): Make
3506 nr_transfered and nr_this_transfer unsigned.
3507
3508 * sim-events.c (sim_events_tickn): N is signed, as limited to
3509 MAXINT.
3510
3511 * sim-n-endian.h (offset_N): Change size to unsigned.
3512
3513 * callback.c (os_poll_quit): Add prototypes for kbhit and getkey.
3514
3515Fri Aug 29 10:10:53 1997 Andrew Cagney <cagney@b1.cygnus.com>
3516
3517 * sim-utils.c (sim_copy_argv): Delete, replaced by dupargv.
3518
3519 * sim-options.c (sim_parse_args): Use dupargv.
3520
3521Thu Aug 28 10:36:34 1997 Doug Evans <dje@canuck.cygnus.com>
3522
3523 * sim-options.c (standard_option_handler): Use xstrdup, not strdup.
3524
3525Thu Aug 28 12:09:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
3526
3527 * sim-base.h (STATE_ARCHITECTURE, STATE_TARGET): Add to simulator
3528 base type.
3529
3530 * sim-options.c (standard_options): Add --architecture=MACHINE and
3531 --target=TARGET options.
3532 (OPTION_ARCHITECTURE, OPTION_TARGET): Define.
3533 (standard_option_handler): Handle architecture and target options.
3534 (bfd.h): Include.
3535
3536 * sim-utils.c (sim_analyze_program): Pass STATE_TARGET to
3537 bfd_openr.
3538 (sim_analyze_program): Set prog_bfd architecture from
3539 STATE_ARCHITECTURE if known.
3540
3541Wed Aug 27 18:13:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
3542
3543 * configure: Regenerated to track ../common/aclocal.m4 changes.
3544 * config.in: Ditto.
3545
3546Wed Aug 27 18:11:30 1997 Andrew Cagney <cagney@b1.cygnus.com>
3547
3548 * aclocal.m4 (enable-sim-warnings): Remove comment stating
3549 that option does not apply to certain files.
3550
3551Wed Aug 27 15:13:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
3552
3553 * sim-bits.h (LSBIT8, LSBIT16, LSBIT32, LSBIT64, LSBIT, MSBIT8,
3554 MSBIT16, MSBIT32, MSBIT64, MSBIT): New macros - single bit as
3555 offset from MSB/LSB.
3556
3557 * sim-endian.h (A1_8, A2_8, A4_8, A1_4, A2_4, A1_2): New macro,
3558 access address of sub word quantity of a hosts 16, 32, 64 bit word
3559 type.
3560 (V1_2, V1_4, V2_4, V1_8, V2_8, V4_8): Ditto for values.
3561 (U8_1, U8_2, U8_4, U4_1, U4_2, U2_1): Ditto for set of values.
3562 (V2_H1, V2_L1, V4_H2, V4_L2, V8_L4, V8_H4): Given N byte argument,
3563 return N*2 byte value with argument in Hi/Lo word. Renamed from
3564 V1_H2, V1_L2, V2_H4, V2_L4, V4_H8, V4_L8.
3565
3566 * sim-alu.h (ALU32_HAD_OVERFLOW): Use 64 bit mask not 32bit.
3567 (ALU16_HAD_CARRY, ALU32_HAD_CARRY, ALU16_HAD_OVERFLOW): Use MSBIT
3568 so that bit offset is explicit.
3569
3570Wed Aug 27 11:55:35 1997 Andrew Cagney <cagney@b1.cygnus.com>
3571
3572 * sim-utils.c (sim_analyze_program): Add prog_name argument.
3573 Update STATE_PROG_BFD when needed with a dup'd copy of the
3574 program.
3575
3576 * sim-config.c (sim_config): Delete ABFD argument, use
3577 STATE_PROG_BFD directly.
3578
3579Tue Aug 26 12:55:26 1997 Andrew Cagney <cagney@b1.cygnus.com>
3580
3581 * run.c (main): Pass the open ABFD to sim_create_inferior.
3582
3583 * nrun.c (main): Determine prog_bfd. Pass to sim_create_inferior
3584 and sim_load.
3585 (bfd.h): Include.
3586
3587 * sim-hload.c (sim_load): New file. Implement generic sim_load for
3588 hardware only simulator targets.
3589
3590 * Make-common.in (sim-hload.o): Add rule.
3591
3592Wed Aug 27 09:51:42 1997 Andrew Cagney <cagney@b1.cygnus.com>
3593
3594 * sim-utils.c (sim_copy_argv): Rewrite to match malloc strategy
3595 used by copyargv and freeargv.
3596
3597 * sim-options.c (sim_parse_args): Save a copy of PROG-ARGS in
3598 STATE_PROG_ARGV, not just a pointer.
3599
3600Mon Aug 25 17:50:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
3601
3602 * configure: Regenerated to track ../common/aclocal.m4 changes.
3603 * config.in: Ditto.
3604
3605Mon Aug 25 12:11:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
3606
3607 * aclocal.m4 (sim-endian): Add second argument to
3608 SIM_AC_OPTION_ENDIAN. First is hardwired endian, second is
3609 default endian when not hardwired.
3610
3611 * sim-config.h (WITH_DEFAULT_TARGET_BYTE_ORDER): New macro, if all
3612 else failes value for target byte order.
3613
3614 * sim-config.c (sim_config): Add abfd arguments. Set
3615 STATE_PROG_BFD accordingly. Determine prefered_target_byte_order
3616 from same.
3617 (sim_config): Return SIM_RC, don't abort.
3618 (bfd.h): Include.
3619
3620 * run.c (main): Update call to sim_open - add ABFD argument.
3621 * nrun.c (main): Add NULL ABFD argument.
3622
3623Thu Aug 14 12:48:57 1997 Doug Evans <dje@canuck.cygnus.com>
3624
3625 * callback.c (os_poll_quit): Make static.
3626 Call sim_cb_eprintf, not p->eprintf.
3627 (sim_cb_printf, sim_cb_eprintf): New functions.
3628 * sim-utils.h (sim_cb_printf, sim_cb_eprintf): Declare.
3629
3630 * sim-basics.h (zalloc,zfree,sim_add_commas,SIM_ELAPSED_TIME,
3631 sim_elapsed_time_get,sim_elapsed_time_since): Move decls to
3632 sim-utils.h. #include sim-utils.h.
3633 * sim-utils.h: Above decls moved here.
3634 (sim_analyze_program,sim_load_file): Use `struct _bfd', not `bfd'.
3635
3636 * sim-watch.c (action_watchpoint): Fix thinkos.
3637
3638Thu Jul 24 08:48:05 1997 Stu Grossman (grossman@critters.cygnus.com)
3639
3640 * sim-types.h: Fix defs of 64 bit data types for MSVC.
3641
3642Tue Jul 22 10:35:37 1997 Doug Evans <dje@canuck.cygnus.com>
3643
3644 * sim-n-core.h (sim_core_write_unaligned_N): Add missing break
3645 to FORCED_ALIGNMENT case.
3646
3647Thu Jun 5 13:48:37 1997 Andrew Cagney <cagney@b1.cygnus.com>
3648
3649 * callback.c (target_to_host_open): Handle hosts with O_BINARY.
3650
3651Thu Jun 5 08:47:10 1997 Jeffrey A Law (law@cygnus.com)
3652
3653 * Make-common.in (libsim.a): Fix typo.
3654
3655Thu Jun 5 13:48:37 1997 Andrew Cagney <cagney@b1.cygnus.com>
3656
3657 * nrun.c (main): Verify the structure returned before using it.
3658
3659Wed Jun 4 11:44:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
3660
3661 * sim-config.h (WITH_ENGINE): Enable the sim-engine module by
3662 default.
3663
3664 * sim-engine.c (sim_engine_install): New function. Install the
3665 engine init functions.
3666 (sim_engine_init): [Re]initialize the simulator engine.
3667
3668 * sim-module.c: Add sim_engine to list of modules that always
3669 install.
3670
3671Tue Jun 3 04:52:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
3672
3673 * sim-watch.c (schedule_watchpoint): Use sim_unschedule_watchpoint
3674 to remove the old watchpoint, not delete_watchpoint.
3675 (watch_option_handler): Action the correct watchpoint, not just
3676 cycles.
3677
3678Wed May 28 14:47:41 1997 Andrew Cagney <cagney@b1.cygnus.com>
3679
3680 * sim-n-core.h (sim_core_write_aligned_N): For 8byte reads, output
3681 both low and high word.
3682 (sim_core_write_aligned_N): Ditto.
3683
3684 * sim-trace.c (set_trace_options): Delete code explicitly setting
3685 core->trace.
3686
3687 * sim-options.c (sim_print_help): Call the list commands if not a
3688 standalone simulator.
3689 (sim_print_help): Advise that some options may not be applicable.
3690
3691 * sim-trace.c (set_trace_options): Assume core present.
3692
3693 * sim-events.c (sim_events_schedule_after_signal): Overflow signal
3694 buffer when full not almost full.
3695
3696Tue May 27 14:32:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
3697
3698 * sim-events.c (sim_events_process): Don't blat the event queue
3699 when processing watchpoints.
3700
3701 * sim-watch.h: Make arg unsigned long - stop sign extension.
3702
3703 * sim-events.c (sim_watch_valid): rewrite so debugable.
3704
3705 * sim-config.h (WITH_XOR_ENDIAN): Default to zero.
3706
3707 * sim-watch.c (schedule_watchpoint): Add is_within option so that
3708 inequality test is possible.
3709 (handle_watchpoint): Re-pass is_within arg.
3710 (watch_option_handler): When `!' prefix to pc-watchpoint arg pass
3711 0 to schedule_watchpoint's is_within arg.
3712 (sim_watchpoint_init): Re-pass is_within arg.
3713
3714 * sim-options.c (sim_print_help): Add is_command argument. Don't
3715 include -- prefix when called from the command line interpreter.
3716
3717 * sim-watch.c (schedule_watchpoint): Pass true is_within argument.
3718
3719 * sim-events.c (sim_events_watch_sim): Add is_within argument,
3720 zero indicates that the test should be reversed.
3721 (sim_events_watch_core): Ditto.
3722 (WATCH_CORE): Compare range against is_within.
3723 (WATCH_SIM): Ditto.
3724
3725Tue May 27 12:48:03 1997 Andrew Cagney <cagney@b2.cygnus.com>
3726
3727 * sim-events.c (WATCH_CORE): Pass NULL cpu argument to
3728 sim_core_read_buffer. Check nr-bytes transfered.
3729
3730 * sim-core.h (sim_core_common): Define a new struct that contains
3731 the common data. to sd and cpu structures.
3732 * sim-core.c (sim_core_attach): Update.
3733 (sim_core_init): Update. Remember to copy initialized data to each
3734 cpu.
3735 (sim_core_find_mapping): Ditto.
3736
3737 * sim-core.c (sim_core_read_buffer): Add cpu argument.
3738 (sim_core_write_buffer): Ditto.
3739
3740 * sim-n-core.h (sim_core_read_unaligned_N): When mis-aligned
3741 transfer use xor version of read buffer.
3742 (sim_core_write_unaligned_N): Ditto for write.
3743
3744 * sim-core.c (sim_core_xor_read_buffer): New function implement
3745 xor-endian data read breaking transfer up into xor-endian sized
3746 blocks.
3747 (sim_core_xor_write_buffer): Ditto for write.
3748 (reverse_n): Reverse order of arbitrary number of bytes in buffer
3749 - needed for xor-endian transfers.
3750
3751Fri May 23 14:24:31 1997 Andrew Cagney <cagney@b1.cygnus.com>
3752
3753 * sim-inline.h: Review description.
3754
3755 * sim-core.h, sim-core.c: Reduce number of functions being inlined
3756 to just those involved in data transfers and configuration.
3757
3758 * sim-xcat.h (XSTRING): New macro, map macro definition onto
3759 string.
3760 * sim-n-core.h (sim_core_read_aligned_N): Use.
3761 (sim_core_read_unaligned_N): Ditto.
3762 (sim_core_read_unaligned_N): Ditto..
3763 (sim_core_write_unaligned_N): Ditto.
3764
3765 * sim-core.h: Add xor endian bitmap to main structure. *
3766
3767 sim-n-core.h (sim_core_write_aligned_N): Add suport for xor
3768 endian.
3769 (sim_core_read_aligned_N): Ditto.
3770
3771 * sim-core.c (sim_core_set_xor_endian): New function.
3772 (sim_core_attach): Don't overwrite the per-cpu xor map when
3773 cloning the global core.
3774
3775Fri May 23 10:53:13 1997 Andrew Cagney <cagney@b1.cygnus.com>
3776
3777 * sim-engine.h: Update below so that it is using an enumerated
3778 type.
3779
3780Thu May 22 09:12:16 1997 Gavin Koch <gavin@cygnus.com>
3781
3782 * sim-engine.c (sim_engine_restart):
3783 * sim-resume.c (sim_resume): Change longjmp param/setjmp
3784 return value used for simulator restart from 0 to 2.
3785
3786Wed May 21 08:47:30 1997 Andrew Cagney <cagney@b1.cygnus.com>
3787
3788 * cgen-scache.c (scache_option_handler): Add is_command arg.
3789
3790 * sim-model.c (model_option_handler): Add is_command argument.
3791
3792 * sim-profile.c (profile_option_handler): Add is_command arg.
3793
3794 * sim-events.c (sim_watch_valid): Use ub64, lb64 when 64bit value
3795 involved.
3796
3797 * sim-module.c (sim_module_add_init_fn): Call init fn in the same
3798 order that they are registered.
3799
3800 * sim-options.h (OPTION_HANDLER): Add argument to differentiate
3801 between option and command line processing.
3802
3803 * sim-options.c: Include stdlib.h, ctype.h.
3804
3805 * Make-common.in (sim-watch.o): Add rule.
3806 (sim_main_headers): Assume sim-assert.h included.
3807 (sim-*.o): Simplify make rule.
3808
3809 * sim-module.c: Add sim_watch_install to module list.
3810
3811Tue May 20 14:15:23 1997 Andrew Cagney <cagney@b1.cygnus.com>
3812
3813 * sim-base.h (STATE_LOADED_P): New predicate. Set once everything
3814 has been loaded.
3815
3816 * sim-trace.c (trace_install): Check magic. Include sim-assert.h.
3817 * sim-events.c (sim_events_install): Ditto.
3818 * sim-core.c (sim_core_install): Ditto.
3819 * sim-model.c (model_install): Ditto.
3820 * sim-options.c (standard_install): Ditto.
3821 * sim-profile.c (profile_install): Ditto.
3822 * sim-reason.c (sim_stop_reason): Ditto.
3823 * sim-run.c (sim_engine_run): Ditto.
3824 * sim-utils.c (sim_analyze_program): Ditto.
3825
3826 * sim-module.c (modules): Make profile_install and trace_install
3827 optional.
3828
3829 * sim-base.h (STATE_MEM_BASE): Define for flat memory systems.
3830
3831 * sim-options.c (standard_option_handler): Set the byte order.
3832
3833 * sim-events.c (sim_events_process): Allow multi tick processing.
3834 (sim_events_tickn): New function - multi cycle tick.
3835
3836 * sim-events.h (sim_events_tickn, sim_events_timewarp): Add
3837 prototypes. Under development.
3838 (sim_events): Replace processing with nr_ticks_to_process.
3839
3840Tue May 20 09:39:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
3841
3842 * nrun.c (main): Pass callbacks to sim_open instead of using
3843 sim_set_callbacks.
3844
3845 * run.c (main): Ditto.
3846
3847Mon May 19 12:07:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
3848
3849 * sim-events.c (sim_events_zalloc): Signal save memory allocator -
3850 stop tk interrupting malloc calls.
3851 (sim_events_zalloc): Converse.
3852
3853 * Make-common.in (sim_main_headers): Add sim-events.h.
3854
3855 * sim-events.c (sim_events_schedule_after_signal): Change return
3856 type to void - signal events are strictly internal.
3857 (sim_events_init): Allocate a finite buffer for signal events.
3858 (sim_events_schedule_after_signal): Enter signal events into the
3859 signal buffer.
3860
3861 * sim-engine.c (sim_engine_halt): Check SIM_DESC magic.
3862 (sim_engine_restart): Ditto.
3863 (sim_engine_abort): Ditto.
3864 * sim-stop.c (sim_stop): Ditto.
3865 (control_c_simulation): Ditto.
3866 * sim-resume.c (sim_resume): Ditto.
3867 (has_stepped): Ditto.
3868 * sim-abort.c (sim_engine_abort): Ditto.
3869
3870 * sim-basics.h (transfer_type): New type.
3871
3872 * sim-core.c (sim_core_signal): New function. Print core signal
3873 information.
3874 (sim_core_find_mapping): Add transfer argument.
3875
3876 * sim-n-core.h (sim_core_{write,write}_unaligned_N): Call
3877 SIM_CORE_SIGNAL if a recoverable abort.
3878 * sim-core.c (sim_core_find_mapping): Ditto.
3879
3880Fri May 16 15:13:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
3881
3882 * sim-core.c (sim_core_find_mapping): Replace calls to
3883 sim_io_error to more resiliant sim_engine_abort.
3884
3885 * sim-n-core.h (sim_core_read_unaligned_N): Ditto.
3886 (sim_core_write_unaligned_N): Ditto.
3887
3888Tue May 13 13:50:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
3889
3890 * sim-module.c: Add sim_events_install to list.
3891
3892 * sim-events.c (sim_events_install, sim_events_uninstall): Clonse
3893 from sim_core_*.
3894 (sim_events_init): Now returns SIG_RC.
3895
3896 * sim-run.c: New file. Generic sim_engine_run.
3897 * sim-reason.c: New file. Generic sim_stop_reason.
3898 * sim-stop.c: New file. Generic sim_stop.
3899 * sim-resume.c: New file. Generic sim_resume.
3900
3901 * Make-common.in (sim-engine.o): Add rule.
3902 (sim-run.o, sim-reason.o, sim-stop.o, sim-resume.o): Ditto.
3903
3904 * sim-engine.h, sim-engine.c: New file. Provide generic
3905 implementation of sim_engine_halt, sim_engine_error. et.al.
3906
3907 * sim-base.h (sim_state_base): Add member halt.
3908 (sim-engine.h): Include.
3909
3910 * sim-events.h (sim_event_handler): Always pass SIM_DESC to event
3911 handlers.
3912 * sim-events.c (sim_events_poll): Update event handler.
3913
3914Tue May 13 09:57:49 1997 Andrew Cagney <cagney@b2.cygnus.com>
3915
3916 * sim-events.h, sim-events.c (sim_events_watch_clock): New
3917 function.
3918 (sim_events_watch_sim): New function.
3919 (sim_events_watch_core): New function.
3920 (sim_watch_valid): New function.
3921 (sim_events_preprocess): New function.
3922 (sim_events_process): Process the watchpoints as well as the timer
3923 queue.
3924 (sim_events_tick): Check WORK_PENDING instead of the hold queue.
3925 (sim_events_deschedule): Check all the queues when removing an
3926 event.
3927 (sim_events_init): Ditto for cleaning.
3928
3929Mon May 19 12:07:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
3930
3931 * sim-fpu.c (is_ufpu_number): Comment out - currently unused.
3932
3933Mon May 19 11:23:03 1997 Andrew Cagney <cagney@b1.cygnus.com>
3934
3935 * callback.c (os_open): Type of arg flags is int.
3936
3937Fri May 16 22:26:43 1997 Michael Meissner <meissner@cygnus.com>
3938
3939 * sim-fpu.c (sim_fpu_is_{eq,ne,lt,le,gt,ge}): Compare Infinities
3940 just like normal numbers as per IEEE rules.
3941
3942Wed May 14 21:20:38 1997 Bob Manson <manson@charmed.cygnus.com>
3943
3944 * callback.c (os_close): Mark the descriptor as being
3945 available if the close succeeded.
3946 (os_open): Pass 0644 as the mode of the file being created.
3947
3948Thu May 15 10:58:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
3949
3950 * sim-fpu.c (pack_fpu, unpack_fpu): New functions - decode a
3951 float.
3952
3953 * sim-inline.c (SIM_INLINE_C): Rename from _SIM_INLINE_C_.
3954 * sim-lnline.h: Update.
3955
3956 * sim-fpu.h, sim-fpu.c (sim_fpu_[iu]{32,64}to): New int2fp
3957 conversion functions.
3958 (sim_fpu_to{32,64}[iu]): New fp2int functions.
3959
3960 * sim-fpu.h, sim-fpu.c (sim_fpu_is_{lt,le,eq,ne,ge,gt}): New fp
3961 compare functions. Replacing.
3962 (sim_fpu_cmp): This. Delete.
3963
3964Mon May 12 14:49:05 1997 Andrew Cagney <cagney@b1.cygnus.com>
3965
3966 * sim-core.c (sim_core_find_mapping): Call engine_error not
3967 sim_io_error when possible.
3968
3969Mon May 12 08:55:07 1997 Andrew Cagney <cagney@b2.cygnus.com>
3970
3971 * sim-endian.h (V1_H2): Add macro's to insert a word into a
3972 high/low double word.
3973
3974 * sim-trace.h: Remove definition of attribute - defined in
3975 sim_basics.h.
3976
3977Mon May 12 08:55:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
3978
3979 * sim-options.h (struct OPTION): Add doc_opt as the documenting
3980 name of the option - or family of options.
3981
3982 * sim-options.c (sim_args_command): Match command `a-b c' with
3983 option `--a-b-c' from option table.
3984
3985Thu May 8 12:40:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
3986
3987 * sim-options.c (sim_print_help): For optional arguments, wrap
3988 them in [].
3989
3990 * sim-trace.c (set_trace_options): New function, handle optional
3991 argument and multiple assignment.
3992 (trace_option_handler): Update.
3993
3994 * sim-trace.c (trace_option_handler): Trace branch and not fpu
3995 when branch tracing selected.
3996
3997Wed May 7 15:19:58 1997 Andrew Cagney <cagney@b1.cygnus.com>
3998
3999 * sim-trace.c (trace_one_insn): Make a va-args function.
4000
4001 * sim-trace.c (trace_vprintf): New function, va-arg version of
4002 trace_printf.
4003
4004Tue May 6 16:38:16 1997 Doug Evans <dje@canuck.cygnus.com>
4005
4006 * sim-trace.c (trace_uninstall): Don't close a file twice.
4007 * sim-profile.c (profile_uninstall): Likewise.
4008
4009Tue May 6 06:14:01 1997 Mike Meissner <meissner@cygnus.com>
4010
4011 * sim-trace.c (toplevel): Include bfd.h.
4012 (trace_options): Note that --trace-linenum also turns on
4013 --trace-insn. Add --trace-{branch,semantics}.
4014 (trace_option_handler): If --trace-linenum, also turn on
4015 --trace-insn. Add --trace-branch support. If --trace-semantics,
4016 turn on ALU, FPU, branch, and memory tracing.
4017 (trace_one_insn): New function to trace an instruction. Support
4018 --trace-linenum.
4019 (OPTION_TRACE_*): Use an enum, rather than lots of defines.
4020
4021 * sim-trace.h (TRACE_{SEMANTICS,BRANCH}_IDX): Add new macros.
4022 (MAX_TRACE_VALUES): Use 32, not 12 by default.
4023 (TRACE_branch): Add new mask.
4024 (TRACE_*_P): Define all possible trace_p macros.
4025 (trace_one_insn): Declare function.
4026
4027Mon May 5 14:08:34 1997 Mike Meissner <meissner@cygnus.com>
4028
4029 * sim-trace.h (__attribute__): Define as nothing if not GNU C or
4030 GNU C doesn't support __attributes__.
4031 ({trace,debug}_printf): Add attribute's so -Wformat can check the
4032 format strings.
4033
4034Mon May 5 11:16:12 1997 Andrew Cagney <cagney@b1.cygnus.com>
4035
4036 * sim-config.h (FORCED_ALIGNMENT): New alignment option -
4037 addresses are masked forcing them to be correctly aligned.
4038 (WITH_ALIGNMENT): Make NONSTRICT_ALIGNMENT the default.
4039 * sim-config.c (config_alignment_to_a): Update.
4040
4041 * sim-core.h (sim_cpu_core): New data type contains cpu specific
4042 core data.
4043 * sim-base.h (CPU_CORE): Add cpu specific core data to cpu base
4044 type.
4045 * sim-core.c (sim_core_attach): Add CPU argument. Ready for
4046 processor specific core maps.
4047 (sim_core_map_attach): Copy the core map data to each of the
4048 processor specific core data structures.
4049 * sim-core.c (sim_core_find_mapping): Update.
4050
4051 * sim-n-core.h (sim_core_read_N, sim_core_write_N): Rename.
4052 (sim_core_write_aligned_N, sim_core_write_aligned_N): New names.
4053 (sim_core_write_unaligned_N, sim_core_write_unaligned_N): New
4054 alternatives that handle unaligned addresses.
4055 (sim_core_{read,write}_{,un}aligned_N): Drop SIM_DESC arg, replace
4056 with just CPU arg.
4057 * cgen-utils.c (sim_disassemble_insn): Update.
4058
4059Mon May 5 13:19:16 1997 Andrew Cagney <cagney@b1.cygnus.com>
4060
4061 * sim-trace.h (TRACE_FPU_IDX): Add Floating-point specific
4062 tracing.
4063
4064 * sim-fpu.h, sim-fpu.c: New files - prototype for generic target
4065 fpu support.
4066
4067 * sim-inline.h, sim-inline.c: Add support for SIM_FPU.
4068
4069Fri May 2 17:59:42 1997 Andrew Cagney <cagney@b1.cygnus.com>
4070
4071 * sim-core.c (sim_core_map_to_str): New function ascii equivalent
4072 to map type.
4073
4074 * sim-n-core.h (sim_core_read_N, sim_core_write_N): Use in trace
4075 statement.
4076
4077Fri May 2 17:28:02 1997 Andrew Cagney <cagney@b2.cygnus.com>
4078
4079 * cgen-trace.c: Prepend additional trace_printf argument.
4080
4081 * cgen-utils.c (sim_disassemble_insn): Add additional core
4082 arguments.
4083
4084Fri May 2 11:40:23 1997 Andrew Cagney <cagney@b1.cygnus.com>
4085
4086 * nrun.c (main): Catch/report errorenous simulator states.
4087
4088 * sim-module.c: #include "libiberty.h" so that xmalloc is defined.
4089 * sim-trace.c: #include string.h/strings.h so that memset is
4090 defined.
4091 * sim-utils.c: Ditto.
4092 * sim-profile.c: Ditto. And stdlib.h.
4093 (print_bar): Only define when used by instruction or memory profiler.
4094
4095 * sim-options.c (standard_option_handler): Make ul more local.
4096
4097 * sim-load.c (sim_load_file): Make the name constant.
4098 (sim_load_file): Passify gcc.
4099
4100 * sim-utils.h: New file, pre-declare utilites in corresponding .c
4101 file.
4102 * sim-utils.c, sim-load.c: Include sim-utils.h.
4103
4104 * sim-base.h (sim_cpu): Pre define here so available to all.
4105
4106 * sim-core.h (DECLARE_SIM_CORE_WRITE_N, DECLARE_SIM_CORE_READ_N):
4107 Restore the sim_cpu and instruction_address arguments so that full
4108 information is available to the abort function.
4109 * sim-core.c (sim_core_find_mapping, sim_core_write_buffer): Ditto.
4110 * sim-n-core.h (sim_core_write_N, sim_core_read_N): Update.
4111
4112 * sim-trace.h, sim-trace.c (trace_option_handler): Add interim
4113 tracing support for sim-events and sim-core.
4114 (trace_option_handler): Convert #if to if where possible so always
4115 compiled/checked by C compiler.
4116 * sim-n-core.h (sim_core_write_N, sim_core_read_N): Update.
4117
4118 * sim-base.h: Adjust comment documenting how to define the cpu
4119 structure.
4120 (sim_state_base): Add sim_core and sim_events to simulator base
4121 object.
4122
4123 * sim-trace.h, sim-trace.c (trace_printf): Add SIM_DESC argument.
4124 * sim-core.c (sim_core_init, sim_core_attach,
4125 sim_core_find_mapping): Update.
4126 * sim-events.c (ETRACE, sim_events_init, sim_events_time,
4127 update_time_from_event, insert_sim_event,
4128 sim_events_schedule_after_signal, sim_events_deschedule,
4129 sim_events_tick): Ditto.
4130
4131 * sim-basics.h (sim-module.h, sim-trace.h, sim-profile.h,
4132 sim-model.h): Move #includes from here.
4133 * sim-base.h: To here.
4134 (sim-core.h, sim-events.h, sim-io.h): Include also
4135
4136Wed Apr 30 15:37:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
4137
4138 * callback.c (default_callback): Missing initialisers.
4139
4140Thu May 1 10:40:47 1997 Doug Evans <dje@canuck.cygnus.com>
4141
4142 * sim-utils.c (sim_add_commas): New function.
4143 * sim-basics.h (sim_add_commas): Add prototype.
4144 * cgen-scache.c (scache_print_profile): Print commas in numbers.
4145 * sim-profile.c (COMMAS): New macro.
4146 (print_*): Use it to print commas in numbers.
4147
4148 * configure: Regenerated.
4149
4150 * cgen-sim.h (sim_signal_type): Add SIM_SIGINT.
4151 (cgen_state): New member run_fast_p.
4152 (cgen_init): Add prototype.
4153 (sim_disassemble_insn): New arg `cpu'.
4154 * cgen-trace.c (trace_insn): Update call to sim_disassemble_insn.
4155 * cgen-utils.c (cgen_init): New function.
4156 (sim_disassemble_insn): New arg `cpu'. Rewrite fetching of insn.
4157 * genmloop.sh: Call engine_halt if loop exits.
4158
4159 * Makefile.in (sim-options_h): Define.
4160 (sim-{module,options,trace,profile,utils}.o): Clean up dependencies.
4161 (sim-model.o): Add new rule.
4162 (cgen-{scache,trace,utils}.o): Add new rules.
4163 * aclocal.m4 (SIM_AC_OPTION_{SCACHE,DEFAULT_MODEL}): Add.
4164 * cgen-scache.c (scache_print_profile): Change `sd' arg to `cpu'.
4165 Indent output by 2 spaces.
4166 * cgen-scache.h (scache_print_profile): Update.
4167 * cgen-trace.c (trace_insn_fini): Indent output by 2 spaces.
4168 Use trace_printf, not fprintf.
4169 (trace_extract): Use trace_printf, not cgen_trace_printf.
4170 * genmloop.sh (!FAST case): Increment `insn_count'.
4171 * sim-base.h (sim_state_base): Only include scache_size if WITH_SCACHE.
4172 (sim_cpu_base): Rename member `sd' to `state' to be consistent with
4173 access macro's name.
4174 * sim-core.c (sim_core_init): Use EXTERN_SIM_CORE to define it.
4175 Change return type to SIM_RC.
4176 (sim_core_{install,uninstall}): New functions.
4177 * sim-core.h (sim_core_{install,uninstall}): Declare.
4178 (sim_core_init): Use EXTERN_SIM_CORE to define it.
4179 Change return type to SIM_RC.
4180 * sim-model.h (models,machs,model_install): Declare.
4181 * sim-module.c (modules): Add scache_install, model_install.
4182 (sim_post_argv_init): Set cpu->state backlinks.
4183 * sim-options.c (standard_options): Delete --simcache-size,--max-insns.
4184 (standard_option_handler): Likewise.
4185 * sim-profile.c (PROFILE_{HISTOGRAM,LABEL}_WIDTH): Move to
4186 sim-profile.h.
4187 (*): Assume ANSI C.
4188 (profile_options): Delete --profile-simcache.
4189 (profile_option_handler): Likewise.
4190 (profile_print_insn): Change `sd' arg to `cpu'. Indent output 2
4191 spaces.
4192 (profile_print_{memory,model}): Likewise.
4193 (profile_print_simcache): Delete.
4194 (profile_print_speed): New function.
4195 (profile_print): Rewrite.
4196 * sim-profile.h (PROFILE_scache): Renamed from PROFILE_simcache.
4197 (WITH_PROFILE_SCACHE_P): Renamed from WITH_PROFILE_SIMCACHE_P.
4198 (PROFILE_DATA): Delete members simcache_{hits,misses}.
4199 (PROFILE_COUNT_SIMCACHE_{HIT,MISS}): Delete.
4200 (PROFILE_{CALLBACK,CPU_CALLBACK}): New types.
4201 (profile_print): Update prototype.
4202
4203Wed Apr 30 11:34:14 1997 Doug Evans <dje@canuck.cygnus.com>
4204
4205 * cgen-scache.[ch], cgen-sim.h: New files.
4206 * cgen-trace.[ch], cgen-types.h, cgen-utils.c, genmloop.sh: New files.
4207 * sim-model.c: New file.
4208
4209 * Make-common.in (clean targets): Undo patch of Apr. 22.
4210
4211Fri Apr 25 15:28:32 1997 Mike Meissner <meissner@cygnus.com>
4212
4213 * sim-n-bits.h (signed): If we have a standard compiler, undef
4214 signed, so that signedN is defined correctly.
4215
4216Thu Apr 24 00:00:07 1997 Doug Evans <dje@canuck.cygnus.com>
4217
4218 * sim-module.h, sim-model.h, sim-profile.h: New files.
4219 * sim-module.c, sim-profile.c: New files.
4220 * Make-common.in (SIM_PROFILE): Define
4221 (CONFIG_CFLAGS): Add $(SIM_PROFILE).
4222 (sim_main_headers): Add sim-module.h, sim-model.h, sim-profile.h.
4223 (sim_module.o,sim-profile.o): Add rules for.
4224 * aclocal.m4 (--enable-sim-trace): Allow symbolic arguments.
4225 (--enable-sim-profile): Add.
4226 * configure: Regenerated.
4227 * sim-base.h (sim_state_base): New members init_list, uninstall_list,
4228 model. Move trace and profile support to sim-{trace,profile}.h.
4229 New members trace_data, profile_data.
4230 * sim-basics.h: #include sim-module.h, sim-model.h, sim-profile.h.
4231 * sim-config.h: Provide default definition of WITH_PROFILE.
4232 (WITH_TRACE): Change default to -1.
4233 (MAX_NR_PROCESSORS): Always define.
4234 * sim-options.c: Move trace and profile support to
4235 sim-{trace,profile}.h.
4236 (sim_pre_argv_init): Moved to sim-model.c.
4237 (standard_install): New function.
4238 * sim-options.h (sim_pre_argv_init): Move decl to sim-model.c.
4239 (standard_install): Declare.
4240 * sim-trace.c: Tracing option handling moved here from sim-options.c.
4241 (trace_install, trace_uninstall): New functions.
4242 (trace_printf): Update reference to TRACE_FILE.
4243 * sim-trace.h (TRACE_FOO_IDX): Moved here from sim-base.h.
4244 (TRACE_foo): Bit masks for symbolic arguments to --enable-sim-trace.
4245 (WITH_TRACE_FOO_P): Define.
4246 (trace_install): Declare.
4247 (TRACE_DATA): New struct.
4248
4249Wed Apr 23 17:23:15 1997 Doug Evans <dje@canuck.cygnus.com>
4250
4251 * run.c: Undo last exec_bfd patch.
4252 (main): Only pass -E ifdef SIM_HAVE_BIENDIAN.
4253
4254Wed Apr 23 17:54:27 1997 Mike Meissner <meissner@cygnus.com>
4255
4256 * run.c (exec_bfd): Add back in.
4257 (main): Set exec_bfd.
4258
4259Tue Apr 22 14:43:46 1997 Doug Evans <dje@canuck.cygnus.com>
4260
4261 * sim-load.c (sim_load_file): #include <stdio.h> for NULL.
4262
4263Wed Apr 23 02:55:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
4264
4265 * sim-events.c (insert_sim_event): Call sim_io_error instead of
4266 less well defined engine_error.
4267 * sim-core.c: Ditto.
4268
4269Tue Apr 22 08:48:16 1997 Stu Grossman (grossman@critters.cygnus.com)
4270
4271 * Make-common.in: Change clean targets to use :: so that other
4272 Makefiles can have their own clean targets.
4273 * sim-load.c (xprintf eprintf): Use ANSI_PROTOTYPES instead of
4274 __STDC__ to control use of stdarg vs. varargs syntax. Some
4275 systems can't use __STDC__, but require stdarg.
4276
4277Fri Apr 18 11:14:43 1997 Doug Evans <dje@canuck.cygnus.com>
4278
4279 * sim-options.c (standard_options): Add --endian.
4280 (standard_option_handler): Likewise.
4281
4282 * nrun.c: #include <signal.h>.
4283 (main, cntrl_c): Wrap calls to sim_resume in a SIGINT
4284 handler that calls sim_stop ().
4285
4286Fri Apr 18 13:11:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
4287
4288 * run.c (main, cntrl_c): Wrap calls to sim_resume in a SIGINT
4289 handler that calls sim_stop (). Simulators may still be
4290 establishing their own handler.
4291
4292 * sim-events.c (sim_events_poll): Rename from
4293 sim_events_at_large_int. Poll IO.
4294
4295 * sim-io.c (sim_io_poll_quit): New function - pass on a polling
4296 request.
4297
4298 * callback.c (os_poll_quit): New function poll for quit signal
4299 where needed.
4300 (default_callback): Include magic number.
4301
4302Thu Apr 17 02:25:11 1997 Doug Evans <dje@canuck.cygnus.com>
4303
4304 * aclocal.m4: Check for headers time.h, sys/time.h, sys/resource.h.
4305 Check for functions getrusage, time.
4306 * sim-basics.h (SIM_ELAPSED_TIME): New typedef.
4307 (sim_elapsed_time_get, sim_elapsed_time_since): Add prototypes.
4308 * sim-utils.c: #include time.h, sys/time.h, sys/resource.h if able.
4309 (sim_elapsed_time_get, sim_elapsed_time_since): New functions.
4310
4311 * sim-utils.c (sim_copy_argv, sim_analyze_program): New functions.
4312
4313 * sim-options.c, sim-options.h: New files.
4314 * sim-config.h (WITH_DEBUG): Provide default value of zero.
4315 * Make-common.in (nrun.o): Add rules for.
4316 * nrun.c: New file.
4317
4318 * run.c (main): Check return value of sim_open.
4319
4320 * Make-common.in (sim-options.o, sim-load.o, sim-trace.o): Add rules.
4321 (sim_main_headers): Add sim-trace.h.
4322 * run.c (exec_bfd, target_byte_order): Delete.
4323 (main): Pass -E <endian> to sim_open. Delete code to load sections,
4324 call sim_load instead. Check return code of sim_create_inferior.
4325 * sim-base.h (CURRENT_STATE): Define.
4326 (sim_state_base): Make typedef. New members options, prog_argv,
4327 prog_bfd, text_{section,start,end}, start_addr, simcache_size,
4328 mem_size, memory [+ corresponding access macros].
4329 (sim_cpu_base): New typedef.
4330 * sim-trace.h: New file.
4331 * sim-trace.c: New file.
4332 * sim-basics.h: #include it.
4333 * sim-load.c: New file.
4334
4335Tue Apr 15 15:10:13 1997 Ian Lance Taylor <ian@cygnus.com>
4336
4337 * Make-common.in (INSTALL): Set to @INSTALL@.
4338 (INSTALL_XFORM, INSTALL_XFORM1): Remove.
4339 (install-common): Depend upon installdirs. Use
4340 $(program_transform_name) directly, rather than using
4341 $(INSTALL_XFORM).
4342 (installdirs): New target.
4343 * Makefile.in (INSTALL): Set to @INSTALL@.
4344 (INSTALL_XFORM, INSTALL_XFORM1): Remove.
4345 (install-man): Depend upon installdirs. Use
4346 $(program_transform_name) directly, rather than using
4347 $(INSTALL_XFORM).
4348 (installdirs): New target.
4349
4350Tue Apr 15 15:08:12 1997 Andrew Cagney <cagney@b1.cygnus.com>
4351
4352 * sim-assert.h (SIM_ASSERT, ASSERT): Allow these macros to
4353 be overriden.
4354
4355Wed Apr 9 16:06:44 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4356
4357 * sim-basics.h: Only bring in config.h and tconfig.h if
4358 HAVE_CONFIG_H.
4359
4360Mon Apr 7 11:39:45 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4361
4362 * sim-config.h (WITH_TARGET_WORD_MSB): New Macro. Define the bit
4363 numbering convention of the target.
4364 * sim-config.c (print_sim_config): Print WITH_TARGET_WORD_BITSIZE
4365 and WITH_TARGET_WORD_MSB.
4366 (sim_config): When possible, check for consistency with bitsize
4367 and msb.
4368
4369 * sim-bits.h: Allow MSB to be other than zero.
4370 * sim-bits.c: Ditto.
4371 * sim-n-bits.h: Ditto.
4372
4373 * sim-bits.h (MSMASK*): New macros - converce to LSMASK*.
4374 * sim-n-bits.h (MSMASKEDn): Ditto.
4375
4376Mon Apr 14 16:29:21 1997 Ian Lance Taylor <ian@cygnus.com>
4377
4378 * Makefile.in (INSTALL): Change install.sh to install-sh.
4379
4380Mon Apr 7 10:46:38 1997 Doug Evans <dje@canuck.cygnus.com>
4381
4382 * sim-base.h (sim_state_base): Move `magic' to end of struct.
4383
4384Mon Apr 7 15:53:21 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4385
4386 * run.c (main): Check that a program to run was specified.
4387
4388Mon Apr 7 15:45:02 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4389
4390 * aclocal.m4 (AC_TYPE_SIGNAL): Add check.
4391
4392 * configure: Regenerated to track ../common/aclocal.m4 changes.
4393 * config.in: Ditto.
4394
4395Wed Apr 2 15:06:28 1997 Doug Evans <dje@canuck.cygnus.com>
4396
4397 * sim-endian.h: Move host {LITTLE,BIG}_ENDIAN support from here,
4398 * sim-config.h: To here.
4399
4400 * Make-common.in (SIM_EXTRA_DEPS): New config var.
4401 (sim_main_headers): Define.
4402 (sim-*.o): Depend on $(SIM_EXTRA_DEPS).
4403 (BUILT_SRC_FROM_COMMON): Move here from ../d30v/Makefile.in.
4404 (clean): Use it.
4405 (sim-utils.o): Add rule for.
4406 * sim-utils.o: New file.
4407 * sim-basics.h: #include sim-base.h.
4408 (zalloc): Make argument unsigned long.
4409 * sim-base.h: New file.
4410 * sim-inline.h (SIM_IO support): Delete.
4411 * sim-io.h: Delete inline support.
4412 * sim-io.c: Likewise. sim-state.h renamed to sim-main.h.
4413 * sim-config.c: sim-state.h renamed to sim-main.h.
4414 * sim-core.c: Likewise.
4415 * sim-events.c: Likewise.
4416
4417 * run.c (main): Pass SIM_OPEN_STANDALONE to sim_open.
4418
4419 * aclocal.m4: Check for stdlib.h, string.h, strings.h, unistd.h.
4420 (sim-debug): Allow arguments. Define WITH_DEBUG in addition to
4421 -DDEBUG.
4422 * configure: Regenerated to track ../common/aclocal.m4 changes.
4423
4424Wed Apr 2 14:34:19 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4425
4426 * configure: Regenerated to track ../common/aclocal.m4 changes.
4427
4428Wed Apr 2 11:08:11 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4429
4430 * sim-config.h (WITH_ALIGNMENT, WITH_FLOATING_POINT,
4431 WITH_XOR_ENDIAN, WITH_SMP, WITH_RESERVED_BITS): Assume that these
4432 are defined by the configure.
4433
4434 * aclocal.m4 (sim-stdio): Add option stdio from ../ppc configure.
4435
4436 * aclocal.m4 (floating-point, xor-endian, alignment, smp,
4437 reserved-bits): Always define.
4438
4439 * sim-config.h, sim-config.c (sim_config): New function - and new
4440 file - co-ordinate the setting/checking of the common simulator
4441 configuration options.
4442
4443 * Make-common.in (sim-config.o): Add rule.
4444
4445Fri Mar 28 15:32:00 1997 Mike Meissner <meissner@cygnus.com>
4446
4447 * callback.c (os_{,e}vprintf_filtered): Change stdarg type to
4448 va_list from void *, since va_list might not be a pointer type.
4449
4450Mon Mar 24 15:27:12 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4451
4452 * sim-n-endian.h (offset_N): Correct assertion - word and sub word
4453 in wrong order.
4454 (offset_N): Correct computation of LE offset.
4455
4456 * sim-io.c (sim_io_error): Include a new line when reporting
4457 errors.
4458
4459 * sim-assert.h (SIM_FILTER_PATH): Out by one when locating last
4460 `/'.
4461
4462Thu Mar 20 22:31:06 1997 Jeffrey A Law (law@cygnus.com)
4463
4464 * run.c: Include alloca-conf.h.
4465
4466 * callback.c (os_evprintf_filtered): Fix typo.
4467
4468Fri Mar 21 13:36:20 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4469
4470 * run.c (string.h, strings.h, stdlib.h): Include.
4471
4472 * sim-events.c (sim_events_tick): Recent cleanup failed to return
4473 0 when nothing pending.
4474
4475 * run.c (sim_size, sim_trace): Plicate GCC - these two functions
4476 will soon be going away.
4477 (getopt): Plicate GCC.
4478
4479 * sim-endian.c (sim-io.h): Plicate GCC.
4480 * sim-bits.c (sim-io.h): Ditto.
4481 * sim-n-bits.h (ROTn): Ditto.
4482
4483 * sim-io.c (sim_io_error): Correct check for NULL.
4484
4485 * sim-assert.h (SIM_FILTER_PATH): Separate out the code filtering
4486 the __FILE__.
4487 * sim-events.c: Use SIM_FILTER_PATH to filter out the filename
4488 path.
4489
4490Wed Mar 19 01:12:06 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4491
4492 * aclocal.m4 (SIM_AC_OPTION_*: Move so that they are outside of
4493 SIM_AC_COMMON - SIM_AC_COMMON was gobling arguments.
4494
4495Tue Mar 18 20:48:12 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4496
4497 * sim-alu.h: Include sim-xcat.h.
4498
4499Tue Mar 18 13:58:18 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4500
4501 * Make-common.in (sim-bits.c, sim-core.c, sim-endian.c,
4502 sim-events.c, sim-inline.c, sim-io.c): Define rules for building
4503 these.
4504
4505 * sim-events.c (sim_events_at_large_int): New function. Just
4506 schedules an event every large-int ticks.
4507 (sim_events_init): Call.
4508 (sim_events_tick, sim_events_process): Move async handing to
4509 sim_events_process. Move timer decrement so that it occures after
4510 events have been processed.
4511
4512 * sim-basics.h (struct _engine): Remove declaration.
4513
4514 * sim-events.h, sim-events.c: Rename type to sim_events. Prefix
4515 everything with same. Rename global struct to SIM_DESC.
4516 * sim-core.h, sim-core.c, sim-n-core.c: Ditto for sim_core.
4517 * sim-io.h, sim-io.c: Ditto.
4518
4519 * sim-assert.h: New file. Optional assertion checking macros.
4520 * sim-io.c (sim_io_error): Make just this function tolerant to
4521 null pointers.
4522
4523 * sim-xcat.h: New file. Define concatenate macros.
4524 * sim-basics.h (XCONCAT*): Move to sim-xcat.h.
4525 * sim-n-core.h, sim-n-bits.h, sim-n-endian.h: Explicitly include
4526 concat macros.
4527
4528
4529Tue Mar 18 12:44:55 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4530
4531 * sim-bits.h (LSMASK): New macro. Create mask of LS bits.
4532
4533Mon Mar 17 18:10:05 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4534
4535 * sim-inline.h: Add definitions for sim-types.
4536 (ALL_BY_MODULE): New macro, encapsulate full inlining by the
4537 module.
4538
4539Mon Mar 17 15:38:27 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4540
4541 * sim-events.h: Remove defunct reference to callback struct.
4542
4543Mon Mar 17 15:10:07 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4544
4545 * configure: Re-generate.
4546
4547Mon Mar 17 15:04:47 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4548
4549 * Make-common.in (CSEARCH): Do not include the gdb directory in
4550 the search path.
4551
4552Mon Mar 17 13:16:26 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4553
4554 * Make-common.in (SIM_ENDIAN, SIM_HOSTENDIAN, SIM_INLINE,
4555 SIM_WARNING): Drop, requiring the simulator specific Makefile.in
4556 to explicitly incorporate these.
4557
4558 * aclocal.m4 (--enable-sim-alignment); New option. Strongly
4559 specify the alignment restrictions of the target architecture -
4560 without this option all alignment restrictions are accomodated.
4561 (--enable-sim-assert): New option. Conditionally compile in
4562 assertion statements.
4563 (--enable-sim-float): New option. Strongly specify the target's
4564 floating point support.
4565 (--enable-sim-hardware): New option. Specify the hardware devices
4566 included in the simulation.
4567 (--enable-sim-packages): New option. Specify the hardware
4568 packages included in the simulation.
4569 (--enable-sim-regparm): New option. Specify that parameters be
4570 passed in registers instead of on the stack.
4571 (--enable-sim-reserved-bits): New option. Specify that reserved
4572 bits within an instruction are are correctly set.
4573 (--enable-sim-smp): New option. Specify the level of SMP support
4574 to be included in the simulator.
4575 (--enable-sim-stdcall): New option. Specify an alternative
4576 function call convention.
4577 (--enable-sim-xor-endian): New option. Configure xor-endian
4578 support used by some targets to implement bi-endian support.
4579
4580Fri Mar 14 19:51:21 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4581
4582 * aclocal.m4 (--enable-sim-hostendian): New option. Allow the
4583 host endianness to be overridden.
4584 (--enable-sim-endian): Allow the target platform's byte order
4585 to be overridden.
4586 (--enable-sim-inline): Control the inlining of common components.
4587 (--enable-sim-bswap): For compatibility, also define WITH_BSWAP.
4588 (--enable-sim-warnings): Enable additional GCC compiler checks.
4589 * Make-common.in (SIM_ENDIAN, SIM_HOSTENDIAN, SIM_INLINE,
4590 SIM_WARNINGS): Add.
4591
4592 * sim-n-core.h, sim-n-bits.h, sim-n-endian.h: Rename from
4593 sim-*-n.h so that the names are uniq on dos machines
4594 * sim-core.c, sim-bits.c, sim-endian.c: Update.
4595
4596Thu Mar 13 12:32:42 1997 Doug Evans <dje@canuck.cygnus.com>
4597
4598 * run.c: #include "libiberty.h".
4599 (main): New locals sd,no_args,sim_argv.
4600 Run buildargv on -a option. Pass argv to sim_open, argv[0]
4601 is program name. Update call to sim_set_callbacks.
4602 Record result of sim_open, pass to other sim_foo routines.
4603
4604Thu Mar 13 10:24:05 1997 Michael Meissner <meissner@cygnus.com>
4605
4606 * callback.c (os_printf_filtered): Do not call exit(1) or print a
4607 final newline.
4608
4609Thu Mar 6 15:50:28 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4610
4611 * callback.c: Add os_flush_stdout and vprintf_filtered callbacks.
4612 Route stdout through buffered IO.
4613
4614 * callback.c: Add os_flush_stderr, os_write_stderr,
4615 os_evprintf_filtered functions to route error output through
4616 stderr.
4617
4618 * sim-io.h, sim-io.c (sim_io_flush_stderr, sim_io_flush_stdout):
4619 Correct return type - should be void.
4620
4621Fri Mar 7 20:14:37 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4622
4623 * sim-basics.h: Clean up. Many macro's moved to sim-inline.h.
4624
4625 * sim-config.h: Ditto. For some options - eg WITH_DEVICES - do
4626 not provide a default value as undefined indicates disable code.
4627
4628Thu Mar 6 15:50:28 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4629
4630 * sim-core.h, sim-core-n.h, sim-core.c: Borrow code from ppc
4631 directory.
4632 * sim-events.h, sim-events.c: Ditto.
4633 * sim-io.h, sim-io.c: Ditto.
4634
4635Tue Mar 4 09:35:56 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4636
4637 * sim-alu.h (ALU_SUB_CA, ALU*_SUB_CA): New alu operation.
4638
4639 * sim-bits.h, sim-bits-n.h, sim-bits.c (LSMASKED*): New macro's
4640 extract the tail or least signifiant bits from an integer of the
4641 specified size.
4642
4643 * sim-bits.h, sim-bits.c: Clean up conditionally compiled #if
4644 WITH_TARGET_BITSIZE so that the compilation will fail when an
4645 unsupported bitsize value is defined.
4646
4647 (INSERTED*): Convert to functions.
4648 (EXTRACTED*): Ditto.
4649
4650 (SIGN_EXTEND, SEXT): Change to more terse name.
4651
4652Tue Mar 4 09:35:56 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4653
4654 * sim-inline.h: Allow explicit control over which .c files will be
4655 included by their header.
4656
4657 * sim-inline.h: Allow explicit control over which .c files use the
4658 alternative - REGPARM - parameter passing mechanism.
4659
4660 * sim-inline.h, sim-inline.c: Don't attempt to include any of
4661 icache.c, idecode.c, semantics.c or support.c. Those names are
4662 not generally applicable.
4663
4664Thu Feb 27 10:17:23 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4665
4666 * sim-bits.c, sim-bits-n.h (new): Split sim-bits.c into two parts
4667 in a fashion similar to sim-endian-n.
4668
4669 * sim-endian.h: (H_word, L_word, AL_*, VL_*): Extend to include
4670 both value and address macro's.
4671
4672Tue Feb 25 18:51:57 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
4673
4674 * sim-alu.h (ALU16_BEGIN, ALU16_SET, ...): Fill in.
4675
4676 * sim-endian.h (L_word, H_word): Replace MS2W_4, LS2W_4 with more
4677 generic L_word, H_word macro's.
4678
4679Thu Feb 20 18:36:55 1997 Andrew Cagney <cagney@critters.cygnus.com>
4680
4681 * sim-basics.h: Borrow code from ppc directory.
4682 * sim-bits.c: Ditto.
4683 * sim-bits.h: Ditto.
4684 * sim-config.h: Ditto.
4685 * sim-endian-n.h: Ditto.
4686 * sim-endian.c: Ditto.
4687 * sim-endian.h: Ditto.
4688 * sim-inline.c: Ditto.
4689 * sim-inline.h: Ditto.
4690 * sim-types.h: Ditto.
4691
4692Wed Feb 19 12:40:50 1997 Andrew Cagney <cagney@critters.cygnus.com>
4693
4694 * sim-alu.h (ALU_SET16, ALU_SET32, ALU_SET64, etc): Make available
4695 all the ALU size alternatives and then auto-configure a default.
4696
4697 * sim-alu.h: Copy ppc/idecode_expression.h.
4698
4699Mon Feb 17 10:44:18 1997 Andrew Cagney <cagney@critters.cygnus.com>
4700
4701 * bits.h, bits.c (SIGN_EXTEND32, SIGN_EXTEND64): New functions,
4702 sign extend a bit within a value.
4703
4704 * sim-endian.h, sim-endian-n.h (offset_N): New functions - return
4705 a pointer into the middle of a host word.
4706 * sim-endian.h (MS2W_4, LS2W_4): Use this function.
4707
4708Tue Feb 11 13:46:49 1997 Michael Meissner <meissner@tiktok.cygnus.com>
4709
4710 * callback.c: If HAVE_CONFIG_H is defined, include config.h from
4711 autoconf. If HAVE_UNISTD_H is defined, include unistd.h to get
4712 appropriate definitions of read, write, etc. Add prototype for
4713 system.
4714
4715Tue Feb 4 13:24:44 1997 Doug Evans <dje@canuck.cygnus.com>
4716
4717 * Makefile.in (libcommon.a): Delete.
4718 (callback.o,targ-map.o): Delete, moved to Make-common.in.
4719 (gentmap,targ-vals.h,targ-map.c): Likewise.
4720 (run-autoconf): Delete.
4721 * aclocal.m4 (SIM_AC_OUTPUT): Redo creation of Makefile.
4722 (common makefile fragment): Moved back into ...
4723 * Make-common.in: Resurrect.
4724 * configure.in (AC_LINK_FILES): Delete, unnecessary now.
4725 * configure: Regenerated.
4726
4727Fri Jan 31 07:16:49 1997 Doug Evans <dje@canuck.cygnus.com>
4728
4729 * aclocal.m4 (SIM_AC_COMMON): Move COMMON_MAKEFILE_FRAG from here.
4730 (SIM_AC_OUTPUT): To here.
4731
4732Fri Jan 24 10:37:17 1997 Stu Grossman (grossman@critters.cygnus.com)
4733
4734 * aclocal.m4 (COMMON_MAKEFILE_FRAG): Quote a couple of $'s in
4735 comments and single quotes. Fixes a problem found on hpux.
4736
4737Thu Jan 23 13:35:03 1997 Stu Grossman (grossman@critters.cygnus.com)
4738
4739 * aclocal.m4: Remove Make-common.in from dependencies.
4740 * (distclean): Remove targ-vals.def.
4741
4742 * aclocal.m4 (SIM_AC_COMMON): Move contents of Make-common.in
4743 into here. Makes insertion into makefiles easier. Also, change
4744 the way that callback.o, gentmap, targ-vals.h, targ-map.c,
4745 targ-map.o, and run are built. They are now built in the
4746 individual simulator directories, taking sources from ../common as
4747 necessary. This replaces the merging of libcommon.a into
4748 linsim.a, which was problematic for the WinGDB build process.
4749 * run.c: Include config.h from . instead of ../common.
4750 * Make-common.in: Remove. It's no longer necessary.
4751
4752Mon Dec 16 15:02:33 1996 Ian Lance Taylor <ian@cygnus.com>
4753
4754 * Make-common.in (ALL_CLAGS): Put CFLAGS at the end.
4755 (.c.o): Put $(ALL_CFLAGS) before the file being compiled.
4756
4757Wed Dec 11 11:30:58 1996 Jim Wilson <wilson@cygnus.com>
4758
4759 * run.c (main): Set target_byte_order before call to sim_open.
4760
4761Sun Dec 8 18:22:06 1996 Doug Evans <dje@canuck.cygnus.com>
4762
4763 * callback.c: #include <stdlib.h>
4764 (os_error): New function.
4765 (default_callback): Add os_error.
4766
4767Mon Nov 25 19:44:35 1996 Doug Evans <dje@canuck.cygnus.com>
4768
4769 * Make-common.in (Makefile): Set CONFIG_HEADERS="".
4770 * aclocal.m4: Mark the fact that --enable-sim-bswap isn't host
4771 specific.
4772 (SIM_AC_OUTPUT): Don't build Makefile if CONFIG_FILES="".
4773
4774Wed Nov 20 01:11:04 1996 Doug Evans <dje@canuck.cygnus.com>
4775
4776 * run.c: #include ../common/config.h, tconfig.h.
4777 (myname): New static global.
4778 (main): Recognize new options -a, -c. Also recognize -h if h8/300.
4779 Only process -c ifdef SIM_HAVE_SIMCACHE.
4780 Only process -p/-s ifdef SIM_HAVE_PROFILE.
4781 Parse program name from argv[0] and use in error messages.
4782 Pass sim_args to sim_open. Pass prog_args to sim_create_inferior.
4783 Add support for incomplete h8/300 termination indicators.
4784 (usage): Make more verbose.
4785 * aclocal.m4,config.in,tconfig.in,configure.in,configure: New files.
4786 * Makefile.in,Make-common.in,callback.c: New files.
4787 * nltvals.def,gentmap.c,gentvals.sh: New files.
4788
4789Tue Nov 12 13:34:00 1996 Dawn Perchik <dawn@cygnus.com>
4790
4791 * run.c: Include stdarg.h if __STDC__.
4792
4793Tue Oct 15 11:16:31 1996 Jeffrey A Law (law@cygnus.com)
4794
4795 * run.c (main): Don't print out anything if the signal
4796 number is zero (ie no signal).
4797
4798Tue Oct 15 11:20:44 1996 Michael Meissner <meissner@tiktok.cygnus.com>
4799
4800 * run.c (main): Print out if the program raised a signal.
4801
4802Wed Sep 18 09:52:14 1996 Michael Meissner <meissner@tiktok.cygnus.com>
4803
4804 * run.c (exec_bfd): Rename from sim_bfd, to use the gdb name.
4805 (main): Ditto.
4806
4807Tue Sep 17 11:04:50 1996 James G. Smith <jsmith@cygnus.co.uk>
4808
4809 * run.c (main): Explicitly cast malloc() parameter.
4810
4811Thu Sep 12 11:27:21 1996 Michael Meissner <meissner@tiktok.cygnus.com>
4812
4813 * run.c (sim_bfd): New global to hold the bfd pointer for the
4814 executable.
4815 (main): Initialize sim_bfd.
4816
4817Fri Dec 15 16:27:49 1995 Ian Lance Taylor <ian@cygnus.com>
4818
4819 * run.c (main): Use new bfd_big_endian macro.
4820
4821Wed Nov 8 15:49:49 1995 James G. Smith <jsmith@pasanda.cygnus.co.uk>
4822
4823 * run.c (main): Removed SH specific comments, so source is
4824 generic. Also updated to only load relevant sections. Moved
4825 sim_open() to after callback attach (to match GDB).
4826
4827 * run.1: Removed SH specific comments.
4828
4829Sat Oct 21 12:31:01 1995 Jim Wilson <wilson@chestnut.cygnus.com>
4830
4831 * run.c (main): Always return sigrc at end.
4832
4833Tue Oct 10 12:03:13 1995 J.T. Conklin <jtc@rtl.cygnus.com>
4834
4835 * run.c (main): Print error diagnostic and exit if bfd_openr() or
4836 bfd_check_format() fails.
4837
4838Thu Sep 28 15:40:36 1995 steve chamberlain <sac@slash.cygnus.com>
4839
4840 * run.c, run.1: From sh directory.