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