]> Git Repo - binutils.git/blame - sim/ppc/ChangeLog
Regenerate configure
[binutils.git] / sim / ppc / ChangeLog
CommitLineData
d865fb6e
MM
1Wed Apr 22 14:28:48 1998 Michael Meissner <[email protected]>
2
3 * configure: Regenerate with autoconf 2.12.1.
4
5Fri Mar 13 09:25:58 1998 Andrew Cagney <[email protected]>
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
16Tue Feb 17 12:48:58 1998 Andrew Cagney <[email protected]>
17
18 * sim_calls.c (sim_store_register, sim_fetch_register): Pass in
19 length parameter. Return -1.
20
21Mon Feb 9 14:13:14 1998 Andrew Cagney <[email protected]>
22
23 * ppc-instructions (fdiv, fdivs): Check for divide by zero.
24 (is_invalid_zero_divide, invalid_zero_divide_operation): New
25 functions.
26
27Wed Dec 10 17:38:28 1997 Andrew Cagney <[email protected]>
28
29 * sim_calls.c (sim_load): Do not parse PROG using buildargv, use
30 raw value instead.
31
321997-11-05 Felix Lee <[email protected]>
33
34 * emul_chirp.c: #ifdef HAVE_UNISTD_H
35
36Wed Oct 15 08:50:54 1997 Andrew Cagney <[email protected]>
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
43Mon Oct 6 18:09:26 1997 Michael Meissner <[email protected]>
44
45 * sim_calls.c (zfree): Call free correctly.
46
63fe2cc7
AC
47Mon Sep 29 10:05:01 1997 Andrew Cagney <[email protected]>
48
49 * sim_calls.c (zfree): Use free, not mfree.
50 (sim_io_flush_stdoutput): Replace gdb_flush with callback ->
51 flush_stdout.
52
53Fri Sep 26 09:50:29 1997 Andrew Cagney <[email protected]>
54
d865fb6e
MM
55 * ppc-instructions (sraw, slw, srw): From Charles Lefurgy, Fix
56 mask extracting shift amount. Correctly condition for setting XER
57 in sraw.
63fe2cc7
AC
58 (ldhau): From Johannes Reisinger, update rA after load.
59
60Tue Sep 9 22:13:23 1997 Felix Lee <[email protected]>
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
9f64f00a
AC
66Wed Aug 27 10:24:15 1997 Andrew Cagney <[email protected]>
67
d6fea803
AC
68 * sim_calls.c (sim_create_inferior): Check the simulator was
69 initialized before creating inferior.
70
9f64f00a
AC
71 * idecode_expression.h (ALU_END): From Charles Lefurgy - Extract
72 sign bit using 64 bit and not a 32 bit mask.
73
74Wed Aug 27 10:15:48 1997 Andrew Cagney <[email protected]>
75
76 * sim_calls.c (sim_load): From Ian Lance Taylor - free argv after
77 it has been used, not before.
78
7230ff0f
AC
79Tue Aug 26 10:41:35 1997 Andrew Cagney <[email protected]>
80
81 * sim_calls.c (sim_kill): Delete.
fafce69a
AC
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.
7230ff0f 86
247fccde
AC
87Mon Aug 25 16:17:06 1997 Andrew Cagney <[email protected]>
88
89 * sim_calls.c (sim_open): Add ABFD argument.
90
91Thu Jul 3 10:18:06 1997 Andrew Cagney <[email protected]>
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
ff82f214
AC
126Tue May 20 10:22:50 1997 Andrew Cagney <[email protected]>
127
128 * sim_calls.c (sim_open): Add callback argument.
247fccde 129 (sim_set_callbacks): Delete.
ff82f214
AC
130
131Tue Apr 22 22:36:57 1997 Mike Meissner <[email protected]>
132
133 * sim_callbacks.h (error): Make declaration match gdb's.
134 * main.c (error): Ditto.
135
8517f62b
AC
136Fri Apr 18 17:03:09 1997 Andrew Cagney <[email protected]>
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
154Fri Apr 18 17:03:08 1997 Andrew Cagney <[email protected]>
155
156 * psim.c (psim_options): Handle -E option correctly.
157 (psim_usage): Document.
158
ed119303
DE
159Thu Apr 17 03:28:03 1997 Doug Evans <[email protected]>
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
04184003
ILT
167Tue Apr 15 14:57:18 1997 Ian Lance Taylor <[email protected]>
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
21a2898b
AC
175Fri Apr 4 17:54:36 1997 Jim Wilson <[email protected]>
176
177 * Makefile.in (tmp-hw, tmp-pk): Use for loop to eliminate duplicates
178 rather than the non-portable cat -n.
179
180Mon Apr 14 16:29:51 1997 Ian Lance Taylor <[email protected]>
181
182 * Makefile.in (INSTALL): Change install.sh to install-sh.
183
1414a2e5
AC
184Tue Apr 1 18:15:14 1997 Jim Wilson <[email protected]>
185
186 * ppc-instructions: Change milhwu to mulhwu.
187
33f00b8b
DE
188Wed Apr 2 15:38:08 1997 Doug Evans <[email protected]>
189
190 * sim_calls.c (sim_open): New arg `kind'.
191
64d20049
ILT
192Wed Apr 2 14:51:17 1997 Ian Lance Taylor <[email protected]>
193
194 * COPYING: Update FSF address.
195
196Tue Mar 25 16:17:59 1997 Andrew Cagney <[email protected]>
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
332cb0a7
AC
201Tue Mar 25 12:13:02 1997 Andrew Cagney <[email protected]>
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 <[email protected]>).
207 * configure: Re-generate.
208
209Fri Mar 14 18:23:02 1997 Andrew Cagney <[email protected]>
210
211 * Makefile.in (targ-vals.def): Re-do rule so that it works with
212 FreeBSD's make. Didn't like $<.
213
87ae64c3
DE
214Thu Mar 13 12:55:48 1997 Doug Evans <[email protected]>
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
220Thu Feb 13 10:35:14 1997 Andrew Cagney <[email protected]>
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
237Wed Feb 12 19:33:45 1997 Andrew Cagney <[email protected]>
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
f9114af5
MM
259Tue Feb 11 13:49:10 1997 Michael Meissner <[email protected]>
260
37404956
MM
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
f9114af5
MM
270 * Makefile.in (callback.o): Define HAVE_CONFIG_H, so callback.c
271 includes our config.h.
272
cef84fb3
DE
273Tue Feb 4 13:42:59 1997 Doug Evans <[email protected]>
274
275 * configure.in: Fix typo in test for callback.c.
276 * configure: Regenerated.
277
37404956
MM
278Fri Feb 7 10:04:25 1997 Andrew Cagney <[email protected]>
279
280 * emul_chirp.c (emul_chirp_create): Handle a virtbase of -1 being
281 found in the device tree.
282
283Wed Feb 5 10:56:27 1997 Andrew Cagney <[email protected]>
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
296Wed Feb 5 10:56:27 1997 Andrew Cagney <[email protected]>
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
303Tue Feb 4 17:44:51 1997 Andrew Cagney <[email protected]>
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
312Mon Feb 3 17:18:16 1997 Andrew Cagney <[email protected]>
313
314 * events.c (insert_event_entry): Correct loop termination
315 assertions.
316
317Fri Jan 31 16:20:26 1997 Andrew Cagney <[email protected]>
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
54973b80
MM
334Thu Jan 30 11:23:20 1997 Andrew Cagney <[email protected]>
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
d2e3d3af
MM
342Wed Jan 29 12:32:41 1997 Michael Meissner <[email protected]>
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
37404956
MM
357Wed Jan 29 12:14:19 1997 Andrew Cagney <[email protected]>
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
366Wed Jan 29 12:14:19 1997 Andrew Cagney <[email protected]>
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
380Wed Jan 29 12:14:19 1997 Andrew Cagney <[email protected]>
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
419Wed Jan 29 12:14:19 1997 Andrew Cagney <[email protected]>
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
432Tue Jan 28 13:00:19 1997 Andrew Cagney <[email protected]>
433
434 * hw_com.c (hw_com_instance_read, hw_com_instance_write):
435 Implement.
436
5c04f4f7
MM
437Thu Jan 23 09:07:26 1997 Andrew Cagney <[email protected]>
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
449Thu Jan 23 09:07:26 1997 Andrew Cagney <[email protected]>
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
481Wed Jan 22 09:38:33 1997 Andrew Cagney <[email protected]>
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
504Wed Jan 22 12:24:52 1997 Andrew Cagney <[email protected]>
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
537Tue Jan 21 13:26:10 1997 Andrew Cagney <[email protected]>
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
547Mon Jan 20 11:20:15 1997 Andrew Cagney <[email protected]>
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
580Sun Jan 19 16:44:29 1997 Andrew Cagney <[email protected]>
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
586Sun Jan 19 15:28:23 1997 Andrew Cagney <[email protected]>
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
599Fri Jan 17 12:01:07 1997 Andrew Cagney <[email protected]>
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
610Fri Jan 17 11:50:13 1997 Andrew Cagney <[email protected]>
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
634Thu Jan 16 08:51:25 1997 Andrew Cagney <[email protected]>
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
648Wed Jan 15 14:38:25 1997 Andrew Cagney <[email protected]>
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
661Wed Jan 15 13:54:50 1997 Andrew Cagney <[email protected]>
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
679Wed Jan 15 12:25:11 1997 Andrew Cagney <[email protected]>
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
695Tue Jan 14 12:19:10 1997 Andrew Cagney <[email protected]>
696
697 * ppc-instructions (Move from Special Purpose Register): Support
698 move from DEC.
699
700Mon Jan 13 16:58:12 1997 Andrew Cagney <[email protected]>
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
720Thu Jan 2 09:10:41 1997 Andrew Cagney <[email protected]>
721
722 * interrupts.c (perform_oea_interrupt): Halt rather than abort on
723 a double interrupt.
724
725Wed Jan 1 22:54:52 1997 Andrew Cagney <[email protected]>
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
740Fri Dec 20 13:19:07 1996 Andrew Cagney <[email protected]>
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
766Thu Dec 19 11:09:43 1996 Andrew Cagney <[email protected]>
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
774Wed Dec 18 17:49:59 1996 Andrew Cagney <[email protected]>
775
776 * interrupts.c (perform_oea_interrupt): Print additional
777 information if a double interrupt is encountered.
778
779Wed Dec 18 17:49:59 1996 Andrew Cagney <[email protected]>
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
785Wed Dec 18 17:49:59 1996 Andrew Cagney <[email protected]>
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
795Tue Dec 17 15:12:38 1996 Andrew Cagney <[email protected]>
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
801Fri Dec 13 14:30:31 1996 Andrew Cagney <[email protected]>
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
811Fri Dec 13 14:30:31 1996 Andrew Cagney <[email protected]>
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
827Tue Dec 10 10:31:48 1996 Michael Meissner <[email protected]>
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
858Tue Dec 10 10:12:44 1996 Andrew Cagney <[email protected]>
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
865Tue Dec 10 10:12:44 1996 Andrew Cagney <[email protected]>
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
876Tue Dec 10 10:12:44 1996 Andrew Cagney <[email protected]>
877
878 * psim.c (psim_merge_device_file): Strip newline from device
879 specs.
880
881Tue Dec 10 10:12:44 1996 Andrew Cagney <[email protected]>
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
895Mon Dec 9 12:08:46 1996 Andrew Cagney <[email protected]>
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
906Mon Dec 9 12:08:46 1996 Andrew Cagney <[email protected]>
907
908 * os_emul.c (os_emul_create): Use tree find property instead of
909 device find property - sigh.
910
911Thu Dec 5 10:46:42 1996 Andrew Cagney <[email protected]>
912
913 * 961205: Release snapshot 961205.
914
915Thu Dec 5 10:46:42 1996 Andrew Cagney <[email protected]>
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
928Wed Dec 4 13:57:31 1996 Andrew Cagney <[email protected]>
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
938Fri Nov 29 11:12:22 1996 Andrew Cagney <[email protected]>
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
939b233a
DE
955Wed Nov 20 00:36:55 1996 Doug Evans <[email protected]>
956
5c04f4f7
MM
957 * sim_calls.c (sim_resume): Reset sim_should_run if single
958 stepping.
959
960Thu Nov 28 13:19:46 1996 Andrew Cagney <[email protected]>
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
982Thu Nov 21 12:05:32 1996 Andrew Cagney <[email protected]>
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
1038Thu Nov 21 12:05:32 1996 Andrew Cagney <[email protected]>
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
1050Thu Nov 21 12:05:32 1996 Andrew Cagney <[email protected]>
1051
1052 * BUGS: Updated a bit.
1053
1054Wed Nov 20 14:06:37 1996 Andrew Cagney <[email protected]>
1055
1056 * hw_opic.c: Finish - third round.
1057
1058Wed Nov 20 12:02:08 1996 Andrew Cagney <[email protected]>
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.
34452aa4 1063
5c04f4f7 1064Tue Nov 19 21:17:08 1996 Andrew Cagney <[email protected]>
939b233a 1065
5c04f4f7
MM
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
f8149dfe
MM
1074Fri Nov 15 15:23:39 1996 Michael Meissner <[email protected]>
1075
1076 * pk_disklabel.c (pk_disklabel_create_instance): Fix up some
1077 warnings generated by GCC.
1078
5c04f4f7
MM
1079Sun Nov 17 17:59:14 1996 Andrew Cagney <[email protected]>
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
1086Sun Nov 17 17:59:14 1996 Andrew Cagney <[email protected]>
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
1096Sun Nov 17 17:59:14 1996 Andrew Cagney <[email protected]>
1097
1098 * device.c (split_find_device): Be tolerant of missing unit
1099 addresses.
1100
1101Fri Nov 15 16:49:49 1996 Andrew Cagney <[email protected]>
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
1115Thu Nov 14 21:38:13 1996 Andrew Cagney <[email protected]>
1116
1117 * hw_opic.c: Finish - second round.
1118
1119Thu Nov 7 00:18:59 1996 Andrew Cagney <[email protected]>
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
1145Wed Nov 6 20:20:58 1996 Andrew Cagney <[email protected]>
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
1174Mon Nov 4 12:49:13 1996 Andrew Cagney <[email protected]>
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
1188Sun Nov 3 18:45:20 1996 Andrew Cagney <[email protected]>
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
1197Sat Nov 2 21:48:57 1996 Andrew Cagney <[email protected]>
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
f8149dfe
MM
1208Fri Nov 1 14:42:57 1996 Michael Meissner <[email protected]>
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
b9f74e0b
MM
1217Tue Oct 29 17:55:43 1996 Michael Meissner <[email protected]>
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
5c04f4f7
MM
1227Tue, 8 Oct 18:42:26 1996 Jason Molenda <[email protected]>
1228
1229 * Makefile.in (clean): Move config.log to distclean.
1230
1231Fri Nov 1 16:44:28 1996 Andrew Cagney <[email protected]>
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
1251Wed Oct 30 18:46:32 1996 Andrew Cagney <[email protected]>
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
1257Tue Oct 29 02:01:29 1996 Andrew Cagney <[email protected]>
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
1297Mon Oct 28 22:55:48 1996 Andrew Cagney <[email protected]>
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
1308Fri Oct 25 21:28:25 1996 Andrew Cagney <[email protected]>
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
1315Fri Oct 25 21:28:25 1996 Andrew Cagney <[email protected]>
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
1328Fri Oct 25 21:28:25 1996 Andrew Cagney <[email protected]>
1329
1330 * device_table.c (generic_device_init_address): Use
1331 assigned-addresses property in preference to any other reg
1332 property.
1333
1334Fri Oct 25 21:28:25 1996 Andrew Cagney <[email protected]>
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
1355Fri Oct 25 21:28:25 1996 Andrew Cagney <[email protected]>
1356
1357 * debug.h, debug.c: Sort debug options, Add entries for the
1358 comming PHB device.
1359
b9f74e0b
MM
1360Fri Oct 18 12:12:21 1996 Michael Meissner <[email protected]>
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
5c04f4f7 1383Wed Sep 25 10:20:29 1996 Andrew Cagney <[email protected]>
b9f74e0b 1384
5c04f4f7
MM
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
1393Tue Sep 24 20:55:38 1996 Andrew Cagney <[email protected]>
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
1405Tue Sep 24 16:30:48 1996 Andrew Cagney <[email protected]>
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
1417Tue Sep 24 16:30:48 1996 Andrew Cagney <[email protected]>
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
1432Mon Sep 23 00:37:49 1996 Andrew Cagney <[email protected]>
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
1442Sun Sep 22 15:56:22 1996 Andrew Cagney <[email protected]>
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
1458Sat Sep 21 19:39:56 1996 Andrew Cagney <[email protected]>
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
1469Sat Sep 21 00:13:02 1996 Andrew Cagney <[email protected]>
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
1477Fri Sep 20 14:04:40 1996 Andrew Cagney <[email protected]>
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.
b9f74e0b
MM
1485
1486Thu Sep 19 14:40:40 1996 Andrew Cagney <[email protected]>
1487
1488 * debug.h: Add disklabel-package and disk-device trace options.
1489 debug.h (PTRACE): Add macro to simplify tracing in packages.
1490
1491Thu Sep 19 14:40:40 1996 Andrew Cagney <[email protected]>
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
1499Thu Sep 19 14:40:40 1996 Andrew Cagney <[email protected]>
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
1512Thu Sep 19 13:05:40 1996 Andrew Cagney <[email protected]>
1513
1514 * emul_chirp.c (chirp_emul_read): Allow reads to be longer then
1515 the internal buffer.
1516
1517Thu Sep 19 13:05:40 1996 Andrew Cagney <[email protected]>
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
1526Wed Sep 18 19:33:54 1996 Andrew Cagney <[email protected]>
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
1539Tue Sep 17 15:57:44 1996 Andrew Cagney <[email protected]>
1540
1541 * device.c (device_tree_add_parsed): Detect and report an
1542 interrupt being attached to an invalid device. Was dumping core.
1543
1544Mon Sep 16 23:09:12 1996 Andrew Cagney <[email protected]>
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
1574Mon Sep 16 23:09:12 1996 Andrew Cagney <[email protected]>
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
1581Thu Sep 12 17:30:56 1996 Andrew Cagney <[email protected]>
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
1592Thu Sep 12 17:30:56 1996 Andrew Cagney <[email protected]>
1593
1594 * mon.c (mon_event): Remove assertion that an unsigned is >= 0.
1595
1596Fri Aug 16 12:05:24 1996 Michael Meissner <[email protected]>
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
1604Tue Aug 13 11:40:14 1996 Michael Meissner <[email protected]>
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
83a650d8
MM
1609Tue Aug 13 11:40:14 1996 Michael Meissner <[email protected]>
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
9aecf50d
MM
1622Mon Aug 12 18:42:37 1996 Michael Meissner <[email protected]>
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
def7f775
MM
1636Wed Aug 7 14:34:20 1996 Michael Meissner <[email protected]>
1637
7b25dea5
MM
1638 * emul_unix.c (HAVE_TCGETATTR): If HAVE_TERMIOS_STRUCTURE is not
1639 defined, make sure HAVE_TCGETATTR is #undef'ed
1640
b9f74e0b
MM
1641Wed Aug 7 14:34:20 1996 Michael Meissner <[email protected]>
1642
def7f775
MM
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
b9f74e0b
MM
1650Wed Aug 7 20:19:55 1996 Andrew Cagney <[email protected]>
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
2e913166
MM
1672Tue Aug 6 09:28:22 1996 Michael Meissner <[email protected]>
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
b9f74e0b
MM
1681Wed Aug 7 00:17:37 1996 Andrew Cagney <[email protected]>
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
1691Tue Aug 6 21:35:18 1996 Andrew Cagney <[email protected]>
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
2e913166
MM
1702Wed Jul 31 00:02:30 1996 Andrew Cagney <[email protected]>
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
1730Tue Jul 30 21:26:14 1996 Andrew Cagney <[email protected]>
1731
1732 * psim.c (psim_init): Back out of change to initial value of
1733 system->last_cpu.
1734
1735Tue Jul 30 21:12:24 1996 Andrew Cagney <[email protected]>
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
1763Fri Jul 26 19:43:03 1996 Andrew Cagney <[email protected]>
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
1778Fri Jul 26 00:36:35 1996 Andrew Cagney <[email protected]>
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
1812Thu Jul 25 22:10:40 1996 Andrew Cagney <[email protected]>
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
1821Thu Jul 25 20:07:30 1996 Andrew Cagney <[email protected]>
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
1835Wed 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
1844Wed Jul 24 15:47:09 1996 Andrew Cagney <[email protected]>
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
1854Tue Jul 23 20:57:01 1996 Andrew Cagney <[email protected]>
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
1875Wed Jul 24 14:02:42 1996 Andrew Cagney <[email protected]>
1876
1877 * gen-idecode.c (print_run_until_stop_body): Too many rparen in
1878 generated code.
1879
1880Tue Jul 23 20:57:01 1996 Andrew Cagney <[email protected]>
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
1888Mon Jul 22 23:25:08 1996 Andrew Cagney <[email protected]>
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
1900Mon Jul 22 22:38:59 1996 Andrew Cagney <[email protected]>
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
1906Mon Jul 22 22:17:08 1996 Andrew Cagney <[email protected]>
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
1920Mon Jul 22 20:46:12 1996 Andrew Cagney <[email protected]>
1921
1922 * Makefile.in (BUILD_CFLAGS): Include -g when building the
1923 generators.
1924
1925Mon Jul 22 20:00:25 1996 Andrew Cagney <[email protected]>
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
30c87b55
MM
1931Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
1938Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
1951Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
1958Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
1982Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
2001Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
2014Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
2023Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
2030Sun Jul 21 21:18:05 1996 Andrew Cagney <[email protected]>
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
2036Mon Jun 24 22:28:00 1996 Andrew Cagney <[email protected]>
2037
2038 * Makefile.in (BUILD_CFLAGS): Include WARNING_CFLAGS.
2039
2040Wed Jun 19 21:45:28 1996 Andrew Cagney <[email protected]>
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
2080Mon Jun 17 20:08:03 1996 Andrew Cagney <[email protected]>
2081
2082 * sim_calls.c (sim_close): If simulator not created, skip printing
2083 of run information.
2084
2085Mon Jun 17 20:08:03 1996 Andrew Cagney <[email protected]>
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
2099Fri Jun 14 00:11:56 1996 Andrew Cagney <[email protected]>
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
2130Thu Jun 13 00:09:29 1996 Andrew Cagney <[email protected]>
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
2138Wed Jun 12 22:30:32 1996 Andrew Cagney <[email protected]>
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
2156Fri Jun 7 23:47:18 1996 Andrew Cagney <[email protected]>
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
2168Wed Jun 26 12:50:33 1996 Michael Meissner <[email protected]>
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
78c09e4a
JM
2183Wed Jun 26 12:26:55 1996 Jason Molenda ([email protected])
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
30c87b55
MM
2192Wed Jun 5 23:53:42 1996 Andrew Cagney <[email protected]>
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
78c09e4a
JM
2199Thu Jun 6 09:52:37 1996 Michael Meissner <[email protected]>
2200
2201 * hw_disk.c (SEEK_SET): If SEEK_SET is not defined, define as 0.
2202
2203Wed 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
8477437c
MM
2208Wed Jun 5 01:39:07 1996 Andrew Cagney <[email protected]>
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
2217Wed Jun 5 01:39:07 1996 Andrew Cagney <[email protected]>
2218
2219 * emul_unix.c (do_unix_umask): Cast printf argument.
2220 (convert_to_linux_termios): Use LINUX_VSWTC not LINUX_VSWCH
2221
5b18a1a0
MM
2222Mon Jun 3 15:02:04 1996 Michael Meissner <[email protected]>
2223
8477437c 2224 * hw_init.c (update_for_binary_section): Abort if we find an
fe098bf4
MM
2225 .interp section, which indicates the need for shared libraries to
2226 be loaded.
2227
8477437c
MM
2228Mon Jun 3 15:02:04 1996 Michael Meissner <[email protected]>
2229
5b18a1a0
MM
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
8477437c
MM
2240Mon Jun 3 23:19:57 1996 Andrew Cagney <[email protected]>
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
88f1eac4
MM
2251Sun Jun 2 11:21:17 1996 Michael Meissner <[email protected]>
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
8477437c
MM
2283Thu May 30 00:00:10 1996 Andrew Cagney <[email protected]>
2284
2285 * hw_iobus.c: Tidy up notes so that they can be auto-extracted.
2286
2287 * README: Correct PSIM's title
2288
2289Wed May 29 23:50:26 1996 Andrew Cagney <[email protected]>
2290
2291 * basics.h: New global type object_disposition, used to indicate
2292 the status of objects when things are restarted.
2293
2294Fri May 17 17:28:52 1996 Andrew Cagney <[email protected]>
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
2311Tue May 14 23:03:53 1996 Andrew Cagney <[email protected]>
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
2342Mon May 6 17:36:15 1996 Andrew Cagney <[email protected]>
2343
2344 * interrupts.c (decrementer_interrupt): Always pend a decrementer
2345 interrupt even if it is not yet possible to deliver it.
2346
2347Wed 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
2359Tue Apr 30 22:09:09 1996 Andrew Cagney <[email protected]>
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
2382Fri Apr 26 00:00:07 1996 Andrew Cagney <[email protected]>
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
2424Thu Apr 18 23:38:10 1996 Andrew Cagney <[email protected]>
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
f64dbcdd
MM
2431Fri May 24 10:08:10 1996 Michael Meissner <[email protected]>
2432
0c18e3f0
MM
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.
119b85f6
MM
2442 (MAXPATHLEN): Undefine if including unistd.h, since sys/param.h
2443 might define it.
0c18e3f0 2444
f64dbcdd
MM
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
2450Tue May 21 17:24:45 1996 Michael Meissner <[email protected]>
2451
2452 * emul_netbsd.c (write_stat): Don't convert st_blocks unless the
2453 host is netbsd.
2454
d61eb812
MM
2455Thu May 16 10:56:45 1996 Michael Meissner <[email protected]>
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
048668d3
MM
2462Tue May 7 17:28:12 1996 Michael Meissner <[email protected]>
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
1ed0c0e7
MM
2473Mon May 6 11:31:43 1996 Michael Meissner <[email protected]>
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
08dc78ad
MM
2479Fri May 3 15:07:42 1996 Michael Meissner <[email protected]>
2480
2481 * Makefile.in: Correctly build simulator for build machine != host
2482 machine.
2483
a72d2509 2484Tue Apr 30 18:46:05 1996 Michael Meissner <[email protected]>
997f0ee9 2485
a72d2509
MM
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.
64646bd3 2493
a72d2509 2494Wed Apr 17 14:38:06 1996 Michael Meissner <[email protected]>
64646bd3 2495
a72d2509
MM
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.
d6103e8e 2500
6740925b
MM
2501 * options.c (print_options): Print out WITH_STDIO.
2502
d6103e8e
MM
2503 * Makefile.in (STDIO_CFLAGS): Pass on result of @sim_stdio@
2504 configuration variable.
2505 (CONFIG_CFLAGS): Include STDIO_CFLAGS.
a72d2509
MM
2506 (hw.{c,h}): Allow for source dir != build dir, and for HW_SRC
2507 files to contain directory pieces.
d6103e8e
MM
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
a72d2509
MM
2517 * interrupts.c (external_interrupt): Declare it to be
2518 INLINE_INTERRUPTS, not INLINE_CPU.
1dc7c0ed 2519
a72d2509 2520Mon Apr 15 23:30:56 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2521
a72d2509
MM
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.
1dc7c0ed 2525
a72d2509
MM
2526 * events.c (update_time_from_event): New function. Calculates the
2527 number of ticks from the next event. Use this.
1dc7c0ed 2528
a72d2509 2529Sun Apr 14 21:39:45 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2530
a72d2509
MM
2531 * emul_netbsd.c (do_break): Return 0 if success (instead of
2532 adjusted break).
1dc7c0ed 2533
a72d2509
MM
2534 * device_table.c (vm_ioctl_callback): Don't return adjusted break
2535 (isn't needed).
1dc7c0ed 2536
a72d2509 2537Sun Apr 14 21:32:41 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2538
a72d2509
MM
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.
1dc7c0ed 2543
a72d2509
MM
2544 * device_table.c (stack_ioctl_callback): Return 0 status.
2545 (vm_ioctl_callback): Ditto
1dc7c0ed 2546
8477437c
MM
2547Sat Apr 13 00:00:24 1996 Andrew Cagney <[email protected]>
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
2566Fri Apr 12 20:56:47 1996 Andrew Cagney <[email protected]>
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
2578Thu Apr 4 23:03:38 1996 Andrew Cagney <[email protected]>
2579
2580 * emul_bugapi.c (emul_bugapi_create): More strict check of OEA
2581 address.
2582
a72d2509 2583Thu Apr 4 20:58:05 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2584
a72d2509
MM
2585 * interrupts.h (interrupts): New structure contains state of
2586 pending interrupts.
1dc7c0ed 2587
a72d2509
MM
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.
1dc7c0ed 2591
a72d2509 2592Fri Mar 29 22:09:25 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2593
a72d2509
MM
2594 * device.c (device_tree_add_parsed): Check that the creation of a
2595 device instance worked before using it.
1dc7c0ed 2596
a72d2509
MM
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.
1dc7c0ed 2599
a72d2509 2600Fri Mar 29 21:30:56 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2601
a72d2509
MM
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.
1dc7c0ed 2604
a72d2509 2605 * device_table.c (halt, icu, console): Delete.
1dc7c0ed 2606
a72d2509 2607 * Makefile.in (hw_pal.o): New dependency.
1dc7c0ed 2608
a72d2509
MM
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.
1dc7c0ed 2612
a72d2509 2613Fri Mar 29 20:17:17 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2614
a72d2509
MM
2615 * hw_iobus.c (hw_iobus_attach_address_callback): Move from
2616 device_table.c to here.
1dc7c0ed 2617
a72d2509 2618 * Makefile.in (hw_iobus.o): New dependency.
1dc7c0ed 2619
8477437c
MM
2620Fri Mar 29 12:17:58 1996 Andrew Cagney <[email protected]>
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
2630Tue Mar 26 14:57:58 1996 Michael Meissner <[email protected]>
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
a72d2509 2639Mon Mar 25 22:07:13 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2640
a72d2509 2641 * configure: Regenerate with autoconf 2.9.
1dc7c0ed 2642
a72d2509 2643Thu Mar 21 00:14:26 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2644
a72d2509 2645 * device_table.h: Always include string headers.
1dc7c0ed 2646
8477437c
MM
2647Thu Mar 21 00:06:09 1996 Andrew Cagney <[email protected]>
2648
2649 * main.c (error): Be careful to not try to print out statistics
2650 when the simulation was never created.
2651
a72d2509 2652Sun Mar 17 22:40:57 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2653
a72d2509
MM
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.
1dc7c0ed 2656
a72d2509
MM
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).
1dc7c0ed 2661
a72d2509
MM
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.
1dc7c0ed 2665
a72d2509 2666Sun Mar 17 22:40:57 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2667
a72d2509
MM
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.
1dc7c0ed 2672
a72d2509 2673 * cpu.c (cpu_decrement_event): adjust
1dc7c0ed 2674
a72d2509 2675 * events.c (event_queue_process): adjust
1dc7c0ed 2676
a72d2509 2677Sun Mar 17 22:40:57 1996 Andrew Cagney <[email protected]>
1dc7c0ed 2678
a72d2509
MM
2679 * device.h, device.c (device_system): New, returns a handle for
2680 the system given the device.
1dc7c0ed 2681
a72d2509
MM
2682 * device.c (device_address_init): Store a pointer back to the
2683 system in each devices node.
1dc7c0ed 2684
a72d2509
MM
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).
1dc7c0ed 2687
a72d2509 2688 * device.c (device_address_init, device_data_init): Adjust.
4f965b81 2689
a72d2509
MM
2690 * hw_cpu.c, hw_nvram.c, hw_memory.c, hw_eeprom.c, device_table.c:
2691 Adjust.
4f965b81 2692
a72d2509 2693Sun Mar 17 22:40:57 1996 Andrew Cagney <[email protected]>
4f965b81 2694
a72d2509
MM
2695 * interrupts.c (decrementer_interrupt, external_interrupt):
2696 Remember that an interrupt wasn't delivered so that it can be
2697 tried again later.
4f965b81 2698
a72d2509
MM
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.
4f965b81 2703
a72d2509
MM
2704 * ppc-instructions (mtmsr, mfmsr, rfi): Check for posibility of
2705 a pending interrupt being delivered using check_masked_interrupt().
4f965b81 2706
a72d2509
MM
2707 * cpu.c (cpu_decrement_event): Just call decrementer_interrupt()
2708 leaving it to that module to handle both interrupt synchronization
2709 and masking.
4f965b81 2710
a72d2509
MM
2711 * cpu.c (struct _cpu): remove variables that were going to record
2712 pending decrementer and external interrupts.
cb7a6892 2713
a72d2509 2714Sun Mar 17 22:40:57 1996 Andrew Cagney <[email protected]>
cb7a6892 2715
a72d2509
MM
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.
cb7a6892 2720
a72d2509 2721Mon Mar 4 06:06:54 1996 Andrew Cagney <[email protected]>
cb7a6892 2722
a72d2509
MM
2723 * hw_nvram.c: NVRAM device that includes a real-time clock that is
2724 updated each second.
cb7a6892 2725
a72d2509 2726Mon Mar 4 04:18:50 1996 Andrew Cagney <[email protected]>
cb7a6892 2727
a72d2509
MM
2728 * device.h (attach_type): Remove attach_default type address
2729 spaces. Will replace with levels of callback memory.
cb7a6892 2730
a72d2509
MM
2731 * corefile.h, corefile.c (new_core_mapping), corefile.c
2732 (core_map_attach): Replace default attach with a layerd callback
2733 approach.
cb7a6892 2734
a72d2509 2735Sun Mar 3 03:58:46 1996 Andrew Cagney <[email protected]>
cb7a6892 2736
a72d2509
MM
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.
cb7a6892 2741
a72d2509
MM
2742 * device.c (device_tree_add_parsed): Use the interrupt conversion
2743 functions to determine the interrupt port numbers.
cb7a6892 2744
a72d2509
MM
2745 * device_table.h: Add table that maps between an interrupts
2746 symbolic name and its port number.
cb7a6892 2747
a72d2509
MM
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.
cb7a6892 2751
a72d2509 2752Sun Mar 3 03:23:59 1996 Andrew Cagney <[email protected]>
cb7a6892 2753
a72d2509
MM
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.
cb7a6892 2758
a72d2509
MM
2759 * device.h, device.c: Re-order declaration and definition of
2760 property functions.
cb7a6892 2761
a72d2509 2762Sun Mar 3 03:10:22 1996 Andrew Cagney <[email protected]>
cb7a6892 2763
a72d2509
MM
2764 * device.c (device_tree_print_device, device_tree_add_parsed):
2765 Remove references to phandle properties.
cb7a6892 2766
8477437c
MM
2767Wed Feb 28 00:43:07 1996 Andrew Cagney - aka Noid <[email protected]>
2768
2769 * Makefile.in (corefile.o): missing dependency on device_table.h
2770 etc.
2771
a72d2509 2772Tue Feb 27 23:59:35 1996 Andrew Cagney - aka Noid <[email protected]>
cb7a6892 2773
a72d2509
MM
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.
cb7a6892 2781
a72d2509
MM
2782 * (io): ditto.
2783 * (dma): ditto.
2784 * (device_instance): ditto.
2785 * (ioctl): ditto.
2786 * (address nee config_address): ditto.
2787 * (interrupt): ditto.
cb7a6892 2788
8477437c
MM
2789Mon Feb 26 21:11:20 1996 Andrew Cagney - aka Noid <[email protected]>
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
a72d2509 2796Mon Feb 26 22:47:15 1996 Andrew Cagney - aka Noid <[email protected]>
cb7a6892 2797
a72d2509
MM
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.
cb7a6892 2802
a72d2509
MM
2803 * Makefile.in (device_table.o): now depends on hw.c a generated
2804 table of hw.
cb7a6892 2805
a72d2509
MM
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.
cb7a6892 2809
a72d2509
MM
2810 * device.c (device_template_create_device): Handle new two level
2811 device lookup table.
2812 * device.c (device_usage): ditto.
cb7a6892 2813
a72d2509 2814Mon Feb 26 22:24:00 1996 Andrew Cagney - aka Noid <[email protected]>
cb7a6892 2815
a72d2509 2816 * device_table.c: Delete the memory device (moved to hw_memory.c).
cb7a6892 2817
a72d2509 2818 * hw_memory.c: New file. Just an OpenBoot memory device.
8477437c
MM
2819
2820Wed Jan 17 21:47:34 1996 Andrew Cagney <[email protected]>
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
2833Wed Jan 17 21:43:09 1996 Andrew Cagney <[email protected]>
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
2843Wed Jan 17 21:24:50 1996 Andrew Cagney <[email protected]>
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
2857Wed Jan 17 21:18:27 1996 Andrew Cagney <[email protected]>
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
2879Wed Jan 17 20:07:15 1996 Andrew Cagney <[email protected]>
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
2898Wed Jan 17 19:51:56 1996 Andrew Cagney <[email protected]>
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
2934Wed Jan 17 19:46:07 1996 Andrew Cagney <[email protected]>
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
2953Wed Jan 17 19:36:52 1996 Andrew Cagney <[email protected]>
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
2966Wed Jan 17 18:36:09 1996 Andrew Cagney <[email protected]>
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
2994Wed Jan 17 18:18:40 1996 Andrew Cagney <[email protected]>
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
3016Sat Jan 6 10:13:26 1996 Andrew Cagney - aka Noid <[email protected]>
3017
3018 * emul_chirp.c (map_over_chirp_note): Tighten up (and fix) checks
3019 on OpenBoot note section.
3020
3021Fri Jan 5 20:28:53 1996 Andrew Cagney <[email protected]>
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
3032Fri Jan 5 18:55:34 1996 Andrew Cagney <[email protected]>
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
3044Fri Jan 5 18:52:28 1996 Andrew Cagney <[email protected]>
3045
3046 * Makefile.in (maintainer-clean): Remove .log, core and *.core
3047 (From NetBSD) files.
3048
3049Wed May 29 22:57:40 1996 Andrew Cagney <[email protected]>
3050
3051 * ChangeLog.00, ChangeLog: ChangeLog from gdb-4.16 becomes
3052 ChangeLog.00
3053
This page took 0.538253 seconds and 4 git commands to generate.