--- trunk/RELEASE 2007/10/08 16:18:51 14 +++ trunk/RELEASE 2007/10/08 16:20:26 28 @@ -1,7 +1,7 @@ -Release notes for Gavare's eXperimental Emulator (GXemul), 0.3.6 +Release notes for Gavare's eXperimental Emulator (GXemul), 0.4.1 ================================================================ -Copyright (C) 2003-2005 Anders Gavare. +Copyright (C) 2003-2006 Anders Gavare. GXemul is an experimental instruction-level machine emulator. Several @@ -9,80 +9,68 @@ hardware components are emulated well enough to let unmodified operating systems (e.g. NetBSD) run as if they were running on a real machine. -The processor architecture best emulated by GXemul is MIPS, but other -architectures are also partially emulated. +The documentation lists the machines and guest operating systems that can +be regarded as "working" in GXemul. The best working guest operating +systems are probably NetBSD/pmax, NetBSD/cats, and OpenBSD/cats. -I have verified that the following "guest" operating systems can run inside -the emulator: - Guest operating system Emulated machine - ---------------------- ---------------- - NetBSD/pmax 2.0.2 (and 1.6.2) DECstation 5000/200 - OpenBSD/pmax 2.8-BETA DECstation 5000/200 - Ultrix 4.2-4.5 DECstation 5000/200 - Sprite demo harddisk image DECstation 5000/200 - Debian GNU/Linux for DECstation DECstation 5000/200 - Redhat Linux 7.1 for mips DECstation 5000/200 - NetBSD/arc 1.6.2 Acer PICA-61 - OpenBSD/arc 2.3 Acer PICA-61 - NetBSD/hpcmips 2.0.2 NEC MobilePro 770, 780, 800, 880 - NetBSD/cobalt 2.0.2 Cobalt - NetBSD/evbmips 2.0.2 Malta 5Kc/4Kc evaluation board - NetBSD/sgimips 2.0.2 SGI O2 ("IP32") - NetBSD/cats 2.0.2 CATS (ARM) - OpenBSD/cats 3.7 CATS (ARM) - -(Most of these are MIPS-based machines, except the CATS, which is an -ARM-based machine.) - -Some of these guest operating systems are easier to install and run than -others. The best supported mode is the DECstation 5000/200 emulation mode, -with NetBSD/pmax as the guest operating system. - -A couple of other emulation modes exist. Some of these modes are almost -working well enough to run complete guest operating systems, but most are -just skeletons. The modes that work are listed in the documentation. - -The emulator can also be used in other experiments; it does not have to run -entire guest operating systems. (However, GXemul does not simulate things -smaller than an instruction. What this means is that pipe-line stalls, -penalties caused by branch-prediction misses or cache misses, and other -micro-architectural effects are not simulated.) - -The most imporant user-visible change between release 0.3.5 and 0.3.6 is: - - (X) The experimental ARM emulation mode is now working well enough - to install NetBSD/cats and OpenBSD/cats onto harddisk images. - -There are two minor issues with the ARM emulation: - - 1) A bug is triggered at the end of the OpenBSD/cats installation, - so the MAKEDEV script must be run manually before booting for - the first time. +Changes between release 0.4.0.1 and 0.4.1 include, among other things: - 2) I have not had time to do any performance optimizations yet, so - the ARM emulation mode is not very fast. + o) Some bugs in the dynamic translation core have been fixed, making + all emulation modes (especially the MIPS mode) more stable. + + o) In the refactoring effort between 0.4.0 and 0.4.0.1, single-stepping + (and instruction tracing) of 64-bit programs was accidentally broken. + Single-stepping in 64-bit mode could result in strange exceptions. + This has been fixed in 0.4.1. + + o) MIPS emulation performance has been improved somewhat: + + R3000: After removing some buggy code (hints for physical page + translations), it was possible to remove the workaround for R3000 + caches which was needed in 0.4.0.1 to make Linux and Ultrix run. + This gives an overall speedup for R2000/R3000. + + For non-R3000, there have been some speedups as well. After fixing + reference count bugs for 64-bit addressing in the dyntrans system, + workarounds/hacks in the tlbwr/tlbwi instructions and in the ASID + change helper function could be removed. + + o) A new -s command line option is now available, for dumping + raw runtime data/statistics on every instruction to a file. + + Currently, the following kinds of data can be dumped: + + 1. the program counter (virtual address) + 2. the physical address representation of the program counter + 3. the internal dyntrans instruction call pointer, useful when + developing/optimizing the emulator + + This data can then be analyzed by external tools. + + (There was a -s command line option in previous releases of + the emulator, but it did not work as intended, and was not + usable from dyntrans emulation modes.) + +Please read the HISTORY files for more details. -There have also been lots of other small changes, too small to mention here. Files included in this release are: - BUGS A list of known bugs. HISTORY Detailed revision history / changelog. LICENSE Copyright message / license. README Quick start instructions, for the impatient. RELEASE This file. TODO TODO notes. configure, Makefile.skel sh and make scripts for building GXemul. + demos Tutorial-like demos of testmachine functionality. doc Documentation. experiments Experimental code. (Usually not needed.) src Source code. -To build the emulator, run the ./configure script, and then run make. +To build the emulator, run the configure script, and then run make. This +should work on most Unix-like systems. -Building the emulator should work on most Unix-like systems. (One system which -is specifically known to NOT work is Ultrix/RISC inside the emulator; Ultrix -chokes on the configure script and the default cc in Ultrix doesn't work.) Regarding files in the src/include/ directory: only some of these are written by me, the rest are from other sources (such as NetBSD). The license text says @@ -153,6 +141,14 @@ This product includes software developed by Mark Brinicombe for the NetBSD Project. + This product includes software developed by TooLs GmbH. + + This product includes software developed by Manuel Bouyer. + + This product includes software developed by the Alice Group. + + This product includes software developed by Ichiro FUKUHARA. + Also, src/include/alpha_rpb.h requires the following: Copyright (c) 1994, 1995, 1996 Carnegie-Mellon University. @@ -169,9 +165,10 @@ See individual files for license details, if you plan to redistribute GXemul or reuse code. -Thanks to (in no specific order) Joachim Buss, Juli Mallett, Juan Romero -Pardines, Alec Voropay, Göran Weinholt, Alexander Yurchenko, and everyone -else who has provided me with feedback. + +Thanks to (in no specific order) Joachim Buss, Olivier Houchard, Juli Mallett, +Juan Romero Pardines, Alec Voropay, Göran Weinholt, Alexander Yurchenko, and +everyone else who has provided me with feedback. If you have found GXemul useful in some way, or feel like sending me comments or feedback in general, then mail me at anders(at)gavare.se.