Changelog

From Msim

(Difference between revisions)
Jump to: navigation, search
(Upcoming)
m
Line 1: Line 1:
-
This page details changes since the relase of Version 3.0 of M-sim. Information about the changes is provided in case mistakes were made and to provide greater understanding of the simulator.
+
This page details changes since the relase of Version 3.0 of M-sim. Information about the changes is provided in case mistakes were made and to provide greater understanding of the simulator. As of 9/8/09, versions will use a version number instead of a date.  
-
=== Upcoming ===
+
=== Upcoming: Release 3.0.10 ===
[[EIO_4|New EIO version]].<br>
[[EIO_4|New EIO version]].<br>
[[New-Syscalls|Syscalls]]<br>
[[New-Syscalls|Syscalls]]<br>
Line 8: Line 8:
[[TIOCISATTY|ioctl(TIOCISATTY)]] didn't work as expected and is now fixed.<br>
[[TIOCISATTY|ioctl(TIOCISATTY)]] didn't work as expected and is now fixed.<br>
-
== July 20th 2009 ==
+
== Release 3.0.09: July 20th 2009 ==
[[Store Conditional Bug|Store Conditional]] did not set its physical register to REG_WB nor set ready times for the result.<br>
[[Store Conditional Bug|Store Conditional]] did not set its physical register to REG_WB nor set ready times for the result.<br>
A [[file handler|file handler]] for both debugging as well as creating accurate and portable checkpoints.<br>
A [[file handler|file handler]] for both debugging as well as creating accurate and portable checkpoints.<br>
Line 22: Line 22:
[[07-17-09_Fetch|Fetch Cache Misses]] were not stopping the current fetch.<br>
[[07-17-09_Fetch|Fetch Cache Misses]] were not stopping the current fetch.<br>
-
== June 16th 2009 ==
+
== Release 3.0.08: June 16th 2009 ==
[[06-16-09-Machine_Def|Machine.def]] updates (RPCC, STQ_C, STL_C, Comments).<br>
[[06-16-09-Machine_Def|Machine.def]] updates (RPCC, STQ_C, STL_C, Comments).<br>
[[06-16-09-Loader|Loader]] issues related to gcc 4.3.2 support.<br>
[[06-16-09-Loader|Loader]] issues related to gcc 4.3.2 support.<br>
Line 38: Line 38:
Corrected incorrect == instead of != in [[06-16-09-Syscalls#OSF_SYS_MMAP|mmap]]. Improved overall behavior but still not full support (syscall.c).<br>
Corrected incorrect == instead of != in [[06-16-09-Syscalls#OSF_SYS_MMAP|mmap]]. Improved overall behavior but still not full support (syscall.c).<br>
-
== May 12th 2009 ==
+
== Release 3.0.07: May 12th 2009 ==
[[05-12-09-Write_Buffer|Write Buffer]] emergency patch issued. Could get caught in an infinite loop trying to remove elements from an empty write buffer.
[[05-12-09-Write_Buffer|Write Buffer]] emergency patch issued. Could get caught in an infinite loop trying to remove elements from an empty write buffer.
-
== May 5th 2009 ==
+
== Release 3.0.06: May 5th 2009 ==
[[05-05-09-Cache|Cache]] fixes made. Correction made to the usage of bus_free. A write buffer (from processor to first level cache) is now implemented per core - this resolves the bzip2 and gzip problem without having to use the "read data block" hack.
[[05-05-09-Cache|Cache]] fixes made. Correction made to the usage of bus_free. A write buffer (from processor to first level cache) is now implemented per core - this resolves the bzip2 and gzip problem without having to use the "read data block" hack.
-
== April 24th 2009 ==
+
== Release 3.0.05: April 24th 2009 ==
Main.c now properly includes fstream (#include<fstream>).  
Main.c now properly includes fstream (#include<fstream>).  
-
== April 20th 2009 ==
+
== Release 3.0.04: April 20th 2009 ==
[[04-20-09-Num_Cores|Num_Cores]] not being handled correctly through a config file has been fixed. Also, MAX_LINE_ARGS in options.c has been increased to handle the large number of options required for CMP.<br>
[[04-20-09-Num_Cores|Num_Cores]] not being handled correctly through a config file has been fixed. Also, MAX_LINE_ARGS in options.c has been increased to handle the large number of options required for CMP.<br>
-
== April 4th 2009 ==
+
== Release 3.0.03: April 4th 2009 ==
[[04-04-09-Options_C|Options.c]] is updated to handle newly created config files from dumpconfig. Minor code adjustment.<br>
[[04-04-09-Options_C|Options.c]] is updated to handle newly created config files from dumpconfig. Minor code adjustment.<br>
[[04-04-09-Dram|Dram]] bug with accesses across two banks is fixed, other minor tweaks.<br>
[[04-04-09-Dram|Dram]] bug with accesses across two banks is fixed, other minor tweaks.<br>
Line 58: Line 58:
[[04-04-09-Opti|Optimizations]] done in sim-outorder.c.<br>
[[04-04-09-Opti|Optimizations]] done in sim-outorder.c.<br>
-
== March 6th 2009 ==
+
== Release 3.0.02: March 6th 2009 ==
Added -max:cycles support - would be nice to avoid the check each cycle though.<br>
Added -max:cycles support - would be nice to avoid the check each cycle though.<br>
[[Dram|Dram]] modeling support is now available - the default is the old chunk style method.<br>
[[Dram|Dram]] modeling support is now available - the default is the old chunk style method.<br>
Memory bus width is now 4 bytes by default.
Memory bus width is now 4 bytes by default.
-
== February 12th 2009 ==
+
== Release 3.0.01: February 12th 2009 ==
mem_access_latency (defined in cmp.h) now takes 4 parameters (address, size, when, context_id) compared to just size. This is intended for DRAM access modeling. This affects cmp.c, cmp.h and sim-outorder.c<br>
mem_access_latency (defined in cmp.h) now takes 4 parameters (address, size, when, context_id) compared to just size. This is intended for DRAM access modeling. This affects cmp.c, cmp.h and sim-outorder.c<br>
OSF_SYS_write is removed from machine.h and replaced in syscall.c<br>
OSF_SYS_write is removed from machine.h and replaced in syscall.c<br>
[[02-12-09-Opti|Optimization]]: When checking the LSQ for a store forward, the for loop was not used effectively.<br>
[[02-12-09-Opti|Optimization]]: When checking the LSQ for a store forward, the for loop was not used effectively.<br>
-
== January 24th 2009 ==
+
== Release 3.0.00: January 24th 2009 ==
Trivial: Removed commented out lines from main.c<br>
Trivial: Removed commented out lines from main.c<br>
Trivial: Re-enabled fclose(outfile) in context desructor in smt.c - fixes ~1K mem leak<br>
Trivial: Re-enabled fclose(outfile) in context desructor in smt.c - fixes ~1K mem leak<br>
[[01-24-09-Bug 1|Bug 1]]: Fixed "issued inst not spec ready" for floating point insts (actually affected all, but only mattered in floating point cases)<br>
[[01-24-09-Bug 1|Bug 1]]: Fixed "issued inst not spec ready" for floating point insts (actually affected all, but only mattered in floating point cases)<br>
[[01-24-09-Bug 2|Bug 2]]: Commit now looks at the correct list of remaining contexts.<br>
[[01-24-09-Bug 2|Bug 2]]: Commit now looks at the correct list of remaining contexts.<br>

Revision as of 16:48, 8 September 2009

This page details changes since the relase of Version 3.0 of M-sim. Information about the changes is provided in case mistakes were made and to provide greater understanding of the simulator. As of 9/8/09, versions will use a version number instead of a date.

Contents

Upcoming: Release 3.0.10

New EIO version.
Syscalls
Fixed quote handling in .arg files
Removal of argc parameter in ld_load_prog (argv is already a vector and argc can be extracted from it).
ioctl(TIOCISATTY) didn't work as expected and is now fixed.

Release 3.0.09: July 20th 2009

Store Conditional did not set its physical register to REG_WB nor set ready times for the result.
A file handler for both debugging as well as creating accurate and portable checkpoints.
Syscalls getgroups, mkdir, readlink, ioctl(winsize), ioctl(istty) are now supported. Kill is very partially supported.
Conditional Memory support is being added.
Issue_Inorder has been fixed.
Libexo is being removed from the simulator.
regs_t now supports input operator for replacing libexo (regs.[hc]).
mem_t now supports input operator for replacing libexo (memory.[hc]).
Tagset error has been corrected.
Redirection of stderr has been updated for a few potential redirection operators.
Incorrect single precision handling through the LDS instruction has been dealt with.
Fetch Cache Misses were not stopping the current fetch.

Release 3.0.08: June 16th 2009

Machine.def updates (RPCC, STQ_C, STL_C, Comments).
Loader issues related to gcc 4.3.2 support.
Rollback support for mt_fpcr (sim-outorder.c)
Rollback support for STQ_C and STL_C (sim-outorder.c)
F_TRAPs should (and have, but apparently this was lost) cause the ROB to drain before rename (sim-outorder.c)
Rollback can't rollback over a F_TRAP (see above, cmp.c, cmp.c)
regs_t now supports output operator (input pending) for replacing libexo (regs.[hc]).
mem_t now supports output operator (input pending) for replacing libexo (memory.[hc]).
Added minor setsysinfo and getsysinfo support (syscall.c).
Added support for fstat64 (syscall.c).
Added support for exit_group (syscall.c).
Fixed obreak (syscall.c).
Fixed uname, which also provides utsname (syscall.c).
Corrected incorrect == instead of != in mmap. Improved overall behavior but still not full support (syscall.c).

Release 3.0.07: May 12th 2009

Write Buffer emergency patch issued. Could get caught in an infinite loop trying to remove elements from an empty write buffer.

Release 3.0.06: May 5th 2009

Cache fixes made. Correction made to the usage of bus_free. A write buffer (from processor to first level cache) is now implemented per core - this resolves the bzip2 and gzip problem without having to use the "read data block" hack.

Release 3.0.05: April 24th 2009

Main.c now properly includes fstream (#include<fstream>).

Release 3.0.04: April 20th 2009

Num_Cores not being handled correctly through a config file has been fixed. Also, MAX_LINE_ARGS in options.c has been increased to handle the large number of options required for CMP.

Release 3.0.03: April 4th 2009

Options.c is updated to handle newly created config files from dumpconfig. Minor code adjustment.
Dram bug with accesses across two banks is fixed, other minor tweaks.
Cache access has been updated to return an unsigned long long, BOUND_POS is no longer needed.
Inflight Queues have been altered to no longer assume compiler eliding, this required const enforcing in the rob.h as well.
Issue Queue has been altered to no longer assume compiler eliding.
Optimizations done in sim-outorder.c.

Release 3.0.02: March 6th 2009

Added -max:cycles support - would be nice to avoid the check each cycle though.
Dram modeling support is now available - the default is the old chunk style method.
Memory bus width is now 4 bytes by default.

Release 3.0.01: February 12th 2009

mem_access_latency (defined in cmp.h) now takes 4 parameters (address, size, when, context_id) compared to just size. This is intended for DRAM access modeling. This affects cmp.c, cmp.h and sim-outorder.c
OSF_SYS_write is removed from machine.h and replaced in syscall.c
Optimization: When checking the LSQ for a store forward, the for loop was not used effectively.

Release 3.0.00: January 24th 2009

Trivial: Removed commented out lines from main.c
Trivial: Re-enabled fclose(outfile) in context desructor in smt.c - fixes ~1K mem leak
Bug 1: Fixed "issued inst not spec ready" for floating point insts (actually affected all, but only mattered in floating point cases)
Bug 2: Commit now looks at the correct list of remaining contexts.

Personal tools