Re-do --enable-sim-hardware so that each simulator can specify the devices
[deliverable/binutils-gdb.git] / sim / common / ChangeLog
1 Wed Mar 25 12:35:29 1998 Andrew Cagney <cagney@b1.cygnus.com>
2
3 * configure: Regenerated to track ../common/aclocal.m4 changes.
4
5 Mon Mar 23 10:25:08 1998 Andrew Cagney <cagney@b1.cygnus.com>
6
7 * aclocal.m4 (SIM_AC_OPTION_HARDWARE): Add second argument,
8 appends extra devices.
9 (SIM_AC_OPTION_HARDWARE): Substute sim_hw, a non-duplicate list of
10 the device names.
11
12 * Make-common.in (hw-config.h): New target, create hw-config.h
13 file.
14 (SIM_HW): Definition from @sim_hw@.
15 (hw-base.o): Depend on hw-config.h
16
17 Tue Mar 24 17:41:35 1998 Stu Grossman <grossman@bhuna.cygnus.co.uk>
18
19 * Make-common.in: Get SHELL from configure.
20 * (stamp-tvals sim-inline.c): Use $(SHELL) when invoking
21 move-if-change. Fixes NT native build problem.
22 * Makefile.in (nltvals.def): Use $(SHELL) when invoking
23 move-if-change. Fixes NT native build problem.
24 * configure: Regenerate with autoconf 2.12.1 to fix shell issues for
25 NT native builds.
26
27 Sun Mar 22 16:54:40 1998 Andrew Cagney <cagney@b1.cygnus.com>
28
29 * hw-device.h, hw-device.c (hw_strdup): New function.
30
31 * hw-base.c (hw_create): Use hw_strdup when saving a copy of the
32 strings name, family and args.
33 (full_name_of_hw): Use hw_strdup when returning the full path.
34
35 * hw-properties.c: Clean up property not found / wrong type error
36 messages.
37
38 * hw-tree.c (hw_tree_parse): Finish a devices initialization
39 before attaching any ports.
40
41 * hw-base.c (hw-config.): Include. Replace hardwired table.
42
43 * dv-glue.c: Copy over ../ppc/hw_glue.c. Update to new framework.
44
45 * Make-common.in: Add rule for dv-glue.o.
46
47 Sun Mar 22 16:45:54 1998 Andrew Cagney <cagney@b1.cygnus.com>
48
49 * hw-base.c (hw_finish): Move setting of trace level to here.
50 (hw_create): From here.
51
52 * hw-base.h, hw-base.c (do_hw_attach_regs): Copy function from
53 ../ppc/device_table.c.
54
55 * dv-pal.c (hw_pal_finish): Attach PAL device to parent bus.
56
57 * hw-tree.c (print_properties): Supress path when printing
58 properties of root node.
59
60 Sun Mar 22 16:21:15 1998 Andrew Cagney <cagney@b1.cygnus.com>
61
62 * hw-device.h (HW_TRACE): Define.
63 (hw_trace): Declare.
64 * hw-device.c (hw_trace): Implement function.
65
66 * hw-base.c (hw_create): Set hw trace level from "trace?"
67 property.
68
69 * dv-core.c (dv_core_attach_address_callback): Add trace.
70
71 * dv-pal.c: Replace DTRACE with HW_TRACE.
72
73 Sun Mar 22 15:23:35 1998 Andrew Cagney <cagney@b1.cygnus.com>
74
75 * hw-device.h (HW_ZALLOC, HW_MALLOC): New macros.
76 (hw_alloc_data): Delcare.
77 (struct hw): Add member alloc_of_hw.
78
79 * hw-device.c (hw_zalloc, hw_malloc, hw_free, hw_free_all): New
80 functions. Assocate memory with a device.
81 (stdlib.h): Include.
82
83 * hw-base.h (set_hw_delete): Define.
84 (hw_delete_callback): Declare.
85 (hw_delete): Declare.
86
87 * hw-base.c (hw_delete): Implement function.
88 (struct hw_base_data): Add member to_delete.
89 (ignore_hw_delete): New function, does nothing.
90 (hw_create): Set the hw_delete method.
91 (hw_create): Allocate the base type using HW_ZALLOC before setting
92 any methods.
93
94 * hw-tree.h, hw-tree.c (hw_tree_delete): New function.
95
96 * hw-properties.c: Replace zalloc/zfree with hw_zalloc/hw_free.
97
98 * hw-ports.c: Replace zalloc/zfree with hw_zalloc/hw_free.
99 (attach_hw_port_edge): Add struct hw argument
100
101 * dv-pal.c (hw_pal_finish): Replace zalloc/zfree with
102 hw_zalloc/hw_free.
103
104 Sun Mar 22 15:09:52 1998 Andrew Cagney <cagney@b1.cygnus.com>
105
106 * hw-device.h (hw_attach_address_callback,
107 hw_detach_address_callback): Attach to a single space not a space
108 mask. Clarify interpretation of SPACE:ADDR parameters.
109
110 * hw-base.c (passthrough_hw_attach_address,
111 passthrough_hw_detach_address): Update.
112 * dv-core.c (dv_core_attach_address_callback): Ditto.
113 * dv-pal.c (hw_pal_attach_address): Ditto.
114
115 Thu Mar 19 00:41:00 1998 Andrew Cagney <cagney@b1.cygnus.com>
116
117 * sim-options.h: Document additional CPU arg to OPTION_HANDLER.
118
119 Wed Mar 18 14:13:02 1998 Andrew Cagney <cagney@b1.cygnus.com>
120
121 * Make-common.in (SIM_HW_OBJS, SIM_HW_SRC, SIM_DV_OBJS): Define.
122 (hw-base_h, hw-device_h, hw-handles_h, hw-instances_h, hw_ports_h,
123 hw-properties_h, hw-tree_h): Define, point at corresponding
124 header.
125 (hw_base_headers): Define list of headers included by hw-base.h
126 (hw-base.o, hw-device.o, hw-instances.o, hw-handles.o, hw-ports.o,
127 hw-properties.o, hw-tree.o): Specify dependencies.
128 (dv-core.o, dv-pal.o): Ditto.
129
130 * sim-hw.h: New file.
131
132 * hw-device.h, hw-device.c, hw-properties.h, hw-properties.c,
133 hw-ports.h, hw-ports.c: New files. Copied from ../ppc/device.[ch].
134
135 * hw-tree.h, hw-tree.c: New files. Copied from ../ppc/tree.[hc].
136
137 * hw-base.h, hw-base.c: new files. Copied from
138 ../ppc/device_table.[hc].
139
140 * dv-core.c, dv-pal.c: New files. Copied from
141 ../ppc/hw_{core,pal}.c
142
143 * sim-basics.h (struct hw): Declare.
144 (enum port_direction, enum object_disposition): Declare.
145
146 Wed Mar 18 12:38:12 1998 Andrew Cagney <cagney@b1.cygnus.com>
147
148 * aclocal.m4 (SIM_AC_OPTION_HARDWARE): Set sim_hw_obj, sim_dv_obj,
149 sim_dv_src in Makefile. Take list of devices as parameter to m4
150 macro..
151
152 * configure: Regenerated to track ../common/aclocal.m4 changes.
153
154 Mon Mar 16 12:37:33 1998 Andrew Cagney <cagney@b1.cygnus.com>
155
156 * sim-trace.h, sim-trace.c (trace_prefix): Pass in sim_cia so that
157 trace_prefix can abort cleanly.
158
159 Sat Mar 14 18:36:12 1998 Doug Evans <devans@seba.cygnus.com>
160
161 * dv-sockser.c, dv-sockser.h: New files.
162 * Make-common.in (dv-sockser.o): Add rule for.
163 * aclocal.m4: Check for fcntl.h.
164 * config.h: Add HAVE_FCNTL_H.
165
166 * sim-break.c (remove_breakpoint): Fix thinko.
167
168 * sim-hload.c (sim_load): Provide default value of SIM_HANDLES_LMA.
169 Use SIM_HANDLES_LMA for lma_p arg to sim_load_file.
170
171 1998-03-13 Fred Fish <fnf@cygnus.com>
172
173 * sim-base.h (struct sim_state_base): Add prog_syms and
174 define macro STATE_PROG_SYMS.
175 * sim-trace.c (trace_prefix): Add variables abfd, symsize,
176 symbol_count, and asymbols. Call bfd_get_symtab_upper_bound
177 and bfd_canonicalize_symtab, to get symbol table on first use
178 and preserve it via STATE_PROG_SYMS for future calls to
179 bfd_find_nearest_line.
180
181 Wed Mar 11 14:02:47 1998 Andrew Cagney <cagney@b1.cygnus.com>
182
183 * sim-core.h, sim-core.c (sim_core_map_to_str): Delete.
184
185 * sim-core.c (sim_core_attach): Handle a generic number of maps -
186 up to nr_maps, not just access_* maps.
187
188 * sim-profile.h (struct PROFILE_DATA): Track nr_maps different
189 maps.
190
191 * sim-profile.c (profile_print_core): Make map unsigned. Iterate
192 over nr_maps not sim_core_nr_maps.
193
194 * sim-events.h, sim-events.c (sim_events_watch_core): Change
195 core_map argument to unsigned.
196 (struct _sim_core): Ditto for struct member core_map.
197
198 * sim-core.h (nr_sim_core_maps, sim_core_*_map): Delete
199
200 * sim-basics.h (access_io, access_*_io): Define.
201 (map_read, map_write, map_exec, map_io): Define.
202
203 * sim-core.c, sim-core.h (sim_core_attach): Replace argument
204 attach with more generic mapmask.
205 (sim_core_{read,write}_*): Change map argument to unsigned.
206
207 * sim-core.c (sim_core_uninstall, sim_core_attach,
208 sim_core_detach): Iterate over nr_maps instead of
209 sim_core_nr_maps.
210
211 * sim-break.c (insert_breakpoint): Write breakpoints to exec_map
212 instead of the write_map.
213 (remove_breakpoint): Ditto.
214
215 * genmloop.sh (engine_resume_full): Replace sim_core_*_map
216 with read_map, write_map, exec_map resp.
217
218 * cgen-mem.h (DECLARE_GETMEM, DECLARE_SETMEM, DECLARE_GETIMEM):
219 Ditto.
220
221 * cgen-utils.c (sim_disassemble_insn): Ditto.
222
223 * sim-hrw.c (sim_write, sim_write): Ditto.
224
225 * sim-utils.h, sim-utils.c (access_to_str, map_to_str,
226 transfer_to_str): New functions.
227
228 Mon Mar 9 12:50:59 1998 Doug Evans <devans@seba.cygnus.com>
229
230 * sim-base.h (sim_state_base): New member environment.
231 (STATE_ENVIRONMENT): New macro.
232 * sim-config.c (current_environment): Delete.
233 (sim_config_default): New function.
234 (sim_config): Set STATE_ENVIRONMENT, not current_environment.
235 * sim-config.h (current_environment,CURRENT_ENVIRONMENT): Delete.
236 (sim_config_default): Add prototype.
237 * sim-module.c (sim_pre_argv_init): Call sim_config_default.
238 * sim-options.c (standard_option_handler, case OPTION_ENVIRONMENT):
239 Set STATE_ENVIRONMENT, not current_environment.
240
241 Mon Mar 9 11:59:03 1998 Jim Wilson <wilson@cygnus.com>
242
243 * sim-fpu.c (NR_GUARDS64): Change NR_PAD32 to NR_PAD64.
244
245 Tue Mar 3 10:53:05 1998 Andrew Cagney <cagney@b1.cygnus.com>
246
247 * sim-types.h (SIGNED32, SIGNED64): Pacify GCC.
248
249 * sim-alu.h (ALU64_BEGIN): Make alu64_r unsigned.
250
251 Mon Mar 2 10:20:06 1998 Doug Evans <devans@seba.cygnus.com>
252
253 * Make-common.in (TAGS): Make smarter.
254 * Makefile.in (TAGS): Ditto.
255
256 Fri Feb 27 19:09:57 1998 Doug Evans <devans@canuck.cygnus.com>
257
258 * sim-module.c (*): Fix typos in assertion tests.
259
260 Sat Feb 28 13:54:10 1998 Andrew Cagney <cagney@b1.cygnus.com>
261
262 * sim-module.c (sim_pre_argv_init): String passed to asprintf
263 can't be constant.
264
265 * sim-options.c (sim_parse_args): Ditto.
266 (sim_args_command): Return OK, instead of nothing, for an empty
267 command.
268
269 Fri Feb 27 13:29:13 1998 Andrew Cagney <cagney@b1.cygnus.com>
270
271 * sim-profile.c (profile_info): Rename from profile_print. Drop
272 misc and misc_cpu callback arguments. Use
273 PROFILE_INFO_CPU_CALLBACK and STATE_PROFILE_INFO_CALLBACK instead.
274 (profile_install): Install profile_info function.
275
276 * sim-profile.h (PROFILE_INFO_CPU_CALLBACK,
277 STATE_PROFILE_INFO_CALLBACK): Define.
278 (struct PROFILE_DATA): Add field info_cpu_callback.
279 (profile_print): Delete function.
280
281 * sim-base.h (STATE_MODULES): Define. Replace individual
282 STATE_*_LIST with single struct module_list.
283
284 * sim-module.h (MODULE_INFO_FN, MODULE_INFO_LIST): Declare.
285 (struct module_list): Declare.
286
287 * sim-module.h, sim-module.c (sim_module_add_info_fn,
288 sim_module_info): New functions.
289 (sim_module_install): Clean up module data structures.
290
291 * sim-info.c (sim_info): New file. New function. Call
292 sim_module_info.
293
294 * Make-common.in (sim-info.o): Define rule.
295 (SIM_NEW_COMMON_OBJS): Add sim-info.o.
296
297
298 Fri Feb 27 18:26:16 1998 Doug Evans <devans@canuck.cygnus.com>
299
300 * sim-base.h (sim_cpu_base): New members name, options.
301 (sim_cpu_lookup): Add prototype.
302 * sim-module.c (sim_pre_argv_init): Provide default names for cpus.
303 * sim-options.h (DECLARE_OPTION_HANDLER): New argument `cpu'.
304 (sim_add_option_table): Update prototype.
305 * sim-options.c (sim_add_option_table): New argument `cpu'.
306 (standard_option_handler,standard_install): Update.
307 (sim_parse_args): Handle cpu specific options.
308 (print_help): New static function.
309 (sim_print_help): Call it. Print cpu specific options.
310 (find_match): New static function.
311 (sim_args_command): Call it. Handle cpu specific options.
312 * sim-utils.c (sim_cpu_lookup): New function.
313 * sim-memopt.c (memory_option_handler): Update.
314 (sim_memopt_install): Update.
315 * sim-model.c (model_option_handler): Update.
316 (model_install): Update.
317 * sim-profile.c (profile_option_handler): Update.
318 (profile_install): Update.
319 * sim-trace.c (trace_option_handler): Update.
320 (trace_install): Update.
321 * sim-watch.c (watchpoint_option_handler): Update.
322 (sim_watchpoint_install): Update.
323 * cgen-scache.c (scache_option_handler): Update.
324 (scache_install): Update.
325
326 Wed Feb 25 11:00:26 1998 Doug Evans <devans@canuck.cygnus.com>
327
328 * Make-common.in (check): Run `make check' in testsuite dir.
329
330 Wed Feb 25 14:40:24 1998 Andrew Cagney <cagney@b1.cygnus.com>
331
332 * sim-trace.c (trace_result0): New function.
333
334 * sim-trace.h (TRACE_FP_*, TRACE_FPU_*): Rename TRACE_FPU_*
335 macro's to TRACE_FP_*. TRACE_FPU_* should be defined and used when
336 tracing sim_fpu variables.
337 (TRACE_ALU_RESULT0): Define.
338 (TRACE_FP_RESULT_WORD): Define.
339 (TRACE_FP_INPUT_WORD1): Define.
340
341 * sim-fpu.c, sim-fpu.h (sim_fpu_max32, sim_fpu_max64, sim_fpu_one,
342 sim_fpu_two): New constants.
343 (sim_fpu_op1, sim_fpu_op2): New types.
344 (struct _sim_fpu): Delete member result. Re-order other members.
345 (sim_fpu_sign, sim_fpu_exp): New functions.
346 (sim_fpu_max, sim_fpu_min): new functions.
347 (EXPMAX32, EXPMAX64, NR_PAD32, NR_PAD64, NR_GUARDS32, NR_GUARDS64,
348 NORMAL_EXPMAX32, NORMAL_EXPMAX64): Define.
349
350 Tue Feb 24 22:45:39 1998 Doug Evans <devans@seba.cygnus.com>
351
352 * sim-profile.c (profile_print): Delete duplicate test of
353 PROFILE_INSN_IDX.
354 (profile_print_pc): Exit early if data collection not set up.
355 (profile_print_core): Simplify by calling sim_core_map_to_str.
356 * sim-core.h (sim_core_map_to_str): Declare.
357 * sim-core.c (sim_core_map_to_str): Make non-static.
358
359 * genmloop.sh (engine_resume): Update insn_count before exiting.
360 (engine_resume_full): Keep accurate core profile data.
361
362 * cgen-utils.c (sim_disassemble_insn): Don't use
363 sim_core_read_aligned_N, it messes up profiling results.
364
365 Mon Feb 23 20:45:57 1998 Mark Alexander <marka@cygnus.com>
366
367 * nltvals.def: Regenerate with MN10300 additions.
368
369 Tue Feb 24 13:18:42 1998 Andrew Cagney <cagney@b1.cygnus.com>
370
371 * sim-trace.h (TRACE_ALU_RESULT2): Define.
372
373 * sim-trace.h, sim-trace.c (trace_result_word2,
374 trace_input_word4, trace_result_word4): New function.
375
376 Mon Feb 23 13:08:35 1998 Doug Evans <devans@canuck.cygnus.com>
377
378 * cgen-sim.h (SEM_NEXT_PC): New arg `len'.
379
380 * sim-xcat.h: Delete.
381 * cgen-mem.h: Delete inclusion of sim-xcat.h.
382 * cgen-sim.h: Ditto.
383 * sim-alu.h: Replace sim-xcat.h with symcat.h.
384 * sim-n-bits.h: Ditto.
385 * sim-n-core.h: Ditto.
386 * sim-n-endian.h: Ditto.
387
388 Mon Feb 23 13:19:58 1998 Michael Meissner <meissner@cygnus.com>
389
390 * syscall.c (cb_syscall): Handle short reads, and EOF.
391
392 Tue Feb 24 00:29:57 1998 Andrew Cagney <cagney@b1.cygnus.com>
393
394 * sim-trace.c (print_data): case trace_fmt_fp missing break. Use
395 sim_fpu to safely print fp_word values.
396 (print_data): Add trace_fmt_bool and trace_fmt_addr.
397 (trace_result_bool1, trace_result_addr1): New functions.
398 (trace_input_bool1, trace_input_addr1): New functions.
399
400 * sim-trace.h (TRACE_FPU_*): Define.
401
402 Mon Feb 23 13:24:54 1998 Andrew Cagney <cagney@b1.cygnus.com>
403
404 * sim-fpu.h (enum sim_fpu_class): Add sim_fpu_class_denorm.
405 (sim_fpu_fpto, sim_fpu_tofp): Define.
406
407 Fri Feb 20 18:08:51 1998 Andrew Cagney <cagney@b1.cygnus.com>
408
409 * sim-fpu.c (sim_fpu_cmp): New function.
410
411 Wed Feb 18 16:29:21 1998 Doug Evans <devans@canuck.cygnus.com>
412
413 * cgen-utils.h (sim_disassemble_insn): Use CGEN_INSN_BITSIZE
414 instead of abuf->length.
415 * sim-trace.c (trace_options): Have -t only trace a few useful things.
416 (set_trace_option_mask): Renamed from set_trace_options.
417 (set_trace_option): New function.
418 (trace_option_handler): Update calls to set_trace_option{,_mask}.
419 * sim-trace.h (TRACE_USEFUL_MASK): New macro.
420
421 Wed Feb 18 12:42:15 1998 Andrew Cagney <cagney@b1.cygnus.com>
422
423 * sim-basics.h: Declare struct _sim_fpu.
424
425 Tue Feb 17 16:27:46 1998 Andrew Cagney <cagney@b1.cygnus.com>
426
427 * sim-trace.h (TRACE_ALU_INPUT*, TRACE_ALU_RESULT): Define.
428 (trace_prefix, trace_input*, trace_result*): Declare.
429 (trace_one_insn): Change declaration, assume trace_prefix called.
430 (trace_generic): Like trace_one_insn.
431 (TRACE_ALU_IDX, TRACE_*_IDX): Change #define's to enum.
432 (TRACE_alu, TRACE_[a-z]*): Update.
433
434 * sim-trace.c (trace_prefix, trace_input*, trace_result*,
435 trace_insn, save_data, trace_idx_to_str, print_data): New
436 functions.
437 (trace_one_insn): Rewrite.
438 (trace_generic): New function.
439
440 Tue Feb 17 17:27:30 1998 Doug Evans <devans@seba.cygnus.com>
441
442 * Make-common.in (CGEN_MAIN_SCM): Update.
443 * aclocal.m4 (USE_MAINTAINER_MODE): New variable.
444
445 * cgen-sim.h (SEMANTIC_CACHE_FN): Delete.
446 (SEMANTIC_FN): Rewrite declaration.
447 (DECODE): Update type of semantic_fast member.
448 ({EX,SEM}_FN_NAME): Have only one version.
449 * cgen.sh: Support building cpu.c.
450 * sim-base.h (sim_state_base): Delete conditionals surrounding
451 member scache_size.
452
453 Tue Feb 10 18:31:49 1998 Andrew Cagney <cagney@b1.cygnus.com>
454
455 * sim-load.c (sim_load_file): Print LMA/VMA according to value
456 used.
457
458 Tue Feb 10 14:56:23 1998 Ian Carmichael <iancarm@cygnus.com>
459
460 * sim-core.c: Add missing prototypes for WITH_DEVICES.
461 Add missing parameters to device_io calls.
462 * sim-core.h: Add missing parameters to device_io calls.
463
464 Mon Feb 9 14:48:37 1998 Doug Evans <devans@canuck.cygnus.com>
465
466 * cgen-sim.h (DECODE): Always use switch for `read' for now.
467 (PAREXEC): Renamed from PARALLEL_EXEC. All uses updated.
468 (SEMANTIC{,_CACHE}_FN): Fix return type.
469 * cgen.sh (decode): Add s/@arch@/$arch/.
470 * genmloop.sh (@cpu@_engine_run): Delete `current_state'.
471 (engine_resume): Likewise. Make `engine' volatile. Save copy
472 of cpu pointer in volatile object. Initialize read switch if
473 -parallel.
474
475 Thu Feb 5 13:27:04 1998 Doug Evans <devans@seba.cygnus.com>
476
477 * cgen-sim.h (EX_FN_NAME): _exc_ -> _ex_.
478 (SEM_INSN): New macro.
479
480 Tue Feb 3 16:31:56 1998 Andrew Cagney <cagney@b1.cygnus.com>
481
482 * sim-run.c (sim_engine_run): Assume IMEM is 32 bit.
483
484 Sun Feb 1 16:47:51 1998 Andrew Cagney <cagney@b1.cygnus.com>
485
486 * configure: Regenerated to track ../common/aclocal.m4 changes.
487
488 Sun Feb 1 16:16:57 1998 Andrew Cagney <cagney@b1.cygnus.com>
489
490 * sim-types.h (fp_word): New type, define according to
491 WITH_TARGET_FLOATING_POINT_BITSIZE.
492
493 * aclocal.m4 (default_sim_floating_point_bitsize): Add
494 configuration of size of floating point registers.
495
496 Sun Feb 1 14:02:31 1998 Andrew Cagney <cagney@b1.cygnus.com>
497
498 * sim-profile.c (profile_print): Only print CPU <N> if other
499 output is going to appear.
500
501 Sat Jan 31 18:15:41 1998 Andrew Cagney <cagney@b1.cygnus.com>
502
503 * configure: Regenerated to track ../common/aclocal.m4 changes.
504
505 Sat Jan 31 18:03:55 1998 Andrew Cagney <cagney@b1.cygnus.com>
506
507 * sim-types.h (address_word): Typedef according to
508 WITH_TARGET_ADDRESS_BITSIZE.
509 (signed_cell, unsigned_cell, natural_cell): Ditto using
510 WITH_TARGET_CELL_BITSIZE.
511
512 * sim-config.h (WITH_TARGET_ADDRESS_BITSIZE): Define.
513 (WITH_TARGET_CELL_BITSIZE): Define.
514 (WITH_HOST_WORD_BITSIZE): Delete.
515
516 * sim-config.c (print_sim_config): Update.
517
518 * aclocal.m4 (SIM_AC_OPTION_BITSIZE): Add support for
519 configuration of address and OpenFirmware cell sizes.
520
521 Fri Jan 30 09:36:33 1998 Andrew Cagney <cagney@b1.cygnus.com>
522
523 * sim-engine.h (sim_engine_run): Add argument nr_cpus.
524 * sim-run.c (sim_engine_run): Update.
525
526 * sim-engine.h (SIM_ENGINE_HALT_HOOK): Use SET_CPU_CIA instead of
527 CPU_CIA.
528 * sim-run.c (sim_engine_run): Ditto.
529
530 * sim-resume.c (sim_resume): Obtain nr_cpus from sim_engine.
531 (sim_resume): Pass nr_cpus to sim_engine_run.
532
533 * sim-engine.h (struct _sim_engine): Add member nr_cpus.
534
535 * sim-engine.c (sim_engine_init): Hardwire nr_cpus to
536 MAX_NR_PROCESSORS.
537 (sim_engine_nr_cpus) sim-engine.c, sim-engine.h: New function
538
539 Thu Jan 29 12:13:01 1998 Doug Evans <devans@canuck.cygnus.com>
540
541 * cgen.sh: Portably read parms past $9.
542
543 Fri Jan 23 14:20:54 1998 Doug Evans <devans@seba.cygnus.com>
544
545 * Make-common.in (stamp-tvals): New rule.
546 (targ-vals.h,targ-map.c): Depend on it.
547 (clean): Remove stamp-tvals.
548
549 Tue Jan 20 21:35:13 1998 Michael Meissner <meissner@cygnus.com>
550
551 * sim-utils.c (sim_state_alloc): #if 0 variable that is only used
552 in code also #if 0'ed.
553
554 Mon Jan 19 22:26:29 1998 Doug Evans <devans@seba>
555
556 * configure: Regenerated to track ../common/aclocal.m4 changes.
557 * aclocal.m4: Recognize --enable-maintainer-mode.
558
559 Mon Jan 19 12:45:45 1998 Doug Evans <devans@seba.cygnus.com>
560
561 start-sanitize-cygnus
562 * Make-common.in (cgen-{arch,cpu,decode}): New targets.
563 * cgen.sh: New file.
564 end-sanitize-cygnus
565 * cgen-scache.h: Deleted.
566 * Make-common.in (cgen-run.o,cgen-scache.o): Delete cgen-scache.h dep.
567 (CGEN_CPU_SCM): Add sim-model.scm.
568 * cgen-scache.c: Only compile contents if WITH_SCACHE.
569 (scache_init): Use runtime computed size of SCACHE.
570 (scache_flush): Likewise.
571 * cgen-mem.h (GETIMEMU[QHSD]I): Declare.
572 ([GS]ETT{QI,UQI,HI,UHI,SI,USI,DI,UDI}): Declare.
573 * cgen-sim.h: Scache support moved here.
574 (PC): Redo definition.
575 (ARGBUF,SCACHE,PARALLEL_EXEC): Provide forward decls.
576 (DECODE): Add parallel execution support.
577 Only include semantic label members if using switch.
578 (SWITCH,CASE,BREAK,DEFAULT,ENDSWITCH): Portable computed goto support.
579 (CGEN_CPU): Delete members exec_state, halt_sigrc, halt_jmp_buf.
580 (IADDR,CIA,SEM_ARG,EX_FN_NAME,SEM_FN_NAME,RECORD_IADDR,SEM_ARGBUF,
581 SEM_NEXT_PC,SEM_BRANCH_VIA_{CACHE,ADDR},SEM_NEW_PC_ADDR): Moved here
582 from cgen-types.h.
583 (engine_{stop,run,resume,halt,signal}): Delete decls.
584 * cgen-types.h (CGEN_{XCAT3,CAT3}): Delete.
585 (argbuf,scache): Delete forward decls.
586 (STATE): Delete decl.
587 * cgen-utils.c: Don't include decode.h, mem-ops.h, sem-ops.h.
588 Include cgen-mem.h, cgen-ops.h.
589 (engine_halt,engine_signal): Delete.
590 ({ex,exc,sem,semc}_illegal): Delete.
591 (sim_disassemble_insn): Result of extract fn is in bits.
592 * genmloop.sh: Rewrite.
593
594 * cgen-trace.c (trace_insn): Set printed_result_p=0 if not tracing
595 line numbers.
596
597 * sim-base.h (sim_state_base): Delete member `model'.
598 (sim_cpu_base): Add member `model'.
599 * sim-model.h (IMP_PROPERTIES): New type.
600 (MACH): New members imp_props, models.
601 (models): Delete decl.
602 * sim-model.c (set_model): Update.
603 * sim-profile.c (profile_print_model): Update.
604
605 * sim-utils.c (sim_state_alloc): Delete setting of cpu backlink here.
606
607 Fri Jan 16 12:33:09 1998 Nick Clifton <nickc@cygnus.com>
608
609 * cgen-trace.c (trace_insn): Call CGEN_INSN_MNEMONIC() rather than
610 CGEN_INSN_SYNTAX().
611
612 Mon Dec 15 23:17:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
613
614 * configure: Regenerated to track ../common/aclocal.m4 changes.
615 * config.in: Ditto.
616
617 Mon Dec 15 23:16:03 1997 Andrew Cagney <cagney@b1.cygnus.com>
618
619 * aclocal.m4 (AR): Check for sigaction.
620
621 Thu Dec 4 09:21:05 1997 Doug Evans <devans@canuck.cygnus.com>
622
623 * Make-common.in (sim-core.o): Depend on $(sim_main_headers).
624
625 * sim-config.h (WITH_TREE_PROPERTIES): Define as 0.
626 * sim-config.c (sim_config): Replace WITH_DEVICES with
627 WITH_TREE_PROPERTIES.
628
629 * configure: Regenerated to track ../common/aclocal.m4 changes.
630
631 Wed Dec 3 17:56:02 1997 Doug Evans <devans@canuck.cygnus.com>
632
633 * Make-common.in (SIM_ENVIRONMENT): New variable.
634 (CONFIG_CFLAGS): Add it.
635 * aclocal.m4 (SIM_AC_OPTION_ENVIRONMENT): Handle
636 --enable-sim-environment option.
637 * configure: Regenerated.
638 * sim-config.h (environment support): Rewrite.
639 * sim-config.c (current_environment): Define as enum, unconditionally.
640 (current_alignment): Define unconditionally.
641 (config_environment_to_a): Update.
642 (config_alignment_to_a): Fix type of argument. Define unconditionally.
643 (sim_config): Handle environment and alignment determination
644 unconditionally. Delete sanity checks of current_environment,
645 unnecessary.
646 (print_sim_config): Update.
647 * sim-options.c (STANDARD_OPTIONS enum): Add OPTION_ENVIRONMENT.
648 (standard_options): Add --environment.
649 (standard_option_handler): Likewise.
650
651 Fri Nov 28 12:21:25 1997 Andrew Cagney <cagney@b1.cygnus.com>
652
653 * sim-alu.h: Add notes on carry vs borrow for subtraction.
654 (ALU{,8,16,32,64}ADD): Redefine ADD macro as add overflowing.
655 (ALU{,8,16,32,64}ADDC): Define - add carrying.
656 (ALU{,8,16,32,64}SUB): Redefine SUB macro as subtract overflowing.
657 (ALU{,8,16,32,64}SUBB): Define - subtract borrowing.
658 (ALU{,8,16,32,64}SUBC): Define - tract carrying.
659 (ALU{,8,16,32,64}ADD_CA, ALU{,8,16,32,64}ADDC_C): Replace single
660 argument ADD_CA macro with two argument ADDC_C - add carrying with
661 carry in.
662 (ALU{,8,16,32,64}SUB_CA, ALU{,8,16,32,64}SUBC_X): Replace single
663 argument SUB_CA macro with two argument SUBC_X - subtract
664 carrying, extended.
665 (ALU{,8,16,32,64}SUBB_B): Define - subtract borrowing with
666 borrow-in.
667 (ALU{,8,16,32,64}NEGC, ALU{,8,16,32,64}NEGB): Define.
668
669 Sun Nov 30 17:40:57 1997 Michael Meissner <meissner@cygnus.com>
670
671 * sim-io.c (sim_io_{syscalls,getstring}): Delete. No longer used.
672 * sim-io.h (sim_io_syscalls): Delete.
673
674 Fri Nov 28 20:10:09 1997 Michael Meissner <meissner@cygnus.com>
675
676 * syscall.c (cb_syscall): Add missing else, so write to stdout
677 isn't doubled.
678
679 * sim-alu.h (ALU{,8,16,32,64}_SET_CARRY): Provide macros to import
680 the carry bit from the CPU's psw.
681
682 Fri Nov 28 11:15:05 1997 Doug Evans <devans@canuck.cygnus.com>
683
684 * gennltvals.sh: Redo syscall support.
685 * nltvals.def: Regenerated.
686
687 Wed Nov 26 16:49:38 1997 Michael Meissner <meissner@cygnus.com>
688
689 * syscall.c (cb_syscall): If writing to stdout or stderr, flush
690 the stream immediately.
691
692 Wed Nov 26 12:32:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
693
694 * sim-io.c (sim_io_getstring): Delete unused len2.
695 (sim_io_syscalls): Ditto for sys_errno.
696
697 Wed Nov 26 11:18:40 1997 Doug Evans <devans@canuck.cygnus.com>
698
699 * syscall.c (cb_syscall): Test CB_SYSCALL struct magic number.
700
701 * Make-common.in (run.o): Depend on remote-sim.h.
702 (nrun.o,sim-hload.o,sim-hrw.o): Likewise.
703 (sim-io.o,sim-reason.o,sim-resume.o): Likewise.
704
705 Tue Nov 25 20:12:46 1997 Michael Meissner <meissner@cygnus.com>
706
707 * sim-io.c (sim_io_syscalls): Disable lseek.
708
709 Tue Nov 25 00:12:38 1997 Doug Evans <devans@seba.cygnus.com>
710
711 start-sanitize-d30v
712 * gennltvals.sh: Generate syscall values for d30v.
713 end-sanitize-d30v
714 * gennltvals.sh: Use libgloss/syscall.h for sparc.
715 * nltvals.def: Regenerate.
716
717 * callback.c (os_stat): Make 3rd arg a host struct stat ptr.
718 (os_fstat): Likewise. Validate fd argument.
719 (cb_host_to_target_stat): Delete big_p arg. If HS arg is NULL,
720 just compute target stat struct length.
721 * syscall.c: #include "libiberty.h", <sys/types.h>, <sys/stat.h>.
722 (ENOSYS,ENAMETOOLONG): Provide definitions if missing.
723 (get_string): Return host errno values so they can be properly
724 translated later.
725 (cb_syscall): Likewise.
726 (cb_syscall, cases open,unlink): Use get_path instead of get_string.
727 (cb_syscall, case read): Use read_stdin for file descriptor 0.
728 (cb_syscall, case write): Use write_stderr for file descriptor 2.
729 (cb_syscall): Add cases for lseek, unlink, stat, fstat, time.
730 (get_path): New function.
731
732 Mon Nov 24 18:56:07 1997 Michael Meissner <meissner@cygnus.com>
733
734 * sim-io.c (sim_io_syscalls): New function to provide system call
735 emulation. Provide exit, open, close, read, write, lseek, and
736 unlink.
737 (sim_io_getstring): New function to return a string from a
738 simulated memory location.
739
740 * sim-io.h (sim_io_syscalls): Add declaration.
741
742 Mon Nov 24 12:09:59 1997 Doug Evans <devans@seba.cygnus.com>
743
744 * sim-core.c (sim_core_signal): Fix spelling error in message.
745
746 * sim-hrw.c (sim_read): Use read map, not write map.
747
748 * Make-common.in (all): Add .gdbinit.
749 * gdbinit.in: Add dump command.
750
751 * sim-model.c (model_options): Use '\0' for `shortopt'.
752
753 * sim-trace.c (trace_option_handler): Set state trace file
754 for --trace-file in addition to cpu's values.
755 (trace_vprintf): If cpu == NULL, try state's trace file.
756 (trace_options): Reorganize table, reword some descriptions.
757
758 Sun Nov 23 10:57:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
759
760 * sim-fpu.c (sim_fpu_abs, sim_fpu_neg, sim_fpu_inv), sim-fpu.h:
761 New functions.
762
763 Sat Nov 22 19:16:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
764
765 * sim-reason.c (sim_stop_reason): For sim_signalled, return the
766 signal untranslated, document problem with this.
767
768 * nrun.c (main): Check for a prog name of `*step'. If present,
769 step the simulator instead of allowing it to run free.
770
771 * sim-signal.c (SIGQUIT): Define on _MSC_VER hosts.
772
773 * Make-common.in (sim_main_headers): Add sim-signal.h.
774
775 Fri Nov 21 09:32:32 1997 Andrew Cagney <cagney@b1.cygnus.com>
776
777 * sim-signal.c (sim_signal_to_host): Return 0 for SIM_SIGNONE.
778
779 Thu Nov 20 20:35:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
780
781 * sim-signal.h: Start simulator signals at 64 so that host signal
782 numbers can be detected and reported.
783
784 * sim-signal.h (SIM_SIGFPE), sim-signal.h: Add signal.
785
786 Wed Nov 19 12:02:41 1997 Doug Evans <devans@seba.cygnus.com>
787
788 * callback.c (cb_host_to_target_stat): Fix return values.
789
790 * cgen-sim.h (enum_signal_type): Delete.
791 (engine_signal): Update prototype.
792 * cgen-utils.c: Don't include <signal.h>.
793 (sim_signal_to_host): Delete, lives in sim-signal.c now.
794 (engine_signal): Update.
795
796 * sim-utils.c (sim_state_alloc): Call SIM_STATE_ALLOC if defined.
797 (sim_state_free): Call SIM_STATE_FREE if defined.
798
799 * sim-module.c (sim_module_install): Don't leave any modules
800 installed if one fails to install.
801
802 Wed Nov 19 13:25:48 1997 Michael Meissner <meissner@cygnus.com>
803
804 * sim-options.c: Don't include ../libiberty/alloca-conf.h any
805 more, since alloca is not used in this file.
806
807 * sim-alu.h (ALU{32,64}_*): Rewrite 32 and 64 bit ALU support to
808 correctly set the carry and overflow bits for those types.
809 (ALU{8,16,32,64}_{ADD,SUB}_CA): Take VAL argument to add along
810 with carry, so carry is correct after doing both adds.
811 (ALU*): Space out '\' to make it easier to read.
812
813 Tue Nov 18 15:53:45 1997 Doug Evans <devans@canuck.cygnus.com>
814
815 * sim-core.c (sim_core_signal): Use sim_stopped instead of
816 sim_signalled.
817
818 * sim-signal.c, sim-signal.h: New files.
819 * Make-common.in (sim-signal.o): Add rule for.
820 (SIM_NEW_COMMON_OBJS): Add sim-signal.o.
821 * sim-abort.c: Don't include <signal.h>.
822 * sim-basics.h: #include "sim-signal.h".
823 * sim-break.c: Don't include <signal.h>.
824 (sim_handle_breakpoint): Replace SIGTRAP with SIM_SIGTRAP.
825 * sim-core.c: Don't include <signal.h>.
826 (SIGBUS): Delete definition.
827 (sim_core_signal): Replace SIGSEGV,SIGBUS with SIM_SIGSEGV,SIM_SIGBUS.
828 * sim-engine.c: Don't include <signal.h>.
829 (sim_engine_abort): Replace SIGABRT with SIM_SIGABRT.
830 * sim-reason.c (sim_stop_reason): Call sim_signal_to_host.
831 * sim-resume.c: Don't include <signal.h>.
832 (SIGTRAP): Delete definition.
833 (has_stepped): Replace SIGTRAP with SIM_SIGTRAP.
834 * sim-stop.c: Don't include <signal.h>.
835 (control_c_simulation): Replace SIGINT with SIM_SIGINT.
836 * sim-watch.c: Don't include <signal.h>.
837 (handle_watchpoint): Replace SIGINT with SIM_SIGINT.
838
839 * Make-common.in (SIM_NEW_COMMON_OBJS): New variable.
840
841 * sim-base.h (CIA_ADDR): Provide default definition.
842 * sim-core.c (sim_core_signal): Use CIA_ADDR to fetch value.
843 * sim-break.c (sim_handle_breakpoint): Likewise.
844
845 Mon Nov 17 14:15:31 1997 Doug Evans <devans@seba.cygnus.com>
846
847 * Make-common.in (srccom): New variable.
848
849 * Make-common.in (DEP, COMMON_DEP_CFLAGS): Define.
850 (LIB_OBJS): Add syscall.o.
851 (gentmap): Pass $(NL_TARGET) to $(CC).
852 (syscall.o): Add rule for.
853 (sim_main_headers): Add $(SIM_EXTRA_DEPS).
854 (sim-bits.o): Depend on $(sim-n-bits_h).
855 (sim-load.o): Depend on callback.h.
856
857 * Make-common.in (cgen-*.o): Update dependencies, mem-ops.h renamed to
858 cgen-mem.h, sem-ops.h renamed to cgen-ops.h.
859 * cgen-mem.h, cgen-ops.h: New files.
860
861 * aclocal.m4 (--enable-sim-scache): Pass -DWITH_SCACHE=0 for "=no".
862
863 * Makefile.in (nltvals.def): Depend on gennltvals.sh.
864 Rewrite build rule.
865 * callback.c: #include string.h or strings.h.
866 #include sys/types.h and sys/stat.h.
867 (cb_init_syscall_map,cb_init_errno_map,cb_init_open_map): Declare.
868 (os_get_errno,os_open): Update.
869 (os_stat,os_fstat): New functions.
870 (os_init): Initialize syscall_map, errno_map, open_map.
871 (default_callback): Add entries for os_stat, os_fstat, syscall_map,
872 errno_map, open_map, signal_map, stat_map.
873 (cb_read_target_syscall_maps): New function.
874 (cb_target_to_host_syscall): New function.
875 (cb_host_to_target_errno): Renamed from host_to_target_errno.
876 (cb_target_to_host_open): Renamed from target_to_host_open.
877 (store): New function.
878 (cb_host_to_target_stat): New function.
879 * syscall.c: New file.
880 * gentmap.c (sys_tdefs): New global.
881 (gen_targ_vals_h): Output target syscall numbers.
882 (gen_targ_map_c): Update. Output target syscall translation map.
883 * gentvals.sh: New first argument `target'. Preface table with
884 #ifdef NL_TARGET_$target if non-null target passed.
885 * gennltvals.sh: New file.
886 * nltvals.def: Regenerated.
887
888 Fri Nov 14 11:33:34 1997 Andrew Cagney <cagney@b1.cygnus.com>
889
890 * sim-n-core.h (sim_core_read_unaligned_N): Return static
891 sim_core_dummy_M.
892 (sim_core_dummy_M): Declare.
893
894 Wed Nov 12 18:16:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
895
896 * sim-core.c (sim_core_signal): Print the address of the
897 instruction.
898
899 Thu Nov 13 11:49:41 1997 Doug Evans <devans@seba.cygnus.com>
900
901 * sim-base.h (sim_state_base): Move `magic' to end of struct.
902
903 * sim-base.h (sim_state_base): Add member trace_data.
904 (STATE_TRACE_DATA): New macro.
905 * sim-trace.h (TRACE_DEBUG_IDX,TRACE_debug): New macros.
906 ({WITH_,}TRACE_DEBUG_P): New macros.
907 (STATE_TRACE_FLAGS,STRACE_P,STRACE_DEBUG_P): New macros.
908 (_sim_cpu): Delete forward reference.
909 (debug_printf): Update.
910 * sim-trace.c (OPTION_TRACE_DEBUG): Define.
911 (trace_options): Add --trace-debug.
912 (set_trace_options): Handle it.
913 (trace_option_handler): Likewise.
914 (trace_install): Init state trace_data struct.
915 (trace_uninstall): Close state trace file.
916 * sim-events.c (ETRACE): Only print source file and line number if
917 --trace-debug.
918 * sim-n-core.h (sim_core_trace_M): Likewise.
919
920 * sim-core.c (sim_core_signal): Add missing "\n" in message.
921
922 1997-11-13 Felix Lee <flee@cygnus.com>
923
924 * sim-n-core.h (sim_core_read_unaligned_N): illegal empty
925 initializer.
926 * sim-types.h (unsigned128,signed128): fix typo for MSVC.
927
928 Wed Nov 12 12:18:08 1997 Doug Evans <devans@canuck.cygnus.com>
929
930 * aclocal.m4 (SIM_AC_OPTION_SCACHE): Fix typo.
931
932 * Make-common.in (BUILT_SRC_FROM_COMMON): Remove files no longer
933 built this way.
934 (sim-config.o): Remove non-existent $(sim-nconfig_h) dependency.
935 (clean): Don't delete $(BUILT_SRC_FROM_COMMON) if building in
936 source tree.
937
938 Tue Nov 11 13:28:02 1997 Andrew Cagney <cagney@b1.cygnus.com>
939
940 * sim-events.c (sim_events_process): Re-compute the time -
941 update_time_from_event - as each event is processed. Reverses
942 previous change.
943
944 Fri Nov 7 00:37:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
945
946 * callback.c (os_poll_quit): Replace _WIN32 with _MSC_VER.
947
948 Fri Nov 7 00:37:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
949
950 * sim-events.c (sim_events_process): Delete redundant call to
951 update_time_from_event.
952 (sim_events_slip): Always decrement time_from_event.
953 (sim_events_tick, sim_events_deschedule, update_time_from_event):
954 Delete assertion that time_from_event >=0 when work in queue, no
955 longer applicable.
956
957 Thu Nov 6 12:06:46 1997 Andrew Cagney <cagney@b1.cygnus.com>
958
959 * sim-options.c (STANDARD_OPTIONS): Change OPTION_* to an enum.
960 (standard_option_handler): Update.
961
962 * sim-options.h: Clarify documentation.
963 (OPTION_LONG_ONLY_P): Delete definition.
964 (OPTION_VALID_P): Define.
965
966 * sim-options.c (sim_print_help): Allow short only options.
967 (sim_parse_args): Ditto.
968 (sim_args_command): Skip short only options.
969 (sim_parse_args): Allocate space for NUM_OPTS not just 256. Make
970 separate entries for short and long options in the HANDLERS and
971 ORIG_VAL tables.
972 (sim_parse_args): Disable argument permutation.
973
974 Wed Nov 5 13:40:31 1997 Andrew Cagney <cagney@b1.cygnus.com>
975
976 * sim-core.h (DECLARE_SIM_CORE_WRITE_N. DECLARE_SIM_CORE_READ_N):
977 Add argument M, size of data type.
978 (sim_core_read_misaligned_3, sim_core_write_misaligned_3):
979 Declare, ditto for 5, 6 & 7 byte transfers.
980 (sim_core_write_unaligned_1, sim_core_write_unaligned_1): Define
981 as aligned variant.
982
983 * sim-n-core.h (sim_core_trace_M): Rename from
984 sim_core_trace_N. Add nr_bytes argument. Replace transfer argument
985 with transfer type. Print transfer direction. Handle 1 and 2 byte
986 transfers.
987 (sim_core_read_unaligned_N, sim_core_write_unaligned_N): Trace
988 unaligned accesses.
989 (unsigned_M, T2H_M, H2T_M): Rename from unsigned_N, T2H_N, H2T_N.
990 Update all functions.
991
992 * sim-core.c: Generate functions starting with 16 not 1.
993 (sim_core_read_unaligned_3): Generate. Ditto for 3 byte write and
994 all 5, 6 & 7 byte transfers.
995
996 * sim-n-core.h (sim_core_read_misaligned_N,
997 sim_core_write_misaligned_N): Implement.
998
999 Mon Nov 3 15:03:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
1000
1001 * sim-endian.h (U16_8): Implement
1002
1003 * sim-endian.c (sim_endian_split_16, sim_endian_join_16): New functions
1004
1005 * sim-endian.h (VL8_16, VH8_16): Implement.
1006
1007 * sim-memopt.c (memory_option_handler): Typecast 64bit value to
1008 long in printf.
1009 (memory_option_handler): Only zalloc modulo bytes when non-zero.
1010 (memory_option_handler): Skip comma in alias address list
1011
1012 Fri Oct 31 13:03:33 1997 Andrew Cagney <cagney@b1.cygnus.com>
1013
1014 * sim-memopt.c (do_memopt_add, do_memopt_delete): Add level and
1015 space params.
1016 (parse_size, parse_addr): New functions
1017 (memory_option_handler, memory_options): Parse address & size
1018 using new functions. Pass level, space, modulo to do_memopt_add &
1019 do_memopt_del.
1020
1021 * sim-memopt.h (struct _sim_memopt): Add level & space fields.
1022
1023 * sim-core.h (sim_core_arrach, sim_core_detach): Replace
1024 `attach_type attach' argument with `unsigned level' argument.
1025 Document.
1026
1027 * sim-core.c (new_sim_core_mapping, sim_core_map_attach,
1028 sim_core_attach): Replace argument attach with level. Update
1029 verification of arguments.
1030 (sim_core_map_detach, sim_core_detach): Replace argument attach
1031 with level.
1032
1033 * sim-basics.h (enum _attach_type): Delete.
1034
1035 Thu Oct 30 13:45:00 1997 Doug Evans <devans@seba.cygnus.com>
1036
1037 * sim-core.h (sim_core_write_8): Define.
1038
1039 Tue Oct 28 12:29:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
1040
1041 * sim-bits.h: Document ROTn macro.
1042
1043 * sim-endian.h (H2T): Handle 16 byte variables.
1044
1045 * sim-n-core.h (sim_core_read_unaligned_N): Return a dummy when an
1046 error.
1047
1048 * sim-core.c: Do not generate sim_core_*_word.
1049
1050 * sim-n-core.h (sim_core_trace_N): Add line_nr argument.
1051 (sim_core_write_aligned_N, sim_core_read_aligned_N): Update.
1052
1053 * sim-core.h (sim_core_read_unaligned_word,
1054 sim_core_read_aligned_word, sim_core_read_word,
1055 sim_core_write_unaligned_word, sim_core_write_aligned_word,
1056 sim_core_write_word): Change to macros that map onto sim_core_*_N.
1057
1058 Mon Oct 27 11:25:10 1997 Doug Evans <devans@canuck.cygnus.com>
1059
1060 * sim-n-endian.h: Add TAGS entrys for 16 byte versions.
1061
1062 * sim-endian.h: Disable 16 byte support.
1063
1064 Mon Oct 27 12:00:48 1997 Andrew Cagney <cagney@b1.cygnus.com>
1065
1066 * sim-endian.c (_SWAP_16): Define. Generate 126 bit swap code.
1067
1068 * sim-n-core.h (sim_core_trace_N): New function.
1069 (sim_core_read_aligned_N, sim_core_write_aligned_N): Use,
1070 (sim_core_read_unaligned_N): Do not retyrn bogus value wden error.
1071
1072 * sim-endian.h: Add 128 bit variant.
1073
1074 * sim-core.h, sim-core.c: Add 128 bit variant.
1075
1076 * sim-types.h: Add signed128 and unsigned128 types using a struct.
1077
1078 Fri Oct 24 11:33:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
1079
1080 * sim-events.c (sim_events_process): Clear events->work_pending.
1081 (sim_events_tickn, sim_events_tick): Accumulate, instead of
1082 setting, nr_ticks_to_process.
1083 (sim_events_preprocess): Allow nr_ticks_to_process to be non-zero
1084 when the event queue isn't next.
1085
1086 * sim-events.h, sim-events.c (sim_events_slip): New function.
1087
1088 Wed Oct 22 14:18:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
1089
1090 * sim-hload.c (sim_load): Pass lma_p==0 and do_load=sim_load.
1091
1092 * sim-utils.h, sim-load.c (sim_load_file): Add lma_p and do_load
1093 arguments.
1094
1095 Tue Oct 21 18:37:57 1997 Doug Evans <devans@canuck.cygnus.com>
1096
1097 * nrun.c (main): Remove useless test of name != NULL.
1098 Exit if bfd_openr fails. Call bfd_check_format after bfd_openr.
1099
1100 Tue Oct 21 10:42:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
1101
1102 * sim-fpu.c (EXPMAX): Type is unsigned.
1103 (MIN_INT, MAX_INT): Type is signed64.
1104 (i2fpu): Type of val is signed64.
1105
1106 Tue Oct 21 10:42:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
1107
1108 * sim-profile.h (PROFILE_PC_BUCKET_SIZE): Treat a shift of zero as
1109 a bucket size of zero.
1110
1111 * sim-profile.c (OPTION_PROFILE_PC_GRANULARITY,
1112 OPTION_PROFILE_PC): Define.
1113 (profile_option_handler): Add support for --profile-pc and
1114 --profile-pc-granularity options.
1115 (profile_pc_init): When possible, compute nr buckets from bucket
1116 size.
1117
1118 * sim-profile.c (profile_pc_init): Align the profile-pc end
1119 address with the profile-pc bucket size.
1120
1121 * sim-profile.h (PROFILE_PC_NR_BUCKETS): Rename PROFILE_PC_SIZE to
1122 something less ambiguous.
1123 (PROFILE_PC_BUCKET_SIZE): Ditto for PROFILE_PC_SAMPLE_SIZE.
1124
1125 * sim-profile.c (profile_pc_cleanup): New function. Move
1126 profile_pc_uninstall code to here.
1127 (profile_pc_uninstall): Call.
1128 (profile_pc_init): Call.
1129
1130 Mon Oct 20 17:23:58 1997 Andrew Cagney <cagney@b1.cygnus.com>
1131
1132 * sim-profile.c (profile_print_pc): Dump pc profile to dmon.out
1133 file using BSD gprof format.
1134
1135 * sim-bits.h (LSBIT, MSBIT, BIT): Force result to type
1136 unsigned_word.
1137 (LSBIT8, LSBIT16, LSBIT32, LSBIT64, MSBIT8, MSBIT16, MSBIT32,
1138 MSBIT64): Force result to unsignedN.
1139
1140 Thu Oct 16 11:38:56 1997 Andrew Cagney <cagney@b1.cygnus.com>
1141
1142 * sim-alu.h (ALU16_BEGIN, ALU32_BEGIN, ALU64_BEGIN): Drop opening
1143 brace from macro.
1144 (ALU8_BEGIN, ALU8_SET, ALU8_ADD, ALU8_SUB, ALU8_NEGATE): Define.
1145 (ALU16_ADD, ALU16_SUB, ALU16_NEGATE): Simplify arrithmetic.
1146 (ALU32_ADD, ALU32_SUB, ALU32_NEGATE): Simplify arrithmetic.
1147 (ALU64_ADD, ALU64_SUB, ALU64_NEGATE): Simplify arrithmetic.
1148
1149 Wed Oct 15 09:24:19 1997 Andrew Cagney <cagney@b1.cygnus.com>
1150
1151 * sim-core.h (struct _sim_core_mapping): Change free_buffer to
1152 type void*.
1153
1154 * sim-core.c (sim_core_uninstall, new_sim_core_mapping,
1155 sim_core_map_attach, sim_core_map_detach): Change free_buffer to
1156 type void*.
1157 (sim_core_attach): Rename buffer_freed to free_buffer, type
1158 void*. Ensure that allocated buffer is alligned according to
1159 region's address.
1160
1161 Mon Oct 13 11:34:50 1997 Andrew Cagney <cagney@b1.cygnus.com>
1162
1163 * sim-alu.h (ALU64_HAD_OVERFLOW): Define.
1164 (ALU64_SUB): Define.
1165
1166 * Make-common.in (all): Build SIM_EXTRA_ALL first.
1167 (.gdbinit): Remove dependencies, generate once per build.
1168
1169 Tue Oct 14 19:20:09 1997 Andrew Cagney <cagney@b1.cygnus.com>
1170
1171 * sim-n-core.h (sim_core_read_aligned_N,
1172 sim_core_write_aligned_N): Make xaddr param type address_word not
1173 unsigned_word.
1174
1175 Fri Oct 3 09:49:18 1997 Andrew Cagney <cagney@b1.cygnus.com>
1176
1177 * sim-fpu.h, sim-fpu.c: Rewrite. Change sim_fpu object to an
1178 unpacked floating point struct. Pass sim_fpu object by reference.
1179 Add preliminary support for rounding modes.
1180
1181 Fri Oct 3 09:28:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
1182
1183 * configure: Regenerated to track ../common/aclocal.m4 changes.
1184
1185 Thu Oct 2 19:43:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
1186
1187 * aclocal.m4 (sim-bitsize): Fix typo, WITH_TARGET_WORD_BITSIZE not
1188 WITH_TARGET_BITSIZE.
1189
1190 Thu Sep 25 23:20:20 1997 Felix Lee <flee@yin.cygnus.com>
1191
1192 * sim-profile.c (profile_print_core): label needs empty statement.
1193
1194 Thu Sep 25 11:20:47 1997 Stu Grossman <grossman@babylon-5.cygnus.com>
1195
1196 * sim-break.c (sim_set_breakpoint sim_clear_breakpoint): Use ZALLOC
1197 and zfree instead of xmalloc and free. Prevents warnings.
1198
1199 Wed Sep 24 17:38:57 1997 Andrew Cagney <cagney@b1.cygnus.com>
1200
1201 * configure: Regenerated to track ../common/aclocal.m4 changes.
1202
1203 Wed Sep 24 17:23:31 1997 Andrew Cagney <cagney@b1.cygnus.com>
1204
1205 * Make-common.in (SIM_BITSIZE): Assign from configured value.
1206 (CONFIG_CFLAGS): Add SIM_BITSIZE.
1207
1208 * aclocal.m4 (--enable-sim-bitsize): Developer option for
1209 controling the bitsize/msb of the target.
1210
1211 Wed Sep 24 17:41:40 1997 Stu Grossman <grossman@babylon-5.cygnus.com>
1212
1213 * Make-common.in: New files sim-break.c, sim-break.h.
1214 * sim-base.h: Add point to breakpoint list to sim_state_base.
1215 * sim-break.c sim-break.h: New modules that implement intrinsic
1216 breakpoint support.
1217 * sim-module.c: Add breakpoint module.
1218
1219 Tue Sep 23 00:26:39 1997 Felix Lee <flee@yin.cygnus.com>
1220
1221 * sim-events.c (SIM_EVENTS_POLL_RATE): poll more often than once
1222 an hour.
1223 * sim-n-core.h (WITH_XOR_ENDIAN): MSVC barfs on
1224 if (0) { 1 % 0; }
1225 * sim-core.c (sim_core_xor_write_buffer): WITH_XOR_ENDIAN + 1.
1226 (SIGBUS) define for Windows.
1227 * sim-trace.c (trace_printf,debug_printf): added ALMOST_STDC.
1228 * sim-resume.c: define SIGTRAP for windows.
1229 * sim-xcat.h: use token pasting if ALMOST_STDC.
1230
1231 Tue Sep 23 11:04:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
1232
1233 * Make-common.in (SIM_SCACHE, SIM_DEFAULT_MODEL): Assign
1234 configured values.
1235 (CONFIG_CFLAGS): Add same.
1236
1237 Mon Sep 22 17:20:27 1997 Felix Lee <flee@cygnus.com>
1238
1239 * sim-types.h (SIGNED64): ##i64 when _MSC_VER, not _WIN32.
1240 (SIGNED32): use ##i32.
1241
1242 Tue Sep 23 11:04:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
1243
1244 * configure: Regenerated to track ../common/aclocal.m4 changes.
1245
1246 Tue Sep 23 10:07:47 1997 Andrew Cagney <cagney@b1.cygnus.com>
1247
1248 * aclocal.m4 (sim-endian): Simplify logic determining [default]
1249 endian of target.
1250
1251 * Make-common.in (SIM_WARNINGS, SIM_ALIGNMENT, SIM_ENDIAN,
1252 SIM_HOSTENDIAN, SIM_RESERVED_BITS, SIM_ASSERT, SIM_FLOAT,
1253 SIM_HARDWARE, SIM_INLINE, SIM_PACKAGES, SIM_REGPARM, SIM_SMP,
1254 SIM_STDCALL, SIM_XOR_ENDIAN): Assign configured values.
1255 (CONFIG_CFLAGS): Add same.
1256
1257 * aclocal.m4: Perform AC_SUBST on optional options.
1258
1259 Mon Sep 22 11:46:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
1260
1261 * sim-config.h (WITH_DEFAULT_ALIGNMENT): Don't hardwire any alignment.
1262
1263 * sim-options.c (standard_option_handler): Typo in warning message.
1264
1265 * sim-base.h (STATE_MODEL): Make conditional on SIM_HAVE_MODEL.
1266
1267 * sim-profile.c (profile_print_insn): Check 0 .. MAX_INSN for any
1268 insn count. Make count conditional on there being a valid
1269 INSN_NAME.
1270 (profile_pc_init): Make default PC profile frequency an arbitrary
1271 256.
1272
1273 * sim-base.h: Ditto.
1274
1275 * sim-profile.h (WITH_PROFILE_MODEL_P): Only enable modeling when
1276 SIM_HAVE_MODEL.
1277
1278 * sim-model.h (struct MACH): Depreciate, to be replaced by bfd
1279 archure struct.
1280
1281 Mon Sep 22 11:46:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
1282
1283 * configure: Regenerated to track ../common/aclocal.m4 changes.
1284
1285 Mon Sep 22 11:45:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
1286
1287 * aclocal.m4 (sim_alignment): Simplify logic for selecting the
1288 configured alignment.
1289
1290 Fri Sep 19 17:45:25 1997 Andrew Cagney <cagney@b1.cygnus.com>
1291
1292 * configure: Regenerated to track ../common/aclocal.m4 changes.
1293
1294 Fri Sep 19 17:26:14 1997 Andrew Cagney <cagney@b1.cygnus.com>
1295
1296 * sim-config.c (sim_config): Check for default alignment.
1297
1298 * sim-options.c (standard_option_handler): Add alignment option.
1299
1300 * aclocal.m4 (sim_alignment): Allow configuration of hardwired and
1301 default alignment requirements on memory accesses.
1302
1303 Fri Sep 19 11:51:35 1997 Jeffrey A Law (law@cygnus.com)
1304
1305 * sim-load.c (sim_load_file): Return failure if the executable
1306 had no loadable sections.
1307
1308 Wed Sep 17 13:33:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
1309
1310 * sim-events.c (ETRACE): Use trace_printf not sim_io_printf for
1311 trace output.
1312
1313 * sim-core.c (sim_core_signal): When bad access halt simulator
1314 SIGSEGV / SIGBUS instead of aborting.
1315 (signal.h): Include.
1316
1317 * sim-watch.c (sim_watchpoint_install): Handler for watchpoint
1318 options was missing.
1319
1320 * sim-bits.h (MOVED): Define
1321
1322 Wed Sep 17 10:33:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
1323
1324 * sim-alu.h (ALU32_HAD_OVERFLOW): Pacify GCC, Use MSBIT instead of
1325 BIT.
1326
1327 * sim-bits.h (LSBIT, MSBIT): Check for overflow of shift value.
1328
1329 * sim-bits.c: Add 8 bit versions of bit macros.
1330
1331 * sim-bits.h: Ditto.
1332
1333 Tue Sep 16 16:15:16 1997 Andrew Cagney <cagney@b1.cygnus.com>
1334
1335 * sim-bits.c (LSSEXT, MSSEXT): Replace SEXT.
1336 (LSINSERTED, MSINSERTED): Ditto for INSERTED.
1337
1338 * sim-n-bits.h (MSSEXTn, LSSEXTn): Replace SEXTn.
1339 (LSINSERTDn, MSINSERTEDN): Ditto for INSERTEDn.
1340
1341 * sim-bits.h (SEXT*): Define as MSEXT/LSEXT.
1342 (INSERTED*): Ditto for LSINSERTED/MSINSERTED.
1343
1344 Mon Sep 15 17:36:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
1345
1346 * aclocal.m4 (SIM_AC_COMMON): Add optional config.h file argument.
1347 configure.in: Output to cconfig.h instead of config.h.
1348
1349 * configure: Regenerated to track ../common/aclocal.m4 changes.
1350
1351 Mon Sep 15 15:39:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
1352
1353 * sim-utils.c (sim_analyze_program): Set STATE_ARCHITECTURE from
1354 BFD if known.
1355
1356 Tue Sep 9 21:46:46 1997 Felix Lee <flee@cygnus.com>
1357
1358 * callback.c (os_write): divert stdout and stderr to their
1359 respective hooks.
1360
1361 Thu Sep 11 10:08:48 1997 Andrew Cagney <cagney@b1.cygnus.com>
1362
1363 * sim-profile.c (profile_print_speed): Call
1364 sim_events_elapsed_time instead of PROFILE_EXEC_TIME for moment.
1365
1366 * sim-events.c (sim_events_elapsed_time): New function return nr
1367 host MS consumed by the simulator.
1368 (sim_watch_valid): Use.
1369
1370 * sim-module.c (modules): Install sim_events very very early.
1371
1372 * sim-profile.c (profile_print): Call profile_print_pc.
1373 (print_bar):
1374 (profile_pc_init): New function, set up processor for PC
1375 profiling.
1376 (profile_print_pc): New function, print a PC profile.
1377 (profile_pc_event): New function, sample PC.
1378
1379 * sim-profile.h (PROFILE_PC_COUNT, PROFILE_PC_START,
1380 PROFILE_PC_END, PROFILE_PC_SHIFT, PROFILE_PC_SAMPLE_SIZE): Add to
1381 profile struct.
1382
1383 * sim-options.c (sim_print_help): Pacify GCC.
1384
1385 * sim-n-core.h (sim_core_read_aligned_N,
1386 sim_core_write_aligned_N): Add un-conditional profile call.
1387 (sim_core_read_unaligned_N, sim_core_write_unaligned_N): Add
1388 profile call when aligned read/write isn't used.
1389
1390 * sim-base.h: Include sim-profile, sim-model after sim-core &
1391 sim-events allow sim-core to define useful values.
1392
1393 * sim-profile.c (OPTION_PROFILE_CORE): Define.
1394 (profile_option_handler, profile_options): Add support for
1395 --profile-core option.
1396 (print_bar): Include when core profiling.
1397 (profile_print_core): New function, print core profile.
1398
1399 * sim-config.c (print_sim_config): Print profile status.
1400
1401 * sim-profile.h (PROFILE_NEXT_IDX, PROFILE_core,
1402 WITH_PROFILE_PC_P): Define.
1403 (PROFILE_CORE_COUNT): Count each core-map/size separatly.
1404 (PROFILE_COUNT_CORE): Define.
1405
1406 Thu Sep 11 08:44:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
1407
1408 * sim-watch.c (handle_watchpoint): Pass a char** index into the
1409 interrupt_names array as the data.
1410 (sim-watch.h): Document.
1411
1412 Wed Sep 10 16:15:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
1413
1414 * sim-options.c (sim_print_help): When the doc string is to long
1415 word wrap it.
1416
1417 * sim-watch.c (sim_watchpoint_install): Use option.doc_name so
1418 that only the first few the watch options are listed. Generate
1419 meanginful usage messages.
1420
1421 * sim-options.h (struct OPTION): Clarify use of doc_name field
1422
1423 Wed Sep 10 13:23:24 1997 Andrew Cagney <cagney@b1.cygnus.com>
1424
1425 * sim-options.c (OPTION_ARCHITECTURE_INFO): New option.
1426 (standard_option_handler): Handle --architecture-info.
1427
1428 Tue Sep 9 21:46:46 1997 Felix Lee <flee@cygnus.com>
1429
1430 * sim-core.h (sim_cpu_core): [WITH_XOR_ENDIAN + 1], to avoid
1431 illegal zero-sized array.
1432 * sim-core.c (sim_core_xor_read_buffer): same.
1433
1434 Tue Sep 9 11:20:35 1997 Doug Evans <dje@canuck.cygnus.com>
1435
1436 * nltvals.def: Regenerate.
1437
1438 Tue Sep 9 02:10:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
1439
1440 * sim-fpu.c (DP_FRACHIGH2): Define LL using SIGNED64.
1441
1442 Mon Sep 8 12:22:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
1443
1444 * sim-bits.c (MASKED): Delete.
1445 (EXTRACTED): Delete.
1446 (LSEXTRACTED, MSEXTRACTED): New functions.
1447
1448 * sim-n-bits.h (MASKEDn): Delete, define as MSMASKED or LSMASKED.
1449 (MSMASKEDn, LSMASKEDn): Add last argument.
1450 (MSMASK*): Ditto.
1451
1452 * sim-bits.h (EXTEND8, EXTEND16): Define.
1453 (EXTRACTED64): Define as 64 bit extract, not 32 bit.
1454
1455 * sim-run.c (sim_engine_run): Use CPU_CIA macro.
1456
1457 * sim-engine.h (SIM_ENGINE_HALT_HOOK): Use CPU_CIA to get at
1458 current instruction address.
1459
1460 * sim-inline.h (*_ENGINE): Define.
1461
1462 Fri Sep 5 08:39:02 1997 Andrew Cagney <cagney@b1.cygnus.com>
1463
1464 * sim-core.c (sim_core_attach): Fix checks of modulo/mask.
1465
1466 * sim-watch.c (delete_watchpoint): Delete by ident and type.
1467 (watch_option_handler): Call delete_watchpoint with ident or type.
1468 (sim_watchpoint_install): Create interrupt specific watchpoint
1469 commands on the fly.
1470 (do_watchpoint_create): New function, create a watch point using
1471 type/int-nr info encoded in the option nr.
1472 (do_watchpoint_info): New function. List active watchpoints.
1473
1474 * sim-watch.h: Change data structure to a list.
1475
1476 * sim-memopt.c (memory_option_handler): Require explicit "all"
1477 before deleting all memory regions.
1478
1479 * sim-utils.c (sim_do_commandf): New function, printf version of
1480 sim_do_command.
1481
1482 * sim-basics.h (asprintf, vasprintf): Hack, define for CYGWIN32.
1483
1484 * sim-alu.h (ALU64_ADD): Use explicit MSEXTRACTED64, do not assume
1485 bit endianness.
1486 (SIGNED64, UNSIGNED64): Delete.
1487 (ALU64_ADD): Don't rely on bit endianness.
1488 (ALU64_BEGIN): Define.
1489
1490 * sim-n-bits.h (MSEXTRACTEDn, LSEXTRACTED): New functions.
1491 (EXTRACTEDn): Delete, define as either LSEXTRACTED or MSEXTRACTED.
1492
1493 * sim-types.h (SIGNED64, UNSIGNED64): New macros, attach relevant
1494 suffix - u64, LL - to 64 bit constants.
1495
1496 Thu Sep 4 09:27:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
1497
1498 * sim-config.c (sim_config): Add assert for SIM_MAGIC_NUMBER.
1499
1500 * sim-utils.h (NZALLOC): Define - zalloc * N.
1501
1502 * sim-hrw.c (sim_read, sim_write): New file. Provide generic
1503 implementation of read/write functions.
1504
1505 * Make-common.in (sim-hrw.o): New target.
1506
1507 * sim-base.h (STATE_MEMOPT_P): Delete, simulators _always_ add
1508 memory.
1509
1510 * sim-memopt.c (memory_option_handler): Implement memory-size
1511 command. Implement memory-alias command. Let memory-delete delete
1512 all memory regions.
1513 (add_memopt): New function. Add a memory region.
1514 (do_memopt_delete): New function. Delete a memory region.
1515
1516 * sim-utils.c (sim_elapsed_time_get): Never return zero.
1517
1518 * sim-core.c (sim_core_detach): New function.
1519 (sim_core_map_detach): New function. Perform the actual detach.
1520 (sim_core_init): Move initialization code from here.
1521 (sim_core_install): To here.
1522 (sim_core_uninstall): And here.
1523
1524 * sim-module.c: Add memopt module.
1525
1526 * sim-base.h (STATE_MEMOPT, STATE_MEMOPT_P): Add memopt to
1527 simulator base type.
1528
1529 * Make-common.in (sim_main_headers): Add sim-memopt.h
1530 (sim-memopt.o): New target.
1531
1532 * sim-core.c (sim_core_install): Add core_options to the option
1533 table.
1534
1535 * sim-watch.c (watch_options): Make --delete-watch a synonym for
1536 --watch-delete.
1537
1538 * sim-config.h (WITH_MODULO_MEMORY): Define as 0. Update
1539 comments.
1540
1541 * sim-core.h (struct _sim_core_mapping): Change nr_bytes to type
1542 address_word, add mask member.
1543
1544 * sim-core.h, sim-core.c (sim_core_attach): Make nr_bytes of type
1545 address_word, allow for 64bit targets in 32bit host. Add modulo
1546 argument.
1547 (sim_core_map_attach): Ditto.
1548 (new_sim_core_mapping): Ditto.
1549 (sim_core_translate): Mask address when modulo memory.
1550
1551 Wed Sep 3 17:32:54 1997 Doug Evans <dje@seba.cygnus.com>
1552
1553 * sim-hload.c (sim_load): Add assert for SIM_MAGIC_NUMBER.
1554
1555 * gdbinit.in: New file.
1556 * aclocal.m4 (SIM_AC_OUTPUT): Build .gdbinit.
1557 * Make-common.in (distclean): Delete .gdbinit.
1558 (.gdbinit): Add rule for.
1559 * configure: Regenerated to track ../common/aclocal.m4 changes.
1560
1561 * Make-common.in (cgen-run.o): Add rule for.
1562
1563 Wed Sep 3 10:08:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
1564
1565 * sim-resume.c (sim_resume): Suspend/resume the simulator.
1566
1567 * sim-events.c (sim_watch_valid): Compute total elapsed time from
1568 both resumed and previous elapsed time.
1569 (sim_events_init): Set initial_wallclock and current_wallclock to
1570 zero.
1571 (sim_events_install): Install sim_events_suspend and
1572 sim_events_resume.
1573 (sim_events_watch_clock): Allow for suspended simulator when
1574 computing the time of the clock event.
1575
1576 * sim-events.h (struct _sim_event): Add resume_wallclock, rename
1577 initial_wallclock to elapsed_wallclock, set both to zero.
1578 (sim_events_init, sim_events_uninstall): Delete prototypes.
1579
1580 * sim-module.h (MODULE_SUSPEND_FN, MODULE_RESUME_FN): Define types.
1581
1582 * sim-module.c(sim_module_resume, sim_module_suspend): New
1583 functions.
1584
1585 Wed Sep 3 10:08:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
1586
1587 * sim-core.c (sim_core_map_attach): Clarify memory overlap error
1588 message.
1589
1590 Tue Sep 2 14:57:06 1997 Doug Evans <dje@canuck.cygnus.com>
1591
1592 * Makefile.in (TAGS): Add support for "/* TAGS: foo */" marker.
1593 * Make-common.in (TAGS): Likewise.
1594 * sim-n-bits.h: Add TAGS comments for all functions.
1595 * sim-n-core.h: Likewise.
1596 * sim-n-endian.h: Likewise.
1597
1598 Mon Sep 1 10:50:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
1599
1600 * sim-utils.c (sim_state_alloc): Set CPU backlinks, callback and
1601 kind.
1602
1603 * sim-base.h (sim_state_alloc): Add callback and kind arguments.
1604
1605 * sim-base.h (INVALID_INSTRUCTION_ADDRESS): Add default
1606 definition.
1607
1608 Sat Aug 30 09:47:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
1609
1610 * sim-fpu.c (DP_GARDMSB, ...): Make unsigned.
1611 (DP_FRACHIGH, DP_FRACHIGH2, ..): Use MSMASK to avoid LL.
1612
1613 Fri Aug 29 13:37:44 1997 Andrew Cagney <cagney@b1.cygnus.com>
1614
1615 * sim-core.c (sim_core_map_attach): Cast attach enum to int.
1616 (sim_core_xor_read_buffer, sim_core_xor_write_buffer): Make
1617 nr_transfered and nr_this_transfer unsigned.
1618
1619 * sim-events.c (sim_events_tickn): N is signed, as limited to
1620 MAXINT.
1621
1622 * sim-n-endian.h (offset_N): Change size to unsigned.
1623
1624 * callback.c (os_poll_quit): Add prototypes for kbhit and getkey.
1625
1626 Fri Aug 29 10:10:53 1997 Andrew Cagney <cagney@b1.cygnus.com>
1627
1628 * sim-utils.c (sim_copy_argv): Delete, replaced by dupargv.
1629
1630 * sim-options.c (sim_parse_args): Use dupargv.
1631
1632 Thu Aug 28 10:36:34 1997 Doug Evans <dje@canuck.cygnus.com>
1633
1634 * sim-options.c (standard_option_handler): Use xstrdup, not strdup.
1635
1636 Thu Aug 28 12:09:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
1637
1638 * sim-base.h (STATE_ARCHITECTURE, STATE_TARGET): Add to simulator
1639 base type.
1640
1641 * sim-options.c (standard_options): Add --architecture=MACHINE and
1642 --target=TARGET options.
1643 (OPTION_ARCHITECTURE, OPTION_TARGET): Define.
1644 (standard_option_handler): Handle architecture and target options.
1645 (bfd.h): Include.
1646
1647 * sim-utils.c (sim_analyze_program): Pass STATE_TARGET to
1648 bfd_openr.
1649 (sim_analyze_program): Set prog_bfd architecture from
1650 STATE_ARCHITECTURE if known.
1651
1652 Wed Aug 27 18:13:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
1653
1654 * configure: Regenerated to track ../common/aclocal.m4 changes.
1655 * config.in: Ditto.
1656
1657 Wed Aug 27 18:11:30 1997 Andrew Cagney <cagney@b1.cygnus.com>
1658
1659 * aclocal.m4 (enable-sim-warnings): Remove comment stating
1660 that option does not apply to certain files.
1661
1662 Wed Aug 27 15:13:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
1663
1664 * sim-bits.h (LSBIT8, LSBIT16, LSBIT32, LSBIT64, LSBIT, MSBIT8,
1665 MSBIT16, MSBIT32, MSBIT64, MSBIT): New macros - single bit as
1666 offset from MSB/LSB.
1667
1668 * sim-endian.h (A1_8, A2_8, A4_8, A1_4, A2_4, A1_2): New macro,
1669 access address of sub word quantity of a hosts 16, 32, 64 bit word
1670 type.
1671 (V1_2, V1_4, V2_4, V1_8, V2_8, V4_8): Ditto for values.
1672 (U8_1, U8_2, U8_4, U4_1, U4_2, U2_1): Ditto for set of values.
1673 (V2_H1, V2_L1, V4_H2, V4_L2, V8_L4, V8_H4): Given N byte argument,
1674 return N*2 byte value with argument in Hi/Lo word. Renamed from
1675 V1_H2, V1_L2, V2_H4, V2_L4, V4_H8, V4_L8.
1676
1677 * sim-alu.h (ALU32_HAD_OVERFLOW): Use 64 bit mask not 32bit.
1678 (ALU16_HAD_CARRY, ALU32_HAD_CARRY, ALU16_HAD_OVERFLOW): Use MSBIT
1679 so that bit offset is explicit.
1680
1681 Wed Aug 27 11:55:35 1997 Andrew Cagney <cagney@b1.cygnus.com>
1682
1683 * sim-utils.c (sim_analyze_program): Add prog_name argument.
1684 Update STATE_PROG_BFD when needed with a dup'd copy of the
1685 program.
1686
1687 * sim-config.c (sim_config): Delete ABFD argument, use
1688 STATE_PROG_BFD directly.
1689
1690 Tue Aug 26 12:55:26 1997 Andrew Cagney <cagney@b1.cygnus.com>
1691
1692 * run.c (main): Pass the open ABFD to sim_create_inferior.
1693
1694 * nrun.c (main): Determine prog_bfd. Pass to sim_create_inferior
1695 and sim_load.
1696 (bfd.h): Include.
1697
1698 * sim-hload.c (sim_load): New file. Implement generic sim_load for
1699 hardware only simulator targets.
1700
1701 * Make-common.in (sim-hload.o): Add rule.
1702
1703 Wed Aug 27 09:51:42 1997 Andrew Cagney <cagney@b1.cygnus.com>
1704
1705 * sim-utils.c (sim_copy_argv): Rewrite to match malloc strategy
1706 used by copyargv and freeargv.
1707
1708 * sim-options.c (sim_parse_args): Save a copy of PROG-ARGS in
1709 STATE_PROG_ARGV, not just a pointer.
1710
1711 Mon Aug 25 17:50:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
1712
1713 * configure: Regenerated to track ../common/aclocal.m4 changes.
1714 * config.in: Ditto.
1715
1716 Mon Aug 25 12:11:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
1717
1718 * aclocal.m4 (sim-endian): Add second argument to
1719 SIM_AC_OPTION_ENDIAN. First is hardwired endian, second is
1720 default endian when not hardwired.
1721
1722 * sim-config.h (WITH_DEFAULT_TARGET_BYTE_ORDER): New macro, if all
1723 else failes value for target byte order.
1724
1725 * sim-config.c (sim_config): Add abfd arguments. Set
1726 STATE_PROG_BFD accordingly. Determine prefered_target_byte_order
1727 from same.
1728 (sim_config): Return SIM_RC, don't abort.
1729 (bfd.h): Include.
1730
1731 * run.c (main): Update call to sim_open - add ABFD argument.
1732 * nrun.c (main): Add NULL ABFD argument.
1733
1734 Thu Aug 14 12:48:57 1997 Doug Evans <dje@canuck.cygnus.com>
1735
1736 * callback.c (os_poll_quit): Make static.
1737 Call sim_cb_eprintf, not p->eprintf.
1738 (sim_cb_printf, sim_cb_eprintf): New functions.
1739 * sim-utils.h (sim_cb_printf, sim_cb_eprintf): Declare.
1740
1741 * sim-basics.h (zalloc,zfree,sim_add_commas,SIM_ELAPSED_TIME,
1742 sim_elapsed_time_get,sim_elapsed_time_since): Move decls to
1743 sim-utils.h. #include sim-utils.h.
1744 * sim-utils.h: Above decls moved here.
1745 (sim_analyze_program,sim_load_file): Use `struct _bfd', not `bfd'.
1746
1747 * sim-watch.c (action_watchpoint): Fix thinkos.
1748
1749 Thu Jul 24 08:48:05 1997 Stu Grossman (grossman@critters.cygnus.com)
1750
1751 * sim-types.h: Fix defs of 64 bit data types for MSVC.
1752
1753 Tue Jul 22 10:35:37 1997 Doug Evans <dje@canuck.cygnus.com>
1754
1755 * sim-n-core.h (sim_core_write_unaligned_N): Add missing break
1756 to FORCED_ALIGNMENT case.
1757
1758 Thu Jun 5 13:48:37 1997 Andrew Cagney <cagney@b1.cygnus.com>
1759
1760 * callback.c (target_to_host_open): Handle hosts with O_BINARY.
1761
1762 Thu Jun 5 08:47:10 1997 Jeffrey A Law (law@cygnus.com)
1763
1764 * Make-common.in (libsim.a): Fix typo.
1765
1766 Thu Jun 5 13:48:37 1997 Andrew Cagney <cagney@b1.cygnus.com>
1767
1768 * nrun.c (main): Verify the structure returned before using it.
1769
1770 Wed Jun 4 11:44:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
1771
1772 * sim-config.h (WITH_ENGINE): Enable the sim-engine module by
1773 default.
1774
1775 * sim-engine.c (sim_engine_install): New function. Install the
1776 engine init functions.
1777 (sim_engine_init): [Re]initialize the simulator engine.
1778
1779 * sim-module.c: Add sim_engine to list of modules that always
1780 install.
1781
1782 Tue Jun 3 04:52:04 1997 Andrew Cagney <cagney@b1.cygnus.com>
1783
1784 * sim-watch.c (schedule_watchpoint): Use sim_unschedule_watchpoint
1785 to remove the old watchpoint, not delete_watchpoint.
1786 (watch_option_handler): Action the correct watchpoint, not just
1787 cycles.
1788
1789 Wed May 28 14:47:41 1997 Andrew Cagney <cagney@b1.cygnus.com>
1790
1791 * sim-n-core.h (sim_core_write_aligned_N): For 8byte reads, output
1792 both low and high word.
1793 (sim_core_write_aligned_N): Ditto.
1794
1795 * sim-trace.c (set_trace_options): Delete code explicitly setting
1796 core->trace.
1797
1798 * sim-options.c (sim_print_help): Call the list commands if not a
1799 standalone simulator.
1800 (sim_print_help): Advise that some options may not be applicable.
1801
1802 * sim-trace.c (set_trace_options): Assume core present.
1803
1804 * sim-events.c (sim_events_schedule_after_signal): Overflow signal
1805 buffer when full not almost full.
1806
1807 Tue May 27 14:32:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
1808
1809 * sim-events.c (sim_events_process): Don't blat the event queue
1810 when processing watchpoints.
1811
1812 * sim-watch.h: Make arg unsigned long - stop sign extension.
1813
1814 * sim-events.c (sim_watch_valid): rewrite so debugable.
1815
1816 * sim-config.h (WITH_XOR_ENDIAN): Default to zero.
1817
1818 * sim-watch.c (schedule_watchpoint): Add is_within option so that
1819 inequality test is possible.
1820 (handle_watchpoint): Re-pass is_within arg.
1821 (watch_option_handler): When `!' prefix to pc-watchpoint arg pass
1822 0 to schedule_watchpoint's is_within arg.
1823 (sim_watchpoint_init): Re-pass is_within arg.
1824
1825 * sim-options.c (sim_print_help): Add is_command argument. Don't
1826 include -- prefix when called from the command line interpreter.
1827
1828 * sim-watch.c (schedule_watchpoint): Pass true is_within argument.
1829
1830 * sim-events.c (sim_events_watch_sim): Add is_within argument,
1831 zero indicates that the test should be reversed.
1832 (sim_events_watch_core): Ditto.
1833 (WATCH_CORE): Compare range against is_within.
1834 (WATCH_SIM): Ditto.
1835
1836 Tue May 27 12:48:03 1997 Andrew Cagney <cagney@b2.cygnus.com>
1837
1838 * sim-events.c (WATCH_CORE): Pass NULL cpu argument to
1839 sim_core_read_buffer. Check nr-bytes transfered.
1840
1841 * sim-core.h (sim_core_common): Define a new struct that contains
1842 the common data. to sd and cpu structures.
1843 * sim-core.c (sim_core_attach): Update.
1844 (sim_core_init): Update. Remember to copy initialized data to each
1845 cpu.
1846 (sim_core_find_mapping): Ditto.
1847
1848 * sim-core.c (sim_core_read_buffer): Add cpu argument.
1849 (sim_core_write_buffer): Ditto.
1850
1851 * sim-n-core.h (sim_core_read_unaligned_N): When mis-aligned
1852 transfer use xor version of read buffer.
1853 (sim_core_write_unaligned_N): Ditto for write.
1854
1855 * sim-core.c (sim_core_xor_read_buffer): New function implement
1856 xor-endian data read breaking transfer up into xor-endian sized
1857 blocks.
1858 (sim_core_xor_write_buffer): Ditto for write.
1859 (reverse_n): Reverse order of arbitrary number of bytes in buffer
1860 - needed for xor-endian transfers.
1861
1862 Fri May 23 14:24:31 1997 Andrew Cagney <cagney@b1.cygnus.com>
1863
1864 * sim-inline.h: Review description.
1865
1866 * sim-core.h, sim-core.c: Reduce number of functions being inlined
1867 to just those involved in data transfers and configuration.
1868
1869 * sim-xcat.h (XSTRING): New macro, map macro definition onto
1870 string.
1871 * sim-n-core.h (sim_core_read_aligned_N): Use.
1872 (sim_core_read_unaligned_N): Ditto.
1873 (sim_core_read_unaligned_N): Ditto..
1874 (sim_core_write_unaligned_N): Ditto.
1875
1876 * sim-core.h: Add xor endian bitmap to main structure. *
1877
1878 sim-n-core.h (sim_core_write_aligned_N): Add suport for xor
1879 endian.
1880 (sim_core_read_aligned_N): Ditto.
1881
1882 * sim-core.c (sim_core_set_xor_endian): New function.
1883 (sim_core_attach): Don't overwrite the per-cpu xor map when
1884 cloning the global core.
1885
1886 Fri May 23 10:53:13 1997 Andrew Cagney <cagney@b1.cygnus.com>
1887
1888 * sim-engine.h: Update below so that it is using an enumerated
1889 type.
1890
1891 Thu May 22 09:12:16 1997 Gavin Koch <gavin@cygnus.com>
1892
1893 * sim-engine.c (sim_engine_restart):
1894 * sim-resume.c (sim_resume): Change longjmp param/setjmp
1895 return value used for simulator restart from 0 to 2.
1896
1897 Wed May 21 08:47:30 1997 Andrew Cagney <cagney@b1.cygnus.com>
1898
1899 * cgen-scache.c (scache_option_handler): Add is_command arg.
1900
1901 * sim-model.c (model_option_handler): Add is_command argument.
1902
1903 * sim-profile.c (profile_option_handler): Add is_command arg.
1904
1905 * sim-events.c (sim_watch_valid): Use ub64, lb64 when 64bit value
1906 involved.
1907
1908 * sim-module.c (sim_module_add_init_fn): Call init fn in the same
1909 order that they are registered.
1910
1911 * sim-options.h (OPTION_HANDLER): Add argument to differentiate
1912 between option and command line processing.
1913
1914 * sim-options.c: Include stdlib.h, ctype.h.
1915
1916 * Make-common.in (sim-watch.o): Add rule.
1917 (sim_main_headers): Assume sim-assert.h included.
1918 (sim-*.o): Simplify make rule.
1919
1920 * sim-module.c: Add sim_watch_install to module list.
1921
1922 Tue May 20 14:15:23 1997 Andrew Cagney <cagney@b1.cygnus.com>
1923
1924 * sim-base.h (STATE_LOADED_P): New predicate. Set once everything
1925 has been loaded.
1926
1927 * sim-trace.c (trace_install): Check magic. Include sim-assert.h.
1928 * sim-events.c (sim_events_install): Ditto.
1929 * sim-core.c (sim_core_install): Ditto.
1930 * sim-model.c (model_install): Ditto.
1931 * sim-options.c (standard_install): Ditto.
1932 * sim-profile.c (profile_install): Ditto.
1933 * sim-reason.c (sim_stop_reason): Ditto.
1934 * sim-run.c (sim_engine_run): Ditto.
1935 * sim-utils.c (sim_analyze_program): Ditto.
1936
1937 * sim-module.c (modules): Make profile_install and trace_install
1938 optional.
1939
1940 * sim-base.h (STATE_MEM_BASE): Define for flat memory systems.
1941
1942 * sim-options.c (standard_option_handler): Set the byte order.
1943
1944 * sim-events.c (sim_events_process): Allow multi tick processing.
1945 (sim_events_tickn): New function - multi cycle tick.
1946
1947 * sim-events.h (sim_events_tickn, sim_events_timewarp): Add
1948 prototypes. Under development.
1949 (sim_events): Replace processing with nr_ticks_to_process.
1950
1951 Tue May 20 09:39:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
1952
1953 * nrun.c (main): Pass callbacks to sim_open instead of using
1954 sim_set_callbacks.
1955
1956 * run.c (main): Ditto.
1957
1958 Mon May 19 12:07:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
1959
1960 * sim-events.c (sim_events_zalloc): Signal save memory allocator -
1961 stop tk interrupting malloc calls.
1962 (sim_events_zalloc): Converse.
1963
1964 * Make-common.in (sim_main_headers): Add sim-events.h.
1965
1966 * sim-events.c (sim_events_schedule_after_signal): Change return
1967 type to void - signal events are strictly internal.
1968 (sim_events_init): Allocate a finite buffer for signal events.
1969 (sim_events_schedule_after_signal): Enter signal events into the
1970 signal buffer.
1971
1972 * sim-engine.c (sim_engine_halt): Check SIM_DESC magic.
1973 (sim_engine_restart): Ditto.
1974 (sim_engine_abort): Ditto.
1975 * sim-stop.c (sim_stop): Ditto.
1976 (control_c_simulation): Ditto.
1977 * sim-resume.c (sim_resume): Ditto.
1978 (has_stepped): Ditto.
1979 * sim-abort.c (sim_engine_abort): Ditto.
1980
1981 * sim-basics.h (transfer_type): New type.
1982
1983 * sim-core.c (sim_core_signal): New function. Print core signal
1984 information.
1985 (sim_core_find_mapping): Add transfer argument.
1986
1987 * sim-n-core.h (sim_core_{write,write}_unaligned_N): Call
1988 SIM_CORE_SIGNAL if a recoverable abort.
1989 * sim-core.c (sim_core_find_mapping): Ditto.
1990
1991 Fri May 16 15:13:21 1997 Andrew Cagney <cagney@b1.cygnus.com>
1992
1993 * sim-core.c (sim_core_find_mapping): Replace calls to
1994 sim_io_error to more resiliant sim_engine_abort.
1995
1996 * sim-n-core.h (sim_core_read_unaligned_N): Ditto.
1997 (sim_core_write_unaligned_N): Ditto.
1998
1999 Tue May 13 13:50:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
2000
2001 * sim-module.c: Add sim_events_install to list.
2002
2003 * sim-events.c (sim_events_install, sim_events_uninstall): Clonse
2004 from sim_core_*.
2005 (sim_events_init): Now returns SIG_RC.
2006
2007 * sim-run.c: New file. Generic sim_engine_run.
2008 * sim-reason.c: New file. Generic sim_stop_reason.
2009 * sim-stop.c: New file. Generic sim_stop.
2010 * sim-resume.c: New file. Generic sim_resume.
2011
2012 * Make-common.in (sim-engine.o): Add rule.
2013 (sim-run.o, sim-reason.o, sim-stop.o, sim-resume.o): Ditto.
2014
2015 * sim-engine.h, sim-engine.c: New file. Provide generic
2016 implementation of sim_engine_halt, sim_engine_error. et.al.
2017
2018 * sim-base.h (sim_state_base): Add member halt.
2019 (sim-engine.h): Include.
2020
2021 * sim-events.h (sim_event_handler): Always pass SIM_DESC to event
2022 handlers.
2023 * sim-events.c (sim_events_poll): Update event handler.
2024
2025 Tue May 13 09:57:49 1997 Andrew Cagney <cagney@b2.cygnus.com>
2026
2027 * sim-events.h, sim-events.c (sim_events_watch_clock): New
2028 function.
2029 (sim_events_watch_sim): New function.
2030 (sim_events_watch_core): New function.
2031 (sim_watch_valid): New function.
2032 (sim_events_preprocess): New function.
2033 (sim_events_process): Process the watchpoints as well as the timer
2034 queue.
2035 (sim_events_tick): Check WORK_PENDING instead of the hold queue.
2036 (sim_events_deschedule): Check all the queues when removing an
2037 event.
2038 (sim_events_init): Ditto for cleaning.
2039
2040 Mon May 19 12:07:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
2041
2042 * sim-fpu.c (is_ufpu_number): Comment out - currently unused.
2043
2044 Mon May 19 11:23:03 1997 Andrew Cagney <cagney@b1.cygnus.com>
2045
2046 * callback.c (os_open): Type of arg flags is int.
2047
2048 Fri May 16 22:26:43 1997 Michael Meissner <meissner@cygnus.com>
2049
2050 * sim-fpu.c (sim_fpu_is_{eq,ne,lt,le,gt,ge}): Compare Infinities
2051 just like normal numbers as per IEEE rules.
2052
2053 Wed May 14 21:20:38 1997 Bob Manson <manson@charmed.cygnus.com>
2054
2055 * callback.c (os_close): Mark the descriptor as being
2056 available if the close succeeded.
2057 (os_open): Pass 0644 as the mode of the file being created.
2058
2059 Thu May 15 10:58:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
2060
2061 * sim-fpu.c (pack_fpu, unpack_fpu): New functions - decode a
2062 float.
2063
2064 * sim-inline.c (SIM_INLINE_C): Rename from _SIM_INLINE_C_.
2065 * sim-lnline.h: Update.
2066
2067 * sim-fpu.h, sim-fpu.c (sim_fpu_[iu]{32,64}to): New int2fp
2068 conversion functions.
2069 (sim_fpu_to{32,64}[iu]): New fp2int functions.
2070
2071 * sim-fpu.h, sim-fpu.c (sim_fpu_is_{lt,le,eq,ne,ge,gt}): New fp
2072 compare functions. Replacing.
2073 (sim_fpu_cmp): This. Delete.
2074
2075 Mon May 12 14:49:05 1997 Andrew Cagney <cagney@b1.cygnus.com>
2076
2077 * sim-core.c (sim_core_find_mapping): Call engine_error not
2078 sim_io_error when possible.
2079
2080 Mon May 12 08:55:07 1997 Andrew Cagney <cagney@b2.cygnus.com>
2081
2082 * sim-endian.h (V1_H2): Add macro's to insert a word into a
2083 high/low double word.
2084
2085 * sim-trace.h: Remove definition of attribute - defined in
2086 sim_basics.h.
2087
2088 Mon May 12 08:55:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
2089
2090 * sim-options.h (struct OPTION): Add doc_opt as the documenting
2091 name of the option - or family of options.
2092
2093 * sim-options.c (sim_args_command): Match command `a-b c' with
2094 option `--a-b-c' from option table.
2095
2096 Thu May 8 12:40:07 1997 Andrew Cagney <cagney@b1.cygnus.com>
2097
2098 * sim-options.c (sim_print_help): For optional arguments, wrap
2099 them in [].
2100
2101 * sim-trace.c (set_trace_options): New function, handle optional
2102 argument and multiple assignment.
2103 (trace_option_handler): Update.
2104
2105 * sim-trace.c (trace_option_handler): Trace branch and not fpu
2106 when branch tracing selected.
2107
2108 Wed May 7 15:19:58 1997 Andrew Cagney <cagney@b1.cygnus.com>
2109
2110 * sim-trace.c (trace_one_insn): Make a va-args function.
2111
2112 * sim-trace.c (trace_vprintf): New function, va-arg version of
2113 trace_printf.
2114
2115 Tue May 6 16:38:16 1997 Doug Evans <dje@canuck.cygnus.com>
2116
2117 * sim-trace.c (trace_uninstall): Don't close a file twice.
2118 * sim-profile.c (profile_uninstall): Likewise.
2119
2120 Tue May 6 06:14:01 1997 Mike Meissner <meissner@cygnus.com>
2121
2122 * sim-trace.c (toplevel): Include bfd.h.
2123 (trace_options): Note that --trace-linenum also turns on
2124 --trace-insn. Add --trace-{branch,semantics}.
2125 (trace_option_handler): If --trace-linenum, also turn on
2126 --trace-insn. Add --trace-branch support. If --trace-semantics,
2127 turn on ALU, FPU, branch, and memory tracing.
2128 (trace_one_insn): New function to trace an instruction. Support
2129 --trace-linenum.
2130 (OPTION_TRACE_*): Use an enum, rather than lots of defines.
2131
2132 * sim-trace.h (TRACE_{SEMANTICS,BRANCH}_IDX): Add new macros.
2133 (MAX_TRACE_VALUES): Use 32, not 12 by default.
2134 (TRACE_branch): Add new mask.
2135 (TRACE_*_P): Define all possible trace_p macros.
2136 (trace_one_insn): Declare function.
2137
2138 Mon May 5 14:08:34 1997 Mike Meissner <meissner@cygnus.com>
2139
2140 * sim-trace.h (__attribute__): Define as nothing if not GNU C or
2141 GNU C doesn't support __attributes__.
2142 ({trace,debug}_printf): Add attribute's so -Wformat can check the
2143 format strings.
2144
2145 Mon May 5 11:16:12 1997 Andrew Cagney <cagney@b1.cygnus.com>
2146
2147 * sim-config.h (FORCED_ALIGNMENT): New alignment option -
2148 addresses are masked forcing them to be correctly aligned.
2149 (WITH_ALIGNMENT): Make NONSTRICT_ALIGNMENT the default.
2150 * sim-config.c (config_alignment_to_a): Update.
2151
2152 * sim-core.h (sim_cpu_core): New data type contains cpu specific
2153 core data.
2154 * sim-base.h (CPU_CORE): Add cpu specific core data to cpu base
2155 type.
2156 * sim-core.c (sim_core_attach): Add CPU argument. Ready for
2157 processor specific core maps.
2158 (sim_core_map_attach): Copy the core map data to each of the
2159 processor specific core data structures.
2160 * sim-core.c (sim_core_find_mapping): Update.
2161
2162 * sim-n-core.h (sim_core_read_N, sim_core_write_N): Rename.
2163 (sim_core_write_aligned_N, sim_core_write_aligned_N): New names.
2164 (sim_core_write_unaligned_N, sim_core_write_unaligned_N): New
2165 alternatives that handle unaligned addresses.
2166 (sim_core_{read,write}_{,un}aligned_N): Drop SIM_DESC arg, replace
2167 with just CPU arg.
2168 * cgen-utils.c (sim_disassemble_insn): Update.
2169
2170 Mon May 5 13:19:16 1997 Andrew Cagney <cagney@b1.cygnus.com>
2171
2172 * sim-trace.h (TRACE_FPU_IDX): Add Floating-point specific
2173 tracing.
2174
2175 * sim-fpu.h, sim-fpu.c: New files - prototype for generic target
2176 fpu support.
2177
2178 * sim-inline.h, sim-inline.c: Add support for SIM_FPU.
2179
2180 Fri May 2 17:59:42 1997 Andrew Cagney <cagney@b1.cygnus.com>
2181
2182 * sim-core.c (sim_core_map_to_str): New function ascii equivalent
2183 to map type.
2184
2185 * sim-n-core.h (sim_core_read_N, sim_core_write_N): Use in trace
2186 statement.
2187
2188 Fri May 2 17:28:02 1997 Andrew Cagney <cagney@b2.cygnus.com>
2189
2190 * cgen-trace.c: Prepend additional trace_printf argument.
2191
2192 * cgen-utils.c (sim_disassemble_insn): Add additional core
2193 arguments.
2194
2195 Fri May 2 11:40:23 1997 Andrew Cagney <cagney@b1.cygnus.com>
2196
2197 * nrun.c (main): Catch/report errorenous simulator states.
2198
2199 * sim-module.c: #include "libiberty.h" so that xmalloc is defined.
2200 * sim-trace.c: #include string.h/strings.h so that memset is
2201 defined.
2202 * sim-utils.c: Ditto.
2203 * sim-profile.c: Ditto. And stdlib.h.
2204 (print_bar): Only define when used by instruction or memory profiler.
2205
2206 * sim-options.c (standard_option_handler): Make ul more local.
2207
2208 * sim-load.c (sim_load_file): Make the name constant.
2209 (sim_load_file): Passify gcc.
2210
2211 * sim-utils.h: New file, pre-declare utilites in corresponding .c
2212 file.
2213 * sim-utils.c, sim-load.c: Include sim-utils.h.
2214
2215 * sim-base.h (sim_cpu): Pre define here so available to all.
2216
2217 * sim-core.h (DECLARE_SIM_CORE_WRITE_N, DECLARE_SIM_CORE_READ_N):
2218 Restore the sim_cpu and instruction_address arguments so that full
2219 information is available to the abort function.
2220 * sim-core.c (sim_core_find_mapping, sim_core_write_buffer): Ditto.
2221 * sim-n-core.h (sim_core_write_N, sim_core_read_N): Update.
2222
2223 * sim-trace.h, sim-trace.c (trace_option_handler): Add interim
2224 tracing support for sim-events and sim-core.
2225 (trace_option_handler): Convert #if to if where possible so always
2226 compiled/checked by C compiler.
2227 * sim-n-core.h (sim_core_write_N, sim_core_read_N): Update.
2228
2229 * sim-base.h: Adjust comment documenting how to define the cpu
2230 structure.
2231 (sim_state_base): Add sim_core and sim_events to simulator base
2232 object.
2233
2234 * sim-trace.h, sim-trace.c (trace_printf): Add SIM_DESC argument.
2235 * sim-core.c (sim_core_init, sim_core_attach,
2236 sim_core_find_mapping): Update.
2237 * sim-events.c (ETRACE, sim_events_init, sim_events_time,
2238 update_time_from_event, insert_sim_event,
2239 sim_events_schedule_after_signal, sim_events_deschedule,
2240 sim_events_tick): Ditto.
2241
2242 * sim-basics.h (sim-module.h, sim-trace.h, sim-profile.h,
2243 sim-model.h): Move #includes from here.
2244 * sim-base.h: To here.
2245 (sim-core.h, sim-events.h, sim-io.h): Include also
2246
2247 Wed Apr 30 15:37:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
2248
2249 * callback.c (default_callback): Missing initialisers.
2250
2251 Thu May 1 10:40:47 1997 Doug Evans <dje@canuck.cygnus.com>
2252
2253 * sim-utils.c (sim_add_commas): New function.
2254 * sim-basics.h (sim_add_commas): Add prototype.
2255 * cgen-scache.c (scache_print_profile): Print commas in numbers.
2256 * sim-profile.c (COMMAS): New macro.
2257 (print_*): Use it to print commas in numbers.
2258
2259 * configure: Regenerated.
2260
2261 * cgen-sim.h (sim_signal_type): Add SIM_SIGINT.
2262 (cgen_state): New member run_fast_p.
2263 (cgen_init): Add prototype.
2264 (sim_disassemble_insn): New arg `cpu'.
2265 * cgen-trace.c (trace_insn): Update call to sim_disassemble_insn.
2266 * cgen-utils.c (cgen_init): New function.
2267 (sim_disassemble_insn): New arg `cpu'. Rewrite fetching of insn.
2268 * genmloop.sh: Call engine_halt if loop exits.
2269
2270 * Makefile.in (sim-options_h): Define.
2271 (sim-{module,options,trace,profile,utils}.o): Clean up dependencies.
2272 (sim-model.o): Add new rule.
2273 (cgen-{scache,trace,utils}.o): Add new rules.
2274 * aclocal.m4 (SIM_AC_OPTION_{SCACHE,DEFAULT_MODEL}): Add.
2275 * cgen-scache.c (scache_print_profile): Change `sd' arg to `cpu'.
2276 Indent output by 2 spaces.
2277 * cgen-scache.h (scache_print_profile): Update.
2278 * cgen-trace.c (trace_insn_fini): Indent output by 2 spaces.
2279 Use trace_printf, not fprintf.
2280 (trace_extract): Use trace_printf, not cgen_trace_printf.
2281 * genmloop.sh (!FAST case): Increment `insn_count'.
2282 * sim-base.h (sim_state_base): Only include scache_size if WITH_SCACHE.
2283 (sim_cpu_base): Rename member `sd' to `state' to be consistent with
2284 access macro's name.
2285 * sim-core.c (sim_core_init): Use EXTERN_SIM_CORE to define it.
2286 Change return type to SIM_RC.
2287 (sim_core_{install,uninstall}): New functions.
2288 * sim-core.h (sim_core_{install,uninstall}): Declare.
2289 (sim_core_init): Use EXTERN_SIM_CORE to define it.
2290 Change return type to SIM_RC.
2291 * sim-model.h (models,machs,model_install): Declare.
2292 * sim-module.c (modules): Add scache_install, model_install.
2293 (sim_post_argv_init): Set cpu->state backlinks.
2294 * sim-options.c (standard_options): Delete --simcache-size,--max-insns.
2295 (standard_option_handler): Likewise.
2296 * sim-profile.c (PROFILE_{HISTOGRAM,LABEL}_WIDTH): Move to
2297 sim-profile.h.
2298 (*): Assume ANSI C.
2299 (profile_options): Delete --profile-simcache.
2300 (profile_option_handler): Likewise.
2301 (profile_print_insn): Change `sd' arg to `cpu'. Indent output 2
2302 spaces.
2303 (profile_print_{memory,model}): Likewise.
2304 (profile_print_simcache): Delete.
2305 (profile_print_speed): New function.
2306 (profile_print): Rewrite.
2307 * sim-profile.h (PROFILE_scache): Renamed from PROFILE_simcache.
2308 (WITH_PROFILE_SCACHE_P): Renamed from WITH_PROFILE_SIMCACHE_P.
2309 (PROFILE_DATA): Delete members simcache_{hits,misses}.
2310 (PROFILE_COUNT_SIMCACHE_{HIT,MISS}): Delete.
2311 (PROFILE_{CALLBACK,CPU_CALLBACK}): New types.
2312 (profile_print): Update prototype.
2313
2314 Wed Apr 30 11:34:14 1997 Doug Evans <dje@canuck.cygnus.com>
2315
2316 * cgen-scache.[ch], cgen-sim.h: New files.
2317 * cgen-trace.[ch], cgen-types.h, cgen-utils.c, genmloop.sh: New files.
2318 * sim-model.c: New file.
2319
2320 * Make-common.in (clean targets): Undo patch of Apr. 22.
2321
2322 Fri Apr 25 15:28:32 1997 Mike Meissner <meissner@cygnus.com>
2323
2324 * sim-n-bits.h (signed): If we have a standard compiler, undef
2325 signed, so that signedN is defined correctly.
2326
2327 Thu Apr 24 00:00:07 1997 Doug Evans <dje@canuck.cygnus.com>
2328
2329 * sim-module.h, sim-model.h, sim-profile.h: New files.
2330 * sim-module.c, sim-profile.c: New files.
2331 * Make-common.in (SIM_PROFILE): Define
2332 (CONFIG_CFLAGS): Add $(SIM_PROFILE).
2333 (sim_main_headers): Add sim-module.h, sim-model.h, sim-profile.h.
2334 (sim_module.o,sim-profile.o): Add rules for.
2335 * aclocal.m4 (--enable-sim-trace): Allow symbolic arguments.
2336 (--enable-sim-profile): Add.
2337 * configure: Regenerated.
2338 * sim-base.h (sim_state_base): New members init_list, uninstall_list,
2339 model. Move trace and profile support to sim-{trace,profile}.h.
2340 New members trace_data, profile_data.
2341 * sim-basics.h: #include sim-module.h, sim-model.h, sim-profile.h.
2342 * sim-config.h: Provide default definition of WITH_PROFILE.
2343 (WITH_TRACE): Change default to -1.
2344 (MAX_NR_PROCESSORS): Always define.
2345 * sim-options.c: Move trace and profile support to
2346 sim-{trace,profile}.h.
2347 (sim_pre_argv_init): Moved to sim-model.c.
2348 (standard_install): New function.
2349 * sim-options.h (sim_pre_argv_init): Move decl to sim-model.c.
2350 (standard_install): Declare.
2351 * sim-trace.c: Tracing option handling moved here from sim-options.c.
2352 (trace_install, trace_uninstall): New functions.
2353 (trace_printf): Update reference to TRACE_FILE.
2354 * sim-trace.h (TRACE_FOO_IDX): Moved here from sim-base.h.
2355 (TRACE_foo): Bit masks for symbolic arguments to --enable-sim-trace.
2356 (WITH_TRACE_FOO_P): Define.
2357 (trace_install): Declare.
2358 (TRACE_DATA): New struct.
2359
2360 Wed Apr 23 17:23:15 1997 Doug Evans <dje@canuck.cygnus.com>
2361
2362 * run.c: Undo last exec_bfd patch.
2363 (main): Only pass -E ifdef SIM_HAVE_BIENDIAN.
2364
2365 Wed Apr 23 17:54:27 1997 Mike Meissner <meissner@cygnus.com>
2366
2367 * run.c (exec_bfd): Add back in.
2368 (main): Set exec_bfd.
2369
2370 Tue Apr 22 14:43:46 1997 Doug Evans <dje@canuck.cygnus.com>
2371
2372 * sim-load.c (sim_load_file): #include <stdio.h> for NULL.
2373
2374 Wed Apr 23 02:55:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
2375
2376 * sim-events.c (insert_sim_event): Call sim_io_error instead of
2377 less well defined engine_error.
2378 * sim-core.c: Ditto.
2379
2380 Tue Apr 22 08:48:16 1997 Stu Grossman (grossman@critters.cygnus.com)
2381
2382 * Make-common.in: Change clean targets to use :: so that other
2383 Makefiles can have their own clean targets.
2384 * sim-load.c (xprintf eprintf): Use ANSI_PROTOTYPES instead of
2385 __STDC__ to control use of stdarg vs. varargs syntax. Some
2386 systems can't use __STDC__, but require stdarg.
2387
2388 Fri Apr 18 11:14:43 1997 Doug Evans <dje@canuck.cygnus.com>
2389
2390 * sim-options.c (standard_options): Add --endian.
2391 (standard_option_handler): Likewise.
2392
2393 * nrun.c: #include <signal.h>.
2394 (main, cntrl_c): Wrap calls to sim_resume in a SIGINT
2395 handler that calls sim_stop ().
2396
2397 Fri Apr 18 13:11:36 1997 Andrew Cagney <cagney@b1.cygnus.com>
2398
2399 * run.c (main, cntrl_c): Wrap calls to sim_resume in a SIGINT
2400 handler that calls sim_stop (). Simulators may still be
2401 establishing their own handler.
2402
2403 * sim-events.c (sim_events_poll): Rename from
2404 sim_events_at_large_int. Poll IO.
2405
2406 * sim-io.c (sim_io_poll_quit): New function - pass on a polling
2407 request.
2408
2409 * callback.c (os_poll_quit): New function poll for quit signal
2410 where needed.
2411 (default_callback): Include magic number.
2412
2413 Thu Apr 17 02:25:11 1997 Doug Evans <dje@canuck.cygnus.com>
2414
2415 * aclocal.m4: Check for headers time.h, sys/time.h, sys/resource.h.
2416 Check for functions getrusage, time.
2417 * sim-basics.h (SIM_ELAPSED_TIME): New typedef.
2418 (sim_elapsed_time_get, sim_elapsed_time_since): Add prototypes.
2419 * sim-utils.c: #include time.h, sys/time.h, sys/resource.h if able.
2420 (sim_elapsed_time_get, sim_elapsed_time_since): New functions.
2421
2422 * sim-utils.c (sim_copy_argv, sim_analyze_program): New functions.
2423
2424 * sim-options.c, sim-options.h: New files.
2425 * sim-config.h (WITH_DEBUG): Provide default value of zero.
2426 * Make-common.in (nrun.o): Add rules for.
2427 * nrun.c: New file.
2428
2429 * run.c (main): Check return value of sim_open.
2430
2431 * Make-common.in (sim-options.o, sim-load.o, sim-trace.o): Add rules.
2432 (sim_main_headers): Add sim-trace.h.
2433 * run.c (exec_bfd, target_byte_order): Delete.
2434 (main): Pass -E <endian> to sim_open. Delete code to load sections,
2435 call sim_load instead. Check return code of sim_create_inferior.
2436 * sim-base.h (CURRENT_STATE): Define.
2437 (sim_state_base): Make typedef. New members options, prog_argv,
2438 prog_bfd, text_{section,start,end}, start_addr, simcache_size,
2439 mem_size, memory [+ corresponding access macros].
2440 (sim_cpu_base): New typedef.
2441 * sim-trace.h: New file.
2442 * sim-trace.c: New file.
2443 * sim-basics.h: #include it.
2444 * sim-load.c: New file.
2445
2446 Tue Apr 15 15:10:13 1997 Ian Lance Taylor <ian@cygnus.com>
2447
2448 * Make-common.in (INSTALL): Set to @INSTALL@.
2449 (INSTALL_XFORM, INSTALL_XFORM1): Remove.
2450 (install-common): Depend upon installdirs. Use
2451 $(program_transform_name) directly, rather than using
2452 $(INSTALL_XFORM).
2453 (installdirs): New target.
2454 * Makefile.in (INSTALL): Set to @INSTALL@.
2455 (INSTALL_XFORM, INSTALL_XFORM1): Remove.
2456 (install-man): Depend upon installdirs. Use
2457 $(program_transform_name) directly, rather than using
2458 $(INSTALL_XFORM).
2459 (installdirs): New target.
2460
2461 Tue Apr 15 15:08:12 1997 Andrew Cagney <cagney@b1.cygnus.com>
2462
2463 * sim-assert.h (SIM_ASSERT, ASSERT): Allow these macros to
2464 be overriden.
2465
2466 Wed Apr 9 16:06:44 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2467
2468 * sim-basics.h: Only bring in config.h and tconfig.h if
2469 HAVE_CONFIG_H.
2470
2471 Mon Apr 7 11:39:45 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2472
2473 * sim-config.h (WITH_TARGET_WORD_MSB): New Macro. Define the bit
2474 numbering convention of the target.
2475 * sim-config.c (print_sim_config): Print WITH_TARGET_WORD_BITSIZE
2476 and WITH_TARGET_WORD_MSB.
2477 (sim_config): When possible, check for consistency with bitsize
2478 and msb.
2479
2480 * sim-bits.h: Allow MSB to be other than zero.
2481 * sim-bits.c: Ditto.
2482 * sim-n-bits.h: Ditto.
2483
2484 * sim-bits.h (MSMASK*): New macros - converce to LSMASK*.
2485 * sim-n-bits.h (MSMASKEDn): Ditto.
2486
2487 Mon Apr 14 16:29:21 1997 Ian Lance Taylor <ian@cygnus.com>
2488
2489 * Makefile.in (INSTALL): Change install.sh to install-sh.
2490
2491 Mon Apr 7 10:46:38 1997 Doug Evans <dje@canuck.cygnus.com>
2492
2493 * sim-base.h (sim_state_base): Move `magic' to end of struct.
2494
2495 Mon Apr 7 15:53:21 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2496
2497 * run.c (main): Check that a program to run was specified.
2498
2499 Mon Apr 7 15:45:02 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2500
2501 * aclocal.m4 (AC_TYPE_SIGNAL): Add check.
2502
2503 * configure: Regenerated to track ../common/aclocal.m4 changes.
2504 * config.in: Ditto.
2505
2506 Wed Apr 2 15:06:28 1997 Doug Evans <dje@canuck.cygnus.com>
2507
2508 * sim-endian.h: Move host {LITTLE,BIG}_ENDIAN support from here,
2509 * sim-config.h: To here.
2510
2511 * Make-common.in (SIM_EXTRA_DEPS): New config var.
2512 (sim_main_headers): Define.
2513 (sim-*.o): Depend on $(SIM_EXTRA_DEPS).
2514 start-sanitize-d30v
2515 (BUILT_SRC_FROM_COMMON): Move here from ../d30v/Makefile.in.
2516 end-sanitize-d30v
2517 (clean): Use it.
2518 (sim-utils.o): Add rule for.
2519 * sim-utils.o: New file.
2520 * sim-basics.h: #include sim-base.h.
2521 (zalloc): Make argument unsigned long.
2522 * sim-base.h: New file.
2523 * sim-inline.h (SIM_IO support): Delete.
2524 * sim-io.h: Delete inline support.
2525 * sim-io.c: Likewise. sim-state.h renamed to sim-main.h.
2526 * sim-config.c: sim-state.h renamed to sim-main.h.
2527 * sim-core.c: Likewise.
2528 * sim-events.c: Likewise.
2529
2530 * run.c (main): Pass SIM_OPEN_STANDALONE to sim_open.
2531
2532 * aclocal.m4: Check for stdlib.h, string.h, strings.h, unistd.h.
2533 (sim-debug): Allow arguments. Define WITH_DEBUG in addition to
2534 -DDEBUG.
2535 * configure: Regenerated to track ../common/aclocal.m4 changes.
2536
2537 Wed Apr 2 14:34:19 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2538
2539 * configure: Regenerated to track ../common/aclocal.m4 changes.
2540
2541 Wed Apr 2 11:08:11 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2542
2543 * sim-config.h (WITH_ALIGNMENT, WITH_FLOATING_POINT,
2544 WITH_XOR_ENDIAN, WITH_SMP, WITH_RESERVED_BITS): Assume that these
2545 are defined by the configure.
2546
2547 * aclocal.m4 (sim-stdio): Add option stdio from ../ppc configure.
2548
2549 * aclocal.m4 (floating-point, xor-endian, alignment, smp,
2550 reserved-bits): Always define.
2551
2552 * sim-config.h, sim-config.c (sim_config): New function - and new
2553 file - co-ordinate the setting/checking of the common simulator
2554 configuration options.
2555
2556 * Make-common.in (sim-config.o): Add rule.
2557
2558 Fri Mar 28 15:32:00 1997 Mike Meissner <meissner@cygnus.com>
2559
2560 * callback.c (os_{,e}vprintf_filtered): Change stdarg type to
2561 va_list from void *, since va_list might not be a pointer type.
2562
2563 Mon Mar 24 15:27:12 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2564
2565 * sim-n-endian.h (offset_N): Correct assertion - word and sub word
2566 in wrong order.
2567 (offset_N): Correct computation of LE offset.
2568
2569 * sim-io.c (sim_io_error): Include a new line when reporting
2570 errors.
2571
2572 * sim-assert.h (SIM_FILTER_PATH): Out by one when locating last
2573 `/'.
2574
2575 Thu Mar 20 22:31:06 1997 Jeffrey A Law (law@cygnus.com)
2576
2577 * run.c: Include alloca-conf.h.
2578
2579 * callback.c (os_evprintf_filtered): Fix typo.
2580
2581 Fri Mar 21 13:36:20 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2582
2583 * run.c (string.h, strings.h, stdlib.h): Include.
2584
2585 * sim-events.c (sim_events_tick): Recent cleanup failed to return
2586 0 when nothing pending.
2587
2588 * run.c (sim_size, sim_trace): Plicate GCC - these two functions
2589 will soon be going away.
2590 (getopt): Plicate GCC.
2591
2592 * sim-endian.c (sim-io.h): Plicate GCC.
2593 * sim-bits.c (sim-io.h): Ditto.
2594 * sim-n-bits.h (ROTn): Ditto.
2595
2596 * sim-io.c (sim_io_error): Correct check for NULL.
2597
2598 * sim-assert.h (SIM_FILTER_PATH): Separate out the code filtering
2599 the __FILE__.
2600 * sim-events.c: Use SIM_FILTER_PATH to filter out the filename
2601 path.
2602
2603 Wed Mar 19 01:12:06 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2604
2605 * aclocal.m4 (SIM_AC_OPTION_*: Move so that they are outside of
2606 SIM_AC_COMMON - SIM_AC_COMMON was gobling arguments.
2607
2608 Tue Mar 18 20:48:12 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2609
2610 * sim-alu.h: Include sim-xcat.h.
2611
2612 Tue Mar 18 13:58:18 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2613
2614 * Make-common.in (sim-bits.c, sim-core.c, sim-endian.c,
2615 sim-events.c, sim-inline.c, sim-io.c): Define rules for building
2616 these.
2617
2618 * sim-events.c (sim_events_at_large_int): New function. Just
2619 schedules an event every large-int ticks.
2620 (sim_events_init): Call.
2621 (sim_events_tick, sim_events_process): Move async handing to
2622 sim_events_process. Move timer decrement so that it occures after
2623 events have been processed.
2624
2625 * sim-basics.h (struct _engine): Remove declaration.
2626
2627 * sim-events.h, sim-events.c: Rename type to sim_events. Prefix
2628 everything with same. Rename global struct to SIM_DESC.
2629 * sim-core.h, sim-core.c, sim-n-core.c: Ditto for sim_core.
2630 * sim-io.h, sim-io.c: Ditto.
2631
2632 * sim-assert.h: New file. Optional assertion checking macros.
2633 * sim-io.c (sim_io_error): Make just this function tolerant to
2634 null pointers.
2635
2636 * sim-xcat.h: New file. Define concatenate macros.
2637 * sim-basics.h (XCONCAT*): Move to sim-xcat.h.
2638 * sim-n-core.h, sim-n-bits.h, sim-n-endian.h: Explicitly include
2639 concat macros.
2640
2641
2642 Tue Mar 18 12:44:55 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2643
2644 * sim-bits.h (LSMASK): New macro. Create mask of LS bits.
2645
2646 Mon Mar 17 18:10:05 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2647
2648 * sim-inline.h: Add definitions for sim-types.
2649 (ALL_BY_MODULE): New macro, encapsulate full inlining by the
2650 module.
2651
2652 Mon Mar 17 15:38:27 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2653
2654 * sim-events.h: Remove defunct reference to callback struct.
2655
2656 Mon Mar 17 15:10:07 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2657
2658 * configure: Re-generate.
2659
2660 Mon Mar 17 15:04:47 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2661
2662 * Make-common.in (CSEARCH): Do not include the gdb directory in
2663 the search path.
2664
2665 Mon Mar 17 13:16:26 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2666
2667 * Make-common.in (SIM_ENDIAN, SIM_HOSTENDIAN, SIM_INLINE,
2668 SIM_WARNING): Drop, requiring the simulator specific Makefile.in
2669 to explicitly incorporate these.
2670
2671 * aclocal.m4 (--enable-sim-alignment); New option. Strongly
2672 specify the alignment restrictions of the target architecture -
2673 without this option all alignment restrictions are accomodated.
2674 (--enable-sim-assert): New option. Conditionally compile in
2675 assertion statements.
2676 (--enable-sim-float): New option. Strongly specify the target's
2677 floating point support.
2678 (--enable-sim-hardware): New option. Specify the hardware devices
2679 included in the simulation.
2680 (--enable-sim-packages): New option. Specify the hardware
2681 packages included in the simulation.
2682 (--enable-sim-regparm): New option. Specify that parameters be
2683 passed in registers instead of on the stack.
2684 (--enable-sim-reserved-bits): New option. Specify that reserved
2685 bits within an instruction are are correctly set.
2686 (--enable-sim-smp): New option. Specify the level of SMP support
2687 to be included in the simulator.
2688 (--enable-sim-stdcall): New option. Specify an alternative
2689 function call convention.
2690 (--enable-sim-xor-endian): New option. Configure xor-endian
2691 support used by some targets to implement bi-endian support.
2692
2693 Fri Mar 14 19:51:21 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2694
2695 * aclocal.m4 (--enable-sim-hostendian): New option. Allow the
2696 host endianness to be overridden.
2697 (--enable-sim-endian): Allow the target platform's byte order
2698 to be overridden.
2699 (--enable-sim-inline): Control the inlining of common components.
2700 (--enable-sim-bswap): For compatibility, also define WITH_BSWAP.
2701 (--enable-sim-warnings): Enable additional GCC compiler checks.
2702 * Make-common.in (SIM_ENDIAN, SIM_HOSTENDIAN, SIM_INLINE,
2703 SIM_WARNINGS): Add.
2704
2705 * sim-n-core.h, sim-n-bits.h, sim-n-endian.h: Rename from
2706 sim-*-n.h so that the names are uniq on dos machines
2707 * sim-core.c, sim-bits.c, sim-endian.c: Update.
2708
2709 Thu Mar 13 12:32:42 1997 Doug Evans <dje@canuck.cygnus.com>
2710
2711 * run.c: #include "libiberty.h".
2712 (main): New locals sd,no_args,sim_argv.
2713 Run buildargv on -a option. Pass argv to sim_open, argv[0]
2714 is program name. Update call to sim_set_callbacks.
2715 Record result of sim_open, pass to other sim_foo routines.
2716
2717 Thu Mar 13 10:24:05 1997 Michael Meissner <meissner@cygnus.com>
2718
2719 * callback.c (os_printf_filtered): Do not call exit(1) or print a
2720 final newline.
2721
2722 Thu Mar 6 15:50:28 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2723
2724 * callback.c: Add os_flush_stdout and vprintf_filtered callbacks.
2725 Route stdout through buffered IO.
2726
2727 * callback.c: Add os_flush_stderr, os_write_stderr,
2728 os_evprintf_filtered functions to route error output through
2729 stderr.
2730
2731 * sim-io.h, sim-io.c (sim_io_flush_stderr, sim_io_flush_stdout):
2732 Correct return type - should be void.
2733
2734 Fri Mar 7 20:14:37 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2735
2736 * sim-basics.h: Clean up. Many macro's moved to sim-inline.h.
2737
2738 * sim-config.h: Ditto. For some options - eg WITH_DEVICES - do
2739 not provide a default value as undefined indicates disable code.
2740
2741 Thu Mar 6 15:50:28 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2742
2743 * sim-core.h, sim-core-n.h, sim-core.c: Borrow code from ppc
2744 directory.
2745 * sim-events.h, sim-events.c: Ditto.
2746 * sim-io.h, sim-io.c: Ditto.
2747
2748 Tue Mar 4 09:35:56 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2749
2750 * sim-alu.h (ALU_SUB_CA, ALU*_SUB_CA): New alu operation.
2751
2752 * sim-bits.h, sim-bits-n.h, sim-bits.c (LSMASKED*): New macro's
2753 extract the tail or least signifiant bits from an integer of the
2754 specified size.
2755
2756 * sim-bits.h, sim-bits.c: Clean up conditionally compiled #if
2757 WITH_TARGET_BITSIZE so that the compilation will fail when an
2758 unsupported bitsize value is defined.
2759
2760 (INSERTED*): Convert to functions.
2761 (EXTRACTED*): Ditto.
2762
2763 (SIGN_EXTEND, SEXT): Change to more terse name.
2764
2765 Tue Mar 4 09:35:56 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2766
2767 * sim-inline.h: Allow explicit control over which .c files will be
2768 included by their header.
2769
2770 * sim-inline.h: Allow explicit control over which .c files use the
2771 alternative - REGPARM - parameter passing mechanism.
2772
2773 * sim-inline.h, sim-inline.c: Don't attempt to include any of
2774 icache.c, idecode.c, semantics.c or support.c. Those names are
2775 not generally applicable.
2776
2777 Thu Feb 27 10:17:23 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2778
2779 * sim-bits.c, sim-bits-n.h (new): Split sim-bits.c into two parts
2780 in a fashion similar to sim-endian-n.
2781
2782 * sim-endian.h: (H_word, L_word, AL_*, VL_*): Extend to include
2783 both value and address macro's.
2784
2785 Tue Feb 25 18:51:57 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
2786
2787 * sim-alu.h (ALU16_BEGIN, ALU16_SET, ...): Fill in.
2788
2789 * sim-endian.h (L_word, H_word): Replace MS2W_4, LS2W_4 with more
2790 generic L_word, H_word macro's.
2791
2792 Thu Feb 20 18:36:55 1997 Andrew Cagney <cagney@critters.cygnus.com>
2793
2794 * sim-basics.h: Borrow code from ppc directory.
2795 * sim-bits.c: Ditto.
2796 * sim-bits.h: Ditto.
2797 * sim-config.h: Ditto.
2798 * sim-endian-n.h: Ditto.
2799 * sim-endian.c: Ditto.
2800 * sim-endian.h: Ditto.
2801 * sim-inline.c: Ditto.
2802 * sim-inline.h: Ditto.
2803 * sim-types.h: Ditto.
2804
2805 Wed Feb 19 12:40:50 1997 Andrew Cagney <cagney@critters.cygnus.com>
2806
2807 * sim-alu.h (ALU_SET16, ALU_SET32, ALU_SET64, etc): Make available
2808 all the ALU size alternatives and then auto-configure a default.
2809
2810 * sim-alu.h: Copy ppc/idecode_expression.h.
2811
2812 Mon Feb 17 10:44:18 1997 Andrew Cagney <cagney@critters.cygnus.com>
2813
2814 * bits.h, bits.c (SIGN_EXTEND32, SIGN_EXTEND64): New functions,
2815 sign extend a bit within a value.
2816
2817 * sim-endian.h, sim-endian-n.h (offset_N): New functions - return
2818 a pointer into the middle of a host word.
2819 * sim-endian.h (MS2W_4, LS2W_4): Use this function.
2820
2821 Tue Feb 11 13:46:49 1997 Michael Meissner <meissner@tiktok.cygnus.com>
2822
2823 * callback.c: If HAVE_CONFIG_H is defined, include config.h from
2824 autoconf. If HAVE_UNISTD_H is defined, include unistd.h to get
2825 appropriate definitions of read, write, etc. Add prototype for
2826 system.
2827
2828 Tue Feb 4 13:24:44 1997 Doug Evans <dje@canuck.cygnus.com>
2829
2830 * Makefile.in (libcommon.a): Delete.
2831 (callback.o,targ-map.o): Delete, moved to Make-common.in.
2832 (gentmap,targ-vals.h,targ-map.c): Likewise.
2833 (run-autoconf): Delete.
2834 * aclocal.m4 (SIM_AC_OUTPUT): Redo creation of Makefile.
2835 (common makefile fragment): Moved back into ...
2836 * Make-common.in: Resurrect.
2837 * configure.in (AC_LINK_FILES): Delete, unnecessary now.
2838 * configure: Regenerated.
2839
2840 Fri Jan 31 07:16:49 1997 Doug Evans <dje@canuck.cygnus.com>
2841
2842 * aclocal.m4 (SIM_AC_COMMON): Move COMMON_MAKEFILE_FRAG from here.
2843 (SIM_AC_OUTPUT): To here.
2844
2845 Fri Jan 24 10:37:17 1997 Stu Grossman (grossman@critters.cygnus.com)
2846
2847 * aclocal.m4 (COMMON_MAKEFILE_FRAG): Quote a couple of $'s in
2848 comments and single quotes. Fixes a problem found on hpux.
2849
2850 Thu Jan 23 13:35:03 1997 Stu Grossman (grossman@critters.cygnus.com)
2851
2852 * aclocal.m4: Remove Make-common.in from dependencies.
2853 * (distclean): Remove targ-vals.def.
2854
2855 * aclocal.m4 (SIM_AC_COMMON): Move contents of Make-common.in
2856 into here. Makes insertion into makefiles easier. Also, change
2857 the way that callback.o, gentmap, targ-vals.h, targ-map.c,
2858 targ-map.o, and run are built. They are now built in the
2859 individual simulator directories, taking sources from ../common as
2860 necessary. This replaces the merging of libcommon.a into
2861 linsim.a, which was problematic for the WinGDB build process.
2862 * run.c: Include config.h from . instead of ../common.
2863 * Make-common.in: Remove. It's no longer necessary.
2864
2865 Mon Dec 16 15:02:33 1996 Ian Lance Taylor <ian@cygnus.com>
2866
2867 * Make-common.in (ALL_CLAGS): Put CFLAGS at the end.
2868 (.c.o): Put $(ALL_CFLAGS) before the file being compiled.
2869
2870 Wed Dec 11 11:30:58 1996 Jim Wilson <wilson@cygnus.com>
2871
2872 * run.c (main): Set target_byte_order before call to sim_open.
2873
2874 Sun Dec 8 18:22:06 1996 Doug Evans <dje@canuck.cygnus.com>
2875
2876 * callback.c: #include <stdlib.h>
2877 (os_error): New function.
2878 (default_callback): Add os_error.
2879
2880 Mon Nov 25 19:44:35 1996 Doug Evans <dje@canuck.cygnus.com>
2881
2882 * Make-common.in (Makefile): Set CONFIG_HEADERS="".
2883 * aclocal.m4: Mark the fact that --enable-sim-bswap isn't host
2884 specific.
2885 (SIM_AC_OUTPUT): Don't build Makefile if CONFIG_FILES="".
2886
2887 Wed Nov 20 01:11:04 1996 Doug Evans <dje@canuck.cygnus.com>
2888
2889 * run.c: #include ../common/config.h, tconfig.h.
2890 (myname): New static global.
2891 (main): Recognize new options -a, -c. Also recognize -h if h8/300.
2892 Only process -c ifdef SIM_HAVE_SIMCACHE.
2893 Only process -p/-s ifdef SIM_HAVE_PROFILE.
2894 Parse program name from argv[0] and use in error messages.
2895 Pass sim_args to sim_open. Pass prog_args to sim_create_inferior.
2896 Add support for incomplete h8/300 termination indicators.
2897 (usage): Make more verbose.
2898 * aclocal.m4,config.in,tconfig.in,configure.in,configure: New files.
2899 * Makefile.in,Make-common.in,callback.c: New files.
2900 * nltvals.def,gentmap.c,gentvals.sh: New files.
2901
2902 Tue Nov 12 13:34:00 1996 Dawn Perchik <dawn@cygnus.com>
2903
2904 * run.c: Include stdarg.h if __STDC__.
2905
2906 Tue Oct 15 11:16:31 1996 Jeffrey A Law (law@cygnus.com)
2907
2908 * run.c (main): Don't print out anything if the signal
2909 number is zero (ie no signal).
2910
2911 Tue Oct 15 11:20:44 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2912
2913 * run.c (main): Print out if the program raised a signal.
2914
2915 Wed Sep 18 09:52:14 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2916
2917 * run.c (exec_bfd): Rename from sim_bfd, to use the gdb name.
2918 (main): Ditto.
2919
2920 Tue Sep 17 11:04:50 1996 James G. Smith <jsmith@cygnus.co.uk>
2921
2922 * run.c (main): Explicitly cast malloc() parameter.
2923
2924 Thu Sep 12 11:27:21 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2925
2926 * run.c (sim_bfd): New global to hold the bfd pointer for the
2927 executable.
2928 (main): Initialize sim_bfd.
2929
2930 Fri Dec 15 16:27:49 1995 Ian Lance Taylor <ian@cygnus.com>
2931
2932 * run.c (main): Use new bfd_big_endian macro.
2933
2934 Wed Nov 8 15:49:49 1995 James G. Smith <jsmith@pasanda.cygnus.co.uk>
2935
2936 * run.c (main): Removed SH specific comments, so source is
2937 generic. Also updated to only load relevant sections. Moved
2938 sim_open() to after callback attach (to match GDB).
2939
2940 * run.1: Removed SH specific comments.
2941
2942 Sat Oct 21 12:31:01 1995 Jim Wilson <wilson@chestnut.cygnus.com>
2943
2944 * run.c (main): Always return sigrc at end.
2945
2946 Tue Oct 10 12:03:13 1995 J.T. Conklin <jtc@rtl.cygnus.com>
2947
2948 * run.c (main): Print error diagnostic and exit if bfd_openr() or
2949 bfd_check_format() fails.
2950
2951 Thu Sep 28 15:40:36 1995 steve chamberlain <sac@slash.cygnus.com>
2952
2953 * run.c, run.1: From sh directory.
2954
2955
This page took 0.093712 seconds and 4 git commands to generate.