Initial implementation of fixes for MPC860 version C0 & earlier.
[binutils-gdb.git] / sim / ppc / ChangeLog
1 1999-01-22 Jim Lemke <jlemke@cygnus.com>
2
3 * igen.c(gen_semantics_[ch]): setup/use of new option (-o mpc860c0[=n]).
4 interrupts.[ch](mpc860c0_instruction_program_interrupt): added.
5 ppc-instructions(the four branch insn groups): detect problematic br's.
6 psim.c(is_num - added, psim_options): Parse and init new option.
7 These changes are currently under #ifdef WITH_OPTION_MPC860C0.
8
9 1998-12-01 Ken Raeburn <raeburn@cygnus.com>
10
11 * hw_nvram.c (hw_nvram_bcd): Force value to fit in 0..99.
12
13 Fri Nov 20 12:17:28 1998 Andrew Cagney <cagney@b1.cygnus.com>
14
15 * main.c (sim_io_poll_quit): Stub function.
16
17 * events.c (SIM_EVENTS_POLL_RATE): Define.
18 (sim_events_poll): Copy function from common/sim-events.c.
19 (event_queue_init): Copy scheduling of sim_events_poll from same.
20
21 * sim_callbacks.h, sim_calls.c (sim_io_poll_quit): New function,
22 poll the external environment.
23
24 1998-11-19 Michael Meissner <meissner@cygnus.com>
25
26 * ppc-instructions (is_{NaN,inf}): Use unsigned64 to get the
27 fractional type, so that quiet NaN's aren't treated like
28 Infinities.
29
30 Mon Sep 28 09:42:45 1998 Drew Moseley <dmoseley@cygnus.com>
31
32 * table.c (table_open): For cygwin hosts, we need to use the
33 return value from the read routine as the number of bytes to
34 process. This apparently is due to text-mode vs binary-mode. If
35 the mounts are done text-mode, then the size returnedby fstat()
36 may be different than the number of bytes "read" in text mode.
37
38 Sun Oct 4 00:50:47 1998 Felix Lee <flee@cygnus.com>
39
40 * emul_netbsd.c (do_open): fix order-of-evaluation problem.
41 (do_close): ditto.
42 (do_fstat): ditto.
43 (do_lstat): ditto.
44
45 1998-09-03 Michael Meissner <meissner@cygnus.com>
46
47 * emul_{netbsd,unix}.c: Update copyright year.
48
49 Mon Jun 29 10:57:36 1998 Michael Snyder <msnyder@cleaver.cygnus.com>
50
51 * sim_calls.c (sim_fetch_register, sim_store_register):
52 return zero when nothing to do.
53
54 1998-06-26 Michael Meissner <meissner@cygnus.com>
55
56 * configure.in (AC_CHECK_HEADERS): Don't check for sys/mount.h.
57 * configure: Regenerate.
58 * emul_{netbsd,unix}.c (toplevel): No longer try to include
59 sys/mount.h. It conflicts on Linux when gnu libc2 is used.
60
61 Tue May 12 12:10:33 PDT 1998 James Ingham <jingham@leda.cygnus.com>
62
63 * Makefile.in: The run target depended on a target psim$(EXEEXT),
64 but there was no such target, only plain psim. So I changed the
65 run target to depend on psim.
66
67 Sat May 2 01:10:12 1998 Stu Grossman <grossman@babylon-5.cygnus.com>
68
69 * aclocal.m4: Remove defs of AM_EXEEXT and AM_CYGWIN32. These are
70 now defined in ../common/aclocal.m4, and the double definition causes
71 problems with AC_SUBST of EXEEXT.
72 * configure: Regenerate.
73
74 Wed Apr 29 15:44:52 1998 Geoffrey Noer <noer@cygnus.com>
75
76 * aclocal.m4: new file for AM_EXEEXT macro
77 * configure.in: call AM_EXEEXT
78 * configure: regenerate with autoconf 2.12.1.
79 * Makefile.in: add EXEEXT support
80
81 Sun Apr 26 15:31:55 1998 Tom Tromey <tromey@creche>
82
83 * configure: Regenerated to track ../common/aclocal.m4 changes.
84 * config.in: Ditto.
85
86 Sun Apr 26 15:19:51 1998 Tom Tromey <tromey@cygnus.com>
87
88 * acconfig.h: New file.
89 * configure.in: Reverted change of Apr 24; use sinclude again.
90 Don't call AC_C_CROSS.
91
92 Fri Apr 24 14:16:40 1998 Tom Tromey <tromey@creche>
93
94 * configure: Regenerated to track ../common/aclocal.m4 changes.
95 * config.in: Ditto.
96
97 Fri Apr 24 11:18:46 1998 Tom Tromey <tromey@cygnus.com>
98
99 * Makefile.in (top_builddir): New macro.
100 (INTLLIBS): New macro.
101 (INTLDEPS): Likewise.
102 (psim): Depend on INTLDEPS; link against INTLLIBS.
103 * configure.in: Call CY_GNU_GETTEXT.
104
105 Wed Apr 22 14:28:48 1998 Michael Meissner <meissner@cygnus.com>
106
107 * configure: Regenerate with autoconf 2.12.1.
108
109 Fri Mar 13 09:25:58 1998 Andrew Cagney <cagney@b1.cygnus.com>
110
111 * psim.c (psim_read_register, psim_write_register): Handle updates
112 for FPSCR.
113
114 * registers.c (register_description): Reconize "FPSCR".
115
116 * emul_netbsd.c (emul_netbsd_create): When FP available, enable
117 MSR FP exception mode. Do not enable FPSCR bits.
118 * emul_unix.c (emul_unix_create): Ditto.
119
120 Tue Feb 17 12:48:58 1998 Andrew Cagney <cagney@b1.cygnus.com>
121
122 * sim_calls.c (sim_store_register, sim_fetch_register): Pass in
123 length parameter. Return -1.
124
125 Mon Feb 9 14:13:14 1998 Andrew Cagney <cagney@b1.cygnus.com>
126
127 * ppc-instructions (fdiv, fdivs): Check for divide by zero.
128 (is_invalid_zero_divide, invalid_zero_divide_operation): New
129 functions.
130
131 Wed Dec 10 17:38:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
132
133 * sim_calls.c (sim_load): Do not parse PROG using buildargv, use
134 raw value instead.
135
136 1997-11-05 Felix Lee <flee@cygnus.com>
137
138 * emul_chirp.c: #ifdef HAVE_UNISTD_H
139
140 Wed Oct 15 08:50:54 1997 Andrew Cagney <cagney@b1.cygnus.com>
141
142 * corefile.c (core_attach): Pad out allocated memory regions so
143 that they are always correctly aligned.
144 (struct _core_mapping, core_map_attach, core_init,
145 new_core_mapping): Change free_buffer to type void*.
146
147 Mon Oct 6 18:09:26 1997 Michael Meissner <meissner@cygnus.com>
148
149 * sim_calls.c (zfree): Call free correctly.
150
151 Mon Sep 29 10:05:01 1997 Andrew Cagney <cagney@b1.cygnus.com>
152
153 * sim_calls.c (zfree): Use free, not mfree.
154 (sim_io_flush_stdoutput): Replace gdb_flush with callback ->
155 flush_stdout.
156
157 Fri Sep 26 09:50:29 1997 Andrew Cagney <cagney@b1.cygnus.com>
158
159 * ppc-instructions (sraw, slw, srw): From Charles Lefurgy, Fix
160 mask extracting shift amount. Correctly condition for setting XER
161 in sraw.
162 (ldhau): From Johannes Reisinger, update rA after load.
163
164 Tue Sep 9 22:13:23 1997 Felix Lee <flee@cygnus.com>
165
166 * basics.h (CONCAT*): token-pasting macros, if ALMOST_STDC,
167 for MSVC.
168 * words.h: __int64 instead of long long for MSVC.
169
170 Wed Aug 27 10:24:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
171
172 * sim_calls.c (sim_create_inferior): Check the simulator was
173 initialized before creating inferior.
174
175 * idecode_expression.h (ALU_END): From Charles Lefurgy - Extract
176 sign bit using 64 bit and not a 32 bit mask.
177
178 Wed Aug 27 10:15:48 1997 Andrew Cagney <cagney@b1.cygnus.com>
179
180 * sim_calls.c (sim_load): From Ian Lance Taylor - free argv after
181 it has been used, not before.
182
183 Tue Aug 26 10:41:35 1997 Andrew Cagney <cagney@b1.cygnus.com>
184
185 * sim_calls.c (sim_kill): Delete.
186 (sim_create_inferior): Add ABFD argument.
187 (entry_point): Delete variable.
188 (sim_load): Move setting of PC from here.
189 (sim_create_inferior): To here.
190
191 Mon Aug 25 16:17:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
192
193 * sim_calls.c (sim_open): Add ABFD argument.
194
195 Thu Jul 3 10:18:06 1997 Andrew Cagney <cagney@b1.cygnus.com>
196
197 * ppc-instructions (PPC_INSN_INT): From Michael Thies - Monitoring
198 CR register updates dependant on RC value had logic backwards.
199
200 * ppc-instructions (Load String Word Immediate): From Brad Parker
201 - sense of wrap test in check for overwriting RA wrong.
202 (Load String Word Indexed): Ditto.
203
204 * configure.in: From Erik Landry - set sim_default_model not
205 sim_model for sim-default-model option.
206 * configure: Regenerate.
207
208 * interrupts.c (check_masked_interrupts): Schedule a hardware
209 interrupt delivery when FP interrupts get enabled.
210 (program_interrupt): Generate FP exceptions instead of aborting.
211 (deliver_hardware_interrupt): Deliver a FP exception if so
212 enabled.
213
214 * registers.h: Add definition of fpscr_vx_bits.
215
216 * idecode_expression.h (FPSCR_END): Always update FEX and VX bits
217 in FPSCR.
218 (FPSCR_END): Explicitly check for possible floating point
219 exception conditions.
220 (FPSCR_BEGIN): Simplify.
221
222 * ppc-instructions (Move From FPSCR): Enable.
223 (Move To FPSCR Bit 1): Ditto.
224 (Move To FPSCR Bit 0): Ditto.
225 (Move To FPSCR Field Immediate): Ditto.
226 (Move to Condition Register from FPSCR): Simplify.
227 (invalid_arithemetic_operation): Generate a QNaN when invalid
228 operation exception disabled.
229
230 Tue May 20 10:22:50 1997 Andrew Cagney <cagney@b1.cygnus.com>
231
232 * sim_calls.c (sim_open): Add callback argument.
233 (sim_set_callbacks): Delete.
234
235 Tue Apr 22 22:36:57 1997 Mike Meissner <meissner@cygnus.com>
236
237 * sim_callbacks.h (error): Make declaration match gdb's.
238 * main.c (error): Ditto.
239
240 Fri Apr 18 17:03:09 1997 Andrew Cagney <cagney@b1.cygnus.com>
241
242 * sim_calls.c (sim_stop_reason): Simplify. Was running implies
243 stopped/SIGINT. Exit implies a status code.
244
245 * psim.c (cntrl_c_simulation): From main.c. Event function that
246 halts the simulator.
247 (psim_stop): New. Asynchronously schedule a stop simulator event.
248 (psim_run_until_stop): Delete. Made redundant by psim_stop.
249
250 * main.c (cntrl_c): Update.
251 (cntrl_c_simulation): Moved to psim.c.
252
253 * sim_calls.c (sim_stop): New function. Use psim_stop which
254 schedules a stop event.
255 (sim_resume): Drop SIGINT handler, now in gdb/main.c.
256 (sim_resume): Use psim_run as stop variable no longer needed.
257
258 Fri Apr 18 17:03:08 1997 Andrew Cagney <cagney@b1.cygnus.com>
259
260 * psim.c (psim_options): Handle -E option correctly.
261 (psim_usage): Document.
262
263 Thu Apr 17 03:28:03 1997 Doug Evans <dje@canuck.cygnus.com>
264
265 * psim.c (psim_options): Ignore -E option (sets endianness).
266 * sim_calls.c: #include bfd.h.
267 (entry_point): New static local.
268 (sim_load): Return SIM_RC. New arg abfd. Set start address from bfd.
269 (sim_create_inferior): Return SIM_RC. Delete arg start_address.
270
271 Tue Apr 15 14:57:18 1997 Ian Lance Taylor <ian@cygnus.com>
272
273 * Makefile.in (INSTALL): Set to @INSTALL@.
274 (INSTALL_XFORM, INSTALL_XFORM1): Remove.
275 (install): Depend upon installdirs. Use $(program_transform_name)
276 directly, rather than using $(INSTALL_XFORM).
277 (installdirs): New target.
278
279 Fri Apr 4 17:54:36 1997 Jim Wilson <wilson@cygnus.com>
280
281 * Makefile.in (tmp-hw, tmp-pk): Use for loop to eliminate duplicates
282 rather than the non-portable cat -n.
283
284 Mon Apr 14 16:29:51 1997 Ian Lance Taylor <ian@cygnus.com>
285
286 * Makefile.in (INSTALL): Change install.sh to install-sh.
287
288 Tue Apr 1 18:15:14 1997 Jim Wilson <wilson@cygnus.com>
289
290 * ppc-instructions: Change milhwu to mulhwu.
291
292 Wed Apr 2 15:38:08 1997 Doug Evans <dje@canuck.cygnus.com>
293
294 * sim_calls.c (sim_open): New arg `kind'.
295
296 Wed Apr 2 14:51:17 1997 Ian Lance Taylor <ian@cygnus.com>
297
298 * COPYING: Update FSF address.
299
300 Tue Mar 25 16:17:59 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
301
302 * main.c (sim_io_read_stdin): Only compile unbuffered IO code if
303 all the required features are supported by the host OS.
304
305 Tue Mar 25 12:13:02 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
306
307 * emul_bugapi.c (emul_bugapi_create): Guard against NULL images.
308
309 * configure.in (enable-sim-endain): Correct typo in usage (from
310 Erik Landry <landry@ENGR.ORST.EDU>).
311 * configure: Re-generate.
312
313 Fri Mar 14 18:23:02 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
314
315 * Makefile.in (targ-vals.def): Re-do rule so that it works with
316 FreeBSD's make. Didn't like $<.
317
318 Thu Mar 13 12:55:48 1997 Doug Evans <dje@canuck.cygnus.com>
319
320 * sim_calls.c (sim_open): New SIM_DESC result. Argument is now
321 in argv form.
322 (other sim_*): New SIM_DESC argument.
323
324 Thu Feb 13 10:35:14 1997 Andrew Cagney <cagney@phydeaux.cygnus.com>
325
326 * ppc-opcode-simple-array, ppc-opcode-simple-goto,
327 ppc-opcode-simple-switch, ppc-opcode-complex-array,
328 ppc-opcode-complex-goto, ppc-opcode-complex-switch,
329 ppc-opcode-jump, ppc-opcode-goto, ppc-opcode-flat: Delete,
330 superseeded by --sim-decode-mechanism option.
331
332 * ppc-opcode-simple, dc-simple: Rename to be 8.3
333 * ppc-opcode-complex, dc-complex: Ditto.
334 * ppc-opcode-stupid, dc-stupid: Ditto.
335 * ppc-opcode-test-1, dc-test.01: Ditto.
336 * ppc-opcode-test-2, dc-test.02: Ditto.
337
338 * configure.in (--enable-sim-opcode): Change prefix to dc- instead
339 of ppc-opcode-.
340
341 Wed Feb 12 19:33:45 1997 Andrew Cagney <cagney@phydeaux.cygnus.com>
342
343 * Many of the ppc-opcode-* files are identical baring the type of
344 lookup table. Instead of having multiple tables, igen can do this
345 via an additional option.
346
347 * ld-decode.h, ld-decode.c (force_decode_gen_type): New function,
348 allow the type of generated table specified in the decode file to
349 be overridden.
350
351 * ld-decode.c (load_decode_table): Allow the table type to be
352 overridden.
353
354 * igen.c (main): Add -T <mechanism> option so that an overriding
355 instruction decode mechanism can be specified.
356
357 * configure.in: New option --sim-decode-mechanism to control
358 igen's new -T <mechanism> flag.
359 * Makefile.in (IGEN_FLAGS): Add IGEN_IDECODE_MECHANISM set by the
360 configure script.
361 * configure: Regenerate.
362
363 Tue Feb 11 13:49:10 1997 Michael Meissner <meissner@tiktok.cygnus.com>
364
365 * events.c (event_queue_create): Don't use NULL to initialize an
366 integer field.
367 (even_queue_{init,schedule_after_signal,tick}): Conditionalize use
368 of sigprocmask to appropriate autoconf test.
369
370 * main.c ({cntrl_c,main}): Use RETSIGTYPE for signal return type,
371 don't assume void.
372 * sim_calls.c (sim_{ctrl_c,resume}): Ditto.
373
374 * Makefile.in (callback.o): Define HAVE_CONFIG_H, so callback.c
375 includes our config.h.
376
377 Tue Feb 4 13:42:59 1997 Doug Evans <dje@canuck.cygnus.com>
378
379 * configure.in: Fix typo in test for callback.c.
380 * configure: Regenerated.
381
382 Fri Feb 7 10:04:25 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
383
384 * emul_chirp.c (emul_chirp_create): Handle a virtbase of -1 being
385 found in the device tree.
386
387 Wed Feb 5 10:56:27 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
388
389 * Property create/initialization still wasn't correctly ordered.
390 Should be delaying everything related to ihandle creation until
391 after the rest of the tree has been established.
392
393 * device.c (device_find_ihandle_runtime_property): Update.
394 (device_add_ihandle_runtime_property): Update.
395
396 * tree.c (parse_ihandle_property): Delay lookup of the device to
397 be opened until the ihandle initialization phase.
398 * tree.c (print_properties): Update.
399
400 Wed Feb 5 10:56:27 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
401
402 * gen-icache.c (print_icache_extraction): Add a reason parameter.
403 Augment each extracted field with a comment citing the codes
404 origin. Should simplify tracking down incorrect cache
405 extractions.
406
407 Tue Feb 4 17:44:51 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
408
409 * gen-icache.c: Generalize code handling XXX_is_NNN so that it
410 works for normal and boolean table entries.
411
412 * psim.c (psim_write_memory): last_cpu == -1 or nr_cpus is now
413 valid. Handle this just like *_{read,write}_register now handles
414 it.
415
416 Mon Feb 3 17:18:16 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
417
418 * events.c (insert_event_entry): Correct loop termination
419 assertions.
420
421 Fri Jan 31 16:20:26 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
422
423 * psim.c (psim_options): Add new option -c for max-iterations or
424 count.
425 (psim_usage): Document.
426 (psim_max_iterations_exceeded): New function, abort simulation if
427 max iterations exceeded.
428
429 * gen-idecode.c: Re-work the table lookup code so that it assumes
430 that the entry is a leaf by default. Simplify the boolean table
431 entry code so that it involves a mask + test instead of shift +
432 shift + mask + test.
433
434 * gen-idecode.c: Correct generated igen body so that it no drops
435 or doubles clock interrupts.
436
437
438 Thu Jan 30 11:23:20 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
439
440 * Makefile.in (BUILT_SRC_WO_CONFIG): Change targ-vals.* to
441 @sim_targ_vals@
442
443 * configure.in (sim_callback, sim_targ_vals): Set sim_targ_valls
444 if common callback is present.
445
446 Wed Jan 29 12:32:41 1997 Michael Meissner <meissner@tiktok.cygnus.com>
447
448 * configure.in (sim_callback): If the gdb is post 4.16, configure
449 callback support from the common directory.
450 * configure: Regenerate.
451
452 * Makefile.in (BUILT_SRC_WO_CONFIG): Add targ-vals.{h,def} and
453 targ-map.c.
454 (GDB_OBJ): Add callback support configured in.
455 (gentmap,targ-vals.def): Build from common directory.
456 (targ-vals.h,targ-map.c): Build by running gentmap.
457 (callback.o): Build from source in common directory.
458 (targ-map.o): Add dependency.
459 (clean): Remove gentmap.
460
461 Wed Jan 29 12:14:19 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
462
463 * igen wasn't aborting if the opcode table contained no valid
464 fields.
465
466 * misc.c (name2i): Possibly abort if an invalid name is
467 encountered.
468 * ld-decode.c: Abort if the table type isn't found.
469
470 Wed Jan 29 12:14:19 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
471
472 * When performance monitoring is disabled, it is still possible to
473 determine the simulation speed by looking at the number of elapsed
474 ticks recorded by the event queue.
475
476 * psim.c (psim_write_register, psim_read_register): Force the cpu
477 to zero when it is either of `-1' or `nr_cpus'. In both cases the
478 next cpu would be zero any way.
479
480 * mon.c (mon_print_info): If possible, print the system cycle
481 performance. This is an indication of the number of instructions
482 per second.
483
484 Wed Jan 29 12:14:19 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
485
486 * The code to allow an event queue to be updated during a signal
487 was missing. For main.c, a cntrl-c simulation termination wasn't
488 handled cleanly.
489
490 * The simulation would not correctly restart if an event requested
491 that the simulation be halted.
492
493 * psim.c (psim_options): Add hack to -i option to optionally
494 include a level vis -i2.
495 (psim_usage): Document.
496
497 * main.c (cntrl_c, cntrl_c_simulation): New functions. When a
498 cntrl-c occures schedule an event to halt the simulation.
499 (main): Catch CNTRL-C signals with the function cntrl_c.
500
501 * events.c (event_queue_process): Mask interrupts while
502 manipulating the async event queue.
503 (event_queue_init): Ditto.
504 (event_queue_schedule_after_signal): Ditto.
505
506 * events.c (event_queue_process): Mark the event queue as being in
507 the processing state when processing has started. Adjust code
508 so that it is tolerant of halts.
509 (event_queue_init): Start the event queue out with processing
510 false.
511 (event_queue_tick): Check that processing isn't still being
512 performed.
513
514 * gen-idecode.c (print_run_until_stop_body): Call
515 event_queue_process_events to clear possibly pending events before
516 starting a simulation run. Re-arange main loop so that simulator
517 is correctly restarted when an event halts the simulation.
518
519 * psim.c (psim_halt): Handle an event halting the simulation.
520 * psim.c (psim_init): Adjust initial cpu - == -1 - to match
521 reworked idecode.
522
523 Wed Jan 29 12:14:19 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
524
525 * ppc-opcode-complex: Correct typo - was expanding ORA instead of
526 RA. Based on instruction frequency stats, expand additional
527 instructions.
528 * ppc-instructions: Change all `RA == 0' to RA_is_0.
529
530 * ppc-opcode-stupid: Move all but the basic table in -complex into
531 here. Update to new format.
532
533 * Makefile.in (tmp-defines): New target. Force defines.h to always
534 be built. Hence get ppc-opcode-goto to build.
535
536 Tue Jan 28 13:00:19 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
537
538 * hw_com.c (hw_com_instance_read, hw_com_instance_write):
539 Implement.
540
541 Thu Jan 23 09:07:26 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
542
543 * hw_trace.c (hw_trace_init_data): Delete. The trace options need
544 to be initialized independant of the rest of the simulation
545 initalization. Otherwize a trace option explictly set from gdb
546 could be overridden by hw_trace.
547
548 * psim.c (psim_options): Clarify reason why the trace ioctl occures.
549
550 * FIXME: The trace code is too scattered - hw_trace.c, psim.c,
551 debug.c. It could be much simpler.
552
553 Thu Jan 23 09:07:26 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
554
555 * Some devices support removable media. Add hooks to the disk
556 device so that it supports this.
557
558 * device.c (device_add_string_array_property,
559 device_find_string_array_property): New functions, manipulate
560 properties containing an array of strings.
561 (device_find_string_property): Allow a string array.
562 (device_init_static_properties): Update.
563 (device_init_runtime_properties): Update.
564
565 * hw_disk.c (hw_disk_ioctl): Add ioctl for changing the disk
566 media. If no file image is specified, use the next one in the
567 image property list.
568 (hw_disk_init_address): Change the file property so that it is a
569 string array - use the first entry for the initial file image.
570
571 * tree.c (print_string_aray_property): New function - print a
572 string array.
573 (print_properties): Adjust.
574 (print_string): Write a string, handling double quotes.
575
576 * device.h: Define an ioctl to `change-media' with an optional new
577 media image.
578
579 * hw_disk.c: Allow floppy disk devices to be specified.
580
581 * psim.c (psim_command): New function, parse more complex psim
582 commands such as "change-media" and "trace".
583 * sim_calls.c (sim_do_command): Use.
584
585 Wed Jan 22 09:38:33 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
586
587 * For expressions like (RA == 0) that are entered in to the cache
588 as RA_is_0. If possible generate the result of the expression so
589 that the compiler gets a better chance of eliminating dead
590 branches.
591
592 * gen-icache.c (print_icache_extraction): For a cache entry of
593 the form <name>_is_<const> where it is a boolean field, generate
594 the result of the expression instead of the expression its self.
595 (print_icache_body): Remove code that was looking for *_is_0 and
596 then generating corresponding definitions.
597
598 * gen-icache.c (print_icache_struct): If there is no cache, do not
599 output expressions in idecode.h file.
600
601 * gen-icache.c (print_icache_body): Output them here.
602
603 * ppc-opcode-complex: Clarify constant values for SPR==LR register
604 expansion.
605
606 * ppc-cache-rules (RA_is_0, SPR_is_256): Two new cache entries.
607
608 Wed Jan 22 12:24:52 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
609
610 * The code that put values in and extracted values from the cache
611 was too compilicated. The cache table did not allow values to be
612 computed from cache entries. #defines could only be used when a
613 cache was present, remove the restriction.
614
615 * ld-cache.h, ld-cache.c: Add a new cache entry type - SCRATCH. A
616 scratch variable is defined when a cache entry is beinf
617 filled. Change the definition of a COMPUTE variable to be defined
618 when the cache entry is being used.
619 * gen-icache.c: Update.
620
621 * ld-cache.h, ld-cache.c: Change field names so that their meaning
622 is more obvious. old_name->field_name, new_name->derived_name.
623 * gen-icache.c: Update
624
625 * gen-icache.h, gen-icache.c (print_icache_body): Make the three
626 different types of cache code - put into cache, extract from
627 cache, no cache - an explicit argument to print_icache_body.
628 * gen-icache.c (print_icache_extraction): Ditto.
629
630 * gen-semantics.c (print_c_semantic): Update use.
631 * gen-idecode.c (print_jump_insn): Update use.
632 * gen-icache.c (print_icache_function): Update use.
633
634 * igen.c (main): Change 'R' option so that it does not force the
635 cache.
636
637 * configure.in (enable-sim-icache): Clarify description. Make
638 #define one of the defaults regardless of the cache. Probably
639 should revamp and add a separate option.
640
641 Tue Jan 21 13:26:10 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
642
643 * pk_disklabel.c (block_is_fdisk): Tidy up traces - use dos
644 partition numbering.
645 (pk_disklabel_create_instance): Partition 1..4 are valid - not
646 1..3.
647 (is_iso9660): New function, verify a CD9660 File system.
648 (pk_disklabel_create_instance): Start expanding so that active
649 partition selection is supported.
650
651 Mon Jan 20 11:20:15 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
652
653 * The cap object was retaining a reference to the instance of a
654 device after it was deleted. Instead add and remove cap's from the
655 cap db as they are created and deleted. This ensuring that a
656 capibility is only used during the lifetime of the corresponding
657 object.
658
659 * cap.h, cap.c: Correct cap type - was signed32 should be
660 signed_cell.
661
662 * cap.c (cap_add, cap_remove): New methods for cap object that
663 allow the explicit addition and removal of internal objects that
664 the cap knows about.
665
666 * cap.c (cap_init): Rewrite. Verify that the only objects
667 remaining in the cap data base are those that were entered first.
668 Thse objects will be the permenant ones.
669 * device.c (device_init_address): Remember to initialize the cap
670 database.
671
672 * device.c (device_create_instance_from): Explicitly add device
673 instances to the cap database. Simplify create code.
674 (device_instance_delete): Explicitly remove device instances from
675 the cap database.
676
677 * device.c (device_create_from): Explicitly add a device to the
678 cap data base.
679
680 * device.c (device_create_from): Always set the cap members.
681
682 * hw_disk.c: Output the instance when tracing.
683
684 Sun Jan 19 16:44:29 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
685
686 * tree.c (split_device_specifier): Add support for aliases when
687 looking up a device. Now needs a device as an argument.
688 (split_property_specifier): Ditto.
689
690 Sun Jan 19 15:28:23 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
691
692 * The memory "claim" and "release" methods take an address and
693 size as arguments. These may be multi cell values. Initially fix
694 the memory code so that they check/detect this. Leave the
695 adjustment of any clients to later.
696
697 * hw_memory.c (hw_memory_instance_claim,
698 hw_memory_instance_release): Handle multi-cell memory devices.
699
700 * hw_memory.c (hw_memory_instance_claim): Be tolerant towards the
701 release of memory regions that were not claimed.
702
703 Fri Jan 17 12:01:07 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
704
705 * device.h, device.c (device_instance_call_method): Correct return
706 type - can return either 0 or -1, hence should be a signed type.
707 * device_table.h: Ditto.
708
709 * hw_memory.c (hw_memory_instance_claim,
710 hw_memory_instance_release): Update.
711 * hw_disk.c (hw_disk_max_transfer, hw_disk_block_size,
712 hw_disk_nr_blocks): Ditto.
713
714 Fri Jan 17 11:50:13 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
715
716 * emul_chirp.c (chirp_emul_claim): Implement using the "claim"
717 method belonging to "/chosen/memory".
718 (chirm_emul_release): Ditto.
719
720 * Makefile.in (LIB_INLINE_SRC): Remove emul_* from list of files
721 that are inlined. These modules are called via a table and are
722 not made inline.
723
724 * hw_init.c (update_for_binary_section): Fix failure to allocate
725 memory used by the binary in real-mode executions. If "claim"
726 property is present, allocate memory from the "/chosen/memory"
727 device.
728
729 * emul_chirp.c (emul_chirp_create): Specify that memory should be
730 claimed when loading a real image.
731
732 * hw_memory.c (hw_memory_instance_claim): Don't page align memory
733 allocations.
734
735 * hw_memory.c (hw_memory_instance_release): Avoid infinite loop
736 when merging adjacent memory chunks.
737
738 Thu Jan 16 08:51:25 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
739
740 * vm.h (vm_data_map_read_buffer, vm_data_map_write_buffer): Add
741 optional PROCESSOR & CIA args so that this routine also abort an
742 access.
743
744 * vm_n.h (vm_data_map_read_N, vm_data_map_write_N): For a
745 miss-aligned access when a transfer fails abort.
746
747 * emul_bugapi.c (emul_bugapi_do_write): Use emul_read_buffer
748 instead of the vm_read_buffer.
749 * emul_netbsd.c (do_write): Ditto.
750 * emul_unix.c (do_unix_write): Ditto.
751
752 Wed Jan 15 14:38:25 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
753
754 * configure.in (--enable-sim-jump): Default is NULL and not -E.
755 * configure: Regenerate.
756
757 * basics.h (__attribute__): Enable attributes if GCC >= 2.6.
758 (UNUSED): Only enable UNUSED if GCC >= 2.7.
759
760 * gen-icache.c (print_icache_extraction): Print UNUSED macro
761 instead of explicit __unused__ attribute.
762 (print_icache_body): Ditto.
763 * idecode_expression.h (FPSCR_BEGIN): Use UNUSED.
764
765 Wed Jan 15 13:54:50 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
766
767 * cpu.h, cpu.c (cpu_synchronize_context): Add CIA argument as
768 reference point.
769
770 * vm.c (vm_synchronize_context): Add PROCESSOR and CIA as
771 arguments so that there is a reference point for recovery.
772 (vm_synchronize_context): Pass processor+cia for errors.
773 (om_unpack_sr): Ditto.
774 (om_unpack_srs): Ditto.
775 * vm.c (vm_create): Review error messages.
776
777 * vm.c: Include "cpu.h" so that cpu_error is visible.
778
779 * ppc-instructions (Return From Interrupt): Pass CIA.
780 (Instruction Synchronize): Ditto.
781 * psim.c (psim_init): Ditto.
782
783 Wed Jan 15 12:25:11 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
784
785 * cpu.h, cpu.c (cpu_error): Aborts simulation with error message,
786 but also saves current processor state.
787
788 * basics.h: Move #include <stdarg.h> to here from device_table.h.
789
790 * interrupts.c (perform_oea_interrupt): Use. No longer loose CIA
791 when simulation aborted.
792 (program_interrupt): Ditto.
793 (floating_point_unavailable_interrupt): Ditto.
794 (alignment_interrupt): Ditto.
795 (floating_point_assist_interrupt): Ditto.
796 (perform_oea_interrupt): Ditto.
797 (machine_check_interrupt): Ditto.
798
799 Tue Jan 14 12:19:10 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
800
801 * ppc-instructions (Move from Special Purpose Register): Support
802 move from DEC.
803
804 Mon Jan 13 16:58:12 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
805
806 * debug.h, debug.c: Add "interrupts" trace option.
807
808 * interrupts.c (data_storage_interrupt): Add tracing.
809 (machine_check_interrupt): Ditto.
810 (instruction_storage_interrupt): Ditto.
811 (alignment_interrupt): Ditto.
812 (program_interrupt): Ditto.
813 (floating_point_unavailable_interrupt): Ditto.
814 (system_call_interrupt): Ditto.
815 (floating_point_assist_interrupt): Ditto.
816 (deliver_hardware_interrupt): Ditto.
817
818 * interrupts.c (program_interrupt): For UEA mode, halt the
819 processor - so that the current state is saved - instead of
820 aborting.
821 (floating_point_unavailable_interrupt): Ditto.
822 (floating_point_assist_interrupt): Ditto.
823
824 Thu Jan 2 09:10:41 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
825
826 * interrupts.c (perform_oea_interrupt): Halt rather than abort on
827 a double interrupt.
828
829 Wed Jan 1 22:54:52 1997 Andrew Cagney <cagney@kremvax.tpgi.com.au>
830
831 * ppc-instructions (Store Multiple Word, Load Multiple Word):
832 Enable.
833
834 * tree.c (print_properties): For an array consider printing it out
835 as an integer array.
836
837 * hw_memory.c (hw_memory_init_address): If an "available" property
838 is present, use that to initialize the available memory instead of
839 using the reg property.
840
841 * emul_generic.c (emul_add_tree_hardware): Add "available"
842 property to memory device.
843
844 Fri Dec 20 13:19:07 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
845
846 * ppc-instructions (Rotate Left Word then AND with Mask): Enable.
847
848 * device.c (device_instance_call_method): Was only looking at the
849 first method.
850
851 * hw_disk.c (hw_disk_nr_blocks): Implement #blocks method.
852 (hw_disk_block_size): Implement block-size method.
853 (hw_disk_max_transfer): Implement max-transfer method.
854
855 * hw_phb.c (hw_phb_init_address): Reinit the rest of the PHB.
856
857 * emul_chirp.c (chirp_emul_instance_to_path): Recover from an
858 invalid ihandle.
859 (chirp_emul_instance_to_package): Ditto.
860 (chirp_emul_method): Ditto.
861 (chirp_emul_read): Ditto.
862 (chirp_emul_write): Ditto.
863 (chirp_emul_close): Ditto.
864 (chirp_emul_seek): Ditto.
865 (chirp_emul_package_to_path): Ditto (for phandle).
866 (chirp_emul_package_to_path): Return the length.
867
868 * psim.c (psim_merge_device_file): Allow continuation lines.
869
870 Thu Dec 19 11:09:43 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
871
872 * emul_chirp.c (chirp_emul_boot): Implement. Well report the new
873 string and exit.
874
875 * emul_chirp.c (chirp_emul_exit): Correct type of args struct
876 members - *_cell not host dependant int.
877
878 Wed Dec 18 17:49:59 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
879
880 * interrupts.c (perform_oea_interrupt): Print additional
881 information if a double interrupt is encountered.
882
883 Wed Dec 18 17:49:59 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
884
885 * psim.c (psim_merge_device_file): Tolerate an incorrect file-name
886 being specified with the -f option.
887 (psim_merge_device_file): Correct check for end of string.
888
889 Wed Dec 18 17:49:59 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
890
891 * emul_chirp.c (chirp_emul_peer): Was falling off the end of the
892 list of devices. Return zero to the client instead.
893 * emul_chirp.c (chirp_emul_child): Ditto
894 * emul_chirp.c (chirp_emul_parent): Ditto
895
896 * device.c (device_root): Assert assumption about the device being
897 valid.
898
899 Tue Dec 17 15:12:38 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
900
901 * emul_chirp.c (emul_chirp_create): Add description property to
902 each significant node in the device tree.
903 * emul_bugapi.c (emul_bugapi_create): Ditto.
904
905 Fri Dec 13 14:30:31 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
906
907 * main.c (sim_io_read_stdin): For a single byte STDIO read, use a
908 tempoary two byte buffer. Single byte read with fgets will not
909 work.
910 * main.c: Include errno.h.
911 (sim_io_read_stdin): For non-STDIO, make it work.
912
913 * emul_chirp.c (chirp_emul_read): Return the correct error status.
914
915 Fri Dec 13 14:30:31 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
916
917 * std-config.h (WITH_STDIO): Don't hard-wire the STDIO mechanism.
918 Instead have each emulation default it to DO_USE_STDIO.
919
920 * emul_generic.c (emul_add_tree_options): Select the STDIO I/O
921 mechanism as the default if enabled or if nothing selected.
922
923 * sim_calls.c (sim_io_read_stdin): Passify GCC's desire for a
924 return value.
925 (sim_io_write_stdout): Ditto.
926 (sim_io_write_stderr): Ditto.
927 * main.c (sim_io_write_stdout): Ditto.
928 (sim_io_write_stderr): Ditto.
929 (sim_io_read_stdin): Ditto.
930
931 Tue Dec 10 10:31:48 1996 Michael Meissner <meissner@tiktok.cygnus.com>
932
933 * emul_chirp.c (emul_chirp_instruction_call): Make *printf calls
934 type correct.
935 * vm.c (om_effective_to_virtual): Ditto.
936 * events.c (event_queue_schedule{,_after_signal}): Ditto.
937 (event_queue_{deschedule,process}): Ditto.
938 * hw_htab.c (htab_decode_hash_table): Ditto.
939 (htab_map_{page,binary}): Ditto.
940 * hw_opic.c (hw_opic_init_data): Ditto.
941 (handle_interrupt): Ditto.
942 (do_processor_init_register_{read,write}): Ditto.
943 (write_vector_priority_register): Ditto.
944 ({read,write}_destination_register): Ditto.
945 (do_suprious_vector_register_{read,write}): Ditto.
946 (do_current_task_priority_register_N_{read,write}): Ditto.
947 (do_timer_frequency_reporting_register_{read,write}): Ditto.
948 (do_timer_N_{current,base}_count_register_{read,write}): Ditto.
949 (do_ipi_N_dispatch_register_write): Ditto.
950 (do_vendor_identification_register_read): Ditto.
951 (do_feature_reporting_register_N_read): Ditto.
952 (do_global_configuration_register_N_{read,write}): Ditto.
953 * hw_phb.c (hw_phb_attach_address): Ditto.
954 (hw_phb_unit_decode): Ditto.
955 (hw_phb_address_to_attach_address): Ditto.
956 (hw_phb_io_{read,write}_buffer): Ditto.
957 * hw_ide.c (setup_fifo): Ditto.
958
959 * sim_calls.c ({defs,callback,remote-sim}.h): Find gdb include
960 files via -I<dir> instead of using "../../gdb/" prefixes.
961
962 Tue Dec 10 10:12:44 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
963
964 * debug.h: Add tracing for the pal device.
965 * hw_pal.c: Update.
966
967 * emul_chirp.c (chirp_emul_getprop): More tracing.
968
969 Tue Dec 10 10:12:44 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
970
971 * device.h, device.c (device_find_ihandle_runtime_property): New
972 function. Reverse of add_ihandle_runtime property.
973 (device_init_runtime_properties): Use it.
974
975 * device.c (find_property_entry): New function returns the
976 internal property spec.
977 (device_set_property): Use.
978 (device_find_property): Use.
979
980 Tue Dec 10 10:12:44 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
981
982 * psim.c (psim_merge_device_file): Strip newline from device
983 specs.
984
985 Tue Dec 10 10:12:44 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
986
987 * hw_htab.c (htab_map_binary): For overlapping text / data maps
988 merge the two. Also check that the merge is safe.
989
990 * emul_chirp.c (emul_chirp_create): Add a description property to
991 the pte's so that they are easier to identify.
992
993 (emul_chirp_create): Don't specify a load address for the CHRP
994 image. Always use the values specified by the executable.
995
996 * hw_htab.c (htab_map_page): Abort if a duplicate map is
997 encountered.
998
999 Mon Dec 9 12:08:46 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
1000
1001 * hw_htab.c (htab_map_page): Formatting.
1002
1003 * emul_chirp.c (emul_chirp_instruction_call): Check for a NULL
1004 method name when handling the client call. Also check for other
1005 bad call arguments.
1006
1007 * emul_chirp.c (emul_chirp_create): Allow real-mode?, real-base,
1008 etc to be overriden.
1009
1010 Mon Dec 9 12:08:46 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
1011
1012 * os_emul.c (os_emul_create): Use tree find property instead of
1013 device find property - sigh.
1014
1015 Thu Dec 5 10:46:42 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
1016
1017 * 961205: Release snapshot 961205.
1018
1019 Thu Dec 5 10:46:42 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
1020
1021 * configure.in (hostbitsize, bitsize): Fix typo in error message -
1022 cannot contain a comma.
1023 (sim-warnings): Check for more potential errors.
1024
1025 * psim.c (psim_usage): Add -f <file> option. Specifies a file
1026 containing device tree specifications that should be merged into
1027 the device tree.
1028
1029 * configure.in: Sort options.
1030 * configure: Rebuild
1031
1032 Wed Dec 4 13:57:31 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
1033
1034 * psim.c (psim_usage): Add -n option - specify number of
1035 processors.
1036
1037 * emul_chirp.c: Add description.
1038 * emul_bugapi.c: Ditto.
1039 * emul_unix.c: Ditto.
1040 * emul_netbsd.c: Ditto.
1041
1042 Fri Nov 29 11:12:22 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
1043
1044 * hw_pal.c (hw_pal_attach_address): New function, if an attach is
1045 encountered, assume that it is the single disk.
1046 * hw_pal.c: Add generic device/size decode methods.
1047
1048 * hw_nvram.c (hw_nvram_init_address): Use the first nonzero reg
1049 property entry when determining the nvram size.
1050
1051 * hw_core.c: Add generic address/size decode methods.
1052
1053 * emul_chirp.c (emul_chirp_instruction_call): Return and trace
1054 nonzero status from client functions.
1055
1056 * main.c (error): Always include a cariage return when writing out
1057 errors.
1058
1059 Wed Nov 20 00:36:55 1996 Doug Evans <dje@canuck.cygnus.com>
1060
1061 * sim_calls.c (sim_resume): Reset sim_should_run if single
1062 stepping.
1063
1064 Thu Nov 28 13:19:46 1996 Andrew Cagney <cagney@kremvax.tpgi.com.au>
1065
1066 * emul_bugapi.c (emul_bugapi_do_diskio): Add support for multiple
1067 optional disks.
1068
1069 * emul_generic.c (emul_add_tree_hardware): Drop the dummy eeprom.
1070 Attach the pal - for I/O - as a pseudo device haning from the
1071 firmware sub tree.
1072
1073 * emul_bugapi.c (emul_bugapi_create): Add a small memory device to
1074 the device tree at the address of the hi-mem interrupt vector
1075 addreses. Used by bugapi to establish its trap instructions.
1076
1077 * debug.h: Add a new macro DITRACE for tracing device instances.
1078
1079 * debug.h: Extend the DTRACE macro so that it can also tests for
1080 device specific tracint.
1081
1082 * device.h, device.c (device_trace): Add method to determine
1083 device specific tracing.
1084 (device_init_address): Set the devices tracing level.
1085
1086 Thu Nov 21 12:05:32 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1087
1088 * tree.h, tree.c (tree_device): New files - separate out the
1089 device parser and other tree operations from the device.
1090
1091 * inline.h, inline.c (INLINE_TREE): Add.
1092 * device.h, device.c (device_tree_add_parsed): Delete.
1093 * Makefile.in (tree.c): Add rules for new file.
1094 * Makefile.in: Better order the emul_* files.
1095
1096 * emul_generic.c (emul_add_tree_hardware): Update.
1097 * emul_netbsd.c (emul_netbsd_create): Update.
1098 * emul_unix.c (emul_unix_create): Ditto.
1099 * emul_chirp.c (emul_chirp_create): Ditto.
1100 * emul_bugapi.c (emul_bugapi_create): Ditto.
1101 * psim.c (psim_tree): Ditto.
1102 * hw_init.c: Ditto.
1103
1104 * emul_generic.h: Include tree.h
1105 * Makefile.in: Add to EMUL_GENERIC_H dependencies.
1106
1107 * device.h, device.c (device_root): New function - returns the
1108 root of the tree.
1109 * corefile.c: Use.
1110
1111 * device.h, device.c (device_clean): New function, clean up device
1112 ready for next simulation run. This includes things like deleting
1113 interrupt edges and properties created during the simulation and
1114 also scrubbing any pre-defined properties.
1115 * tree.c (tree_init): Use.
1116
1117 * device.h, device.c (device_init_static_properties): New
1118 function. Initialize any static predefined properties. By static
1119 we mean those that have values that can be determined before the
1120 device tree initialization has started.
1121 * tree.c (tree_init): Use.
1122
1123 * device.h, device.c (device_init_address): Add code to
1124 check/verify the devices #address-cells and #size-cells.
1125 (device_add_integer_property): Delete corresponding code.
1126 (device_nr_address_cells, device_nr_data_cells): Check for
1127 property when returning value.
1128
1129 * device.h, device.c (device_init_runtime_properties): New
1130 function. Initialize those properties that are not `static'. At
1131 present the only such property is the ihandle.
1132 * tree.c (tree_init): Use.
1133
1134 * device.h, device.c (reg, ranges): Rework these so that they use
1135 an array of the fundamental type - single reg or single range
1136 entry.
1137
1138 * device.h, device.c (device_add_ihandle_runtime_property):
1139 Re-implement the adding of an ihandle during tree construction so
1140 that it better fits in with device initialization.
1141
1142 Thu Nov 21 12:05:32 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1143
1144 * device.h, device.c (device_ioctl): Add additional argument -
1145 request - so that the caller must always specify the type of
1146 the ioctl request.
1147
1148 * device_table.h: Update.
1149 * hw_trace.c (hw_trace_ioctl): Ditto.
1150 * hw_vm.c (hw_vm_ioctl_callback): Ditto.
1151 * hw_init.c (hw_stack_ioctl_callback): Ditto.
1152 * psim.c (psim_options): Ditto.
1153
1154 Thu Nov 21 12:05:32 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1155
1156 * BUGS: Updated a bit.
1157
1158 Wed Nov 20 14:06:37 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1159
1160 * hw_opic.c: Finish - third round.
1161
1162 Wed Nov 20 12:02:08 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1163
1164 * hw_glue.c (hw_glue_io_read_buffer_callback): Fix miscalc of glue
1165 reg index.
1166 (hw_glue_io_write_buffer_callback): Ditto.
1167
1168 Tue Nov 19 21:17:08 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1169
1170 * events.c (event_queue_process): Was incorrectly consuming future
1171 events on the queue when they should be left alone.
1172
1173 * debug.h, debug.c (events): Add support for event queue tracing.
1174 * events.c: Add event tracing.
1175
1176 * debug.h, debug.c: Order device trace options.
1177
1178 Fri Nov 15 15:23:39 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1179
1180 * pk_disklabel.c (pk_disklabel_create_instance): Fix up some
1181 warnings generated by GCC.
1182
1183 Sun Nov 17 17:59:14 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1184
1185 * sim-endian.h: Add LE versions of byte swap macros. Needed for
1186 PCI devices which are little-endian.
1187
1188 * sim-endian-n.h (endian_le2h_N, endian_h2le_N): Ditto
1189
1190 Sun Nov 17 17:59:14 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1191
1192 * hw_iobus.c (hw_iobus_attach_address_callback): Change the iobus
1193 so that it is implementing a 1-1 address map.
1194
1195 * emul_generic.c (emul_add_tree_hardware): Adjust.
1196
1197 * emul_generic.c (emul_add_tree_hardware): Don't add the nvram as
1198 a default.
1199
1200 Sun Nov 17 17:59:14 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1201
1202 * device.c (split_find_device): Be tolerant of missing unit
1203 addresses.
1204
1205 Fri Nov 15 16:49:49 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1206
1207 * basics.h (port_direction): New type, specify the direction of
1208 any `port'.
1209
1210 * device.h, device.c (device_interrupt_decode): Include
1211 specification of port direction in operations.
1212 (device_interrupt_encode): Ditto.
1213
1214 * device_table.h: Add a direction field to the interrupt port
1215 table.
1216
1217 * device.c (device_tree_add_parsed): Specify port direction.
1218
1219 Thu Nov 14 21:38:13 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1220
1221 * hw_opic.c: Finish - second round.
1222
1223 Thu Nov 7 00:18:59 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1224
1225 * hw_htab.c (htab_init_data_callback): Allow the virtual-address
1226 to be specified as an array which allows 64bit addresses.
1227
1228 * device.c (device_find_integer_array_property): New function.
1229 Simplify the querying of elements of an integer array.
1230 (device_add_integer_property, device_find_integer_property):
1231 Update to correctly use the cell type.
1232
1233 * vm.c (om_unpack_sr): Clarify shifting comment.
1234 (om_pte_0_masked_vsid): Ditto. Add 64bit version.
1235
1236 * emul_chirp.c (emul_chirp_create): Initialize the segment
1237 registers.
1238
1239 * vm.c (om_effective_to_virtual): Trace segment register use.
1240
1241 * hw_htab.c (htab_map_page): Print out the pteg base address to
1242 simplify cross checking between vm and the htab.
1243 (htab_decode_hash_table): Use device_error instead of error.
1244 (htab_map_page): Ditto.
1245 (htab_dma_binary): Ditto.
1246 (htab_map_binary): Ditto.
1247 (htab_init_data_callback): Ditto.
1248
1249 Wed Nov 6 20:20:58 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1250
1251 * interrupts.h: Clarify what the optional instruction program
1252 interrupt is - a subset of illegal instruction program interrupt.
1253
1254 * interrupts.c (program_interrupt): For UEA mode, clarify what an
1255 optional instruction program interrupt is.
1256 (program_interrupt): For OEA mode, as per spec, generate an
1257 illegal instruction program interrupt when an optional instruction
1258 is encountered.
1259
1260 * gen-semantics.c (print_semantic_body): Delete code
1261 differentiating between an unimplemented floating point and normal
1262 instruction. Instead, such a case can be handled explicitly.
1263
1264 * ppc-instructions (store floating-point as integer word indexed):
1265 Mark as optional.
1266 (Floating Convert to Integer Doubleword): Make the floating point
1267 assist interrupt explicit.
1268 (Floating Convert To Integer Doubleword with round towards Zero):
1269 Ditto.
1270 (Floating Convert To Integer Word): Ditto
1271 (Move From FPSCR): Ditto.
1272 (Move to Condition Register from FPSCR): Ditto.
1273 (Move To FPSCR Fields): Ditto.
1274 (Move To FPSCR Field Immediate): Ditto.
1275 (Move To FPSCR Bit 0): Ditto.
1276 (Move To FPSCR Bit 1): Ditto.
1277
1278 Mon Nov 4 12:49:13 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1279
1280 * corefile.c (core_map_read_buffer, core_map_write_buffer): Avoid
1281 breaking up transfers.
1282
1283 * corefile.c: Adjust arguments so that the client server
1284 relationship is clarified.
1285
1286 * hw_glue.c (hw_glue_init_address): Update so it can be attached
1287 to a PCI bus.
1288
1289 * hw_disk.c (hw_disk_instance_write): Add more checks to disk IO -
1290 looking for things like overflow/underflow.
1291
1292 Sun Nov 3 18:45:20 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1293
1294 * emul_generic.c (emul_add_tree_hardware): Hang the disk off the
1295 PAL device instead of the IOBUS. The disk must be attached to a
1296 logical bus.
1297
1298 * hw_disk.c (hw_disk_init_address): Just use the unit address
1299 directly in the attach - the rest isn't relevant.
1300
1301 Sat Nov 2 21:48:57 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1302
1303 * configure.in (sim-hardware, sim-packages): Allow additional
1304 hardware and packages to be prefixed as well as appended.
1305
1306 * Makefile.in (tmp-hw, tmp-pk): Retain the user specified order of
1307 packages when building them. Consequently, a user can override a
1308 standard device by prefixing their own version.
1309
1310 * Makefile.in (hw_opic.o, hw_pci.o, hw_ide.o): Add dependencies.
1311
1312 Fri Nov 1 14:42:57 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1313
1314 * mon.c (_cpu_mon): Add fields for counting 1, 2, 4, and 8 byte
1315 reads and writes.
1316 (mon_{read,write}): Count 1, 2, 4, and 8 byte reads/writes.
1317 (mon_print_info): Correct typo regarding # of unaligned reads and
1318 writes. Print out how many 1, 2, 4, and 8 byte reads/writes there
1319 are.
1320
1321 Tue Oct 29 17:55:43 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1322
1323 * configure.in (AC_CHECK_FUNCS): Add access.
1324 * config{.in,ure}: Regenerate.
1325
1326 * emul_unix.c (do_unix_nop): System call that always succeeds.
1327 (do_unix_access): Support access system call.
1328 (solaris_descriptors): Make sigaltstack and sigaction nops.
1329 ({solaris,linux}_descriptors): Add support for access.
1330
1331 Tue, 8 Oct 18:42:26 1996 Jason Molenda <crash@cygnus.co.jp>
1332
1333 * Makefile.in (clean): Move config.log to distclean.
1334
1335 Fri Nov 1 16:44:28 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1336
1337 * corefile-n.h (core_map_write_N): Improve abort messages.
1338
1339 * device.h, device.c (device_attach_address): Remove unused name
1340 parameter.
1341 (device_detach_address): Ditto.
1342 * device_table.h, device_table.c: Update.
1343 * hw_iobus.c (hw_iobus_attach_address_callback): Ditto.
1344 * hw_nvram.c (hw_nvram_init_address): Ditto.
1345 * hw_memory.c (hw_memory_init_address): Ditto.
1346 * hw_vm.c (hw_vm_init_address_callback): Ditto.
1347 (hw_vm_attach_address): Ditto.
1348 (hw_vm_add_space): Ditto.
1349 * hw_init.c (update_for_binary_section): Ditto.
1350 * hw_core.c (hw_core_attach_address_callback): Ditto.
1351
1352 * hw_iobus.c (hw_iobus_attach_address_callback): Rewrite to handle
1353 configurable parent busses.
1354
1355 Wed Oct 30 18:46:32 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1356
1357 * device_table.c (generic_device_size_to_attach_size): Provide
1358 limited support for multi-cell sizes.
1359 (generic_device_address_to_attach_address): Ditto for addresses.
1360
1361 Tue Oct 29 02:01:29 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1362
1363 * device.c (device_add_integer_property): Check for setting of
1364 #address-cells and #size-cells properties. For these, update the
1365 corresponding device values.
1366 (device_nr_address_cells, device_nr_size_cells): Use the value
1367 from the device instead of the property.
1368
1369 * hw_core.c: Use generic address and size conversions for the top
1370 bus.
1371
1372 * hw_memory.c (hw_memory_init_address): Tolerate case where
1373 #address and #size cells is greater than 1.
1374
1375 * device.c (device_tree_print_device): Clean out printing of
1376 properties.
1377
1378 * device.c (split_device_specifier): Don't detect comments here -
1379 "#" can be a valid prefix - eg #size-cells.
1380
1381 * psim.c (psim_merge_device_file): Suppress comments and blank
1382 lines here.
1383
1384 * emul_generic.c (emul_add_tree_hardware): Fix typo of incorrect
1385 pal unit address. Add the property /#address-cells to the root of
1386 the tree.
1387
1388 * device.c (device_template_create_device): Check that the unit
1389 address was successfully parsed.
1390
1391 * device_table.c (generic_device_unit_decode): Rewrite to better
1392 handle multi-cell addresses.
1393 (generic_device_unit_encode): Ditto.
1394
1395 * emul_generic.c (emul_add_tree_hardware): "reg" properties no
1396 longer need the explicit array type - the parser takes care of it.
1397
1398 * pk_disklabel.c (pk_disklabel_create_instance): Add NULL return
1399 to keep GCC happy.
1400
1401 Mon Oct 28 22:55:48 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1402
1403 * hw_ide.c: New file. Model of a basic IDE interface attached to
1404 a PCI bus.
1405
1406 * configure.in (hardware): Add the ide device to the default
1407 configuration.
1408 * configure: Regenerate.
1409
1410 * debug.h, debug.c: Add tracing option for the IDE device.
1411
1412 Fri Oct 25 21:28:25 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1413
1414 * hw_phb.c, hw_phb.h: New files - implement a PHB.
1415
1416 * configure.in (hardware): Add the phb to the list of devices to
1417 build by default.
1418
1419 Fri Oct 25 21:28:25 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1420
1421 * hw_com.c: Review description.
1422 * hw_disk.c: Ditto.
1423 * hw_htab.c: Ditto.
1424 * hw_eeprom.c: Ditto.
1425 * hw_init.c: Ditto.
1426 * hw_cpu.c: Ditto.
1427
1428 * hw_com.c: Update event handling.
1429
1430 * hw_disk.c: Implement tracing.
1431
1432 Fri Oct 25 21:28:25 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1433
1434 * device_table.c (generic_device_init_address): Use
1435 assigned-addresses property in preference to any other reg
1436 property.
1437
1438 Fri Oct 25 21:28:25 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1439
1440 * device.h, device.c (device_find_ranges_property): New function.
1441 Simplify the manipulation of "ranges" properties.
1442
1443 * device.c (device_add_parsed): Extend to include support for the
1444 ranges property.
1445
1446 * device.c (device_add_parsed): Add assigned-addresses to the list
1447 of reg type properties.
1448
1449 * device.c (device_tree_print_device): Add code to format and
1450 print a ranges property.
1451
1452 * device.h, device.c (device_nr_address_cells,
1453 device_nr_size_cells): New functions. Determine the values of the
1454 standard properties #address-cells and #size-cells. Both of which
1455 are optional and have default values of two and one respectfuly.
1456 Previously, code that determined #address-cells was incorrectly
1457 using a value of one.
1458
1459 Fri Oct 25 21:28:25 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1460
1461 * debug.h, debug.c: Sort debug options, Add entries for the
1462 comming PHB device.
1463
1464 Fri Oct 18 12:12:21 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1465
1466 * ppc-instructions (Floating Select): Add support for fsel unless
1467 model is 601. Allow user to filter out instruction unless -Fs is
1468 passed to igen.
1469 (Store Floating-Point as Integer Word Indexed): Raise optional
1470 instruction program abort. Allow user to filter out instruction
1471 unless -Fs is passed to igen.
1472 (Floating Square Root{, Single}): Ditto.
1473 (Floating Reciprocal Estimate Single): Ditto.
1474 (Floating Reciprocal Square Root Estimate): Ditto.
1475
1476 * configure.in (--enable-sim-filter): If not passed, pass 32,f,s
1477 to igen.
1478 * configure: Regenerate.
1479
1480 * interrupts.h (program_interrupt_reasons): Add
1481 optional_instruction_program_interrupt.
1482
1483 * interrupts.c (program_interrupt): Call error with more detailed
1484 information on program interrupts, particularly in user mode. Add
1485 support for optional_instruction_program_interrupt.
1486
1487 Wed Sep 25 10:20:29 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1488
1489 * hw_glue.c: New device. Hooks for manipulating interrupt ports.
1490
1491 * debug.h, debug.c (trace_glue_device): Add tracing support for
1492 the interrupt glue logic device.
1493
1494 * configure.in (hardware): Add glue device.
1495 * configure: Regenerate.
1496
1497 Tue Sep 24 20:55:38 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1498
1499 * device.c (device_tree_parse_integer_property): New function,
1500 parse a list of integers as an array property.
1501 (device_tree_add_parsed): Call it.
1502
1503 * device.c (device_tree_parse_string_property): New function,
1504 parse a list of strings as a string property (with embeded
1505 null's). For moment, don't try to implement a complext string
1506 parser.
1507 (device_tree_add_parsed): Call it.
1508
1509 Tue Sep 24 16:30:48 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1510
1511 * hw_opic.c: New file. OpenPIC interrupt controller.
1512
1513 * configure.in (hardware): Add opic device.
1514 * configure: re-generate.
1515
1516 * hw_pic.c: Delete, replaced with hw_opic.c.
1517
1518 * debug.h, debug.c: Add debug option for OpenPIC device. -
1519 opic-device.
1520
1521 Tue Sep 24 16:30:48 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1522
1523 * Makefile.in (psim.o, idecode.o): Since idecode and not psim is
1524 now the file that does all the inlining.
1525
1526 * Makefile.in (LIB_SRC, LIB_INLINE_SRC, idecode.o): Break out the
1527 library source code that could be involved in an inlining. Make
1528 idecode.o only dependant on the inlined library source code.
1529
1530 * Makefile.in (LIB_OBJ): Put options last on the list so that it
1531 is compiled last.
1532
1533 * std-config.h (DEVICE_INLINE): Only inline locals when the
1534 default is to inline.
1535
1536 Mon Sep 23 00:37:49 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1537
1538 * hw_htab.c (htab_sum_binary): Determine the real-base for the
1539 binary.
1540
1541 * hw_htab.c (htab_map_binary): Depending on the value of the
1542 load-base, either map the program in as a contiguous section or as
1543 separate sections controled by th binaries lma values.
1544 (htab_init_data_callback): Ditto.
1545
1546 Sun Sep 22 15:56:22 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1547
1548 * emul_generic.c (emul_add_tree_options): Remove load-base option.
1549
1550 * emul_chirp.c (map_over_chirp_note): Add load_base field to note
1551 struct. Don't require the load_base field to be present - just
1552 issue warning - it is a recent addition.
1553 (emul_chirp_create): Support both virtual and physical modes.
1554
1555 * emul_chirp.c (emul_chirp_create): Add a stack initialization
1556 property so that any arguments specified on the command line can
1557 be passed on to user programs.
1558
1559 * hw_init.c (create_ppc_chirp_bootargs): Add support for chirp
1560 argument passing to the pseudo device stack.
1561
1562 Sat Sep 21 19:39:56 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1563
1564 * device.c (device_error): Make it more tolerant to incomplete
1565 devices.
1566
1567 * hw_init.c (hw_data_init_data_callback): Extend the data device
1568 so that it can perform initialization operations either dma or a
1569 more complex instance open, seek, write operation.
1570 * hw_init.c: Update the description of the data device to reflect
1571 this.
1572
1573 Sat Sep 21 00:13:02 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1574
1575 * device.c (device_event_queue_schedule,
1576 device_event_queue_deschedule, device_event_queue_time): Have the
1577 device object export the event operations. Making these available
1578 from the device object should hopefully simplify writing device
1579 models.
1580
1581 Fri Sep 20 14:04:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1582
1583 * configure.in (sim-hardware): Add eeprom device to default build.
1584
1585 * hw_eeprom.c: Rewrite so it works.
1586
1587 * debug.h, debug.c: Add tracing support for the eeprom and com
1588 devices.
1589
1590 Thu Sep 19 14:40:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1591
1592 * debug.h: Add disklabel-package and disk-device trace options.
1593 debug.h (PTRACE): Add macro to simplify tracing in packages.
1594
1595 Thu Sep 19 14:40:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1596
1597 * device.c (device_create_instance_from): Tighten up loop
1598 searching for device instances.
1599 (device_instance_delete): Ditto.
1600 (device_instance_delete): Only leaf instances need to be removed
1601 from a devices list of active instances.
1602
1603 Thu Sep 19 14:40:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1604
1605 * hw_disk.c: Add the cdrom as an alias.
1606
1607 * pk_disklabel.c (disklabel_delete): Implement, remembering to
1608 delete the raw disk instance while we're at it.
1609
1610 * pk_disklabel.c (pk_disklabel_create_instance): Implement a
1611 little bit more - still a long way to go.
1612
1613 * pk_disklabel.c (disklabel_write, disklabel_read): Remember the
1614 new head position after a read or write.
1615
1616 Thu Sep 19 13:05:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1617
1618 * emul_chirp.c (chirp_emul_read): Allow reads to be longer then
1619 the internal buffer.
1620
1621 Thu Sep 19 13:05:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1622
1623 * emul_chirp.c (chirp_read_t2h_args): Call memset-0 with the args
1624 in the correct order.
1625
1626 * emul_chirp.c (chirp_emul_call_method): Correct computation for
1627 the address of the first stack argument passed in from the client
1628 program.
1629
1630 Wed Sep 18 19:33:54 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1631
1632 * words.h: Add new types signed_cell and unsigned_cell which
1633 correspond to the signed and unsigned IEEE 1275 memory locations.
1634 * device.h, device.c, emul_chirp.c: Where refering to an IEEE 1275
1635 memory cell, replace uses of unsigned32 with unsigned_cell.
1636 * device_table.h: Ditto.
1637
1638 * sim-endian.h: Add new macros H2BE_cell and BE2H_cell which
1639 convert cell sized values to from big endian.
1640 * device.c, emul_chirp.c: Where refering to IEEE 1275 memory cells
1641 use these new macros.
1642
1643 Tue Sep 17 15:57:44 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1644
1645 * device.c (device_tree_add_parsed): Detect and report an
1646 interrupt being attached to an invalid device. Was dumping core.
1647
1648 Mon Sep 16 23:09:12 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1649
1650 * device.h, device.c (device_address_to_attach_address,
1651 device_size_to_attach_size): New functions. Convert a devices
1652 unit address or unit size structure into a form suitable for
1653 passing on to the attach and detach functions.
1654 * device_table.h: Add extra methods to device table.
1655
1656 * device.h, device.c (device_find_reg_property): New function.
1657 For a reg type property, return the selected address + size
1658 tupple, along with a positive success status. Add a reg_property
1659 to the list of property types.
1660 * (device_tree_add_parsed): Make array properties with the name
1661 reg or alternate-reg of type reg_property.
1662
1663 * hw_memory.c (hw_memory_init_address): Rewrite to use new
1664 find_reg_property method.
1665 * hw_nvram.c (hw_nvram_init_address): Ditto.
1666
1667 * device.c (device_tree_print_device): Add code to print out a reg
1668 property.
1669
1670 * device_table.c (generic_device_address_to_attach_address,
1671 generic_device_size_to_attach_size ): New functions. Generic
1672 functions for converting between unit and attach address or size.
1673
1674 * device_table.c (generic_device_init_address): Rewrite to use the
1675 new find_reg and address convert functions. Look for both reg and
1676 alternate-reg properties.
1677
1678 Mon Sep 16 23:09:12 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1679
1680 * hw_com.c: New file. A '550 serial device that can quickly be
1681 attached to any bus.
1682 * configure.in (enable-sim-hardware): Add the com device.
1683 * configure: re-generate.
1684
1685 Thu Sep 12 17:30:56 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1686
1687 * device.c (device_tree_verify_reg_unit_address): New
1688 function. Check that the unit address as specified by the reg
1689 property correctly corresponds to any unit address previously
1690 specified by the devices name.
1691 (device_tree_add_parsed): When adding a reg property, verify
1692 that the unit-address - first value of property - correctly
1693 matches any previous value specified when creating the device
1694 node.
1695
1696 Thu Sep 12 17:30:56 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1697
1698 * mon.c (mon_event): Remove assertion that an unsigned is >= 0.
1699
1700 Fri Aug 16 12:05:24 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1701
1702 * device.c (device_full_name): Cast strdup to char *, since AIX
1703 3.2.5 mistakenly declares the function to be const char *.
1704 (device_create_from): Ditto.
1705 (device_create_instance_from): Ditto.
1706 (device_add_property): Ditto.
1707
1708 Tue Aug 13 11:40:14 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1709
1710 * debug.c (trace_option): For -t all, do not set the
1711 trace_dump_device_tree flag, so that the simulator is run.
1712
1713 Tue Aug 13 11:40:14 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1714
1715 * Makefile.in (options.o): Depend on defines.h.
1716 (defines.h): New rule, go through config.h and make strings of all
1717 of the #define HAVE_xxx macros.
1718 (distclean): Remove defines.h.
1719
1720 * options.c (print_options): Print whether many of the
1721 configuration macros are defined.
1722
1723 * main.c (main): If -t options and no filename, just print the
1724 options, and don't print the usage message.
1725
1726 Mon Aug 12 18:42:37 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1727
1728 * configure.in: Test whether /dev/zero works on the system, and if
1729 it does, define HAVE_DEVZERO.
1730 * configure: Regenerate.
1731
1732 * emul_generic.c (emul_add_tree_hardware): Do not add /iobus/disk
1733 if we don't have a working /dev/zero on the system.
1734
1735 * emul_bugapi.c (emul_bugapi_init): If HAVE_DEVZERO is not
1736 defined, don't add disk support.
1737 (emul_bugapi_do_diskio): Ditto.
1738 (emul_bugapi_instruction_call): Ditto.
1739
1740 Wed Aug 7 14:34:20 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1741
1742 * emul_unix.c (HAVE_TCGETATTR): If HAVE_TERMIOS_STRUCTURE is not
1743 defined, make sure HAVE_TCGETATTR is #undef'ed
1744
1745 Wed Aug 7 14:34:20 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1746
1747 * std-config.h (REGPARM): Only define REGPARM attributes if using
1748 GNU C. Test for __i686__ in case GCC ever defines it. If not on
1749 a x86 platform, define REGPARM as nothing.
1750
1751 * sim-endian.h (WITH_HOST_BYTE_ORDER): Test for i686 and __i686__
1752 also.
1753
1754 Wed Aug 7 20:19:55 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1755
1756 * ld-decode.h, ld-decode.c: Rename goto_gen to the more correct
1757 goto_switch_gen.
1758 * gen-idecode.c: Ditto.
1759
1760 * gen-idecode.c (print_idecode_table): Comment out check for
1761 switch/table combination until a bug with it is fixed.
1762
1763 * ppc-opcode-goto: New file. Like complex and flat but uses
1764 goto-switch instead of padded-switch for the tables.
1765
1766 * gen-idecode.c (print_goto_switch_name): New function.
1767 (print_goto_switch_table_leaf): New function.
1768 (print_goto_switch_break): New function.
1769 (print_goto_switch_table): New function. Prints a jump table
1770 that can be jumped into instead of a switch statement.
1771
1772 * gen-idecode.c (*switch_*): As an option output a switch that is
1773 implemented using a jump table but only if the switch is not
1774 boolean.
1775
1776 Tue Aug 6 09:28:22 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1777
1778 * configure.in (--enable-sim-{hardware,packages}): Fix typos.
1779 * configure: Regenerate.
1780
1781 * device.c (device_instance_call_method): Fixup format message in
1782 error case. Return 0 in case of error to shut up compiler
1783 warnings.
1784
1785 Wed Aug 7 00:17:37 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1786
1787 * device_table.c (generic_device_unit_decode): Require a comma
1788 between elements of a unit address.
1789
1790 * device.c (device_tree_print_device): For reg, alternate-reg and
1791 ranges properties use special print functions.
1792 (device_print_ranges_property): Print formatted ranges property.
1793 (device_print_reg_property): Print formatted reg property.
1794
1795 Tue Aug 6 21:35:18 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1796
1797 * device.c (device_tree_add_parsed): For reg, ranges and
1798 alternate-reg properties use a special parser.
1799 (device_tree_parse_reg_property): New function to parse a reg
1800 property.
1801 (device_tree_parse_ranges_property): New function to parse a
1802 ranges property.
1803 (device_encode_unit): Wrapper for encode_unit callback.
1804 (device_decoce_unit): Wrapper for decode_unit callback.
1805
1806 Wed Jul 31 00:02:30 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1807
1808 * device_table.h (device_instance_callbacks): Relace the claim and
1809 release methods with a more general table mapping from method-name
1810 to method-function.
1811
1812 * device.c (device_instance_call_method): New function. Implement
1813 the OpenBoot call-method client interface. Attempts to locate the
1814 instances method in the callback table.
1815 (device_instance_claim, device_instance_release): Delete.
1816 Replaced with call-method and a lookup table.
1817
1818 * emul_chirp.c (chirp_emul_call_method): Use the new device
1819 instance call method and let that handle a client claim call.
1820
1821 * hw_htab.c (claim_memory): Wrapper function to call the memory
1822 devices "claim" method using the new device-instance call-method
1823 interface. Replaces the previous direct calls to claim.
1824 (htab_map_region): Use claim_memory.
1825 (htab_init_data_callback): Ditto.
1826
1827 * hw_memory.c (hw_memory_instance_claim): Update function
1828 interface so that it is compatible with call-method.
1829 (hw_memory_instance_release): Ditto.
1830 (hw_memory_instance_methods): New table of memory specific
1831 methods claim and release. Add to the hw_memory_callback
1832 table.
1833
1834 Tue Jul 30 21:26:14 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1835
1836 * psim.c (psim_init): Back out of change to initial value of
1837 system->last_cpu.
1838
1839 Tue Jul 30 21:12:24 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1840
1841 * sim_callbacks.h (sim_io_printf_filtered): Replace
1842 printf_filtered with a local simulator specific version. Add
1843 #define printf_filtered to simplify updating of existing code.
1844
1845 * sim_callbacks.h (sim_io_write_stdout, sim_io_read_stdin,
1846 sim_io_write_stderr): New functions. Read / write to the
1847 simulations stdin and stdout and stderr interfaces. Merge in code
1848 from hw_pal that previously handled async I/O.
1849 (sim_io_flush_stdoutput): Rename flush_stdoutput. Add #define
1850 flush_stdoutput to simplify updating of existing code.
1851
1852 * hw_pal.c (scan_hw_pal, write_hw_pal,
1853 hw_pal_instance_write_callback): Use the new sim_io functions.
1854
1855 * main.c: Implement standalone versions of the new sim_io
1856 functions. Include support for async I/O.
1857 * sim_calls.c: Ditto. This time using the gdb callback table.
1858
1859 * std-config.h (CURRENT_STDIO, current_stdio): New macro. Set up
1860 stdio configuration so that it works in the same way as the rest
1861 of the simulation.
1862 * psim.c (psim_create): Initialize current_stdio from the device
1863 tree.
1864 * emul_generic.c (emul_add_tree_options): Enter a default value
1865 for use-stdio in the device tree.
1866
1867 Fri Jul 26 19:43:03 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1868
1869 * gen-idecode.c (print_jump): Was always generating a jump back to
1870 idecode. Only necessary at tail of semantic code.
1871 (print_jump): Was always setting the processor's cia, even during
1872 startup when the processor was still undefined.
1873 (print_jump): For safety, restart smp loop when cpu_nr >= nr_cpus,
1874 not just equal.
1875
1876 * options.c (print_options): Add printing of WITH_REGPARM and
1877 WITH_STDCALL.
1878
1879 * std-config.h (WITH_REGPARM, WITH_STDCALL): Provide default
1880 (disabled) values if not defined.
1881
1882 Fri Jul 26 00:36:35 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1883
1884 * ppc-cache-rules (cache): Change RS and RB to cache instead of
1885 compute. The block move instructions use them.
1886
1887 * idecode_expression.h (FPSCR_SET): New macro, set specific FPSCR
1888 register.
1889 (CR_FIELD): New macro, extract specific CR register.
1890 (FPSCR_FIELD): New macro, extract specific FPSCR register.
1891
1892 * registers.h (GPR): New macro, simplify accesses to GPR[i].
1893
1894 * bits.c (INSERTED): Covert INSERTED macro into a function.
1895 (EXTRACTED): Conditionally compile on correct bit size macro.
1896
1897 * bits.h (BIT8): New macro, set a single bit in an 8 bit byte.
1898
1899 * ppc-instructions: With hints from Paul Martin, type in missing
1900 some instruction semantics. Leave disabled for the moment.
1901 (Load Multiple Word): Ditto.
1902 (Store Multiple Word): Ditto.
1903 (Load String Word Immediate): Ditto.
1904 (Load String Word Indexed): Ditto.
1905 (Store String Word Immedate): Ditto.
1906 (Store String Word Indexed): Ditto.
1907 (Move to Condition Register from XER): Ditto.
1908 (Move From Condition Register): Ditto.
1909 (Move From FPSCR): Ditto.
1910 (Move to Condition Register from FPSCR): Ditto.
1911 (Move To FPSCR Field Immediate): Ditto.
1912 (Move To FPSCR Fields): Ditto.
1913 (Move To FPSCR Bit 0): Ditto.
1914 (Move To FPSCR Bit 1): Ditto.
1915
1916 Thu Jul 25 22:10:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1917
1918 * std-config.h (SEMANTICS_INLINE): By default, mask out the
1919 inlining of semantic functions from DEFAULT_INLINE. Almost all
1920 configurations call the semantic code via a pointer so there is
1921 little benefit.
1922
1923 * std-config.h (ICACHE_INLINE): Ditto.
1924
1925 Thu Jul 25 20:07:30 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1926
1927 * configure.in (sim_regparm): Add configuration option for
1928 enabling GCC's regparm attribute.
1929 * (sim_stdcall): Add configuration option for enabling GCC's
1930 stdcall attribute.
1931
1932 * Makefile.in (REGPARM_CFLAGS): Pass regparam configuration onto
1933 compilations.
1934 * (STDCALL_CFLAGS): Pass stdcall configuration onto compilations.
1935
1936 * std-config.h (REGPARM): Extend construction of REGPARM macro so
1937 that it can include __stdcall__ function attribute.
1938
1939 Wed Jul 24 19:04:20 1996 Andrew Cagney <cagney@sawnoff>
1940
1941 * options.c (print_options): Include SUPPORT_INLINE in information
1942 dump.
1943
1944 * gen-idecode.c (print_run_until_stop_body): Only generate loop
1945 termination test if creating idecode_run_until_stop. Push the
1946 loop termination test back into each alternative branch.
1947
1948 Wed Jul 24 15:47:09 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1949
1950 * gen-icache.c (print_icache_function): Have the cache function
1951 always update the cache_entries semantic and address fields.
1952
1953 * gen-idecode.c (print_idecode_switch_illegal): Include a break
1954 when generating illegal instructions. This was commented out
1955 which is a hangover from looking a at switch statements generated
1956 using indirect jumps.
1957
1958 Tue Jul 23 20:57:01 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1959
1960 * igen.c (print_my_defines): Replaces print_define_my_index.
1961 Print both a definition for MY_INDEX and MY_PREFIX.
1962 * gen-icache.c (print_icache_function): Adjust.
1963 * gen-idecode.c (print_jump_insn): Adjust.
1964 * gen-semantics.c (print_c_semantic): Adjust.
1965
1966 * gen-support.c (gen_support_h): Add optional include to created
1967 support.h so that, like cpu, it is optionally inlined for all
1968 modules that include it.
1969 * inline.h, inline.c: Adjust so that support.[hc] is handled the
1970 same as cpu.[hc].
1971
1972 * idecode_fields.h (LABEL, GOTO): Macro's that create a unique
1973 name for a lable and then branch to it.
1974
1975 * ppc-instructions (convert_to_integer, Floating Round to
1976 Single-Precision, Floating Convert from Integer Doubleword): Use
1977 LABEL and GOTO instead of the recently added switch statements.
1978
1979 Wed Jul 24 14:02:42 1996 Andrew Cagney <cagney@sawnoff.highland.com.au>
1980
1981 * gen-idecode.c (print_run_until_stop_body): Too many rparen in
1982 generated code.
1983
1984 Tue Jul 23 20:57:01 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
1985
1986 * configure.in (--enable-sim-line-nr): Typo - sim_line-nr.
1987 * (--enable-sim-inline): Reorder patern matching of arguments so
1988 that SUPPORT=ALL_INLINE is reconized as *=* and not *_INLINE.
1989
1990 * configure: rebuild.
1991
1992 Mon Jul 22 23:25:08 1996 Andrew Cagney <cagney@highland.com.au>
1993
1994 * configure.in (--enable-sim-hardware, --enable-sim-packages): New
1995 configuration options. Let the user specify the packages or
1996 hardware devices that are to be included in the build. Makes it
1997 possible for user packages to be specified.
1998
1999 * Makefile.in (tmp-pk, tmp-hw): Just use the list of packages and
2000 hardware instead of checking it using ls. configure.in should
2001 have taken care of any problems.
2002 (HW_SRC, HW_OBJ, PACKAGE_SRC, PACKAGE_OBJ): Set by configure.
2003
2004 Mon Jul 22 22:38:59 1996 Andrew Cagney <cagney@highland.com.au>
2005
2006 * psim.c (psim_options): Enter the argument to the memory size
2007 option directly into the device tree. Was using atol() which is
2008 dangerously non portable.
2009
2010 Mon Jul 22 22:17:08 1996 Andrew Cagney <cagney@highland.com.au>
2011
2012 * configure.in (icache): Extend icache flag to include an insn
2013 option. If specifyed the insn - aka instruction - is included in
2014 the instruction cache. Make this the default.
2015 * configure: re-generate.
2016
2017 * igen.c (main), igen.h: Add option -S - inSn - for specifying
2018 that the instruction should be included in the icache.
2019
2020 * gen-icache.c (print_icache_body): If enabled, output code to put
2021 the instruction into the icache.
2022 (print_icache_struct): If enabled, add insn to the icache struct.
2023
2024 Mon Jul 22 20:46:12 1996 Andrew Cagney <cagney@highland.com.au>
2025
2026 * Makefile.in (BUILD_CFLAGS): Include -g when building the
2027 generators.
2028
2029 Mon Jul 22 20:00:25 1996 Andrew Cagney <cagney@highland.com.au>
2030
2031 * emul_generic.c (emul_add_tree_options): Was incorrectly setting
2032 the strict-alignment option when hardwired for non-strict
2033 alignment.
2034
2035 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2036
2037 * gen-semantics.c: Make the my_index variable a macro MY_INDEX.
2038
2039 * ppc-instructions: Adjust so that references are to MY_INDEX and
2040 not my_index.
2041
2042 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2043
2044 * gen-idecode.c: Output the complete run_until_stop function
2045 instead of just the code to handle a single instruction issue.
2046 * : Have the generated idecode.c include inline.c (instead of psim.c).
2047
2048 * std-config.h: Change psim.c so that it isn't inlined (as this is
2049 no longer needed).
2050
2051 * psim.c (run_until_stop): Delete the old run_until_stop function
2052 instead calling the idecode_run and idecode_run_until_stop
2053 functions that gen-idecode.c is now creating.
2054
2055 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2056
2057 * dgen.c: Maintenance - update to use new features found in lf.c.
2058
2059 * filter_filename.c (filter_filename): Maintenance - make the
2060 string constant.
2061
2062 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2063
2064 * debug.c (TRACE, ITRACE, DTRACE): Have GCC instead of CPP
2065 eliminate trace statements.
2066
2067 * debug.c: Change trace format so that it is consistent
2068 (file:line-nr) with CC's error output.
2069
2070 * gen-itable.c (itable_c_insn): Add the source file name and
2071 source line number to the instruction's informational entry.
2072
2073 * debug.c (ITRACE): Use the itable (and my_index) to get the
2074 current instructions name and source line number.
2075
2076 * gen-semantics.c, gen-icache.c: Adjust generated ITRACE calls to
2077 match new interface.
2078
2079 * emul_bugapi.c (emul_bugapi_instruction_call): Adjust
2080 corresponding call to ITRACE so that it still matches.
2081
2082 * idecode_expression.h (ALU_END, CR0_COMPARE): Use TRACE instead
2083 of ITRACE. The CPP line directives would have previously set the
2084 line-nr and file name so ITRACE isn't needed.
2085
2086 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2087
2088 * gen-idecode.c (print_jump_until_stop_body): New function and
2089 idecode generation option. Instead of generating and calling
2090 separate functions containing the semantic and icache code
2091 generate a single monolythic function and use goto's (and GCC's
2092 indirect jump) to move between code blocks.
2093
2094 * Makefile.in: Add sim_jump flag to those passed to igen.
2095
2096 * configure.in: New option --enable-sim-jump (default disabled)
2097
2098 * ppc-instructions: Eliminate any uses of labels and goto's.
2099 These result in duplicate declarations when a single flat function
2100 is being create.
2101
2102 * ppc-opcode-jump: New file. Set of opcode rules useful when
2103 testing jumping idecodes.
2104
2105 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2106
2107 * gen-idecode.c: Optionally include the semantic code for an
2108 instruction in the function that is doing the decoding.
2109
2110 * igen.c: Add option (-C) to generate semantics in the instruction
2111 decode functions.
2112
2113 * configure.in (--enable-sim-icache): Accept an option list such
2114 as 1024,define. Add a new choice to the list - semantic - which
2115 will cause igen to generate instruction decode functions that
2116 include the corresponding semantic code.
2117
2118 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2119
2120 * configure.in: New option --enable-sim-line-nr (default enabled).
2121 Enable/disable the inclusion of CPP line directives in the
2122 generated files. Such directives refer back to the source files
2123 used when generating the simulator code.
2124
2125 * Makefile.in (sim_line_nr): Pass to igen.
2126
2127 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2128
2129 * igen.c (main): Revamp the options so that more letters are
2130 available.
2131
2132 * configure.in: Adjust to match igen's revamped options
2133
2134 Sun Jul 21 21:18:05 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2135
2136 * Makefile.in (pk.h, hw.h): Rewrite depenencies for hw.h (etc) so
2137 that they use the same technique as igen (ie a dummy targets
2138 tmp-pk and tmp-hw are created).
2139
2140 Mon Jun 24 22:28:00 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2141
2142 * Makefile.in (BUILD_CFLAGS): Include WARNING_CFLAGS.
2143
2144 Wed Jun 19 21:45:28 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2145
2146 * ld-cache.[hc], ld-decode.[hc], ld-insn.[hc]: New files. Separate
2147 out the loading of each of the tables from the rest of igen.
2148 * Makefile.in: Adjust.
2149 * igen.c: Adjust.
2150
2151 * gen-icache.[hc], gen-idecode.[hc], gen-itable.[hc],
2152 gen-model.[hc], gen-semantics.[hc]: New files. Separate out the
2153 code creating each separate set of generated files.
2154 * Makefile.in: Adjust.
2155 * igen.c: Adjust.
2156
2157 * gen-support.[ch]: New files. Output the support functions (found
2158 in the ppc-instructions file) into a separate file.
2159 * Makefile.in: Add.
2160 * inline.h, inline.c: Add.
2161 * std-config.h: Add.
2162
2163 * ld-cache.c: Re-design the cache table format.
2164 * ppc-cache-rules: Update to new format.
2165
2166 * ld-decode.c: Re-design the decode table format.
2167 * ppc-opcode-simple: Update to new format
2168 * ppc-opcode-complex: Ditto
2169 * ppc-opcode-flat: Ditto
2170
2171 * filter.h, filter.c: New files. Separate the opcode filter table
2172 reading code from the rest of igen.c. Re-design the filter so that
2173 it works inclusivly not exclusivly.
2174 * igen.c: Remove the opcode filter table loading code.
2175 * Makefile.in (filter.o): Adjust
2176 * configure.in: Adjust filter flag so that default includes 32bit
2177 and floating point.
2178 * ppc-instructions: Clean up filter fields so that only in use
2179 entries are specifed (ie delete `be').
2180
2181 * misc.c (name2i, i2name): New function. Map between a string and
2182 an integer value.
2183
2184 Mon Jun 17 20:08:03 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2185
2186 * sim_calls.c (sim_close): If simulator not created, skip printing
2187 of run information.
2188
2189 Mon Jun 17 20:08:03 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2190
2191 * registers.c (register_description): Typo, insns not insn.
2192
2193 * ppc-instructions (model_get_number_of_stalls): New model function,
2194 returns number of stalls for the specified processor.
2195 * psim.c (psim_read_register): Add call to new function
2196 model_get_number_of_stalls().
2197
2198 * ppc-instructions (model_get_number_of_cycles): New model function,
2199 returns number of stalls for the specified processor.
2200 * psim.c (psim_read_register): Add call to new function
2201 model_get_number_of_cycles().
2202
2203 Fri Jun 14 00:11:56 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2204
2205 * device_table.h: Don't pass the parent device into a devices
2206 create function. This makes the create function consistent with
2207 the documentation.
2208 * device.c (device_template_create_device): Ditto
2209 * hw_pal.c (hw_pal_create): Ditto
2210 * hw_core.c (hw_core_create): Ditto
2211 * hw_vm.c (hw_vm_create): Ditto
2212 * hw_disk.c (hw_disk_create): Ditto
2213 * hw_nvram.c (hw_nvram_create): Ditto
2214 * hw_memory.c (hw_memory_create): Ditto
2215 * hw_cpu.c (hw_cpu_create): Ditto.
2216
2217 * device.c (split_find_device): Allow a null initial parent device.
2218 (device_template_create_device): Ditto.
2219
2220 * device.c (device_create_from): Make local (static) only used
2221 within device.c.
2222 * device_table.h: typedef device_callbacks moved here (from
2223 device.h) where it belongs.
2224
2225 * hw_core.c: New file. Implements just the core device using the
2226 core object.
2227
2228 * corefile.c: Moved all core device functions into the new
2229 hw_core.c file. core_device_create() disapears.
2230
2231 * psim.c (psim_tree): Use device_tree_add_parsed() to create the
2232 core device.
2233
2234 Thu Jun 13 00:09:29 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2235
2236 * hw_init.c: Correct typo in comment.
2237
2238 * corefile.c (core_init): Remove any remaining references to a
2239 default map.
2240 (core_map_find_mapping): Ditto.
2241
2242 Wed Jun 12 22:30:32 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2243
2244 * corefile.c (core_init): Make function global so that other
2245 devices are able to use the full core object.
2246
2247 * corefile.c (core_create, core_from_device): Break core_create
2248 into two functions. The first creates a core object, the second
2249 returns the core object associated with a core device.
2250
2251 * corefile.c (core_device_create): Use core_create to make the
2252 core object.
2253
2254 * psim.c (psim_create): Use core_from_device() instead of
2255 core_create().
2256
2257 * device.c (device_template_create_device): Make static as only
2258 needed by functions internal to device.c.
2259
2260 Fri Jun 7 23:47:18 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2261
2262 * ppc-opcode-test-2: Remove description of fields.
2263 * ppc-opcode-complex: Ditto
2264 * ppc-opcode-flat: Ditto
2265 * ppc-opcode-simple: Ditto
2266 * ppc-opcode-stupid: Ditto
2267 * ppc-opcode-test-1: Ditto
2268 * ppc-cache-rules: Ditto
2269
2270 * igen.c: Add description of files as a comment at the front.
2271
2272 Wed Jun 26 12:50:33 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2273
2274 * configure.in: Check for whether the termios and termio
2275 structures are really defined, and whether or not, they define the
2276 c_line field.
2277 * configure: Regenerate.
2278
2279 * Makefile.in ({,TERMIO_}CFLAGS): Add TERMIO_CFLAGS options set by
2280 configure.
2281
2282 * emul_unix.c: Various changes to allow for building on systems
2283 with different termio and termios structures. If host has both
2284 termio and termios, just use termios. No longer include
2285 sys/ioctl.h.
2286
2287 Wed Jun 26 12:26:55 1996 Jason Molenda (crash@godzilla.cygnus.co.jp)
2288
2289 * Makefile.in (bindir, libdir, datadir, mandir, infodir, includedir,
2290 INSTALL_PROGRAM, INSTALL_DATA): Use autoconf-set values.
2291 (docdir): Removed.
2292 * configure.in (AC_PREREQ): autoconf 2.5 or higher.
2293 (AC_PROG_INSTALL): Added.
2294 * configure: Rebuilt.
2295
2296 Wed Jun 5 23:53:42 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2297
2298 * corefile.h: Rewrite documentation so that it can be extracted and
2299 converted into texinfo (and hence ready for translation into html,
2300 tex or nroff).
2301 * device.h: Ditto
2302
2303 Thu Jun 6 09:52:37 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2304
2305 * hw_disk.c (SEEK_SET): If SEEK_SET is not defined, define as 0.
2306
2307 Wed Jun 5 11:46:52 1996 Andrew Cagney <cagney@puddin>
2308
2309 * hw_disk.c: Include <unistd.h> if available. Under SunOS, that
2310 is the source of SEEK_SET.
2311
2312 Wed Jun 5 01:39:07 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2313
2314 * psim.c (psim_options): Correct type of dummy arguments being
2315 passed to a device_ioctl call.
2316
2317 * hw_init.c (hw_data_init_data_callback): Adjust printf arguments.
2318 (write_stack_arguments): Ditto.
2319 * hw_trace.c: Instance callback entry no longer a table.
2320
2321 Wed Jun 5 01:39:07 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2322
2323 * emul_unix.c (do_unix_umask): Cast printf argument.
2324 (convert_to_linux_termios): Use LINUX_VSWTC not LINUX_VSWCH
2325
2326 Mon Jun 3 15:02:04 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2327
2328 * hw_init.c (update_for_binary_section): Abort if we find an
2329 .interp section, which indicates the need for shared libraries to
2330 be loaded.
2331
2332 Mon Jun 3 15:02:04 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2333
2334 * emul_unix.c (do_unix_{time,gettimeofday,getrusage}): Add support
2335 for time, gettimeofday, and getrusage system calls.
2336 ({solaris,linux}_descriptors): Add new system calls.
2337 (do_get{,e}{uid,gid}): Use gid_t/uid_t types.
2338 (do_get{,p}pid): Use pic_t types.
2339
2340 * configure.in (AC_TYPE_{GETGROUPS,SIGNAL}): Define.
2341 (AC_TYPE_{MODE,OFF,PID,SIZE,UID}_T): Define.
2342 * config{.in,ure}: Regenerate.
2343
2344 Mon Jun 3 23:19:57 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2345
2346 * emul_netbsd.c (emul_netbsd_create): Use the more specific names
2347 `ppc-elf' and `ppc-xcoff' for the stack-type.
2348 * emul_unix.c (emul_unix_create): Ditto.
2349 * emul_bugapi.c (emul_bugapi_create): Ditto.
2350 * hw_init.c: Reconize the new names.
2351
2352 * emul_unix.c (do_unix_break): Adjust so that the updated ioctl
2353 call is used (no system parameter).
2354
2355 Sun Jun 2 11:21:17 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2356
2357 * emul_unix.{h,c}: New files to provide Solaris and Linux system
2358 call emulations.
2359
2360 * Makefile.in (LIB_{SRC,OBJ}): Add emul_unix.{c,o}.
2361 (os_emul.o): Depend on emul_unix.h.
2362 (emul_unix.o): New dependency.
2363
2364 * configure.in (--enable-sim-alignment): Add 0|default to mean set
2365 alignment to 0, which means use appropriate alignment for mode.
2366 (AC_CHECK_FUNCS): Add new functions needed by emul_unix.c.
2367 (AC_CHECK_HEADERS): Add new include files needed by emul_unix.c.
2368 * config.in: Regenerate.
2369 * configure: Regenerate.
2370
2371 * emul_generic.c (emul_write2_status): New function to return
2372 results in r3 and r4 for Solaris system calls.
2373 (emul_do_system_call): If the system call is not support, but
2374 there is a string for the system call name, print out the string
2375 instead of the system call number.
2376
2377 * emul_generic.h (emul_write2_status): Declare it.
2378
2379 * emul_netbsd.c: Use /* */ around comment on #endif.
2380
2381 * os_emul.c: Include emul_unix.h.
2382 (os_emulations): Add emulations for Solaris, and Linux.
2383
2384 * psim.c (psim_usage): Add message about solaris, linux
2385 emulations.
2386
2387 Thu May 30 00:00:10 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2388
2389 * hw_iobus.c: Tidy up notes so that they can be auto-extracted.
2390
2391 * README: Correct PSIM's title
2392
2393 Wed May 29 23:50:26 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2394
2395 * basics.h: New global type object_disposition, used to indicate
2396 the status of objects when things are restarted.
2397
2398 Fri May 17 17:28:52 1996 Andrew Cagney <cagney@benjimen.highland.com.au>
2399
2400 * device_table.h: Change the interrupt descriptor structure so
2401 that it includes an additional member - an upper bound on the
2402 interrupts by that name.
2403
2404 * device.c (device_interrupt_decode): Allow a range of interrupt
2405 ports (eg rst0 .. rst6) if the port descriptors bound is non zero.
2406
2407 * device.c (device_tree_print_device): Include a list of valid
2408 interrupt ports when listing supported devices.
2409
2410 * device.h, device.c (device_child_interrupt_*): Delete. Not used.
2411
2412 * emul_generic.c (emul_add_tree_hardware): Modify the creation of
2413 the interrupt net so that it uses int0 .. intN.
2414
2415 Tue May 14 23:03:53 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2416
2417 * device.h, device.c (device_ioctl): Drop the system argument.
2418 Devices can not obtain this using the device_system() call.
2419 * device_table.h: Adjust accordingly.
2420 * hw_*.c: Adjust accordingly.
2421 * emul_netbsd.c (do_break): Adjust call to vm device accordingly.
2422 * psim.c (psim_options): Use a device_ioctl call to force the
2423 hw_trace device to update the trace options.
2424 * hw_trace.c: Replace the init function with an ioctl call. Adjust
2425 doc accordingly.
2426
2427 * psim.c (psim_init): Re-order initialization so that the
2428 os-emulation is initialized after the device tree. Without this,
2429 os-emul's are not able to create instances or access properties
2430 that contain an instance handle.
2431
2432 * device.h, device.c (device_add_*_property): Make these functions
2433 internal to device.c. The user has access to the more generic
2434 device_tree_add_parsed function. Differentiate between the initial
2435 and current value for each property.
2436 * (clean_device_properties): New function that deletes any
2437 properties created after the start of a simulation and restores
2438 the initial value of any others (ignoring ihandles).
2439 * (init_device_properties): (Re)Initialize any properties that
2440 contain ihandles. create
2441
2442 * (device_tree_init): Include calls to clean the device tree's
2443 properties and then initialize them. Document this in the device.h
2444 file.
2445
2446 Mon May 6 17:36:15 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2447
2448 * interrupts.c (decrementer_interrupt): Always pend a decrementer
2449 interrupt even if it is not yet possible to deliver it.
2450
2451 Wed May 1 12:26:51 1996 Andrew Cagney <cagney@benjimen>
2452
2453 * mon.h, mon.c (mon_get_number_of_insns): Make this externally
2454 visable adjusting the arguments so that the interface is correct.
2455 (mon_print_info): Adjust calls.
2456
2457 * registers.h, registers.c (register_description): Add phony
2458 cycle, insn and stall registers.
2459
2460 * psim.c (psim_read_register): Return nr of instructions for given
2461 processor.
2462
2463 Tue Apr 30 22:09:09 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2464
2465 * hw_htab.c: New file. Extract contents from disk_table.c.
2466 Contains a device that, during initialization will create a
2467 PowerPC htab in memory.
2468 * hw_register.c: New file. Extract contents from disk_table.c.
2469 Contains a device that, during initialization, will parse its
2470 property list and use that to initialize various processor
2471 registers (not target specific).
2472 * hw_vm.c: New file. Extract contents from disk_table.c. Contains
2473 a device that handles accesses to invalid virtual memory addresses
2474 (in user mode).
2475 * hw_init.c: New file. Extract contents from disk_table.c. Misc
2476 devices that can initialize memory from a file.
2477 * hw_trace.c: New file. Extract contents from disk_table.c.
2478 Configure trace options from property values.
2479
2480 * Makefile.in (hw_htab.o, hw_register.o, hw_vm.o, hw_init.o,
2481 hw_trace.c): Add new device files.
2482
2483 * device_table.c: Remove above code, now in separate independant
2484 files.
2485
2486 Fri Apr 26 00:00:07 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2487
2488 * hw_disk.c: New file. Disk and CDROM device.
2489
2490 * Makefile.in (hw_disk.o): Add device hw_disk.c.
2491
2492 * pk_disklabel.c: New file. Implement the miss-named disk-label
2493 package.
2494
2495 * Makefile.in (pk.h): Create the file pk.h that contains a list of all
2496 the packages.
2497
2498 * Makefile.in (hw.h, hw.c): Add dependancy on Makefile so that
2499 they are re-created when the makefile is updated.
2500
2501 * emul_generic.c (emul_add_tree_hardware): Add a disk device
2502 (below the iobus) to the device tree. Include an ihandle of
2503 the disk as /chosen/disk.
2504
2505 * emul_bugapi.c (emul_bugapi_create): Don't initialize the input,
2506 output and (new) disk handles yet.
2507 * (emul_bugapi_init): Initialize the input, output (and just added)
2508 disk ihandles here.
2509 * (emul_bugapi_do_diskio): New. Performs disk i/o (well at least
2510 what I think the behavour is).
2511 * emul_bugapi.c (emul_bugapi_instruction_call): Add hook to disk
2512 i/o bug call. For RETURN call, exit using gpr[3]'s status even
2513 though this isn't part of the spec - makes it possible for machine
2514 code to signal the aporting of a simulation run.
2515
2516 * emul_chirp.c (chirp_emul_call_method): Add support for the
2517 claim/release methods.
2518 * (chirp_emul_exit): Add an optional exit status argument to
2519 the exit method. Makes it possible for chirp emul simulations
2520 to abort upon an error.
2521 * device.h, device.c (device_instance_claim,
2522 device_instance_release): New methods for claiming and releasing
2523 memory.
2524 * hw_memory.c: add claim and release memory methods.
2525 * hw_*: Use the claim memory method when allocating physical
2526 memory.
2527
2528 Thu Apr 18 23:38:10 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2529
2530 * hw_nvram.c (hw_nvram_update_clock): Use the current not previous
2531 time when updating the clock.
2532
2533 * hw_nvram.c: Tidy up documentation
2534
2535 Fri May 24 10:08:10 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2536
2537 * configure.in (AC_STRUCT_ST_{BLKSIZE,BLOCKS,RDEV}): Use these
2538 macros to determine whether or not the appropriate st_<xxx> fields
2539 exist in the stat structure.
2540 (AC_CHECK_FUNCS): Check for all unix system calls used, except for
2541 the real basic ones like open, read, write, etc.
2542 * config{.in,ure}: Regenerate.
2543
2544 * emul_netbsd.c: Add support for missing system calls, and/or
2545 missing stat fields.
2546 (MAXPATHLEN): Undefine if including unistd.h, since sys/param.h
2547 might define it.
2548
2549 * hw_pal.c (WITH_STDIO): Redefine if O_NDELAY, F_GETFL, or F_SETFL
2550 are not defined.
2551 (scan_hw_pal): Do not cause syntax error if O_NDELAY, F_GETFL, or
2552 F_SETFL not defined.
2553
2554 Tue May 21 17:24:45 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2555
2556 * emul_netbsd.c (write_stat): Don't convert st_blocks unless the
2557 host is netbsd.
2558
2559 Thu May 16 10:56:45 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2560
2561 * configure.in (AC_CHECK_HEADERS): Add sys/ioctl.h.
2562 * config{.in,ure}: Regenerate.
2563 * emul_netbsd.c: If HAVE_SYS_IOCTL_H is not defined, don't include
2564 sys/ioctl.h.
2565
2566 Tue May 7 17:28:12 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2567
2568 * hw_pal.c (hw_pal_instance_read_callback): Remove unused
2569 variable.
2570
2571 * misc.c ({,target_}a2i): Rewrite to not use strtoul.
2572
2573 * Makefile.in ({spreg,misc}.o): Add dependency on .c file.
2574 ({i,d}gen): Don't link in liberity. Use BUILD_LIBS instead of
2575 LIBS.
2576
2577 Mon May 6 11:31:43 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2578
2579 * hw_pal.c (hw_pal_instance_read_callback): If using stdio, use
2580 fgets to read line. If not using stdio, do a simple blocking read
2581 of len bytes.
2582
2583 Fri May 3 15:07:42 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2584
2585 * Makefile.in: Correctly build simulator for build machine != host
2586 machine.
2587
2588 Tue Apr 30 18:46:05 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2589
2590 * configure.in (--enable-hostendian): Rework so the default uses
2591 the AC_C_BIGENDIAN results. Only run AC_C_BIGENDIAN if not cross
2592 compiling.
2593 * configure: Regenerate.
2594
2595 * sim-endian.h: Add more tests for host endian to support more
2596 platforms in a cross compilation environment.
2597
2598 Wed Apr 17 14:38:06 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2599
2600 * hw_pal.c ({scan,write}_hw_pal): If WITH_STDIO == DO_USE_STDIO,
2601 use stdio, instead of unpended read/printf_filtered.
2602 (hw_pal_instance_write_callback): If WITH_STDIO == DO_USE_STDIO,
2603 flush stdout after writing the characters.
2604
2605 * options.c (print_options): Print out WITH_STDIO.
2606
2607 * Makefile.in (STDIO_CFLAGS): Pass on result of @sim_stdio@
2608 configuration variable.
2609 (CONFIG_CFLAGS): Include STDIO_CFLAGS.
2610 (hw.{c,h}): Allow for source dir != build dir, and for HW_SRC
2611 files to contain directory pieces.
2612
2613 * std-config.h (DO{,NT}_USE_STDIO): New flags for whether we
2614 should use stdio for console input.
2615 (WITH_STDIO): If not defined, define as DONT_USE_STDIO.
2616
2617 * configure.in (--enable-sim-stdio): Add new switch to control
2618 whether stdio is used for console I/O.
2619 * configure: Regenerate.
2620
2621 * interrupts.c (external_interrupt): Declare it to be
2622 INLINE_INTERRUPTS, not INLINE_CPU.
2623
2624 Mon Apr 15 23:30:56 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2625
2626 * events.c (insert_event_entry): Allow events to be scheduled
2627 *NOW* (at delta time 0). Add assertions to clarify behavour of
2628 event queue.
2629
2630 * events.c (update_time_from_event): New function. Calculates the
2631 number of ticks from the next event. Use this.
2632
2633 Sun Apr 14 21:39:45 1996 Andrew Cagney <cagney@highland.com.au>
2634
2635 * emul_netbsd.c (do_break): Return 0 if success (instead of
2636 adjusted break).
2637
2638 * device_table.c (vm_ioctl_callback): Don't return adjusted break
2639 (isn't needed).
2640
2641 Sun Apr 14 21:32:41 1996 Andrew Cagney <cagney@highland.com.au>
2642
2643 * device_table.h: Change type of the device ioctl so that it
2644 returns an int (status).
2645 * device.h (device_ioctl): Ditto.
2646 * device.c (device_ioctl): Ditto.
2647
2648 * device_table.c (stack_ioctl_callback): Return 0 status.
2649 (vm_ioctl_callback): Ditto
2650
2651 Sat Apr 13 00:00:24 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2652
2653 * emul_netbsd.c (do_read): Correctly set the return value.
2654 (do_getpid): Ditto.
2655 (do_getuid): Ditto.
2656 (do_geteuid): Ditto.
2657 (do_dup): Ditto.
2658 (do_getegid): Ditto.
2659 (do_getgid): Ditto.
2660 (do_sigprocmask): Ditto.
2661 (do_umask): Ditto.
2662 (do_dup2): Ditto.
2663 (do_gettimeofday): Ditto.
2664 (do_getrusage): Ditto.
2665 (do_fstat): Ditto.
2666 (do_stat): Ditto.
2667 (do_lseek): Ditto.
2668 (do___sysctl): Ditto.
2669
2670 Fri Apr 12 20:56:47 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2671
2672 * device_table.c (vm_ioctl_callback): Don't access the processor
2673 registers directly, instead leave it to the caller to handle this.
2674
2675 * emul_netbsd.c (do_break): Which calls vm_ioctl_callback to
2676 perform a break. Pass in the new break value and set the
2677 registers according to the result.
2678
2679 * emul_generic.c (emul_write_status): Change so that r3 contains
2680 either status or errno and failure is indicated by SO.
2681
2682 Thu Apr 4 23:03:38 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2683
2684 * emul_bugapi.c (emul_bugapi_create): More strict check of OEA
2685 address.
2686
2687 Thu Apr 4 20:58:05 1996 Andrew Cagney <cagney@highland.com.au>
2688
2689 * interrupts.h (interrupts): New structure contains state of
2690 pending interrupts.
2691
2692 * cpu.c (cpu_interrupts): New function. Pending interrupt status
2693 in the cpu and grant access to it. Add interrupts to cpu
2694 structure.
2695
2696 Fri Mar 29 22:09:25 1996 Andrew Cagney <cagney@highland.com.au>
2697
2698 * device.c (device_tree_add_parsed): Check that the creation of a
2699 device instance worked before using it.
2700
2701 * psim.c (psim_halt): Remove cia argument from psim_halt. This
2702 function does not save the CIA so do not pass it in.
2703
2704 Fri Mar 29 21:30:56 1996 Andrew Cagney <cagney@highland.com.au>
2705
2706 * hw_pal.c (hw_pal): Merge the halt and icu and console devices
2707 found in device_table.c into a single hack pal.
2708
2709 * device_table.c (halt, icu, console): Delete.
2710
2711 * Makefile.in (hw_pal.o): New dependency.
2712
2713 * emul_generic.c (emul_add_tree_hardware): Re-arange device tree
2714 so that it uses the pal instead of the icu/halt/console devices.
2715 Wire the pal's interrupt ports up to the cpu nodes.
2716
2717 Fri Mar 29 20:17:17 1996 Andrew Cagney <cagney@highland.com.au>
2718
2719 * hw_iobus.c (hw_iobus_attach_address_callback): Move from
2720 device_table.c to here.
2721
2722 * Makefile.in (hw_iobus.o): New dependency.
2723
2724 Fri Mar 29 12:17:58 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2725
2726 * emul_bugapi.c (_os_emul_data): Add fields for output, input.
2727 (emul_bugapi_create): Create input, output from /chosen/stdin and
2728 /chosen/stdout.
2729 (emul_bugapi_do_{read,write}): Switch to use device_instance
2730 interface.
2731 (emul_bugapi_instruction_call): Change calls to
2732 emul_bugapi_do_{read,write} to pass device instance argument.
2733
2734 Tue Mar 26 14:57:58 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2735
2736 * igen.c (idecode_switch_end): Fix 2/26 change so that an extra
2737 default is not written out if a default was already written.
2738
2739 * psim.c (psim_{read,write}_register): Use sizeof unsigned_8 to
2740 size cooked_buf, not sizeof natural_word, since floating point
2741 registers are 8 bytes.
2742
2743 Mon Mar 25 22:07:13 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2744
2745 * configure: Regenerate with autoconf 2.9.
2746
2747 Thu Mar 21 00:14:26 1996 Andrew Cagney <cagney@highland.com.au>
2748
2749 * device_table.h: Always include string headers.
2750
2751 Thu Mar 21 00:06:09 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2752
2753 * main.c (error): Be careful to not try to print out statistics
2754 when the simulation was never created.
2755
2756 Sun Mar 17 22:40:57 1996 Andrew Cagney <cagney@highland.com.au>
2757
2758 * basics.h: Move the event queue's definition to here so that it
2759 can be refered to globally with out importing all of events.h.
2760
2761 * psim.h, psim.c (psim_event_queue): New function. Grant access
2762 to the simulation event queue. Will make this the single point of
2763 access (there is after all only one event queue in the
2764 simulation).
2765
2766 * cpu.c (cpu_create): Use psim_event_queue to obtain the event
2767 queue instead of it being passed in. No longer allow access to
2768 the cpu's copy of the event queue.
2769
2770 Sun Mar 17 22:40:57 1996 Andrew Cagney <cagney@highland.com.au>
2771
2772 * events.h, events.c (event_handler): Remove event_queue from
2773 arguments passed to an event handler. That argument is redundant
2774 - the `data' should refer to a data structure that contains the
2775 event queue if queing is needed.
2776
2777 * cpu.c (cpu_decrement_event): adjust
2778
2779 * events.c (event_queue_process): adjust
2780
2781 Sun Mar 17 22:40:57 1996 Andrew Cagney <cagney@highland.com.au>
2782
2783 * device.h, device.c (device_system): New, returns a handle for
2784 the system given the device.
2785
2786 * device.c (device_address_init): Store a pointer back to the
2787 system in each devices node.
2788
2789 * device_table.h: Don't pass `system' into each device when it is
2790 being initialized, this is now available using device_system(me).
2791
2792 * device.c (device_address_init, device_data_init): Adjust.
2793
2794 * hw_cpu.c, hw_nvram.c, hw_memory.c, hw_eeprom.c, device_table.c:
2795 Adjust.
2796
2797 Sun Mar 17 22:40:57 1996 Andrew Cagney <cagney@highland.com.au>
2798
2799 * interrupts.c (decrementer_interrupt, external_interrupt):
2800 Remember that an interrupt wasn't delivered so that it can be
2801 tried again later.
2802
2803 * interrupts.c (check_masked_interrupt): New function. (re)
2804 checks for the posibility that a recent change to the MSR may have
2805 made it possible to deliver an interrupt that was previously
2806 masked be the EE bit.
2807
2808 * ppc-instructions (mtmsr, mfmsr, rfi): Check for posibility of
2809 a pending interrupt being delivered using check_masked_interrupt().
2810
2811 * cpu.c (cpu_decrement_event): Just call decrementer_interrupt()
2812 leaving it to that module to handle both interrupt synchronization
2813 and masking.
2814
2815 * cpu.c (struct _cpu): remove variables that were going to record
2816 pending decrementer and external interrupts.
2817
2818 Sun Mar 17 22:40:57 1996 Andrew Cagney <cagney@highland.com.au>
2819
2820 * hw_cpu.c, hw_cpu.h: New files. Implement a device that sits
2821 between the interrupt controller and the simulators internal
2822 processor model. Maps device interrupts onto the processor
2823 interrupt function calls.
2824
2825 Mon Mar 4 06:06:54 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2826
2827 * hw_nvram.c: NVRAM device that includes a real-time clock that is
2828 updated each second.
2829
2830 Mon Mar 4 04:18:50 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2831
2832 * device.h (attach_type): Remove attach_default type address
2833 spaces. Will replace with levels of callback memory.
2834
2835 * corefile.h, corefile.c (new_core_mapping), corefile.c
2836 (core_map_attach): Replace default attach with a layerd callback
2837 approach.
2838
2839 Sun Mar 3 03:58:46 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2840
2841 * device.c (split_property_specifier): ensure that only a single
2842 property is found.
2843 (split_value): New function, parses the value part of a device
2844 spec.
2845
2846 * device.c (device_tree_add_parsed): Use the interrupt conversion
2847 functions to determine the interrupt port numbers.
2848
2849 * device_table.h: Add table that maps between an interrupts
2850 symbolic name and its port number.
2851
2852 * device.h, device.c (device_interrupt_decode,
2853 device_interrupt_encode): new functions use the recently added
2854 interrupt port name/number tables to perform conversion.
2855
2856 Sun Mar 3 03:23:59 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2857
2858 * device.h, device.c (device_set_array_property,
2859 device_set_boolean_property, device_set_ihandle_property,
2860 device_set_integer_property, device_set_string_property): New
2861 functions - allow the value of a given property to be changed.
2862
2863 * device.h, device.c: Re-order declaration and definition of
2864 property functions.
2865
2866 Sun Mar 3 03:10:22 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
2867
2868 * device.c (device_tree_print_device, device_tree_add_parsed):
2869 Remove references to phandle properties.
2870
2871 Wed Feb 28 00:43:07 1996 Andrew Cagney - aka Noid <cagney@highland.com.au>
2872
2873 * Makefile.in (corefile.o): missing dependency on device_table.h
2874 etc.
2875
2876 Tue Feb 27 23:59:35 1996 Andrew Cagney - aka Noid <cagney@highland.com.au>
2877
2878 * device_table.h: Revamp device init callbacks so that they are a
2879 sub structure.
2880 * device.c (device_init_data, device_init_address): If an init
2881 callback is NULL assume it should do nothing.
2882 * device_table.c (ignore_device_init, unimp_device_init): delete
2883 as redundant.
2884 * device_table.c, hw_memory.c: adjust.
2885
2886 * (io): ditto.
2887 * (dma): ditto.
2888 * (device_instance): ditto.
2889 * (ioctl): ditto.
2890 * (address nee config_address): ditto.
2891 * (interrupt): ditto.
2892
2893 Mon Feb 26 21:11:20 1996 Andrew Cagney - aka Noid <cagney@highland.com.au>
2894
2895 * igen.c (idecode_switch_end): Output a default entry when the
2896 switch statement is perfect. Firstly stops GCC complaining about
2897 an incomplete switch and secondly it will be eliminated by a good
2898 compiler any way.
2899
2900 Mon Feb 26 22:47:15 1996 Andrew Cagney - aka Noid <cagney@highland.com.au>
2901
2902 * Makefile.in (hw.h, hw.c): New targets. Create from the list of
2903 hw_*.c files. hw.h declares a device descriptor table for each hw
2904 device while hw.c lists those tables in a form suitable for the
2905 construction of a top leveltable in device_table.c.
2906
2907 * Makefile.in (device_table.o): now depends on hw.c a generated
2908 table of hw.
2909
2910 * device_table.c (device_table): Re-arange the table of devices so
2911 that two levels are possible. Make use of hw.c.
2912 * device_table.h: ditto.
2913
2914 * device.c (device_template_create_device): Handle new two level
2915 device lookup table.
2916 * device.c (device_usage): ditto.
2917
2918 Mon Feb 26 22:24:00 1996 Andrew Cagney - aka Noid <cagney@highland.com.au>
2919
2920 * device_table.c: Delete the memory device (moved to hw_memory.c).
2921
2922 * hw_memory.c: New file. Just an OpenBoot memory device.
2923
2924 Wed Jan 17 21:47:34 1996 Andrew Cagney <cagney@highland.com.au>
2925
2926 * device.c (device_init_address): New. Split initialization into
2927 two stages, address and address spaces
2928 * device.c (device_init_data): New. ... and data or other work.
2929 With out this, devices try to modify memory before it as been
2930 attached.
2931
2932 * device.c (device_tree_init): Update to perform staged
2933 initialization.
2934
2935 * device.c (device_init): Delete.
2936
2937 Wed Jan 17 21:43:09 1996 Andrew Cagney <cagney@highland.com.au>
2938
2939 * device_table.c (data_*): Rewrite to make heaver use of property
2940 nodes. Allow initialization by different data types.
2941 * device_table.c (htab_* pte_*): Rewrite to use properties.
2942
2943 * emul_chirp.c (emul_chirp_create): Use
2944 * emul_bugapi.c (emul_bugapi_create): Ditto
2945 * emul_netbsd.c (emul_netbsd_create): Ditto
2946
2947 Wed Jan 17 21:24:50 1996 Andrew Cagney <cagney@highland.com.au>
2948
2949 * emul_generic.c (emul_add_tree_options): Annotate existing tree
2950 with options that haven't yet been specified.
2951 * emul_generic.c (emul_add_tree_hardware): Annotate existing tree
2952 with demo devices and properties.
2953
2954 * emul_chirp.c (emul_chirp_create): Update to use new
2955 device_tree_add_parsed call and additional information now
2956 included in the device tree. Use emul_add_tree* functions to add
2957 any missing details.
2958 * emul_bugapi.c (emul_bugapi_create): Ditto
2959 * emul_netbsd.c (emul_netbsd_create): Ditto
2960
2961 Wed Jan 17 21:18:27 1996 Andrew Cagney <cagney@highland.com.au>
2962
2963 * device.c (device_instance_create): New. Create/delete and
2964 operate on instances of a device.
2965 * device.c (device_instance_delete): Ditto
2966 * device.c (device_instance_read): Ditto
2967 * device.c (device_instance_write): Ditto
2968 * device.c (device_instance_seek): Ditto
2969 * device.c (device_instance_data): Ditto
2970 * device.c (device_instance_name): Ditto
2971 * device.c (device_instance_path): Ditto
2972
2973 * emul_chirp.c (chirp_emul_open): Implement using device_instance.
2974 * emul_chirp.c (chirp_emul_close): Ditto
2975 * emul_chirp.c (chirp_emul_read): Ditto
2976 * emul_chirp.c (chirp_emul_write): Ditto
2977 * emul_chirp.c (chirp_emul_seek): Ditto
2978
2979 * emul_chirp.c (chirp_read_t2h_args): Read arguments from device.
2980 Being careful to convert all from target to host byte order.
2981 * emul_chirp.c (chirp_write_h2t_args): Converse.
2982
2983 Wed Jan 17 20:07:15 1996 Andrew Cagney <cagney@highland.com.au>
2984
2985 * device.c (device_tree_add_parsed): New. Rewrite code to add
2986 devices to the device tree so that a single printf style function
2987 is used.
2988
2989 * device.c (device_tree_add_*): Delete. Replaced by above.
2990
2991 * device.c (split_device_specifier): Functions to manipulate a
2992 device specifier (path) breaking it into its components
2993 * device.c (split_property_specifier): Ditto
2994 * device.c (split_device_name): Ditto
2995 * device.c (split_find_device): Ditto
2996
2997 * device.c (scan_*): Delete
2998
2999 * device.c (device_tree_find_device): Rewrite to use above.
3000 * device.c (device_add_property): Ditto
3001
3002 Wed Jan 17 19:51:56 1996 Andrew Cagney <cagney@highland.com.au>
3003
3004 * psim.c(psim_options): Parse the psim options, installing their
3005 value in the device tree. Options are now first entered into a
3006 device tree and then extracted out again when needed. This allows
3007 greater flexability in configuration.
3008
3009 * psim.c (psim_tree): Returns a basic device tree ready for
3010 parsing by psim_options.
3011 * psim.c (psim_usage): New. Give usage to varing levels of detail
3012 according to the verbosity. In turn output device and trace
3013 usage.
3014
3015 * main.c (main): Update to use new system
3016 * sim_calls.c (sim_open, sim_do_command): Ditto
3017
3018 * psim.c (psim_options): Add `r' option - ram size.
3019 * psim.c (psim_options): Add `o' option - openboot tree entry.
3020 * psim.c (psim_options): Add `h'/`H' options - more help.
3021
3022 * debug.c (trace_usage): Add more detailed help.
3023 * device.c (device_usage): New. Output help including a list of
3024 the devices currently available in the device table.
3025 * device_table.c: Add usage operator to each device.
3026
3027 * corefile.c (core_create, core_device_create): Adjust so that the
3028 core device is created earlier for psim_tree(). Core can later be
3029 created from it.
3030
3031 * psim.c (psim_create): Update to handle above way of creating
3032 things. Extract all information from the device tree.
3033
3034 * device_tree.c (trace_*): New device node, its properties are
3035 used to set the value of the trace options. Init this device (in
3036 psim_options) when ever the options are updated.
3037
3038 Wed Jan 17 19:46:07 1996 Andrew Cagney <cagney@highland.com.au>
3039
3040 * debug.h: Add trace_print_info, trace_print_device_tree and
3041 trace_dump_device_tree. The first is a replacement for the
3042 variable `print_info' found in main.c and sim_calls.c. The latter
3043 two enable the dumping of the entire device tree.
3044
3045 * debug.c: Add to trace_description table.
3046
3047 * main.c (main): Use above trace instead of local variable
3048 * sim_calls.c (sim_close): Ditto
3049
3050 * device.c (device_tree_print_device): New. Prints the device
3051 tree in a format that is consistent with what can be parsed by the
3052 device tree load from file code.
3053
3054 * psim.c (psim_create): Dump device tree if enabled. If nump
3055 selected, exit psim immediatly.
3056
3057 Wed Jan 17 19:36:52 1996 Andrew Cagney <cagney@highland.com.au>
3058
3059 * corefile-n.h (core_map_read_N): When mapping from an address to
3060 a device, do not subtract the devices base. The device its self
3061 can do this. Brings the behavour into line with OpenBoot.
3062 * corefile-n.h (core_map_write_N): Ditto
3063 * corefile.c (core_map_read_buffer): Ditto
3064 * corefile.c (core_map_write_buffer): Ditto
3065
3066 * device_table.c (console_io_read_buffer_callback): Adjust to
3067 handle biased address.
3068 * device_table.c (console_io_write_buffer_callback): Ditto
3069
3070 Wed Jan 17 18:36:09 1996 Andrew Cagney <cagney@highland.com.au>
3071
3072 * device.c (attach_device_interrupt_edge): New. Interrupt model
3073 did not allow interrupts to be wired up as a general net (edges).
3074 Re-implement so that interrupt events can be passed to multiple
3075 controllers and interrupt controllers can further propogate
3076 interrupt events.
3077
3078 * device.c (attach_device_interrupt_edge) : New, Ditto
3079 * device.c (detach_device_interrupt_edge) : New, Ditto
3080 * device.c (clean_device_interrupt_edges) : New, Ditto
3081 * device.c (device_interrupt_event) : New, Ditto
3082 * device.c (device_interrupt_attach) : New, Ditto
3083 * device.c (device_interrupt_detach) : New, Ditto
3084 * device.c (device_child_interrupt_attach) : New, Ditto
3085 * device.c (device_child_interrupt_detach) : New, Ditto
3086
3087 * device.c (device_attach_interrupt) : Delete old
3088 * device.c (device_detach_interrupt) : Delete old
3089 * device.c (device_interrupt) : Delete old
3090 * device.c (device_interrupt_ack) : Delete old
3091
3092 * device_table.c (unimp_*) : Update to match
3093
3094 * device_table.c (icu_io_write_buffer_callback) : Update to use
3095 interface.
3096 * device_table.c (icu_interrupt_event_callback) : Ditto
3097
3098 Wed Jan 17 18:18:40 1996 Andrew Cagney <cagney@highland.com.au>
3099
3100 * device.c (external_to_device) : New function that provides a
3101 standard mapping between a devices internal representation (a
3102 pointer) and its external (or what is passed to a client)
3103 representation (a phandle). Implement using the cap object
3104 attached to the root node.
3105
3106 * device.c (device_to_external) : Ditto
3107 * device.c (external_to_device_instance) : Ditto but for ihandle
3108 and device instance.
3109 * device.c (device_instance_to_external) : Ditto
3110
3111 * Makefile (device.o): Add dependency on cap.
3112
3113 * emul_chirp.c (struct _emul_chirp_data) : Elimate use of cap. Code
3114 needing to translate between internal and external representations
3115 changed to use the external_to_device et.al. device operations.
3116 * emul_chirp.c (chirp_emul_*) : Ditto
3117
3118 * Makefile (emul_chirp.o): Remove dependency on cap
3119
3120 Sat Jan 6 10:13:26 1996 Andrew Cagney - aka Noid <cagney@highland.com.au>
3121
3122 * emul_chirp.c (map_over_chirp_note): Tighten up (and fix) checks
3123 on OpenBoot note section.
3124
3125 Fri Jan 5 20:28:53 1996 Andrew Cagney <cagney@hignland.com.au>
3126
3127 * emul_generic.c (emul_write_buffer): Use vm faulting byte
3128 read/write calls for buffer transfers. This will cause a fault to
3129 occure if the transfer fails. CHRP catches the fault while the
3130 others suffer the consequences.
3131 (emul_read_buffer): Ditto.
3132 (emul_write_word): Ditto.
3133 (emul_read_word): Ditto.
3134 (emul_read_string): Ditto.
3135
3136 Fri Jan 5 18:55:34 1996 Andrew Cagney <cagney@highland.com.au>
3137
3138 * emul_chirp.c (emul_chirp_create, emul_chirp_instruction_call),
3139 emul_generic (emul_blr_instruction): Use a real blr instruction to
3140 return from a client service call.
3141
3142 * emul_chirp.c (services): Add all OpenBoot services to table.
3143
3144 * emul_generic.h, emul_bugapi.c (emul_bugapi_create), emul_chirp.c
3145 (emul_chirp_create) : Use names instead of numbers for
3146 instructions being stored in memory.
3147
3148 Fri Jan 5 18:52:28 1996 Andrew Cagney <cagney@highland.com.au>
3149
3150 * Makefile.in (maintainer-clean): Remove .log, core and *.core
3151 (From NetBSD) files.
3152
3153 Wed May 29 22:57:40 1996 Andrew Cagney <cagney@kremvax.highland.com.au>
3154
3155 * ChangeLog.00, ChangeLog: ChangeLog from gdb-4.16 becomes
3156 ChangeLog.00
3157