summaryrefslogtreecommitdiff
path: root/util/m5/m5.c
diff options
context:
space:
mode:
authorNathan Binkert <binkertn@umich.edu>2003-11-02 01:08:59 -0500
committerNathan Binkert <binkertn@umich.edu>2003-11-02 01:08:59 -0500
commit1cd3757db92528bf1805fabe59db45f6359ab5b9 (patch)
tree9c6ef518edadfb4538c4c4126e0b39bb6a547063 /util/m5/m5.c
parenta800d6abf71ea14f05e2e7a895e43d0ca8f8f553 (diff)
downloadgem5-1cd3757db92528bf1805fabe59db45f6359ab5b9.tar.xz
add several new functions that can be called from the guest
to tell the simulator to do something. exit -> exit_old (deprecated exit now takes an optional parameter that tells it to execute at a specified time in the future The next four functions have two optional parameters. The first specifies a delay for how long to wait to issue the instruction. The second will tell the simulator to repeat that command at the specified interval. checkpoint will trigger a checkpoint dumpstats will cause the simulator to dump stats resetstats will cause all stats to be reset dumpreset will dump and reset stats all times are in nanoseconds util/m5/Makefile: Clean up to make it a bit easier to muck with util/m5/m5.c: Add a bunch of new commands and clean up the command parsing path Convert atoi to strtoul so that we can use 64bit numbers and even hex if we want to. (this runs on alpha, so a long is 64bit) util/m5/m5op.h: add prototypes for new m5 instructions use uint64_t since it's nicer --HG-- extra : convert_revision : 664ff00f0f0dfc5263c4e873d82fd9996a4521e9
Diffstat (limited to 'util/m5/m5.c')
-rw-r--r--util/m5/m5.c158
1 files changed, 127 insertions, 31 deletions
diff --git a/util/m5/m5.c b/util/m5/m5.c
index d17faf90b..1271bc9e1 100644
--- a/util/m5/m5.c
+++ b/util/m5/m5.c
@@ -26,9 +26,7 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
-#include <c_asm.h>
-
-#include <libgen.h>
+#include <inttypes.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
@@ -40,51 +38,149 @@ char *progname;
void
usage()
{
- char *name = basename(progname);
- printf("usage: %s ivlb <interval>\n"
- " %s ivle <interval>\n"
- " %s initparam\n"
- " %s sw99param\n"
- " %s resetstats\n"
- " %s exit\n", name, name, name, name, name, name);
+ printf("usage: m5 ivlb <interval>\n"
+ " m5 ivle <interval>\n"
+ " m5 initparam\n"
+ " m5 sw99param\n"
+ " m5 exit [delay]\n"
+ " m5 resetstats [delay [period]]\n"
+ " m5 dumpstats [delay [period]]\n"
+ " m5 dumpresetstats [delay [period]]\n"
+ " m5 checkpoint [delay [period]]\n"
+ "\n"
+ "All times in nanoseconds!\n");
exit(1);
}
+#define COMPARE(X) (strcmp(X, command) == 0)
+
int
main(int argc, char *argv[])
{
- int start;
- int interval;
- unsigned long long param;
+ char *command;
+ uint64_t param;
+ uint64_t arg1 = 0;
+ uint64_t arg2 = 0;
progname = argv[0];
if (argc < 2)
usage();
- if (strncmp(argv[1], "ivlb", 5) == 0) {
- if (argc != 3) usage();
- ivlb((unsigned long)atoi(argv[2]));
- } else if (strncmp(argv[1], "ivle", 5) == 0) {
- if (argc != 3) usage();
- ivle((unsigned long)atoi(argv[2]));
- } else if (strncmp(argv[1], "exit", 5) == 0) {
- if (argc != 2) usage();
- m5exit();
- } else if (strncmp(argv[1], "initparam", 10) == 0) {
- if (argc != 2) usage();
- printf("%d", initparam());
- } else if (strncmp(argv[1], "sw99param", 10) == 0) {
- if (argc != 2) usage();
+ command = argv[1];
+
+ if (COMPARE("ivlb")) {
+ if (argc != 3)
+ usage();
+
+ arg1 = strtoul(argv[2], NULL, 0);
+ ivlb(arg1);
+ return 0;
+ }
+
+ if (COMPARE("ivle")) {
+ if (argc != 3)
+ usage();
+
+ arg1 = strtoul(argv[2], NULL, 0);
+ ivle(arg1);
+ return 0;
+ }
+
+ if (COMPARE("initparam")) {
+ if (argc != 2)
+ usage();
+
+ printf("%ld", initparam());
+ return 0;
+ }
+
+ if (COMPARE("sw99param")) {
+ if (argc != 2)
+ usage();
param = initparam();
// run-time, rampup-time, rampdown-time, warmup-time, connections
printf("%d %d %d %d %d", (param >> 48) & 0xfff,
(param >> 36) & 0xfff, (param >> 24) & 0xfff,
(param >> 12) & 0xfff, (param >> 0) & 0xfff);
- } else if (strncmp(argv[1], "resetstats", 11) == 0) {
- if (argc != 2) usage();
- resetstats();
+
+ return 0;
+ }
+
+ if (COMPARE("exit")) {
+ switch (argc) {
+ case 3:
+ arg1 = strtoul(argv[2], NULL, 0);
+ case 2:
+ m5exit(arg1);
+ return 0;
+
+ default:
+ usage();
+ }
+ }
+
+ if (COMPARE("resetstats")) {
+ switch (argc) {
+ case 4:
+ arg2 = strtoul(argv[3], NULL, 0);
+ case 3:
+ arg1 = strtoul(argv[2], NULL, 0);
+ case 2:
+ reset_stats(arg1, arg2);
+ return 0;
+
+ default:
+ usage();
+ }
+ }
+
+ if (COMPARE("dumpstats")) {
+ switch (argc) {
+ case 4:
+ arg2 = strtoul(argv[3], NULL, 0);
+ case 3:
+ arg1 = strtoul(argv[2], NULL, 0);
+ case 2:
+ dump_stats(arg1, arg2);
+ return 0;
+
+ default:
+ usage();
+ }
+ }
+
+ if (COMPARE("dumpresetstats")) {
+ switch (argc) {
+ case 4:
+ arg2 = strtoul(argv[3], NULL, 0);
+ case 3:
+ arg1 = strtoul(argv[2], NULL, 0);
+ case 2:
+ dumpreset_stats(arg1, arg2);
+ return 0;
+
+ default:
+ usage();
+ }
+ }
+
+ if (COMPARE("checkpoint")) {
+ switch (argc) {
+ case 4:
+ arg2 = strtoul(argv[3], NULL, 0);
+ case 3:
+ arg1 = strtoul(argv[2], NULL, 0);
+ case 2:
+ checkpoint(arg1, arg2);
+ return 0;
+
+ default:
+ usage();
+ }
+
+ return 0;
}
- return 0;
+ usage();
}