Redo watchpoint code so that it target can specify interrupt names.
[binutils-gdb.git] / sim / common / ChangeLog
1 Fri Sep 5 08:39:02 1997 Andrew Cagney <cagney@b1.cygnus.com>
2
3 * sim-core.c (sim_core_attach): Fix checks of modulo/mask.
4
5 * sim-watch.c (delete_watchpoint): Delete by ident and type.
6 (watch_option_handler): Call delete_watchpoint with ident or type.
7 (sim_watchpoint_install): Create interrupt specific watchpoint
8 commands on the fly.
9 (do_watchpoint_create): New function, create a watch point using
10 type/int-nr info encoded in the option nr.
11 (do_watchpoint_info): New function. List active watchpoints.
12
13 * sim-watch.h: Change data structure to a list.
14
15 * sim-memopt.c (memory_option_handler): Require explicit "all"
16 before deleting all memory regions.
17
18 * sim-utils.c (sim_do_commandf): New function, printf version of
19 sim_do_command.
20
21 * sim-basics.h (asprintf, vasprintf): Hack, define for CYGWIN32.
22
23 * sim-alu.h (ALU64_ADD): Use explicit MSEXTRACTED64, do not assume
24 bit endianness.
25 (SIGNED64, UNSIGNED64): Delete.
26 (ALU64_ADD): Don't rely on bit endianness.
27 (ALU64_BEGIN): Define.
28
29 * sim-n-bits.h (MSEXTRACTEDn, LSEXTRACTED): New functions.
30 (EXTRACTEDn): Delete, define as either LSEXTRACTED or MSEXTRACTED.
31
32 * sim-types.h (SIGNED64, UNSIGNED64): New macros, attach relevant
33 suffix - u64, LL - to 64 bit constants.
34
35 Thu Sep 4 09:27:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
36
37 * sim-config.c (sim_config): Add assert for SIM_MAGIC_NUMBER.
38
39 * sim-utils.h (NZALLOC): Define - zalloc * N.
40
41 * sim-hrw.c (sim_read, sim_write): New file. Provide generic
42 implementation of read/write functions.
43
44 * Make-common.in (sim-hrw.o): New target.
45
46 * sim-base.h (STATE_MEMOPT_P): Delete, simulators _always_ add
47 memory.
48
49 * sim-memopt.c (memory_option_handler): Implement memory-size
50 command. Implement memory-alias command. Let memory-delete delete
51 all memory regions.
52 (add_memopt): New function. Add a memory region.
53 (do_memopt_delete): New function. Delete a memory region.
54
55 * sim-utils.c (sim_elapsed_time_get): Never return zero.
56
57 * sim-core.c (sim_core_detach): New function.
58 (sim_core_map_detach): New function. Perform the actual detach.
59 (sim_core_init): Move initialization code from here.
60 (sim_core_install): To here.
61 (sim_core_uninstall): And here.
62
63 * sim-module.c: Add memopt module.
64
65 * sim-base.h (STATE_MEMOPT, STATE_MEMOPT_P): Add memopt to
66 simulator base type.
67
68 * Make-common.in (sim_main_headers): Add sim-memopt.h
69 (sim-memopt.o): New target.
70
71 * sim-core.c (sim_core_install): Add core_options to the option
72 table.
73
74 * sim-watch.c (watch_options): Make --delete-watch a synonym for
75 --watch-delete.
76
77 * sim-config.h (WITH_MODULO_MEMORY): Define as 0. Update
78 comments.
79
80 * sim-core.h (struct _sim_core_mapping): Change nr_bytes to type
81 address_word, add mask member.
82
83 * sim-core.h, sim-core.c (sim_core_attach): Make nr_bytes of type
84 address_word, allow for 64bit targets in 32bit host. Add modulo
85 argument.
86 (sim_core_map_attach): Ditto.
87 (new_sim_core_mapping): Ditto.
88 (sim_core_translate): Mask address when modulo memory.
89
90 Wed Sep 3 17:32:54 1997 Doug Evans <dje@seba.cygnus.com>
91
92 * sim-hload.c (sim_load): Add assert for SIM_MAGIC_NUMBER.
93
94 * gdbinit.in: New file.
95 * aclocal.m4 (SIM_AC_OUTPUT): Build .gdbinit.
96 * Make-common.in (distclean): Delete .gdbinit.
97 (.gdbinit): Add rule for.
98 * configure: Regenerated to track ../common/aclocal.m4 changes.
99
100 * Make-common.in (cgen-run.o): Add rule for.
101
102 Wed Sep 3 10:08:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
103
104 * sim-resume.c (sim_resume): Suspend/resume the simulator.
105
106 * sim-events.c (sim_watch_valid): Compute total elapsed time from
107 both resumed and previous elapsed time.
108 (sim_events_init): Set initial_wallclock and current_wallclock to
109 zero.
110 (sim_events_install): Install sim_events_suspend and
111 sim_events_resume.
112 (sim_events_watch_clock): Allow for suspended simulator when
113 computing the time of the clock event.
114
115 * sim-events.h (struct _sim_event): Add resume_wallclock, rename
116 initial_wallclock to elapsed_wallclock, set both to zero.
117 (sim_events_init, sim_events_uninstall): Delete prototypes.
118
119 * sim-module.h (MODULE_SUSPEND_FN, MODULE_RESUME_FN): Define types.
120
121 * sim-module.c(sim_module_resume, sim_module_suspend): New
122 functions.
123
124 Wed Sep 3 10:08:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
125
126 * sim-core.c (sim_core_map_attach): Clarify memory overlap error
127 message.
128
129 Tue Sep 2 14:57:06 1997 Doug Evans <dje@canuck.cygnus.com>
130
131 * Makefile.in (TAGS): Add support for "/* TAGS: foo */" marker.
132 * Make-common.in (TAGS): Likewise.
133 * sim-n-bits.h: Add TAGS comments for all functions.
134 * sim-n-core.h: Likewise.
135 * sim-n-endian.h: Likewise.
136
137 Mon Sep 1 10:50:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
138
139 * sim-utils.c (sim_state_alloc): Set CPU backlinks, callback and
140 kind.
141
142 * sim-base.h (sim_state_alloc): Add callback and kind arguments.
143
144 * sim-base.h (INVALID_INSTRUCTION_ADDRESS): Add default
145 definition.
146
147 Sat Aug 30 09:47:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
148
149 * sim-fpu.c (DP_GARDMSB, ...): Make unsigned.
150 (DP_FRACHIGH, DP_FRACHIGH2, ..): Use MSMASK to avoid LL.
151
152 Fri Aug 29 13:37:44 1997 Andrew Cagney <cagney@b1.cygnus.com>
153
154 * sim-core.c (sim_core_map_attach): Cast attach enum to int.
155 (sim_core_xor_read_buffer, sim_core_xor_write_buffer): Make
156 nr_transfered and nr_this_transfer unsigned.
157
158 * sim-events.c (sim_events_tickn): N is signed, as limited to
159 MAXINT.
160
161 * sim-n-endian.h (offset_N): Change size to unsigned.
162
163 * callback.c (os_poll_quit): Add prototypes for kbhit and getkey.
164
165 Fri Aug 29 10:10:53 1997 Andrew Cagney <cagney@b1.cygnus.com>
166
167 * sim-utils.c (sim_copy_argv): Delete, replaced by dupargv.
168
169 * sim-options.c (sim_parse_args): Use dupargv.
170
171 Thu Aug 28 10:36:34 1997 Doug Evans <dje@canuck.cygnus.com>
172
173 * sim-options.c (standard_option_handler): Use xstrdup, not strdup.
174
175 Thu Aug 28 12:09:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
176
177 * sim-base.h (STATE_ARCHITECTURE, STATE_TARGET): Add to simulator
178 base type.
179
180 * sim-options.c (standard_options): Add --architecture=MACHINE and
181 --target=TARGET options.
182 (OPTION_ARCHITECTURE, OPTION_TARGET): Define.
183 (standard_option_handler): Handle architecture and target options.
184 (bfd.h): Include.
185
186 * sim-utils.c (sim_analyze_program): Pass STATE_TARGET to
187 bfd_openr.
188 (sim_analyze_program): Set prog_bfd architecture from
189 STATE_ARCHITECTURE if known.
190
191 Wed Aug 27 18:13:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
192
193 * configure: Regenerated to track ../common/aclocal.m4 changes.
194 * config.in: Ditto.
195
196 Wed Aug 27 18:11:30 1997 Andrew Cagney <cagney@b1.cygnus.com>
197
198 * aclocal.m4 (enable-sim-warnings): Remove comment stating
199 that option does not apply to certain files.
200
201 Wed Aug 27 15:13:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
202
203 * sim-bits.h (LSBIT8, LSBIT16, LSBIT32, LSBIT64, LSBIT, MSBIT8,
204 MSBIT16, MSBIT32, MSBIT64, MSBIT): New macros - single bit as
205 offset from MSB/LSB.
206
207 * sim-endian.h (A1_8, A2_8, A4_8, A1_4, A2_4, A1_2): New macro,
208 access address of sub word quantity of a hosts 16, 32, 64 bit word
209 type.
210 (V1_2, V1_4, V2_4, V1_8, V2_8, V4_8): Ditto for values.
211 (U8_1, U8_2, U8_4, U4_1, U4_2, U2_1): Ditto for set of values.
212 (V2_H1, V2_L1, V4_H2, V4_L2, V8_L4, V8_H4): Given N byte argument,
213 return N*2 byte value with argument in Hi/Lo word. Renamed from
214 V1_H2, V1_L2, V2_H4, V2_L4, V4_H8, V4_L8.
215
216 * sim-alu.h (ALU32_HAD_OVERFLOW): Use 64 bit mask not 32bit.
217 (ALU16_HAD_CARRY, ALU32_HAD_CARRY, ALU16_HAD_OVERFLOW): Use MSBIT
218 so that bit offset is explicit.
219
220 Wed Aug 27 11:55:35 1997 Andrew Cagney <cagney@b1.cygnus.com>
221
222 * sim-utils.c (sim_analyze_program): Add prog_name argument.
223 Update STATE_PROG_BFD when needed with a dup'd copy of the
224 program.
225
226 * sim-config.c (sim_config): Delete ABFD argument, use
227 STATE_PROG_BFD directly.
228
229 Tue Aug 26 12:55:26 1997 Andrew Cagney <cagney@b1.cygnus.com>
230
231 * run.c (main): Pass the open ABFD to sim_create_inferior.
232
233 * nrun.c (main): Determine prog_bfd. Pass to sim_create_inferior
234 and sim_load.
235 (bfd.h): Include.
236
237 * sim-hload.c (sim_load): New file. Implement generic sim_load for
238 hardware only simulator targets.
239
240 * Make-common.in (sim-hload.o): Add rule.
241
242 Wed Aug 27 09:51:42 1997 Andrew Cagney <cagney@b1.cygnus.com>
243
244 * sim-utils.c (sim_copy_argv): Rewrite to match malloc strategy
245 used by copyargv and freeargv.
246
247 * sim-options.c (sim_parse_args): Save a copy of PROG-ARGS in
248 STATE_PROG_ARGV, not just a pointer.
249
250 Mon Aug 25 17:50:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
251
252 * configure: Regenerated to track ../common/aclocal.m4 changes.
253 * config.in: Ditto.
254
255 Mon Aug 25 12:11:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
256
257 * aclocal.m4 (sim-endian): Add second argument to
258 SIM_AC_OPTION_ENDIAN. First is hardwired endian, second is
259 default endian when not hardwired.
260
261 * sim-config.h (WITH_DEFAULT_TARGET_BYTE_ORDER): New macro, if all
262 else failes value for target byte order.
263
264 * sim-config.c (sim_config): Add abfd arguments. Set
265 STATE_PROG_BFD accordingly. Determine prefered_target_byte_order
266 from same.
267 (sim_config): Return SIM_RC, don't abort.
268 (bfd.h): Include.
269
270 * run.c (main): Update call to sim_open - add ABFD argument.
271 * nrun.c (main): Add NULL ABFD argument.
272
273 Thu Aug 14 12:48:57 1997 Doug Evans <dje@canuck.cygnus.com>
274
275 * callback.c (os_poll_quit): Make static.
276 Call sim_cb_eprintf, not p->eprintf.
277 (sim_cb_printf, sim_cb_eprintf): New functions.
278 * sim-utils.h (sim_cb_printf, sim_cb_eprintf): Declare.
279
280 * sim-basics.h (zalloc,zfree,sim_add_commas,SIM_ELAPSED_TIME,
281 sim_elapsed_time_get,sim_elapsed_time_since): Move decls to
282 sim-utils.h. #include sim-utils.h.
283 * sim-utils.h: Above decls moved here.
284 (sim_analyze_program,sim_load_file): Use `struct _bfd', not `bfd'.
285
286 * sim-watch.c (action_watchpoint): Fix thinkos.
287
288 Thu Jul 24 08:48:05 1997 Stu Grossman (grossman@critters.cygnus.com)
289
290 * sim-types.h: Fix defs of 64 bit data types for MSVC.
291
292 Tue Jul 22 10:35:37 1997 Doug Evans <dje@canuck.cygnus.com>
293
294 * sim-n-core.h (sim_core_write_unaligned_N): Add missing break
295 to FORCED_ALIGNMENT case.
296
297 Thu Jun 5 13:48:37 1997 Andrew Cagney <cagney@b1.cygnus.com>
298
299 * callback.c (target_to_host_open): Handle hosts with O_BINARY.
300
301 Thu Jun 5 08:47:10 1997 Jeffrey A Law (law@cygnus.com)
302
303 * Make-common.in (libsim.a): Fix typo.
304
305 Thu Jun 5 13:48:37 1997 Andrew Cagney <cagney@b1.cygnus.com>
306
307 * nrun.c (main): Verify the structure returned before using it.
308
309 Wed Jun 4 11:44:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
310
311 * sim-config.h (WITH_ENGINE): Enable the sim-engine module by
312 default.
313
314 * sim-engine.c (sim_engine_install): New function. Install the
315 engine init functions.
316 (sim_engine_init): [Re]initialize the simulator engine.
317
318 * sim-module.c: Add sim_engine to list of modules that always
319 install.
320
321 Tue Jun 3 04:52:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
322
323 * sim-watch.c (schedule_watchpoint): Use sim_unschedule_watchpoint
324 to remove the old watchpoint, not delete_watchpoint.
325 (watch_option_handler): Action the correct watchpoint, not just
326 cycles.
327
328 Wed May 28 14:47:41 1997 Andrew Cagney <cagney@b1.cygnus.com>
329
330 * sim-n-core.h (sim_core_write_aligned_N): For 8byte reads, output
331 both low and high word.
332 (sim_core_write_aligned_N): Ditto.
333
334 * sim-trace.c (set_trace_options): Delete code explicitly setting
335 core->trace.
336
337 * sim-options.c (sim_print_help): Call the list commands if not a
338 standalone simulator.
339 (sim_print_help): Advise that some options may not be applicable.
340
341 * sim-trace.c (set_trace_options): Assume core present.
342
343 * sim-events.c (sim_events_schedule_after_signal): Overflow signal
344 buffer when full not almost full.
345
346 Tue May 27 14:32:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
347
348 * sim-events.c (sim_events_process): Don't blat the event queue
349 when processing watchpoints.
350
351 * sim-watch.h: Make arg unsigned long - stop sign extension.
352
353 * sim-events.c (sim_watch_valid): rewrite so debugable.
354
355 * sim-config.h (WITH_XOR_ENDIAN): Default to zero.
356
357 * sim-watch.c (schedule_watchpoint): Add is_within option so that
358 inequality test is possible.
359 (handle_watchpoint): Re-pass is_within arg.
360 (watch_option_handler): When `!' prefix to pc-watchpoint arg pass
361 0 to schedule_watchpoint's is_within arg.
362 (sim_watchpoint_init): Re-pass is_within arg.
363
364 * sim-options.c (sim_print_help): Add is_command argument. Don't
365 include -- prefix when called from the command line interpreter.
366
367 * sim-watch.c (schedule_watchpoint): Pass true is_within argument.
368
369 * sim-events.c (sim_events_watch_sim): Add is_within argument,
370 zero indicates that the test should be reversed.
371 (sim_events_watch_core): Ditto.
372 (WATCH_CORE): Compare range against is_within.
373 (WATCH_SIM): Ditto.
374
375 Tue May 27 12:48:03 1997 Andrew Cagney <cagney@b2.cygnus.com>
376
377 * sim-events.c (WATCH_CORE): Pass NULL cpu argument to
378 sim_core_read_buffer. Check nr-bytes transfered.
379
380 * sim-core.h (sim_core_common): Define a new struct that contains
381 the common data. to sd and cpu structures.
382 * sim-core.c (sim_core_attach): Update.
383 (sim_core_init): Update. Remember to copy initialized data to each
384 cpu.
385 (sim_core_find_mapping): Ditto.
386
387 * sim-core.c (sim_core_read_buffer): Add cpu argument.
388 (sim_core_write_buffer): Ditto.
389
390 * sim-n-core.h (sim_core_read_unaligned_N): When mis-aligned
391 transfer use xor version of read buffer.
392 (sim_core_write_unaligned_N): Ditto for write.
393
394 * sim-core.c (sim_core_xor_read_buffer): New function implement
395 xor-endian data read breaking transfer up into xor-endian sized
396 blocks.
397 (sim_core_xor_write_buffer): Ditto for write.
398 (reverse_n): Reverse order of arbitrary number of bytes in buffer
399 - needed for xor-endian transfers.
400
401 Fri May 23 14:24:31 1997 Andrew Cagney <cagney@b1.cygnus.com>
402
403 * sim-inline.h: Review description.
404
405 * sim-core.h, sim-core.c: Reduce number of functions being inlined
406 to just those involved in data transfers and configuration.
407
408 * sim-xcat.h (XSTRING): New macro, map macro definition onto
409 string.
410 * sim-n-core.h (sim_core_read_aligned_N): Use.
411 (sim_core_read_unaligned_N): Ditto.
412 (sim_core_read_unaligned_N): Ditto..
413 (sim_core_write_unaligned_N): Ditto.
414
415 * sim-core.h: Add xor endian bitmap to main structure. *
416
417 sim-n-core.h (sim_core_write_aligned_N): Add suport for xor
418 endian.
419 (sim_core_read_aligned_N): Ditto.
420
421 * sim-core.c (sim_core_set_xor_endian): New function.
422 (sim_core_attach): Don't overwrite the per-cpu xor map when
423 cloning the global core.
424
425 Fri May 23 10:53:13 1997 Andrew Cagney <cagney@b1.cygnus.com>
426
427 * sim-engine.h: Update below so that it is using an enumerated
428 type.
429
430 Thu May 22 09:12:16 1997 Gavin Koch <gavin@cygnus.com>
431
432 * sim-engine.c (sim_engine_restart):
433 * sim-resume.c (sim_resume): Change longjmp param/setjmp
434 return value used for simulator restart from 0 to 2.
435
436 Wed May 21 08:47:30 1997 Andrew Cagney <cagney@b1.cygnus.com>
437
438 * cgen-scache.c (scache_option_handler): Add is_command arg.
439
440 * sim-model.c (model_option_handler): Add is_command argument.
441
442 * sim-profile.c (profile_option_handler): Add is_command arg.
443
444 * sim-events.c (sim_watch_valid): Use ub64, lb64 when 64bit value
445 involved.
446
447 * sim-module.c (sim_module_add_init_fn): Call init fn in the same
448 order that they are registered.
449
450 * sim-options.h (OPTION_HANDLER): Add argument to differentiate
451 between option and command line processing.
452
453 * sim-options.c: Include stdlib.h, ctype.h.
454
455 * Make-common.in (sim-watch.o): Add rule.
456 (sim_main_headers): Assume sim-assert.h included.
457 (sim-*.o): Simplify make rule.
458
459 * sim-module.c: Add sim_watch_install to module list.
460
461 Tue May 20 14:15:23 1997 Andrew Cagney <cagney@b1.cygnus.com>
462
463 * sim-base.h (STATE_LOADED_P): New predicate. Set once everything
464 has been loaded.
465
466 * sim-trace.c (trace_install): Check magic. Include sim-assert.h.
467 * sim-events.c (sim_events_install): Ditto.
468 * sim-core.c (sim_core_install): Ditto.
469 * sim-model.c (model_install): Ditto.
470 * sim-options.c (standard_install): Ditto.
471 * sim-profile.c (profile_install): Ditto.
472 * sim-reason.c (sim_stop_reason): Ditto.
473 * sim-run.c (sim_engine_run): Ditto.
474 * sim-utils.c (sim_analyze_program): Ditto.
475
476 * sim-module.c (modules): Make profile_install and trace_install
477 optional.
478
479 * sim-base.h (STATE_MEM_BASE): Define for flat memory systems.
480
481 * sim-options.c (standard_option_handler): Set the byte order.
482
483 * sim-events.c (sim_events_process): Allow multi tick processing.
484 (sim_events_tickn): New function - multi cycle tick.
485
486 * sim-events.h (sim_events_tickn, sim_events_timewarp): Add
487 prototypes. Under development.
488 (sim_events): Replace processing with nr_ticks_to_process.
489
490 Tue May 20 09:39:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
491
492 * nrun.c (main): Pass callbacks to sim_open instead of using
493 sim_set_callbacks.
494
495 * run.c (main): Ditto.
496
497 Mon May 19 12:07:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
498
499 * sim-events.c (sim_events_zalloc): Signal save memory allocator -
500 stop tk interrupting malloc calls.
501 (sim_events_zalloc): Converse.
502
503 * Make-common.in (sim_main_headers): Add sim-events.h.
504
505 * sim-events.c (sim_events_schedule_after_signal): Change return
506 type to void - signal events are strictly internal.
507 (sim_events_init): Allocate a finite buffer for signal events.
508 (sim_events_schedule_after_signal): Enter signal events into the
509 signal buffer.
510
511 * sim-engine.c (sim_engine_halt): Check SIM_DESC magic.
512 (sim_engine_restart): Ditto.
513 (sim_engine_abort): Ditto.
514 * sim-stop.c (sim_stop): Ditto.
515 (control_c_simulation): Ditto.
516 * sim-resume.c (sim_resume): Ditto.
517 (has_stepped): Ditto.
518 * sim-abort.c (sim_engine_abort): Ditto.
519
520 * sim-basics.h (transfer_type): New type.
521
522 * sim-core.c (sim_core_signal): New function. Print core signal
523 information.
524 (sim_core_find_mapping): Add transfer argument.
525
526 * sim-n-core.h (sim_core_{write,write}_unaligned_N): Call
527 SIM_CORE_SIGNAL if a recoverable abort.
528 * sim-core.c (sim_core_find_mapping): Ditto.
529
530 Fri May 16 15:13:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
531
532 * sim-core.c (sim_core_find_mapping): Replace calls to
533 sim_io_error to more resiliant sim_engine_abort.
534
535 * sim-n-core.h (sim_core_read_unaligned_N): Ditto.
536 (sim_core_write_unaligned_N): Ditto.
537
538 Tue May 13 13:50:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
539
540 * sim-module.c: Add sim_events_install to list.
541
542 * sim-events.c (sim_events_install, sim_events_uninstall): Clonse
543 from sim_core_*.
544 (sim_events_init): Now returns SIG_RC.
545
546 * sim-run.c: New file. Generic sim_engine_run.
547 * sim-reason.c: New file. Generic sim_stop_reason.
548 * sim-stop.c: New file. Generic sim_stop.
549 * sim-resume.c: New file. Generic sim_resume.
550
551 * Make-common.in (sim-engine.o): Add rule.
552 (sim-run.o, sim-reason.o, sim-stop.o, sim-resume.o): Ditto.
553
554 * sim-engine.h, sim-engine.c: New file. Provide generic
555 implementation of sim_engine_halt, sim_engine_error. et.al.
556
557 * sim-base.h (sim_state_base): Add member halt.
558 (sim-engine.h): Include.
559
560 * sim-events.h (sim_event_handler): Always pass SIM_DESC to event
561 handlers.
562 * sim-events.c (sim_events_poll): Update event handler.
563
564 Tue May 13 09:57:49 1997 Andrew Cagney <cagney@b2.cygnus.com>
565
566 * sim-events.h, sim-events.c (sim_events_watch_clock): New
567 function.
568 (sim_events_watch_sim): New function.
569 (sim_events_watch_core): New function.
570 (sim_watch_valid): New function.
571 (sim_events_preprocess): New function.
572 (sim_events_process): Process the watchpoints as well as the timer
573 queue.
574 (sim_events_tick): Check WORK_PENDING instead of the hold queue.
575 (sim_events_deschedule): Check all the queues when removing an
576 event.
577 (sim_events_init): Ditto for cleaning.
578
579 Mon May 19 12:07:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
580
581 * sim-fpu.c (is_ufpu_number): Comment out - currently unused.
582
583 Mon May 19 11:23:03 1997 Andrew Cagney <cagney@b1.cygnus.com>
584
585 * callback.c (os_open): Type of arg flags is int.
586
587 Fri May 16 22:26:43 1997 Michael Meissner <meissner@cygnus.com>
588
589 * sim-fpu.c (sim_fpu_is_{eq,ne,lt,le,gt,ge}): Compare Infinities
590 just like normal numbers as per IEEE rules.
591
592 Wed May 14 21:20:38 1997 Bob Manson <manson@charmed.cygnus.com>
593
594 * callback.c (os_close): Mark the descriptor as being
595 available if the close succeeded.
596 (os_open): Pass 0644 as the mode of the file being created.
597
598 Thu May 15 10:58:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
599
600 * sim-fpu.c (pack_fpu, unpack_fpu): New functions - decode a
601 float.
602
603 * sim-inline.c (SIM_INLINE_C): Rename from _SIM_INLINE_C_.
604 * sim-lnline.h: Update.
605
606 * sim-fpu.h, sim-fpu.c (sim_fpu_[iu]{32,64}to): New int2fp
607 conversion functions.
608 (sim_fpu_to{32,64}[iu]): New fp2int functions.
609
610 * sim-fpu.h, sim-fpu.c (sim_fpu_is_{lt,le,eq,ne,ge,gt}): New fp
611 compare functions. Replacing.
612 (sim_fpu_cmp): This. Delete.
613
614 Mon May 12 14:49:05 1997 Andrew Cagney <cagney@b1.cygnus.com>
615
616 * sim-core.c (sim_core_find_mapping): Call engine_error not
617 sim_io_error when possible.
618
619 Mon May 12 08:55:07 1997 Andrew Cagney <cagney@b2.cygnus.com>
620
621 * sim-endian.h (V1_H2): Add macro's to insert a word into a
622 high/low double word.
623
624 * sim-trace.h: Remove definition of attribute - defined in
625 sim_basics.h.
626
627 Mon May 12 08:55:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
628
629 * sim-options.h (struct OPTION): Add doc_opt as the documenting
630 name of the option - or family of options.
631
632 * sim-options.c (sim_args_command): Match command `a-b c' with
633 option `--a-b-c' from option table.
634
635 Thu May 8 12:40:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
636
637 * sim-options.c (sim_print_help): For optional arguments, wrap
638 them in [].
639
640 * sim-trace.c (set_trace_options): New function, handle optional
641 argument and multiple assignment.
642 (trace_option_handler): Update.
643
644 * sim-trace.c (trace_option_handler): Trace branch and not fpu
645 when branch tracing selected.
646
647 Wed May 7 15:19:58 1997 Andrew Cagney <cagney@b1.cygnus.com>
648
649 * sim-trace.c (trace_one_insn): Make a va-args function.
650
651 * sim-trace.c (trace_vprintf): New function, va-arg version of
652 trace_printf.
653
654 Tue May 6 16:38:16 1997 Doug Evans <dje@canuck.cygnus.com>
655
656 * sim-trace.c (trace_uninstall): Don't close a file twice.
657 * sim-profile.c (profile_uninstall): Likewise.
658
659 Tue May 6 06:14:01 1997 Mike Meissner <meissner@cygnus.com>
660
661 * sim-trace.c (toplevel): Include bfd.h.
662 (trace_options): Note that --trace-linenum also turns on
663 --trace-insn. Add --trace-{branch,semantics}.
664 (trace_option_handler): If --trace-linenum, also turn on
665 --trace-insn. Add --trace-branch support. If --trace-semantics,
666 turn on ALU, FPU, branch, and memory tracing.
667 (trace_one_insn): New function to trace an instruction. Support
668 --trace-linenum.
669 (OPTION_TRACE_*): Use an enum, rather than lots of defines.
670
671 * sim-trace.h (TRACE_{SEMANTICS,BRANCH}_IDX): Add new macros.
672 (MAX_TRACE_VALUES): Use 32, not 12 by default.
673 (TRACE_branch): Add new mask.
674 (TRACE_*_P): Define all possible trace_p macros.
675 (trace_one_insn): Declare function.
676
677 Mon May 5 14:08:34 1997 Mike Meissner <meissner@cygnus.com>
678
679 * sim-trace.h (__attribute__): Define as nothing if not GNU C or
680 GNU C doesn't support __attributes__.
681 ({trace,debug}_printf): Add attribute's so -Wformat can check the
682 format strings.
683
684 Mon May 5 11:16:12 1997 Andrew Cagney <cagney@b1.cygnus.com>
685
686 * sim-config.h (FORCED_ALIGNMENT): New alignment option -
687 addresses are masked forcing them to be correctly aligned.
688 (WITH_ALIGNMENT): Make NONSTRICT_ALIGNMENT the default.
689 * sim-config.c (config_alignment_to_a): Update.
690
691 * sim-core.h (sim_cpu_core): New data type contains cpu specific
692 core data.
693 * sim-base.h (CPU_CORE): Add cpu specific core data to cpu base
694 type.
695 * sim-core.c (sim_core_attach): Add CPU argument. Ready for
696 processor specific core maps.
697 (sim_core_map_attach): Copy the core map data to each of the
698 processor specific core data structures.
699 * sim-core.c (sim_core_find_mapping): Update.
700
701 * sim-n-core.h (sim_core_read_N, sim_core_write_N): Rename.
702 (sim_core_write_aligned_N, sim_core_write_aligned_N): New names.
703 (sim_core_write_unaligned_N, sim_core_write_unaligned_N): New
704 alternatives that handle unaligned addresses.
705 (sim_core_{read,write}_{,un}aligned_N): Drop SIM_DESC arg, replace
706 with just CPU arg.
707 * cgen-utils.c (sim_disassemble_insn): Update.
708
709 Mon May 5 13:19:16 1997 Andrew Cagney <cagney@b1.cygnus.com>
710
711 * sim-trace.h (TRACE_FPU_IDX): Add Floating-point specific
712 tracing.
713
714 * sim-fpu.h, sim-fpu.c: New files - prototype for generic target
715 fpu support.
716
717 * sim-inline.h, sim-inline.c: Add support for SIM_FPU.
718
719 Fri May 2 17:59:42 1997 Andrew Cagney <cagney@b1.cygnus.com>
720
721 * sim-core.c (sim_core_map_to_str): New function ascii equivalent
722 to map type.
723
724 * sim-n-core.h (sim_core_read_N, sim_core_write_N): Use in trace
725 statement.
726
727 Fri May 2 17:28:02 1997 Andrew Cagney <cagney@b2.cygnus.com>
728
729 * cgen-trace.c: Prepend additional trace_printf argument.
730
731 * cgen-utils.c (sim_disassemble_insn): Add additional core
732 arguments.
733
734 Fri May 2 11:40:23 1997 Andrew Cagney <cagney@b1.cygnus.com>
735
736 * nrun.c (main): Catch/report errorenous simulator states.
737
738 * sim-module.c: #include "libiberty.h" so that xmalloc is defined.
739 * sim-trace.c: #include string.h/strings.h so that memset is
740 defined.
741 * sim-utils.c: Ditto.
742 * sim-profile.c: Ditto. And stdlib.h.
743 (print_bar): Only define when used by instruction or memory profiler.
744
745 * sim-options.c (standard_option_handler): Make ul more local.
746
747 * sim-load.c (sim_load_file): Make the name constant.
748 (sim_load_file): Passify gcc.
749
750 * sim-utils.h: New file, pre-declare utilites in corresponding .c
751 file.
752 * sim-utils.c, sim-load.c: Include sim-utils.h.
753
754 * sim-base.h (sim_cpu): Pre define here so available to all.
755
756 * sim-core.h (DECLARE_SIM_CORE_WRITE_N, DECLARE_SIM_CORE_READ_N):
757 Restore the sim_cpu and instruction_address arguments so that full
758 information is available to the abort function.
759 * sim-core.c (sim_core_find_mapping, sim_core_write_buffer): Ditto.
760 * sim-n-core.h (sim_core_write_N, sim_core_read_N): Update.
761
762 * sim-trace.h, sim-trace.c (trace_option_handler): Add interim
763 tracing support for sim-events and sim-core.
764 (trace_option_handler): Convert #if to if where possible so always
765 compiled/checked by C compiler.
766 * sim-n-core.h (sim_core_write_N, sim_core_read_N): Update.
767
768 * sim-base.h: Adjust comment documenting how to define the cpu
769 structure.
770 (sim_state_base): Add sim_core and sim_events to simulator base
771 object.
772
773 * sim-trace.h, sim-trace.c (trace_printf): Add SIM_DESC argument.
774 * sim-core.c (sim_core_init, sim_core_attach,
775 sim_core_find_mapping): Update.
776 * sim-events.c (ETRACE, sim_events_init, sim_events_time,
777 update_time_from_event, insert_sim_event,
778 sim_events_schedule_after_signal, sim_events_deschedule,
779 sim_events_tick): Ditto.
780
781 * sim-basics.h (sim-module.h, sim-trace.h, sim-profile.h,
782 sim-model.h): Move #includes from here.
783 * sim-base.h: To here.
784 (sim-core.h, sim-events.h, sim-io.h): Include also
785
786 Wed Apr 30 15:37:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
787
788 * callback.c (default_callback): Missing initialisers.
789
790 Thu May 1 10:40:47 1997 Doug Evans <dje@canuck.cygnus.com>
791
792 * sim-utils.c (sim_add_commas): New function.
793 * sim-basics.h (sim_add_commas): Add prototype.
794 * cgen-scache.c (scache_print_profile): Print commas in numbers.
795 * sim-profile.c (COMMAS): New macro.
796 (print_*): Use it to print commas in numbers.
797
798 * configure: Regenerated.
799
800 * cgen-sim.h (sim_signal_type): Add SIM_SIGINT.
801 (cgen_state): New member run_fast_p.
802 (cgen_init): Add prototype.
803 (sim_disassemble_insn): New arg `cpu'.
804 * cgen-trace.c (trace_insn): Update call to sim_disassemble_insn.
805 * cgen-utils.c (cgen_init): New function.
806 (sim_disassemble_insn): New arg `cpu'. Rewrite fetching of insn.
807 * genmloop.sh: Call engine_halt if loop exits.
808
809 * Makefile.in (sim-options_h): Define.
810 (sim-{module,options,trace,profile,utils}.o): Clean up dependencies.
811 (sim-model.o): Add new rule.
812 (cgen-{scache,trace,utils}.o): Add new rules.
813 * aclocal.m4 (SIM_AC_OPTION_{SCACHE,DEFAULT_MODEL}): Add.
814 * cgen-scache.c (scache_print_profile): Change `sd' arg to `cpu'.
815 Indent output by 2 spaces.
816 * cgen-scache.h (scache_print_profile): Update.
817 * cgen-trace.c (trace_insn_fini): Indent output by 2 spaces.
818 Use trace_printf, not fprintf.
819 (trace_extract): Use trace_printf, not cgen_trace_printf.
820 * genmloop.sh (!FAST case): Increment `insn_count'.
821 * sim-base.h (sim_state_base): Only include scache_size if WITH_SCACHE.
822 (sim_cpu_base): Rename member `sd' to `state' to be consistent with
823 access macro's name.
824 * sim-core.c (sim_core_init): Use EXTERN_SIM_CORE to define it.
825 Change return type to SIM_RC.
826 (sim_core_{install,uninstall}): New functions.
827 * sim-core.h (sim_core_{install,uninstall}): Declare.
828 (sim_core_init): Use EXTERN_SIM_CORE to define it.
829 Change return type to SIM_RC.
830 * sim-model.h (models,machs,model_install): Declare.
831 * sim-module.c (modules): Add scache_install, model_install.
832 (sim_post_argv_init): Set cpu->state backlinks.
833 * sim-options.c (standard_options): Delete --simcache-size,--max-insns.
834 (standard_option_handler): Likewise.
835 * sim-profile.c (PROFILE_{HISTOGRAM,LABEL}_WIDTH): Move to
836 sim-profile.h.
837 (*): Assume ANSI C.
838 (profile_options): Delete --profile-simcache.
839 (profile_option_handler): Likewise.
840 (profile_print_insn): Change `sd' arg to `cpu'. Indent output 2
841 spaces.
842 (profile_print_{memory,model}): Likewise.
843 (profile_print_simcache): Delete.
844 (profile_print_speed): New function.
845 (profile_print): Rewrite.
846 * sim-profile.h (PROFILE_scache): Renamed from PROFILE_simcache.
847 (WITH_PROFILE_SCACHE_P): Renamed from WITH_PROFILE_SIMCACHE_P.
848 (PROFILE_DATA): Delete members simcache_{hits,misses}.
849 (PROFILE_COUNT_SIMCACHE_{HIT,MISS}): Delete.
850 (PROFILE_{CALLBACK,CPU_CALLBACK}): New types.
851 (profile_print): Update prototype.
852
853 Wed Apr 30 11:34:14 1997 Doug Evans <dje@canuck.cygnus.com>
854
855 * cgen-scache.[ch], cgen-sim.h: New files.
856 * cgen-trace.[ch], cgen-types.h, cgen-utils.c, genmloop.sh: New files.
857 * sim-model.c: New file.
858
859 * Make-common.in (clean targets): Undo patch of Apr. 22.
860
861 Fri Apr 25 15:28:32 1997 Mike Meissner <meissner@cygnus.com>
862
863 * sim-n-bits.h (signed): If we have a standard compiler, undef
864 signed, so that signedN is defined correctly.
865
866 Thu Apr 24 00:00:07 1997 Doug Evans <dje@canuck.cygnus.com>
867
868 * sim-module.h, sim-model.h, sim-profile.h: New files.
869 * sim-module.c, sim-profile.c: New files.
870 * Make-common.in (SIM_PROFILE): Define
871 (CONFIG_CFLAGS): Add $(SIM_PROFILE).
872 (sim_main_headers): Add sim-module.h, sim-model.h, sim-profile.h.
873 (sim_module.o,sim-profile.o): Add rules for.
874 * aclocal.m4 (--enable-sim-trace): Allow symbolic arguments.
875 (--enable-sim-profile): Add.
876 * configure: Regenerated.
877 * sim-base.h (sim_state_base): New members init_list, uninstall_list,
878 model. Move trace and profile support to sim-{trace,profile}.h.
879 New members trace_data, profile_data.
880 * sim-basics.h: #include sim-module.h, sim-model.h, sim-profile.h.
881 * sim-config.h: Provide default definition of WITH_PROFILE.
882 (WITH_TRACE): Change default to -1.
883 (MAX_NR_PROCESSORS): Always define.
884 * sim-options.c: Move trace and profile support to
885 sim-{trace,profile}.h.
886 (sim_pre_argv_init): Moved to sim-model.c.
887 (standard_install): New function.
888 * sim-options.h (sim_pre_argv_init): Move decl to sim-model.c.
889 (standard_install): Declare.
890 * sim-trace.c: Tracing option handling moved here from sim-options.c.
891 (trace_install, trace_uninstall): New functions.
892 (trace_printf): Update reference to TRACE_FILE.
893 * sim-trace.h (TRACE_FOO_IDX): Moved here from sim-base.h.
894 (TRACE_foo): Bit masks for symbolic arguments to --enable-sim-trace.
895 (WITH_TRACE_FOO_P): Define.
896 (trace_install): Declare.
897 (TRACE_DATA): New struct.
898
899 Wed Apr 23 17:23:15 1997 Doug Evans <dje@canuck.cygnus.com>
900
901 * run.c: Undo last exec_bfd patch.
902 (main): Only pass -E ifdef SIM_HAVE_BIENDIAN.
903
904 Wed Apr 23 17:54:27 1997 Mike Meissner <meissner@cygnus.com>
905
906 * run.c (exec_bfd): Add back in.
907 (main): Set exec_bfd.
908
909 Tue Apr 22 14:43:46 1997 Doug Evans <dje@canuck.cygnus.com>
910
911 * sim-load.c (sim_load_file): #include <stdio.h> for NULL.
912
913 Wed Apr 23 02:55:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
914
915 * sim-events.c (insert_sim_event): Call sim_io_error instead of
916 less well defined engine_error.
917 * sim-core.c: Ditto.
918
919 Tue Apr 22 08:48:16 1997 Stu Grossman (grossman@critters.cygnus.com)
920
921 * Make-common.in: Change clean targets to use :: so that other
922 Makefiles can have their own clean targets.
923 * sim-load.c (xprintf eprintf): Use ANSI_PROTOTYPES instead of
924 __STDC__ to control use of stdarg vs. varargs syntax. Some
925 systems can't use __STDC__, but require stdarg.
926
927 Fri Apr 18 11:14:43 1997 Doug Evans <dje@canuck.cygnus.com>
928
929 * sim-options.c (standard_options): Add --endian.
930 (standard_option_handler): Likewise.
931
932 * nrun.c: #include <signal.h>.
933 (main, cntrl_c): Wrap calls to sim_resume in a SIGINT
934 handler that calls sim_stop ().
935
936 Fri Apr 18 13:11:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
937
938 * run.c (main, cntrl_c): Wrap calls to sim_resume in a SIGINT
939 handler that calls sim_stop (). Simulators may still be
940 establishing their own handler.
941
942 * sim-events.c (sim_events_poll): Rename from
943 sim_events_at_large_int. Poll IO.
944
945 * sim-io.c (sim_io_poll_quit): New function - pass on a polling
946 request.
947
948 * callback.c (os_poll_quit): New function poll for quit signal
949 where needed.
950 (default_callback): Include magic number.
951
952 Thu Apr 17 02:25:11 1997 Doug Evans <dje@canuck.cygnus.com>
953
954 * aclocal.m4: Check for headers time.h, sys/time.h, sys/resource.h.
955 Check for functions getrusage, time.
956 * sim-basics.h (SIM_ELAPSED_TIME): New typedef.
957 (sim_elapsed_time_get, sim_elapsed_time_since): Add prototypes.
958 * sim-utils.c: #include time.h, sys/time.h, sys/resource.h if able.
959 (sim_elapsed_time_get, sim_elapsed_time_since): New functions.
960
961 * sim-utils.c (sim_copy_argv, sim_analyze_program): New functions.
962
963 * sim-options.c, sim-options.h: New files.
964 * sim-config.h (WITH_DEBUG): Provide default value of zero.
965 * Make-common.in (nrun.o): Add rules for.
966 * nrun.c: New file.
967
968 * run.c (main): Check return value of sim_open.
969
970 * Make-common.in (sim-options.o, sim-load.o, sim-trace.o): Add rules.
971 (sim_main_headers): Add sim-trace.h.
972 * run.c (exec_bfd, target_byte_order): Delete.
973 (main): Pass -E <endian> to sim_open. Delete code to load sections,
974 call sim_load instead. Check return code of sim_create_inferior.
975 * sim-base.h (CURRENT_STATE): Define.
976 (sim_state_base): Make typedef. New members options, prog_argv,
977 prog_bfd, text_{section,start,end}, start_addr, simcache_size,
978 mem_size, memory [+ corresponding access macros].
979 (sim_cpu_base): New typedef.
980 * sim-trace.h: New file.
981 * sim-trace.c: New file.
982 * sim-basics.h: #include it.
983 * sim-load.c: New file.
984
985 Tue Apr 15 15:10:13 1997 Ian Lance Taylor <ian@cygnus.com>
986
987 * Make-common.in (INSTALL): Set to @INSTALL@.
988 (INSTALL_XFORM, INSTALL_XFORM1): Remove.
989 (install-common): Depend upon installdirs. Use
990 $(program_transform_name) directly, rather than using
991 $(INSTALL_XFORM).
992 (installdirs): New target.
993 * Makefile.in (INSTALL): Set to @INSTALL@.
994 (INSTALL_XFORM, INSTALL_XFORM1): Remove.
995 (install-man): Depend upon installdirs. Use
996 $(program_transform_name) directly, rather than using
997 $(INSTALL_XFORM).
998 (installdirs): New target.
999
1000 Tue Apr 15 15:08:12 1997 Andrew Cagney <cagney@b1.cygnus.com>
1001
1002 * sim-assert.h (SIM_ASSERT, ASSERT): Allow these macros to
1003 be overriden.
1004
1005 Wed Apr 9 16:06:44 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1006
1007 * sim-basics.h: Only bring in config.h and tconfig.h if
1008 HAVE_CONFIG_H.
1009
1010 Mon Apr 7 11:39:45 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1011
1012 * sim-config.h (WITH_TARGET_WORD_MSB): New Macro. Define the bit
1013 numbering convention of the target.
1014 * sim-config.c (print_sim_config): Print WITH_TARGET_WORD_BITSIZE
1015 and WITH_TARGET_WORD_MSB.
1016 (sim_config): When possible, check for consistency with bitsize
1017 and msb.
1018
1019 * sim-bits.h: Allow MSB to be other than zero.
1020 * sim-bits.c: Ditto.
1021 * sim-n-bits.h: Ditto.
1022
1023 * sim-bits.h (MSMASK*): New macros - converce to LSMASK*.
1024 * sim-n-bits.h (MSMASKEDn): Ditto.
1025
1026 Mon Apr 14 16:29:21 1997 Ian Lance Taylor <ian@cygnus.com>
1027
1028 * Makefile.in (INSTALL): Change install.sh to install-sh.
1029
1030 Mon Apr 7 10:46:38 1997 Doug Evans <dje@canuck.cygnus.com>
1031
1032 * sim-base.h (sim_state_base): Move `magic' to end of struct.
1033
1034 Mon Apr 7 15:53:21 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1035
1036 * run.c (main): Check that a program to run was specified.
1037
1038 Mon Apr 7 15:45:02 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1039
1040 * aclocal.m4 (AC_TYPE_SIGNAL): Add check.
1041
1042 * configure: Regenerated to track ../common/aclocal.m4 changes.
1043 * config.in: Ditto.
1044
1045 Wed Apr 2 15:06:28 1997 Doug Evans <dje@canuck.cygnus.com>
1046
1047 * sim-endian.h: Move host {LITTLE,BIG}_ENDIAN support from here,
1048 * sim-config.h: To here.
1049
1050 * Make-common.in (SIM_EXTRA_DEPS): New config var.
1051 (sim_main_headers): Define.
1052 (sim-*.o): Depend on $(SIM_EXTRA_DEPS).
1053 (BUILT_SRC_FROM_COMMON): Move here from ../d30v/Makefile.in.
1054 (clean): Use it.
1055 (sim-utils.o): Add rule for.
1056 * sim-utils.o: New file.
1057 * sim-basics.h: #include sim-base.h.
1058 (zalloc): Make argument unsigned long.
1059 * sim-base.h: New file.
1060 * sim-inline.h (SIM_IO support): Delete.
1061 * sim-io.h: Delete inline support.
1062 * sim-io.c: Likewise. sim-state.h renamed to sim-main.h.
1063 * sim-config.c: sim-state.h renamed to sim-main.h.
1064 * sim-core.c: Likewise.
1065 * sim-events.c: Likewise.
1066
1067 * run.c (main): Pass SIM_OPEN_STANDALONE to sim_open.
1068
1069 * aclocal.m4: Check for stdlib.h, string.h, strings.h, unistd.h.
1070 (sim-debug): Allow arguments. Define WITH_DEBUG in addition to
1071 -DDEBUG.
1072 * configure: Regenerated to track ../common/aclocal.m4 changes.
1073
1074 Wed Apr 2 14:34:19 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1075
1076 * configure: Regenerated to track ../common/aclocal.m4 changes.
1077
1078 Wed Apr 2 11:08:11 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1079
1080 * sim-config.h (WITH_ALIGNMENT, WITH_FLOATING_POINT,
1081 WITH_XOR_ENDIAN, WITH_SMP, WITH_RESERVED_BITS): Assume that these
1082 are defined by the configure.
1083
1084 * aclocal.m4 (sim-stdio): Add option stdio from ../ppc configure.
1085
1086 * aclocal.m4 (floating-point, xor-endian, alignment, smp,
1087 reserved-bits): Always define.
1088
1089 * sim-config.h, sim-config.c (sim_config): New function - and new
1090 file - co-ordinate the setting/checking of the common simulator
1091 configuration options.
1092
1093 * Make-common.in (sim-config.o): Add rule.
1094
1095 Fri Mar 28 15:32:00 1997 Mike Meissner <meissner@cygnus.com>
1096
1097 * callback.c (os_{,e}vprintf_filtered): Change stdarg type to
1098 va_list from void *, since va_list might not be a pointer type.
1099
1100 Mon Mar 24 15:27:12 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1101
1102 * sim-n-endian.h (offset_N): Correct assertion - word and sub word
1103 in wrong order.
1104 (offset_N): Correct computation of LE offset.
1105
1106 * sim-io.c (sim_io_error): Include a new line when reporting
1107 errors.
1108
1109 * sim-assert.h (SIM_FILTER_PATH): Out by one when locating last
1110 `/'.
1111
1112 Thu Mar 20 22:31:06 1997 Jeffrey A Law (law@cygnus.com)
1113
1114 * run.c: Include alloca-conf.h.
1115
1116 * callback.c (os_evprintf_filtered): Fix typo.
1117
1118 Fri Mar 21 13:36:20 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1119
1120 * run.c (string.h, strings.h, stdlib.h): Include.
1121
1122 * sim-events.c (sim_events_tick): Recent cleanup failed to return
1123 0 when nothing pending.
1124
1125 * run.c (sim_size, sim_trace): Plicate GCC - these two functions
1126 will soon be going away.
1127 (getopt): Plicate GCC.
1128
1129 * sim-endian.c (sim-io.h): Plicate GCC.
1130 * sim-bits.c (sim-io.h): Ditto.
1131 * sim-n-bits.h (ROTn): Ditto.
1132
1133 * sim-io.c (sim_io_error): Correct check for NULL.
1134
1135 * sim-assert.h (SIM_FILTER_PATH): Separate out the code filtering
1136 the __FILE__.
1137 * sim-events.c: Use SIM_FILTER_PATH to filter out the filename
1138 path.
1139
1140 Wed Mar 19 01:12:06 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1141
1142 * aclocal.m4 (SIM_AC_OPTION_*: Move so that they are outside of
1143 SIM_AC_COMMON - SIM_AC_COMMON was gobling arguments.
1144
1145 Tue Mar 18 20:48:12 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1146
1147 * sim-alu.h: Include sim-xcat.h.
1148
1149 Tue Mar 18 13:58:18 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1150
1151 * Make-common.in (sim-bits.c, sim-core.c, sim-endian.c,
1152 sim-events.c, sim-inline.c, sim-io.c): Define rules for building
1153 these.
1154
1155 * sim-events.c (sim_events_at_large_int): New function. Just
1156 schedules an event every large-int ticks.
1157 (sim_events_init): Call.
1158 (sim_events_tick, sim_events_process): Move async handing to
1159 sim_events_process. Move timer decrement so that it occures after
1160 events have been processed.
1161
1162 * sim-basics.h (struct _engine): Remove declaration.
1163
1164 * sim-events.h, sim-events.c: Rename type to sim_events. Prefix
1165 everything with same. Rename global struct to SIM_DESC.
1166 * sim-core.h, sim-core.c, sim-n-core.c: Ditto for sim_core.
1167 * sim-io.h, sim-io.c: Ditto.
1168
1169 * sim-assert.h: New file. Optional assertion checking macros.
1170 * sim-io.c (sim_io_error): Make just this function tolerant to
1171 null pointers.
1172
1173 * sim-xcat.h: New file. Define concatenate macros.
1174 * sim-basics.h (XCONCAT*): Move to sim-xcat.h.
1175 * sim-n-core.h, sim-n-bits.h, sim-n-endian.h: Explicitly include
1176 concat macros.
1177
1178
1179 Tue Mar 18 12:44:55 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1180
1181 * sim-bits.h (LSMASK): New macro. Create mask of LS bits.
1182
1183 Mon Mar 17 18:10:05 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1184
1185 * sim-inline.h: Add definitions for sim-types.
1186 (ALL_BY_MODULE): New macro, encapsulate full inlining by the
1187 module.
1188
1189 Mon Mar 17 15:38:27 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1190
1191 * sim-events.h: Remove defunct reference to callback struct.
1192
1193 Mon Mar 17 15:10:07 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1194
1195 * configure: Re-generate.
1196
1197 Mon Mar 17 15:04:47 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1198
1199 * Make-common.in (CSEARCH): Do not include the gdb directory in
1200 the search path.
1201
1202 Mon Mar 17 13:16:26 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1203
1204 * Make-common.in (SIM_ENDIAN, SIM_HOSTENDIAN, SIM_INLINE,
1205 SIM_WARNING): Drop, requiring the simulator specific Makefile.in
1206 to explicitly incorporate these.
1207
1208 * aclocal.m4 (--enable-sim-alignment); New option. Strongly
1209 specify the alignment restrictions of the target architecture -
1210 without this option all alignment restrictions are accomodated.
1211 (--enable-sim-assert): New option. Conditionally compile in
1212 assertion statements.
1213 (--enable-sim-float): New option. Strongly specify the target's
1214 floating point support.
1215 (--enable-sim-hardware): New option. Specify the hardware devices
1216 included in the simulation.
1217 (--enable-sim-packages): New option. Specify the hardware
1218 packages included in the simulation.
1219 (--enable-sim-regparm): New option. Specify that parameters be
1220 passed in registers instead of on the stack.
1221 (--enable-sim-reserved-bits): New option. Specify that reserved
1222 bits within an instruction are are correctly set.
1223 (--enable-sim-smp): New option. Specify the level of SMP support
1224 to be included in the simulator.
1225 (--enable-sim-stdcall): New option. Specify an alternative
1226 function call convention.
1227 (--enable-sim-xor-endian): New option. Configure xor-endian
1228 support used by some targets to implement bi-endian support.
1229
1230 Fri Mar 14 19:51:21 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1231
1232 * aclocal.m4 (--enable-sim-hostendian): New option. Allow the
1233 host endianness to be overridden.
1234 (--enable-sim-endian): Allow the target platform's byte order
1235 to be overridden.
1236 (--enable-sim-inline): Control the inlining of common components.
1237 (--enable-sim-bswap): For compatibility, also define WITH_BSWAP.
1238 (--enable-sim-warnings): Enable additional GCC compiler checks.
1239 * Make-common.in (SIM_ENDIAN, SIM_HOSTENDIAN, SIM_INLINE,
1240 SIM_WARNINGS): Add.
1241
1242 * sim-n-core.h, sim-n-bits.h, sim-n-endian.h: Rename from
1243 sim-*-n.h so that the names are uniq on dos machines
1244 * sim-core.c, sim-bits.c, sim-endian.c: Update.
1245
1246 Thu Mar 13 12:32:42 1997 Doug Evans <dje@canuck.cygnus.com>
1247
1248 * run.c: #include "libiberty.h".
1249 (main): New locals sd,no_args,sim_argv.
1250 Run buildargv on -a option. Pass argv to sim_open, argv[0]
1251 is program name. Update call to sim_set_callbacks.
1252 Record result of sim_open, pass to other sim_foo routines.
1253
1254 Thu Mar 13 10:24:05 1997 Michael Meissner <meissner@cygnus.com>
1255
1256 * callback.c (os_printf_filtered): Do not call exit(1) or print a
1257 final newline.
1258
1259 Thu Mar 6 15:50:28 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1260
1261 * callback.c: Add os_flush_stdout and vprintf_filtered callbacks.
1262 Route stdout through buffered IO.
1263
1264 * callback.c: Add os_flush_stderr, os_write_stderr,
1265 os_evprintf_filtered functions to route error output through
1266 stderr.
1267
1268 * sim-io.h, sim-io.c (sim_io_flush_stderr, sim_io_flush_stdout):
1269 Correct return type - should be void.
1270
1271 Fri Mar 7 20:14:37 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1272
1273 * sim-basics.h: Clean up. Many macro's moved to sim-inline.h.
1274
1275 * sim-config.h: Ditto. For some options - eg WITH_DEVICES - do
1276 not provide a default value as undefined indicates disable code.
1277
1278 Thu Mar 6 15:50:28 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1279
1280 * sim-core.h, sim-core-n.h, sim-core.c: Borrow code from ppc
1281 directory.
1282 * sim-events.h, sim-events.c: Ditto.
1283 * sim-io.h, sim-io.c: Ditto.
1284
1285 Tue Mar 4 09:35:56 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1286
1287 * sim-alu.h (ALU_SUB_CA, ALU*_SUB_CA): New alu operation.
1288
1289 * sim-bits.h, sim-bits-n.h, sim-bits.c (LSMASKED*): New macro's
1290 extract the tail or least signifiant bits from an integer of the
1291 specified size.
1292
1293 * sim-bits.h, sim-bits.c: Clean up conditionally compiled #if
1294 WITH_TARGET_BITSIZE so that the compilation will fail when an
1295 unsupported bitsize value is defined.
1296
1297 (INSERTED*): Convert to functions.
1298 (EXTRACTED*): Ditto.
1299
1300 (SIGN_EXTEND, SEXT): Change to more terse name.
1301
1302 Tue Mar 4 09:35:56 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1303
1304 * sim-inline.h: Allow explicit control over which .c files will be
1305 included by their header.
1306
1307 * sim-inline.h: Allow explicit control over which .c files use the
1308 alternative - REGPARM - parameter passing mechanism.
1309
1310 * sim-inline.h, sim-inline.c: Don't attempt to include any of
1311 icache.c, idecode.c, semantics.c or support.c. Those names are
1312 not generally applicable.
1313
1314 Thu Feb 27 10:17:23 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1315
1316 * sim-bits.c, sim-bits-n.h (new): Split sim-bits.c into two parts
1317 in a fashion similar to sim-endian-n.
1318
1319 * sim-endian.h: (H_word, L_word, AL_*, VL_*): Extend to include
1320 both value and address macro's.
1321
1322 Tue Feb 25 18:51:57 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
1323
1324 * sim-alu.h (ALU16_BEGIN, ALU16_SET, ...): Fill in.
1325
1326 * sim-endian.h (L_word, H_word): Replace MS2W_4, LS2W_4 with more
1327 generic L_word, H_word macro's.
1328
1329 Thu Feb 20 18:36:55 1997 Andrew Cagney <cagney@critters.cygnus.com>
1330
1331 * sim-basics.h: Borrow code from ppc directory.
1332 * sim-bits.c: Ditto.
1333 * sim-bits.h: Ditto.
1334 * sim-config.h: Ditto.
1335 * sim-endian-n.h: Ditto.
1336 * sim-endian.c: Ditto.
1337 * sim-endian.h: Ditto.
1338 * sim-inline.c: Ditto.
1339 * sim-inline.h: Ditto.
1340 * sim-types.h: Ditto.
1341
1342 Wed Feb 19 12:40:50 1997 Andrew Cagney <cagney@critters.cygnus.com>
1343
1344 * sim-alu.h (ALU_SET16, ALU_SET32, ALU_SET64, etc): Make available
1345 all the ALU size alternatives and then auto-configure a default.
1346
1347 * sim-alu.h: Copy ppc/idecode_expression.h.
1348
1349 Mon Feb 17 10:44:18 1997 Andrew Cagney <cagney@critters.cygnus.com>
1350
1351 * bits.h, bits.c (SIGN_EXTEND32, SIGN_EXTEND64): New functions,
1352 sign extend a bit within a value.
1353
1354 * sim-endian.h, sim-endian-n.h (offset_N): New functions - return
1355 a pointer into the middle of a host word.
1356 * sim-endian.h (MS2W_4, LS2W_4): Use this function.
1357
1358 Tue Feb 11 13:46:49 1997 Michael Meissner <meissner@tiktok.cygnus.com>
1359
1360 * callback.c: If HAVE_CONFIG_H is defined, include config.h from
1361 autoconf. If HAVE_UNISTD_H is defined, include unistd.h to get
1362 appropriate definitions of read, write, etc. Add prototype for
1363 system.
1364
1365 Tue Feb 4 13:24:44 1997 Doug Evans <dje@canuck.cygnus.com>
1366
1367 * Makefile.in (libcommon.a): Delete.
1368 (callback.o,targ-map.o): Delete, moved to Make-common.in.
1369 (gentmap,targ-vals.h,targ-map.c): Likewise.
1370 (run-autoconf): Delete.
1371 * aclocal.m4 (SIM_AC_OUTPUT): Redo creation of Makefile.
1372 (common makefile fragment): Moved back into ...
1373 * Make-common.in: Resurrect.
1374 * configure.in (AC_LINK_FILES): Delete, unnecessary now.
1375 * configure: Regenerated.
1376
1377 Fri Jan 31 07:16:49 1997 Doug Evans <dje@canuck.cygnus.com>
1378
1379 * aclocal.m4 (SIM_AC_COMMON): Move COMMON_MAKEFILE_FRAG from here.
1380 (SIM_AC_OUTPUT): To here.
1381
1382 Fri Jan 24 10:37:17 1997 Stu Grossman (grossman@critters.cygnus.com)
1383
1384 * aclocal.m4 (COMMON_MAKEFILE_FRAG): Quote a couple of $'s in
1385 comments and single quotes. Fixes a problem found on hpux.
1386
1387 Thu Jan 23 13:35:03 1997 Stu Grossman (grossman@critters.cygnus.com)
1388
1389 * aclocal.m4: Remove Make-common.in from dependencies.
1390 * (distclean): Remove targ-vals.def.
1391
1392 * aclocal.m4 (SIM_AC_COMMON): Move contents of Make-common.in
1393 into here. Makes insertion into makefiles easier. Also, change
1394 the way that callback.o, gentmap, targ-vals.h, targ-map.c,
1395 targ-map.o, and run are built. They are now built in the
1396 individual simulator directories, taking sources from ../common as
1397 necessary. This replaces the merging of libcommon.a into
1398 linsim.a, which was problematic for the WinGDB build process.
1399 * run.c: Include config.h from . instead of ../common.
1400 * Make-common.in: Remove. It's no longer necessary.
1401
1402 Mon Dec 16 15:02:33 1996 Ian Lance Taylor <ian@cygnus.com>
1403
1404 * Make-common.in (ALL_CLAGS): Put CFLAGS at the end.
1405 (.c.o): Put $(ALL_CFLAGS) before the file being compiled.
1406
1407 Wed Dec 11 11:30:58 1996 Jim Wilson <wilson@cygnus.com>
1408
1409 * run.c (main): Set target_byte_order before call to sim_open.
1410
1411 Sun Dec 8 18:22:06 1996 Doug Evans <dje@canuck.cygnus.com>
1412
1413 * callback.c: #include <stdlib.h>
1414 (os_error): New function.
1415 (default_callback): Add os_error.
1416
1417 Mon Nov 25 19:44:35 1996 Doug Evans <dje@canuck.cygnus.com>
1418
1419 * Make-common.in (Makefile): Set CONFIG_HEADERS="".
1420 * aclocal.m4: Mark the fact that --enable-sim-bswap isn't host
1421 specific.
1422 (SIM_AC_OUTPUT): Don't build Makefile if CONFIG_FILES="".
1423
1424 Wed Nov 20 01:11:04 1996 Doug Evans <dje@canuck.cygnus.com>
1425
1426 * run.c: #include ../common/config.h, tconfig.h.
1427 (myname): New static global.
1428 (main): Recognize new options -a, -c. Also recognize -h if h8/300.
1429 Only process -c ifdef SIM_HAVE_SIMCACHE.
1430 Only process -p/-s ifdef SIM_HAVE_PROFILE.
1431 Parse program name from argv[0] and use in error messages.
1432 Pass sim_args to sim_open. Pass prog_args to sim_create_inferior.
1433 Add support for incomplete h8/300 termination indicators.
1434 (usage): Make more verbose.
1435 * aclocal.m4,config.in,tconfig.in,configure.in,configure: New files.
1436 * Makefile.in,Make-common.in,callback.c: New files.
1437 * nltvals.def,gentmap.c,gentvals.sh: New files.
1438
1439 Tue Nov 12 13:34:00 1996 Dawn Perchik <dawn@cygnus.com>
1440
1441 * run.c: Include stdarg.h if __STDC__.
1442
1443 Tue Oct 15 11:16:31 1996 Jeffrey A Law (law@cygnus.com)
1444
1445 * run.c (main): Don't print out anything if the signal
1446 number is zero (ie no signal).
1447
1448 Tue Oct 15 11:20:44 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1449
1450 * run.c (main): Print out if the program raised a signal.
1451
1452 Wed Sep 18 09:52:14 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1453
1454 * run.c (exec_bfd): Rename from sim_bfd, to use the gdb name.
1455 (main): Ditto.
1456
1457 Tue Sep 17 11:04:50 1996 James G. Smith <jsmith@cygnus.co.uk>
1458
1459 * run.c (main): Explicitly cast malloc() parameter.
1460
1461 Thu Sep 12 11:27:21 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1462
1463 * run.c (sim_bfd): New global to hold the bfd pointer for the
1464 executable.
1465 (main): Initialize sim_bfd.
1466
1467 Fri Dec 15 16:27:49 1995 Ian Lance Taylor <ian@cygnus.com>
1468
1469 * run.c (main): Use new bfd_big_endian macro.
1470
1471 Wed Nov 8 15:49:49 1995 James G. Smith <jsmith@pasanda.cygnus.co.uk>
1472
1473 * run.c (main): Removed SH specific comments, so source is
1474 generic. Also updated to only load relevant sections. Moved
1475 sim_open() to after callback attach (to match GDB).
1476
1477 * run.1: Removed SH specific comments.
1478
1479 Sat Oct 21 12:31:01 1995 Jim Wilson <wilson@chestnut.cygnus.com>
1480
1481 * run.c (main): Always return sigrc at end.
1482
1483 Tue Oct 10 12:03:13 1995 J.T. Conklin <jtc@rtl.cygnus.com>
1484
1485 * run.c (main): Print error diagnostic and exit if bfd_openr() or
1486 bfd_check_format() fails.
1487
1488 Thu Sep 28 15:40:36 1995 steve chamberlain <sac@slash.cygnus.com>
1489
1490 * run.c, run.1: From sh directory.
1491
1492