code/bin/main.c
/*
Copyright (c) 1992-1993 The Regents of the University of California.
All rights reserved. See copyright.h for copyright notice and limitation
of liability and disclaimer of warranty provisions.
*/
#include "copyright.h"
/* MIPS instruction interpreter */
#include
#include
#include
#include
#include
#include "int.h"
static FILE *fp;
static LDFILE *ldptr;
static SCNHDR texthead, rdatahead, datahead, sdatahead, sbsshead, bsshead;
static char filename[1000] = "a.out"; /* default a.out file */
static char self[256]; /* name of invoking program */
char mem[MEMSIZE]; /* main memory. use malloc later */
int TRACE, Traptrace, Regtrace;
int NROWS=64, ASSOC=1, LINESIZE=4, RAND=0, LRD=0;
extern char *strcpy();
main(argc, argv)
int argc;
char *argv[];
{
register char *s;
char *fakeargv[3];
strcpy(self, argv[0]);
while ( argc > 1 && argv[1][0] == '-' )
{
--argc; ++argv;
for ( s=argv[0]+1; *s != '\0'; ++s )
switch ( *s )
{
case 't': TRACE = 1; break;
case 'T': Traptrace = 1; break;
case 'r': Regtrace = 1; break;
case 'm':
NROWS = atoi(*++argv);
ASSOC = atoi(*++argv);
LINESIZE = atoi(*++argv);
RAND = ((*++argv)[0] == 'r');
LRD = ((*argv)[0] == 'l')
&& ((*argv)[1] == 'r')
&& ((*argv)[2] == 'd');
argc -= 4;
break;
}
}
if (argc >= 2)
strcpy(filename, argv[1]);
fp = fopen(filename, "r");
if (fp == NULL)
{
fprintf(stderr, "%s: Could not open '%s'\n", self, filename);
exit(0);
}
fclose(fp);
load_program(filename);
if ( argv[1] == NULL )
{
fakeargv[1] = "a.out";
fakeargv[2] = NULL;
argv = fakeargv;
++argc;
}
runprogram(memoffset, argc-1, argv+1); /* where things normally start */
}
char *string(s)
char *s;
{
char *p;
extern char *malloc();
p = malloc((unsigned) strlen(s)+1);
strcpy(p, s);
return p;
}
load_program(filename)
char *filename;
{
register int pc, i, j, strindex, stl;
char str[1111];
int rc1, rc2;
ldptr = ldopen(filename, NULL);
if ( ldptr == NULL )
{
fprintf(stderr, "%s: Load read error on %s\n", self, filename);
exit(0);
}
if ( TYPE(ldptr) != 0x162 )
{
fprintf(stderr,
"big-endian object file (little-endian interp)\n");
exit(0);
}
#define LOADSECTION(head) \
if ( head.s_scnptr != 0 ) \
{ \
/* printf("loading %s\n", head.s_name); /* */ \
pc = head.s_vaddr; \
FSEEK(ldptr, head.s_scnptr, 0); \
for ( i=0; i= MEMSIZE) \
{ printf("MEMSIZE too small. Fix and recompile.\n"); \
exit(1); } \
}
if ( ldnshread(ldptr, ".text", &texthead) != 1 )
printf("text section header missing\n");
else
LOADSECTION(texthead)
if ( ldnshread(ldptr, ".rdata", &rdatahead) != 1 )
printf("rdata section header missing\n");
else
LOADSECTION(rdatahead)
if ( ldnshread(ldptr, ".data", &datahead) != 1 )
printf("data section header missing\n");
else
LOADSECTION(datahead)
if ( ldnshread(ldptr, ".sdata", &sdatahead) != 1 )
printf("sdata section header missing\n");
else
LOADSECTION(sdatahead)
if ( ldnshread(ldptr, ".sbss", &sbsshead) != 1 )
printf("sbss section header missing\n");
else
LOADSECTION(sbsshead)
if ( ldnshread(ldptr, ".bss", &bsshead) != 1 )
printf("bss section header missing\n");
else
LOADSECTION(bsshead)
/* BSS is already zeroed (statically-allocated mem) */
/* this version ignores relocation info */
}
int *m_alloc(n)
int n;
{
extern char *malloc();
return (int *) (int) malloc((unsigned) n);
}