2003-06-27 Michael Snyder <msnyder@redhat.com>
[deliverable/binutils-gdb.git] / sim / sh / ChangeLog
CommitLineData
e53a5a69
MS
12003-07-03 Michael Snyder <msnyder@redhat.com>
2
3 * gencode.c (movs): Fix a couple of text transpositions.
4
15dee5d5
MS
52003-06-27 Michael Snyder <msnyder@redhat.com>
6
b939d772
MS
7 * gencode.c (op tab): Some fix-ups of refs and defs.
8 (ocbi, ocbp): Cache not simulated, but may cause memory fault.
9 (gensym_caselist): Add default case to switch statement.
10 (expand_ppi_code): Add default case to switch statement.
d2f18ae4 11 * gencode.c (op tab): Implement movca.l.
9e1d0fc1 12 * gencode.c (op movsxy_tab): Fix an error in the bit pattern.
15dee5d5
MS
13 * gencode.c (gensim_caselist): The movy instructions use
14 registers R6 and R7 (not R4 and R5 like the movx insns).
15
8dc30ef7
MS
162003-06-27 Michael Snyder <msnyder@redhat.com>
17
0b282859
MS
18 * gencode.c (op movsxy_tab): Fix up some copy/paste errors
19 in name: s/REG_x/REG_y/.
20
8dc30ef7
MS
21 * gencode.c (op tab): Move misplaced semicolon.
22
6b4a8935
AC
232003-02-27 Andrew Cagney <cagney@redhat.com>
24
25 * interp.c (init_dsp, sim_open, sim_create_inferior): Rename _bfd
26 to bfd.
27
fd8f4948
JR
28Fri Oct 11 16:22:28 2002 J"orn Rennecke <joern.rennecke@superh.com>
29
30 * interp.c (trap): Return int. Take extra parameter for address
31 of the trap instruction. Changed all callers.
32 Add case 33 for profiling.
33 * gencode.c (trapa): Handle trap 33 using the trap function.
34 Add read of vector for generic traps.
35
2f14585c
JR
36Wed Jul 17 19:36:38 2002 J"orn Rennecke <joern.rennecke@superh.com>
37
38 * Makefile.in (interp.o): Depend on $(srcroot)/include/gdb/sim-sh.h.
39 * interp.c: Include "gdb/sim-sh.h".
40 (sim_store_register, sim_fetch_register): Use constants defined there.
41
dc9feb5c
JR
42Tue Jun 18 16:53:11 2002 J"orn Rennecke <joern.rennecke@superh.com>
43
44 * interp.c (sim_resume): Fix setting of bus error for
45 instruction fetch.
46
c8cca39f
AC
472002-06-16 Andrew Cagney <ac131313@redhat.com>
48
49 * configure: Regenerated to track ../common/aclocal.m4 changes.
50
3c25f8c7
AC
512002-06-08 Andrew Cagney <cagney@redhat.com>
52
53 * interp.c: Include "gdb/callback.h" and "gdb/remote-sim.h".
54
de0492b6
AO
552001-01-30 Ben Elliston <bje@redhat.com>
56
57 * interp.c (sim_create_inferior): Record program arguments for
58 later inspection by the trap handler.
59 (count_argc): New function.
60 (prog_argv): Declare static.
61 (sim_write): Declare.
62 (trap): Implement argc, argnlen and argn system calls. Do not
63 abort on unknown system calls--simply return -1.
64 * syscall.h (SYS_argc, SYS_argnlen, SYS_argn): Define.
65
55406459
AO
662001-01-24 Alexandre Oliva <aoliva@redhat.com>
67
68 * interp.c (trap): Implement time.
69
8f1e3ff5
BE
702000-10-24 Ben Elliston <bje@redhat.com>
71
72 * gencode.c (tab): Delimit strings with commas where applicable.
73
eb2d80b4
AC
74Tue May 23 21:39:23 2000 Andrew Cagney <cagney@b1.cygnus.com>
75
76 * configure: Regenerated to track ../common/aclocal.m4 changes.
77
63978407
JR
78Mon May 15 22:04:51 2000 J"orn Rennecke <amylaar@cygnus.co.uk>
79
80sh-dsp support, simulator speedup by using host byte order:
81
82 * Makefile.in (interp.o): Depends on ppi.c .
83 (ppi.c): New rule.
84 * gencode.c (printonmatch, think, genopc): Deleted.
85 (MAX_NR_STUFF): Now 42.
86 (tab): Add SH-DSP CPU instructions.
87 Amalgamate ldc / stc / lds / sts instructions with similar
88 bit patterns. Fix opcodes of stc Rm_BANK,@-<REG_N>.
89 Fix semantics of lds.l @<REG_N>+,MACH (no sign extend).
90 (movsxy_tab): New array.
91 For movs, change MMMM field to GGGG, and mmmm field to MMMM.
92 Added entries for movx, movy and parallel processing insns.
93 (ppi_tab): New array.
94 (qfunc): Stabilize sort.
95 (expand_opcode): Handle [01][01]NN, [01][01]xx and [01][01]yy.
96 Handle 'M', 'G' 's' 'X', 'a', 'Y' and 'A'.
97 (dumptable): Now takes three arguments. Changed all callers.
98 Emit just one contigous jump table.
99 (filltable): Now takes an argument. Changed all callers.
100 Make index static.
101 (ppi_moves, expand_ppi_code, ppi_filltable, ppi_gensim): New functions.
102 (gensim_caselist): New function, broken out of gensim.
103 Handle opcode fields 'x', 'y', 's', 'M', 'G', 'X', 'a', and 'Y'.
104 Handle ref '9'.
105 (gensim): Handle 'N' in code field and '8' in refs field.
106 Call gensim_caselist - twice.
107 (ppi_index): New static variable.
108 (main): Unsupport default action.
109 Add dsp support for -x / -s option. Add -p option.
110 * interp.c (sh_jump_table, sh_dsp_table, ppi_table): Declare.
111 (saved_state_type): Rearrange to allow amalgamated ldc / stc /
112 lds / sts to work efficiently.
113 (target_dsp): New static variable.
114 (GBR, VBR, SSR, SPC, MACH, MACL): Reflect saved_state_type change.
115 (FPUL, Rn_BANK, SET_Rn_BANK, M, Q, S, T, SR_BL, SR_RB): Likewise.
116 (SR_MD, SR_RC, SET_SR_BIT, GET_SR, SET_RC, GET_FPSCR): Likewise.
117 (RS, RE, MOD, MOD_ME, DSP_R): Likewise.
118 (set_fpscr1): Likewise. Use target_dsp to check for dsp.
119 (MOD_MSi, SIG_BUS_FETCH): Deleted.
120 (CREG, SREG, PR, SR_MASK_DMY, SR_MASK_DMX, SR_DMY): New macros.
121 (SR_DMX, DSR, MOD_DELTA, GET_DSP_GRD): Likewise.
122 (SET_MOD): Reflect saved_state_type change. Set MOD_DELTA instead
123 of MOD_MS, and encode SR_DMY / SR_DMX into high word of MOD_ME.
124 (set_sr): Reflect saved_state_type change. Fix SR_RB handling.
125 Use SET_MOD.
126 (MA, L, TL, TB): Now controlled by ACE_FAST.
127 (SEXT32): Just cast to int.
128 (SIGN32): Fixed to only shift by 31.
129 (CHECK_INSN_PTR): SIGBUS at insn fetch now represented by insn_end 0.
130 (ppi_insn): Declare.
131 (ppi.c): Include.
132 (init_dsp): Set target_dsp. When it changes, switch end of
133 sh_jump_table with sh_dsp_table.
134 (sim_resume) Don't declare sh_jump_table0. Use sh_jump_table instead.
135 Don't Declare PR if it's #defined.
136 Fix single-stepping (Was broken in Mar 6 16:59:10 patch).
137 (sim_store_register, sim_read_register): Translate accesses to
138 reflect saved_state_type change.
139
140 * interp.c (set_sr): Set sr.
141 (SET_RC, MOD, MOD_MS, MOD_ME, SET_MOD, MOD_MS, MOD_ME): New macros.
142 (set_fpscr1): Don't bank-switch fpu registers when simulating sh-dsp.
143 (DSP_R): Fix definition.
144 (sim_resume): Remove outdated SET_SR use.
145
146 * interp.c (saved_state): New members for struct member asregs:
147 rs, re, insn_end, xram_start, yram_start.
148 (struct loop_bounds): New struct.
149 (SKIP_INSN): New macro.
150 (get_loop_bounds): New function.
151 (endianw): Renamed to global_endianw.
152 (maskw): negated bits.
153 (PC): Now insn_ptr.
154 (SR_MASK_RC, SR_RC_INCREMENT, SR_RC, RAISE_EXCEPTION): New macros.
155 (RS, RE, DSP_R, DSP_GRD, A1, A0, X0, X1, Y0, Y1, M0, A1G): Likewise.
156 (M1, A0G, RIAT, PT2H, PH2T, SET_NIP, CHECK_INSN_PTR): Likewise.
157 (SIG_BUS_FETCH): Likewise
158 (raise_exception, riat_fast): New functions.
159 (raise_buserror, sim_stop): Use raise_exception.
160 (PROCESS_SPECIAL_ADDRESS): Use xram_start / yram_start.
161 (BUSERROR, WRITE_BUSERROR, READ_BUSERROR):
162 Reverse sense of mask argument.
163 (FP_OP, set_dr): Use RAISE_EXCEPTION.
164 (wlat_fast, wwat_fast, wbat_fast, rlat_fast, rwat_fast, rbat_fast):
165 Declare. Remove redundant masking.
166 (wwat_fast, rwat_fast): Add argument endianw. Changed callers.
167 (MA): Updated for change pc -> PC.
168 (Delay_Slot): Use RIAT.
169 (empty): Deleted.
170 (trap): Remove argument little_endian. Add argument endianw.
171 Changed all callers. Use raise_exception.
172 (macw): Add argument endainw. Changed all callers.
173 (init_dsp): New function, extended after broken out of init_pointers.
174 (sim_resume): Replace pc with insn_ptr. Replace little_endian with
175 endianw. Replace nia with nip. Reverse sense of maskb / maskw /
176 maskl. Implement logic for zero-overhead loops. Don't try to
177 interpret garbage when getting a SIGBUS at insn fetch.
178 (sim_open): Call init_dsp.
179 * gencode.c (tab): Use SET_NIP instead of nia = . Use PH2T / PT2H /
180 RAISE_EXCEPTION where appropriate.
181 Add extra cycles for brai, braf , bsr, bsrf, jmp, jsr.
182
183 * interp.c (sim_store_register, sim_fetch_register):
184 Do proper endianness switch.
185
186 * interp.c (saved_state_type): New members for struct member asregs:
187 xymem_select, xmem, ymem, xmem_offset, ymem_offset.
188 (special_address): Delete.
189 (BUSERROR): Now a two-argument predicate.
190 (PROCESS_SPECIAL_ADDRESS, WRITE_BUSERROR, READ_BUSERROR): New macros.
191 (wlat_little, wwat_little, wbat_any, wlat_big, wwat_big): Delete.
192 (process_wlat_addr, process_wwat_addr): New functions.
193 (process_wbat_addr, process_rlat_addr, process_rwat_addr): Likewise.
194 (process_rbat_addr): Likewise.
195 (wlat_fast, wwat_fast, wbat_fast): Use WRITE_BUSERROR.
196 (rlat_little, rwat_little, rbat_any, rlat_big, rwat_big): Delete.
197 (rlat_fast, rwat_fast, rbat_fast): Use READ_BUSERROR.
198 (RWAT, RLAT, RBAT, WWAT, WLAT, WBAT): Delete SLOW versions.
199 (do_rdat, trap): Delete SLOW code.
200 (SEXT32, SIGN32): New macros.
201 (swap, swap16): Now integer in - integer out. Changed all callers.
202 (strswaplen, strnswap): Delete SLOW versions.
203 (init_pointers): Initialize dsp memory selection (preliminary).
204 (sim_store_register, sim_fetch_register): Use swap instead of
205 big / little endian read / write functions.
206
207 * interp.c (maskl): Deleted.
208 (endianw, endianb): New variables.
209 (special_address): Now inline.
210 (bp_holder): Put raising of buserror there, rename to:
211 (raise_buserror).
212 (BUSERROR): Now yields a value. Changed all users.
213 (wbat_big): Delete.
214 (wlat_fast, wwat_fast, wbat_fast): New functions.
215 (rlat_fast, rwat_fast, rbat_fast): Likewise.
216 (RWAT, RLAT, RBAT, WWAT, WLAT, WBAT): Use new functions.
217 (do_rdat, do_wdat): Likewise. Take maskl argument instead of
218 little_endian one. Changed caller macros.
219 (swap, swap16): Use w[rw]lat_big / w[rw]lat_little directly.
220 (strswaplen, strnswap): New functions.
221 (trap): Use them to fix up endian mismatches;
222 disable SYS_execve and SYS_execv; fix double address translation for
223 SYS_pipe and SYS_stat.
224 (sym_write, sym_read): Add endianness translation.
225 (sym_store_register, sym_fetch_register): Add maskl local variable.
226 (sim_open): Set endianw and endianb.
227
d4f3574e
SS
228Thu Sep 2 18:15:53 1999 Andrew Cagney <cagney@b1.cygnus.com>
229
230 * configure: Regenerated to track ../common/aclocal.m4 changes.
231
104c1213
JM
232Wed Aug 25 07:55:23 1999 Brendan Kehoe <brendan@cygnus.com>
233
234 * gencode.c (fcnvds <DR_N>,FPUL): Rewrite to use a local anonymous
235 union type, instead of casting to an int* then a float*.
236 (fcnvsd FPUL,<DR_N>): Likewise.
237 (flds <FREG_N>,FPUL): Likewise.
238 (fsts FPUL,<FREG_N>): Likewise.
239
cd0fc7c3
SS
2401999-05-08 Felix Lee <flee@cygnus.com>
241
242 * configure: Regenerated to track ../common/aclocal.m4 changes.
243
7a292a7a
SS
2441999-04-02 Keith Seitz <keiths@cygnus.com>
245
246 * interp.c (POLL_QUIT_INTERVAL): Define. Used to tweak the
247 frequency at which the poll_quit callback is called.
248 (sim_resume): Use POLL_QUIT_INTERVAL instead of a
249 hard-coded value.
250
c906108c
SS
251Thu Sep 10 02:16:39 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
252
253 * interp.c (saved_state.asregs): Add new member pad_dummy.
254 (sim_store_register, sim_fetch_regsiter): Add 1 to rn for use
255 as index into saved_state.asints.
256
257Mon Jun 29 19:35:24 1998 Jason Molenda (crash@bugshack.cygnus.com)
258
259 * interp.c (sim_open): set endianness based on the ABFD if a -E
260 option is not present and we have an ABFD.
261
262Tue Apr 28 18:33:31 1998 Geoffrey Noer <noer@cygnus.com>
263
264 * configure: Regenerated to track ../common/aclocal.m4 changes.
265
266Sun Apr 26 15:31:55 1998 Tom Tromey <tromey@creche>
267
268 * configure: Regenerated to track ../common/aclocal.m4 changes.
269 * config.in: Ditto.
270
271Sun Apr 26 15:19:48 1998 Tom Tromey <tromey@cygnus.com>
272
273 * acconfig.h: New file.
274 * configure.in: Reverted change of Apr 24; use sinclude again.
275
276Fri Apr 24 14:16:40 1998 Tom Tromey <tromey@creche>
277
278 * configure: Regenerated to track ../common/aclocal.m4 changes.
279 * config.in: Ditto.
280
281Fri Apr 24 11:18:35 1998 Tom Tromey <tromey@cygnus.com>
282
283 * configure.in: Don't call sinclude.
284
285Sat Apr 4 20:36:25 1998 Andrew Cagney <cagney@b1.cygnus.com>
286
287 * configure: Regenerated to track ../common/aclocal.m4 changes.
288
289Fri Mar 27 16:15:52 1998 Andrew Cagney <cagney@b1.cygnus.com>
290
291 * configure: Regenerated to track ../common/aclocal.m4 changes.
292
293Wed Mar 25 12:35:29 1998 Andrew Cagney <cagney@b1.cygnus.com>
294
295 * configure: Regenerated to track ../common/aclocal.m4 changes.
296
297Wed Mar 18 12:38:12 1998 Andrew Cagney <cagney@b1.cygnus.com>
298
299 * configure: Regenerated to track ../common/aclocal.m4 changes.
300
301Tue Feb 17 12:49:44 1998 Andrew Cagney <cagney@b1.cygnus.com>
302
303 * interp.c (sim_fetch_register, sim_store_register): Pass in
304 length parameter. Return -1.
305
306Sun Feb 1 16:47:51 1998 Andrew Cagney <cagney@b1.cygnus.com>
307
308 * configure: Regenerated to track ../common/aclocal.m4 changes.
309
310Sat Jan 31 18:15:41 1998 Andrew Cagney <cagney@b1.cygnus.com>
311
312 * configure: Regenerated to track ../common/aclocal.m4 changes.
313
314Mon Jan 19 22:26:29 1998 Doug Evans <devans@seba>
315
316 * configure: Regenerated to track ../common/aclocal.m4 changes.
317
318Mon Dec 15 23:17:11 1997 Andrew Cagney <cagney@b1.cygnus.com>
319
320 * configure: Regenerated to track ../common/aclocal.m4 changes.
321 * config.in: Ditto.
322
323Thu Dec 4 09:21:05 1997 Doug Evans <devans@canuck.cygnus.com>
324
325 * configure: Regenerated to track ../common/aclocal.m4 changes.
326
327Wed Oct 22 14:43:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
328
329 * interp.c (sim_load): Pass lma_p and sim_write args to
330 sim_load_file.
331
332Fri Oct 3 09:28:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
333
334 * configure: Regenerated to track ../common/aclocal.m4 changes.
335
336Wed Sep 24 17:38:57 1997 Andrew Cagney <cagney@b1.cygnus.com>
337
338 * configure: Regenerated to track ../common/aclocal.m4 changes.
339
340Tue Sep 23 11:04:38 1997 Andrew Cagney <cagney@b1.cygnus.com>
341
342 * configure: Regenerated to track ../common/aclocal.m4 changes.
343
344Mon Sep 22 11:46:20 1997 Andrew Cagney <cagney@b1.cygnus.com>
345
346 * configure: Regenerated to track ../common/aclocal.m4 changes.
347
348Fri Sep 19 17:45:25 1997 Andrew Cagney <cagney@b1.cygnus.com>
349
350 * configure: Regenerated to track ../common/aclocal.m4 changes.
351
352Mon Sep 15 17:36:15 1997 Andrew Cagney <cagney@b1.cygnus.com>
353
354 * configure: Regenerated to track ../common/aclocal.m4 changes.
355
356Tue Sep 9 20:52:21 1997 Felix Lee <flee@cygnus.com>
357
358 * interp.c (sim_resume): poll_quit() at least once per call;
359 otherwise gdb can loop sim_resume() uninterruptably.
360
361Thu Sep 4 17:21:23 1997 Doug Evans <dje@seba>
362
363 * configure: Regenerated to track ../common/aclocal.m4 changes.
364
365Tue Sep 2 13:15:27 1997 Andrew Cagney <cagney@b1.cygnus.com>
366
367 * gencode.c (tab): Order instructions according to SH3 document.
368
369Wed Aug 27 18:13:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
370
371 * configure: Regenerated to track ../common/aclocal.m4 changes.
372 * config.in: Ditto.
373
374Tue Aug 26 10:41:55 1997 Andrew Cagney <cagney@b1.cygnus.com>
375
376 * interp.c (sim_kill): Delete.
377 (sim_create_inferior): Add ABFD argument.
378 (sim_load): Move setting of PC from here.
379 (sim_create_inferior): To here.
380
381Mon Aug 25 17:50:22 1997 Andrew Cagney <cagney@b1.cygnus.com>
382
383 * configure: Regenerated to track ../common/aclocal.m4 changes.
384 * config.in: Ditto.
385
386Mon Aug 25 16:17:51 1997 Andrew Cagney <cagney@b1.cygnus.com>
387
388 * interp.c (sim_open): Add ABFD argument.
389
390Mon Jun 23 15:49:14 1997 Andrew Cagney <cagney@b1.cygnus.com>
391
392 * interp.c (get_dr): Avoid SIGFPE by moving integers instead of
393 FP's around.
394 (set_dr): Ditto.
395
7a292a7a
SS
396Mon Jun 23 15:02:40 1997 Andrew Cagney <cagney@b1.cygnus.com>
397
398 * interp.c (XD, SET_XD): Delete.
399 (XF, SET_XF, XD_TO_XF): Define, move around registers in either
400 FP bank.
401
402 * gencode.c (fmov): Update.
403
c906108c
SS
404Sun Jun 22 19:33:33 1997 Andrew Cagney <cagney@b1.cygnus.com>
405
406 * interp.c (set_fpscr1): From J"orn Rennecke
407 <amylaar@cygnus.co.uk>, Fix typo. Ditto for comment.
408
7a292a7a
SS
409Tue Aug 12 00:19:11 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
410
411 * interp.c (special_address): New function.
412 (BUSERROR): Call it. Added parameters bits_written and data.
413 Changed all callers.
414 * gencode.c (tab): Fixed ocbwb and pref.
415
416Fri Jun 20 22:03:18 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
417
418 * interp.c (do_wdat, do_wdat): Fix bug in register number calculation.
419
c906108c
SS
420Thu Jun 19 00:28:08 1997 Andrew Cagney <cagney@b1.cygnus.com>
421
422 * interp.c (sim_create_inferior): Clear registers each time an
423 inferior is started.
424
7a292a7a
SS
425Mon Jun 16 14:01:55 1997 Andrew Cagney <cagney@b1.cygnus.com>
426
427 * interp.c (*FP, FP_OP, FP_CMP, FP_UNARY): Provide a hook for
428 when a host doesn't support IEEE FP.
429 (*DP): Provide alternative definition that supports 64bit floating
430 point.
431 (target_little_endian): Combine little_endian and little_endian_p.
432 (saved_state_type): Make fpscr and sr simple integers.
433 (SET_FPSCR, GET_FPSCR): Use macros to update fpscr register.
434 (set_fpscr1): New function. Handle swapping when PR / FR bits
435 changed. Call via *_FPSCR macro.
436 (SET_SR*, GET_SR*): Use macro's to access the SR bits - avoids
437 endian problems.
438
439 * gencode.c (tab): Update.
440
c906108c
SS
441Sun Jun 15 15:22:52 1997 Andrew Cagney <cagney@b1.cygnus.com>
442
443 * gencode.c (main): Perform basic checks on tab entries.
444
445 * Makefile.in (gencode): Always compile with -g.
446
447Sat Jun 14 13:45:09 1997 Andrew Cagney <cagney@b1.cygnus.com>
448
449 * gencode.c (gensim): Move ref checking code to before `stuff'.
450 For branches with delay slots refs were not being checked.
451
452 * interp.c (sim_resume): Use nia to specify the next instruction
453 address instead of overloading pc.
454 (C): Delete definiton - refer to cycles directly.
455 (SEXT12): New macro - sign extend a 12 bit quantity.
456 (Delay_Slot): Rename from SL.
457
458 * gencode.c (tab): Update/simplify.
459
460 * gencode.c (gensim): Better formatting of output code.
461 (gensim): Replace 10 with constant MAX_NR_STUFF- define as 15.
462 (tab): Sort alphabetically. Break `stuff' into multiple lines.
463
464Fri Jun 13 22:10:13 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
465
466 * gencode.c (braf, bsrf): Fix branch destination calculation to
467 be in accordance with the documentation.
468
469Fri Jun 13 15:33:53 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
470
471 * interp.c (init_pointers): Fix little endian test.
472
7a292a7a
SS
473Thu Jun 5 12:56:08 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
474
475 * interp.c (init_pointers): SH4 hardware is always WORDS_BIT_ENDIAN.
476 * gencode (fmov from/to memory): take endian_mismatch into account
477 for 32 bit moves too.
478
c906108c
SS
479Wed May 28 23:42:35 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
480
481 * gencode.c (swap.b): Fix treatment of high word.
482
7a292a7a
SS
483Wed May 28 23:42:35 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
484
485 * sh/gencode.c,
486 * interp.c: experimental SH4 support.
487 DFmode moves are probaly broken for target little endian.
488
c906108c
SS
489Tue May 20 10:23:28 1997 Andrew Cagney <cagney@b1.cygnus.com>
490
491 * interp.c (sim_open): Add callback argument.
492 (sim_set_callbacks): Delete SIM_DESC argument.
493
494Wed Apr 30 11:38:08 1997 Doug Evans <dje@canuck.cygnus.com>
495
496 * Makefile.in (SIM_EXTRA_CLEAN): Define.
497 (clean targets): Delete.
498 (sh-clean): New target.
499
500Thu Apr 24 00:39:51 1997 Doug Evans <dje@canuck.cygnus.com>
501
502 * configure: Regenerated to track ../common/aclocal.m4 changes.
503
504Wed Apr 23 17:55:22 1997 Doug Evans <dje@canuck.cygnus.com>
505
506 * tconfig.in: New file.
507 * interp.c (sim_open): Handle missing arg to -E.
508
509Tue Apr 22 08:55:35 1997 Stu Grossman (grossman@critters.cygnus.com)
510
511 * Makefile.in: Add clean targets.
512
513Fri Apr 18 18:57:04 1997 Stu Grossman (grossman@critters.cygnus.com)
514
515 * interp.c: Include float.h and define SIGTRAP if _WIN32.
516 WIN32 -> _WIN32.
517 * (trap): Do do SYS_chown for _WIN32.
518
519Fri Apr 18 13:33:09 1997 Doug Evans <dje@canuck.cygnus.com>
520
521 * interp.c (sim_resume): Fix argument to poll_quit.
522
523Fri Apr 18 14:14:49 1997 Andrew Cagney <cagney@b1.cygnus.com>
524
525 * interp.c (sim_stop): New function.
526 (sim_resume): Use poll_quit for polling.
527
528Thu Apr 17 03:32:04 1997 Doug Evans <dje@canuck.cygnus.com>
529
530 * Makefile.in (SIM_OBJS): Add sim-load.o.
531 * interp.c (target_byte_order): Delete.
532 (sim_kind, myname, little_endian_p): New static locals.
533 (init_pointers): Use little_endian_p instead of target_byte_order.
534 (sim_resume): Likewise.
535 (sim_open): Set sim_kind, myname. Set little_endian_p from -E arg.
536 (sim_load): Return SIM_RC. New arg abfd. Call sim_load_file to
537 load file into simulator. Set start address from bfd.
538 (sim_create_inferior): Return SIM_RC. Delete arg start_address.
539
540Mon Apr 7 15:45:02 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
541
542 * configure: Regenerated to track ../common/aclocal.m4 changes.
543 * config.in: Ditto.
544
545Wed Apr 2 15:06:28 1997 Doug Evans <dje@canuck.cygnus.com>
546
547 * interp.c (sim_open): New arg `kind'.
548
549 * configure: Regenerated to track ../common/aclocal.m4 changes.
550
551Wed Apr 2 14:34:19 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
552
553 * configure: Regenerated to track ../common/aclocal.m4 changes.
554
555Wed Mar 19 09:34:36 1997 Fred Fish <fnf@cygnus.com>
556
557 * interp.c (sim_do_command): Check for NULL command or empty
558 string and handle it the same as a "help" command. Use callback
559 to print error message for unrecognized commands. Replace
560 hardcoded tab in literal string with a \t. Other minor code
561 cleanup.
562
563Wed Mar 19 01:14:00 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
564
565 * configure: Regenerated to track ../common/aclocal.m4 changes.
566
567Mon Mar 17 15:10:07 1997 Andrew Cagney <cagney@kremvax.cygnus.com>
568
569 * configure: Re-generate.
570
571Fri Mar 14 10:34:11 1997 Michael Meissner <meissner@cygnus.com>
572
573 * configure: Regenerate to track ../common/aclocal.m4 changes.
574
575Thu Mar 13 13:00:00 1997 Doug Evans <dje@canuck.cygnus.com>
576
577 * interp.c (sim_open): New SIM_DESC result. Argument is now
578 in argv form.
579 (other sim_*): New SIM_DESC argument.
580
581Tue Feb 4 13:33:30 1997 Doug Evans <dje@canuck.cygnus.com>
582
583 * Makefile.in (@COMMON_MAKEFILE_FRAG): Use
584 COMMON_{PRE,POST}_CONFIG_FRAG instead.
585 * configure.in: sinclude ../common/aclocal.m4.
586 * configure: Regenerated.
587
588Thu Jan 23 11:46:23 1997 Stu Grossman (grossman@critters.cygnus.com)
589
590 * configure configure.in Makefile.in: Update to new configure
591 scheme which is more compatible with WinGDB builds.
592 * configure.in: Improve comment on how to run autoconf.
593 * configure: Re-run autoconf to get new ../common/aclocal.m4.
594 * Makefile.in: Use autoconf substitution to install common
595 makefile fragment.
596
597Wed Nov 20 02:04:32 1996 Doug Evans <dje@canuck.cygnus.com>
598
599 * Makefile.in: Delete stuff moved to ../common/Make-common.in.
600 (SIM_OBJS,SIM_EXTRA_LIBS): Define.
601 * configure.in: Simplify using macros in ../common/aclocal.m4.
602 Call AC_CHECK_HEADERS(unistd.h).
603 * configure: Regenerated.
604 * config.in: New file.
605 * interp.c: #include "config.h". #include <unistd.h> if present.
606 (trap): Fetch errno value with callback->get_errno.
607
608Tue Nov 12 13:34:00 1996 Dawn Perchik <dawn@cygnus.com>
609
610 * interp.c: Don't include windows polling code if inside simluator.
611
612Fri Sep 20 14:57:50 1996 Stan Shebs <shebs@andros.cygnus.com>
613
614 * interp.c: Minor formatting improvements.
615 (saved_state_type): Add bank registers.
616 (bp_holder): New function, use to break on when debugging BUSERROR.
617 (BUSERROR): Call it if bus error occurs.
618
619Wed Jun 26 12:29:22 1996 Jason Molenda (crash@godzilla.cygnus.co.jp)
620
621 * Makefile.in (bindir, libdir, datadir, mandir, infodir, includedir,
622 INSTALL_PROGRAM, INSTALL_DATA): Use autoconf-set values.
623 (docdir): Removed.
624 * configure.in (AC_PREREQ): autoconf 2.5 or higher.
625 (AC_PROG_INSTALL): Added.
626 * configure: Rebuilt.
627
628Thu May 16 15:44:29 1996 Ian Lance Taylor <ian@cygnus.com>
629
630 * interp.c (saved_state_type): Add memstalls field.
631 (MA) Define macro.
632 (sim_resume): New local variable memstalls. Add it back in to
633 saved_state at the end of the function.
634 (sim_info): Report memstalls.
635 * gencode.c (tab): Add MA() to the execution string of all
636 instructions which access memory.
637
638Wed Feb 21 12:16:41 1996 Ian Lance Taylor <ian@cygnus.com>
639
640 * configure: Regenerate with autoconf 2.7.
641
642Tue Dec 5 16:38:55 1995 Stu Grossman (grossman@cygnus.com)
643
644 * gencode.c (mac.l): Don't abort GDB if executing mac.l
645 instruction (which is unimplemented). Generate a SIGTRAP (in the
646 simulated target) instead.
647
648Mon Dec 4 12:22:24 1995 J.T. Conklin <jtc@rtl.cygnus.com>
649
650 * gencode.c (tab): Added several sh3 opcodes.
651 (think): Added printonmatch for A_SSR and A_SPC.
652 * interp.c (SSR, SPC): Added definitions.
653 (saved_state_type): Added ssr and spc registers.
654
655Wed Nov 29 12:39:27 1995 Jim Wilson <wilson@chestnut.cygnus.com>
656
657 * gencode.c (tab): In shad/shld definitions, negate R[m] before
658 the and operation instead of after. For shad delete cast. For shld
659 use UR instead of R and delete cast.
660
661Fri Nov 17 12:48:55 1995 Jim Wilson <wilson@chestnut.cygnus.com>
662
663 * gencode.c (tab): Add explicit NaN support for ftrc instruction.
664
665Wed Nov 15 11:25:27 1995 Stu Grossman (grossman@cygnus.com)
666
667 * interp.c: Make target_byte_order be extern to prevent SGI cc from
668 issuing warnings about the use of common symbols.
669
670Tue Nov 14 15:19:43 1995 Stu Grossman (grossman@cygnus.com)
671
672 * gencode.c: jsr, bsr and bsrf actually save pc+4 in pr, and rts
673 actually uses pr+0.
674
675Sat Oct 21 13:01:18 1995 Jim Wilson <wilson@chestnut.cygnus.com>
676
677 * sh/interp.c (sim_stop_reason): Catch SIGQUIT and indicate
678 program exited.
679 (sim_get_quit_code): Delete.
680
681 * gencode.c (gensim): Indicate SIGILL instead of calling abort for
682 default case.
683
684Mon Oct 16 18:24:03 1995 Jim Wilson <wilson@chestnut.cygnus.com>
685
686 * interp.c (saved_state_type): Move FP registers to immediately
687 after SR.
688
689Tue Oct 10 11:12:15 1995 Fred Fish <fnf@cygnus.com>
690
691 * Makefile.in (BISON): Remove macro.
692
693Fri Oct 6 12:08:18 1995 Jim Wilson <wilson@chestnut.cygnus.com>
694
695 * interp.c (trap, case SYS_utime): Cast second arg of utime to
696 void * to avoid compiler error.
697
698 * interp.c (callback): Remove last change. It is initialized by
699 a sim_set_callbacks call.
700
701Thu Oct 5 14:13:29 1995 steve chamberlain <sac@slash.cygnus.com>
702
703 * interp.c (callback): Initialize to default callback.
704
705Thu Sep 28 15:26:59 1995 steve chamberlain <sac@slash.cygnus.com>
706
707 * run.c: Moved to ../common.
708 * interp.c (trap): Use gdb's callback interface.
709 * Makefile.in: Updated.
710
711Wed Sep 20 13:35:13 1995 Ian Lance Taylor <ian@cygnus.com>
712
713 * Makefile.in (maintainer-clean): New synonym for realclean.
714
715Wed Sep 20 09:51:50 1995 steve chamberlain <sac@slash.cygnus.com>
716
717 * run.c (sim_callback_write_stdout): New.
718 * interp.c (trap): Call sim_callback_write_stdout when needed.
719
720Mon Sep 18 18:42:27 1995 steve chamberlain <sac@slash.cygnus.com>
721
722 * interp.c (trap): Remove useless code.
723
724Fri Sep 15 19:30:05 1995 steve chamberlain <sac@slash.cygnus.com>
725
726 * syscall.h: Copy from newlib.
727
728Thu Sep 14 19:32:59 1995 Stu Grossman (grossman@cygnus.com)
729
730 * gencode.c: Back up PC by 2 for breakpoints.
731 * interp.c: Move fp regs beyond pc/pr/etc to avoid confusing GDB,
732 which expect pc to immediatly follow regs[].
733
734Fri Sep 8 14:18:13 1995 Ian Lance Taylor <ian@cygnus.com>
735
736 * configure.in: Define CC_FOR_BUILD. Don't call AC_PROG_INSTALL.
737 * configure: Rebuild.
738 * Makefile.in (INSTALL): Revert to using install.sh.
739 (INSTALL_PROGRAM, INSTALL_DATA): Set to $(INSTALL).
740 (INSTALL_XFORM, INSTALL_XFORM1): Restore.
741 (CC_FOR_BUILD): Restore.
742 (gencode): Build using $(CC_FOR_BUILD).
743 (install): Don't install in $(tooldir).
744
745Thu Sep 7 15:02:31 1995 J.T. Conklin <jtc@rtl.cygnus.com>
746
747 (Try to) Update to new bfd autoconf scheme.
748 * run.c: Don't include sysdep.h.
749 * Makefile.in (INSTALL{,_PROGRAM,_DATA}): Use autoconf computed value.
750 (CC, CFLAGS, AR, RANLIB): Likewise.
751 (HDEFINES, TDEFINES): Define.
752 (CC_FOR_BUILD): Delete.
753 (host_makefile_frag): Delete.
754 (Makefile): Don't depend on frags.
755 * configure.in (sysdep.h): Don't create symlink.
756 (host_makefile_frag, frags): Deleted.
757 (CC, CFLAGS, AR, RANLIB, INSTALL): Compute values.
758 * configure: Regenerated.
759
760Thu Aug 31 12:39:07 1995 Jim Wilson <wilson@chestnut.cygnus.com>
761
762 * interp.c: Include <math.h>.
763
764Wed Aug 30 22:05:17 1995 Jeff Law (law@snake.cs.utah.edu)
765
766 * Makefile.in (run): Link in math library too.
767 * gencode.c (gensim): abort if an unknown opcode is encountered.
768 * interp.c (FPSCR, FPUL): Define.
769 (struct save_state): Add fields for floating point registers,
770 FPSCR and FPUL.
771 (sim_resume): Add 'F' for accessing floating point registers
772 in the save state structure.
773 * gencode.c: Add sh3e opcodes.
774 (gensym): Define a buffer for int<->fp conversions.
775
776Tue Aug 22 14:16:46 1995 J.T. Conklin <jtc@rtl.cygnus.com>
777
778 * interp.c (trap): Use trap vector 34 for host system interface.
779 * gencode.c: Add 34 to conditional which determines which traps
780 will be handled by simulator.
781
782Fri Aug 11 17:59:15 1995 Jim Wilson <wilson@chestnut.cygnus.com>
783
784 * run.c: Include <signal.h>. Define SIGQUIT if not defined.
785 (main): New variables reason and sigrc. After simulator exits,
786 check to see if it exited because of a signal, and if so, then
787 use the signal number as the return value.
788
789Thu Aug 3 10:45:37 1995 Fred Fish <fnf@cygnus.com>
790
791 * Update all FSF addresses except those in COPYING* files.
792
793Tue Jul 18 23:33:10 1995 Fred Fish <fnf@fishbowl>
794
795 * interp.c (trap): Only use SYS_execv if defined. Might be
796 implemented as execve(arg1,arg2,0), as with Unixware 2.0.
797 (sim_resume): In sbit initializer, cast shifted arg to unsigned
798 to avoid signed integer overflow.
799
800Wed Jul 5 14:32:54 1995 J.T. Conklin <jtc@rtl.cygnus.com>
801
802 * Makefile.in (clean): Remove run, libsim.a.
803 (distclean, mostlyclean, realclean): Remove Makefile and
804 autoconf files.
805
806 * sh.mt: Removed.
807
808 * Makefile.in, configure.in: converted to autoconf.
809 * configure: New file, generated with autconf 2.4.
810
811Fri Jun 30 16:51:38 1995 Stan Shebs <shebs@andros.cygnus.com>
812
813 * interp.c (sim_open): If argument supplied, interpret as
814 desired memory size.
815 (parse_and_set_memory_size): New function.
816 (sim_do_command): New function.
817
818Thu Jun 29 10:02:28 1995 Fred Fish <fnf@deneb.cygnus.com>
819
820 * interp.c (SYS_wait): Define as SYS_wait4 if available and
821 SYS_wait is not already defined (SunOS 4.1.3 for example).
822 (SYS_utime): Define as SYS_utimes if available and
823 SYS_utime is not already defined.
824
825Thu Jun 22 17:25:57 1995 Steve Chamberlain <sac@slash.cygnus.com>
826
827 * interp.c: Don't include sys/times.h or sys/param.h
828
829Wed Jun 21 15:03:49 1995 Steve Chamberlain <sac@slash.cygnus.com>
830
831 * interp.c (SIGBUS, SIGTERM): Define if not.
832 (sim_memory_size): default to 2^19 on PCs.
833 (sim_resume): Poll for quits on win32.
834
835Wed May 24 16:22:48 1995 Jim Wilson <wilson@chestnut.cygnus.com>
836
837 * gencode.c (op_tab): Add SH3 support.
838
839Wed May 24 14:07:11 1995 Steve Chamberlain <sac@slash.cygnus.com>
840
841 * gencode.c (tab): Add bsrf and braf.
842
843Mon Apr 24 15:09:49 1995 Jason Molenda (crash@cygnus.com)
844
845 * configure.in: use ../../bfd/hosts/std-host.h, not
846 ../bfd/hosts/std-host.h (which doesn't exist).
847
848Mon Mar 27 10:32:34 1995 J.T. Conklin <jtc@rtl.cygnus.com>
849
850 * run.c: parse arguments with getopt().
851
852Sun Feb 26 15:27:24 1995 Steve Chamberlain <sac@cygnus.com>
853
854 * configure.in: Use ../../bfd/hosts/std-host.h if specific
855 host unavailable.
856
857Mon Jan 23 16:10:58 1995 Torbjorn Granlund <tege@rtl.cygnus.com>
858
859 * interp.c (macw): Sign extend MACH at bit 10 for non-saturating case.
860
861Sun Jan 22 13:55:36 1995 Torbjorn Granlund <tege@rtl.cygnus.com>
862
863 * gencode.c (op_tab): Make MAC.W call macw, not abort.
864 * interp.c (macw): New function.
865 (S): New #define.
866
867Sat Jan 21 15:52:30 1995 Torbjorn Granlund <tege@rtl.cygnus.com>
868
869 * gencode.c (op_tab): New code for ADDV and SUBV.
870 Make MAC.L abort sicne it is not implemented.
871
872 * interp.c (dmul): Handle the signed case by adjusting after unsigned multiply.
873 Get rid of __GNUC__ conditional.
874
875aThu Jan 19 05:50:50 1995 Torbjorn Granlund <tege@rtl.cygnus.com>
876
877 * gencode.c (op_tab): Also replace NEGC, and try again with SUBC.
878 Change ADDC for symmetry.
879
880 * gencode.c (op_tab): Replace code for ADDC and SUBC.
881
882Mon Jan 9 15:43:53 1995 Stu Grossman (grossman@cygnus.com)
883
884 * interp.c: Remove def of INLINE. This comes from bfd.h. Also,
885 declare IOMEM before using it.
886
887Wed Dec 28 21:25:31 1994 Steve Chamberlain (sac@jonny.cygnus.com)
888
889 * interp.c (BUSERROR): New macro.
890 ([r|w][bwl]at[little|big]) New functions.
891 (sim_resume): If GO32 check for interrupt every now
892 and again. Decrement PC if SIGBUS seen.
893 * run.c (main): Return result of simulated _exit.
894
895Mon Dec 5 21:59:51 1994 Doug Evans <dje@canuck.cygnus.com>
896
897 * Makefile.in (gencode): Allow build in different directory.
898
899Wed Nov 30 17:47:13 1994 Jim Wilson <wilson@chestnut.cygnus.com>
900
901 * Makefile.in (gencode): Change $< to gencode.c for portability.
902
903Wed Nov 23 21:31:55 1994 Steve Chamberlain (sac@jonny.cygnus.com)
904
905 * interp.c ([wr][bwl]at): New functions.
906 (trap): Cope with both byte modes.
907
908Thu Sep 8 17:35:07 1994 Steve Chamberlain (sac@jonny.cygnus.com)
909
910 * gencode.c (tab): Simulate T bit after a negc insn right.
911 * interp.c (RSBAT): Sign extend the arg.
912 (ACE_FAST): New macro.
913 (sim_resume): Remove obsolete test of sim_timeout.
914
915Fri Aug 5 14:12:31 1994 Steve Chamberlain (sac@jonny.cygnus.com)
916
917 * interp.c (IOMEM): New function, simulates very basic I/O area of
918 the SH.
919 (WBAT, RBAT) : Call I/O functions.
920 * gencode.c (tab): Special case trapa #3.
921
922Mon Jun 27 18:04:54 1994 Steve Chamberlain (sac@cirdan.cygnus.com)
923
924 * run.c (main): Specify the file type again.
925
926Thu May 26 19:04:37 1994 Steve Chamberlain (sac@thepub.cygnus.com)
927
928 * interp.c (trap): Fix irix incompatibility.
929 * run.c (main): open without specifying file type.
930
931Wed May 18 14:18:53 1994 Doug Evans (dje@canuck.cygnus.com)
932
933 * interp.c (sim_*): Make result void where there isn't one.
934 (sim_set_pc): Delete.
935 (sim_info): Delete printf_fn arg, all callers changed.
936 Call printf_filtered instead.
937 (sim_close): New function.
938 (sim_load): New function.
939 (sim_create_inferior): Renamed from sim_set_args, all callers changed.
940 * run.c: #include <varargs.h>, "remote-sim.h".
941 (printf_filtered): New function.
942
943Wed Apr 27 12:03:48 1994 Steve Chamberlain (sac@cygnus.com)
944
945 * gencode.c (table): Get direction of some opcodes right.
946 (trapa, rte): Implement fully.
947 * interp.c (trap): Make stat call more portable.
948
949Fri Feb 11 21:59:38 1994 Steve Chamberlain (sac@sphagnum.cygnus.com)
950
951 * gencode.c (main, gendefines): New -d option prints table of defines.
952 * interp.c (trap): Add a load of system calls.
953 (sim_memory_size): Now default to 8Mbyte.
954 (PARANOID): Keep vector of registers with undefined contents.
955
956Mon Nov 15 14:37:18 1993 Steve Chamberlain (sac@jonny.cygnus.com)
957
958 * gencode.c: mova uses aligned addresses
959 * interp.c (trap): Return results in r0.
960
961Tue Oct 26 10:38:55 1993 Doug Evans (dje@canuck.cygnus.com)
962
963 * Makefile.in (CSEARCH): Add -I$(srcdir)/../../gdb
964 * interp.c: #include "remote-sim.h".
965 (sim_resume): int result, new arg `siggnal'.
966 (sim_write): Use SIM_ADDR for type of arg `addr'.
967 (sim_read): Use SIM_ADDR for type of arg `addr'.
968 Use unsigned char * for `buffer'.
969 (sim_store_register): int result.
970 (sim_fetch_register): Ditto.
971 (sim_stop_reason): Renamed from sim_stop_signal. New arg `reason'.
972 (sim_set_pc): int result, use SIM_ADDR for type of arg `x'.
973 (sim_info): int result, new args `verbose', `printf_fn'.
974 (sim_kill): int result.
975 (sim_open): int result, new arg `name'.
976 * run.c: #include <stdio.h>
977 (main): Update call to sim_info.
978
979Sat Oct 23 15:09:29 1993 Doug Evans (dje@canuck.cygnus.com)
980
981 * interp.c (sim_stop_signal): Result is now enum sim_stop.
982
983Fri Oct 8 10:47:09 1993 Steve Chamberlain (sac@phydeaux.cygnus.com)
984
985 * gencode.c (table): Becomes unsigned.
986 * interp.c (trap): Get right breakpoint SIGnum. (sim_write,
987 sim_read): Return number of bytes copied. (sim_store_register):
988 Value passed by reference. (sim_kill, sim_open, sim_set_args): New functions.
989
990Tue Sep 7 16:24:13 1993 Stan Shebs (shebs@rtl.cygnus.com)
991
992 * interp.c (sim_info): Fix small typo in printf string.
993
994Thu Aug 5 11:37:48 1993 Stan Shebs (shebs@rtl.cygnus.com)
995
996 * interp.c (sim_resume): Set memory after pointers inited.
997
998Mon Aug 2 14:13:22 1993 Steve Chamberlain (sac@phydeaux.cygnus.com)
999
1000 * interp.c (get_now): Use time system call.
1001 * Makefile.in: install correctly.
1002
1003Tue Jul 6 10:30:46 1993 Steve Chamberlain (sac@phydeaux.cygnus.com)
1004
1005 * run.c (main), interp.c (sim_set_timeout): Remove timeout
1006 functionality.
1007
1008Thu Jun 24 13:29:57 1993 david d `zoo' zuhn (zoo at rtl.cygnus.com)
1009
1010 * Makefile.in: don't run indent everytime; also add a space in the
1011 includes
1012
1013Thu Jun 17 18:30:42 1993 Steve Chamberlain (sac@phydeaux.cygnus.com)
1014
1015 * gencode.c: Fix some opcodes.
1016 * interp.c: Support for profiling and portability fixes.
1017 * run.c (main): Get profiling args.
1018
1019Wed May 5 13:17:22 1993 Steve Chamberlain (sac@cygnus.com)
1020
1021 * gencode.c (tab): Lint for sgi compiler
1022 * interp.c: Lint for sgi compiler.
1023
1024Mon May 3 15:25:33 1993 Steve Chamberlain (sac@thepub.cygnus.com)
1025
1026 * run.c (main): Support for resizing simulated RAM.
1027 * Makefile.in: Support for broken makes.
1028 * interp.c, gencode.c: Lint.
1029
1030Mon Apr 26 18:01:10 1993 Steve Chamberlain (sac@thepub.cygnus.com)
1031
1032 * created
1033
This page took 0.220242 seconds and 4 git commands to generate.