aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bfd/.Sanitize2
-rw-r--r--bfd/archures.c3
-rw-r--r--bfd/configure.in2
-rw-r--r--bfd/cpu-rce.c11
-rw-r--r--bfd/libaout.h23
-rw-r--r--gas/.Sanitize2
-rw-r--r--gas/as.c41
-rw-r--r--gas/config/.Sanitize2
-rw-r--r--gas/config/rce.mt1
-rw-r--r--gas/config/tc-rce.c260
-rw-r--r--ld/emulparams/rce.sh7
-rw-r--r--ld/scripttempl/rce.sc66
-rw-r--r--opcodes/rce-opc.h57
13 files changed, 349 insertions, 128 deletions
diff --git a/bfd/.Sanitize b/bfd/.Sanitize
index c5a8fe4..c5f1dae 100644
--- a/bfd/.Sanitize
+++ b/bfd/.Sanitize
@@ -263,7 +263,7 @@ else
done
fi
-rce_files="ChangeLog archures.c bfd-in2.h config.bfd configure.in targets.c"
+rce_files="ChangeLog archures.c bfd-in2.h config.bfd configure.in targets.c aoutx.h libaout.h"
if ( echo $* | grep keep\-rce > /dev/null ) ; then
for i in $rce_files ; do
if test ! -d $i && (grep sanitize-rce $i > /dev/null) ; then
diff --git a/bfd/archures.c b/bfd/archures.c
index ea4586d..a748437 100644
--- a/bfd/archures.c
+++ b/bfd/archures.c
@@ -111,6 +111,9 @@ DESCRIPTION
. bfd_arch_alpha, {* Dec Alpha *}
. bfd_arch_arm, {* Advanced Risc Machines ARM *}
. bfd_arch_ns32k, {* National Semiconductors ns32000 *}
+. start-sanitize-rce
+. bfd_arch_rce, {* Motorola RCE *}
+. end-sanitize-rce
. bfd_arch_last
. };
diff --git a/bfd/configure.in b/bfd/configure.in
index ab3ef94..b8c8940 100644
--- a/bfd/configure.in
+++ b/bfd/configure.in
@@ -203,7 +203,7 @@ do
rs6000coff_vec) tb="$tb coff-rs6000.o" ;;
shcoff_vec) tb="$tb coff-sh.o cofflink.o" ;;
# start-sanitize-rce
- rce_aout_vec) tb="$tb aout32.o reloc16.o" ;;
+ rce_aout_vec) tb="$tb aout-rce.o aout32.o stab-syms.o" ;;
# end-sanitize-rce
shlcoff_vec) tb="$tb coff-sh.o cofflink.o" ;;
som_vec) tb="$tb som.o" ;;
diff --git a/bfd/cpu-rce.c b/bfd/cpu-rce.c
index 57b44ba..12b752a 100644
--- a/bfd/cpu-rce.c
+++ b/bfd/cpu-rce.c
@@ -1,4 +1,4 @@
-/* BFD library support routines for the Experiment SOP architecture.
+/* BFD library support routines for the Experiment RCE architecture.
Copyright (C) 1993 Free Software Foundation, Inc.
This file is part of BFD, the Binary File Descriptor library.
@@ -29,8 +29,8 @@ DEFUN(scan_mach,(info, string),
CONST struct bfd_arch_info *info AND
CONST char *string)
{
- if (strcmp(string,"sop") == 0) return true;
- if (strcmp(string,"SOP") == 0) return true;
+ if (strcmp(string,"rce") == 0) return true;
+ if (strcmp(string,"RCE") == 0) return true;
return false;
}
@@ -58,8 +58,8 @@ static bfd_arch_info_type arch_info_struct[] =
8, /* 8 bits in a byte */
bfd_arch_rce,
0, /* only 1 machine */
- "SOP", /* arch_name */
- "SOP", /* printable name */
+ "RCE", /* arch_name */
+ "RCE", /* printable name */
1,
true, /* the default machine */
bfd_default_compatible,
@@ -76,4 +76,3 @@ DEFUN_VOID(bfd_rce_arch)
{
bfd_arch_linkin(&arch_info_struct[0]);
}
-
diff --git a/bfd/libaout.h b/bfd/libaout.h
index fc4e3c5..a40f3c0 100644
--- a/bfd/libaout.h
+++ b/bfd/libaout.h
@@ -203,15 +203,26 @@ enum machine_type {
M_68020 = 2,
M_SPARC = 3,
/* skip a bunch so we don't run into any of suns numbers */
+ /* make these up for the ns32k*/
+ M_NS32032 = (64), /* ns32032 running ? */
+ M_NS32532 = (64 + 5), /* ns32532 running mach */
+
M_386 = 100,
M_29K = 101, /* AMD 29000 */
M_386_DYNIX = 102, /* Sequent running dynix */
- M_386_NETBSD = 134, /* NetBSD/386 binary */
+ M_ARM = 103, /* Advanced Risc Machines ARM */
+ M_386_NETBSD = 134, /* NetBSD/i386 binary */
+ M_68K_NETBSD = 135, /* NetBSD/m68k binary */
+ M_532_NETBSD = 137, /* NetBSD/ns32k binary */
+ M_SPARC_NETBSD = 138, /* NetBSD/sparc binary */
M_MIPS1 = 151, /* MIPS R2000/R3000 binary */
M_MIPS2 = 152, /* MIPS R4000/R6000 binary */
M_HP200 = 200, /* HP 200 (68010) BSD binary */
M_HP300 = (300 % 256), /* HP 300 (68020+68881) BSD binary */
M_HPUX = (0x20c % 256)/* HP 200/300 HPUX binary */
+/* start-sanitize-rce */
+ M_RCE = 155, /* Motorola RCE binary */
+/* end-sanitize-rce */
};
#define N_DYNAMIC(exec) ((exec).a_info & 0x80000000)
@@ -295,6 +306,10 @@ struct aoutdata {
/* Segment size - needed for alignment of demand paged files. */
unsigned long segment_size;
+ /* Zmagic disk block size - need to align the start of the text
+ section in ZMAGIC binaries. Normally the same as page_size. */
+ unsigned long zmagic_disk_block_size;
+
unsigned exec_bytes_size;
unsigned vma_adjusted : 1;
@@ -374,10 +389,10 @@ NAME(aout,squirt_out_relocs) PARAMS ((bfd *abfd, asection *section));
boolean
NAME(aout,make_sections) PARAMS ((bfd *));
-bfd_target *
+const bfd_target *
NAME(aout,some_aout_object_p) PARAMS ((bfd *abfd,
- struct internal_exec *execp,
- bfd_target * (*callback)(bfd *)));
+ struct internal_exec *execp,
+ const bfd_target *(*callback)(bfd *)));
boolean
NAME(aout,mkobject) PARAMS ((bfd *abfd));
diff --git a/gas/.Sanitize b/gas/.Sanitize
index a6e4825..c84aef3 100644
--- a/gas/.Sanitize
+++ b/gas/.Sanitize
@@ -125,7 +125,7 @@ else
done
fi
-rce_files="configure.in"
+rce_files="configure.in as.c"
if ( echo $* | grep keep\-rce > /dev/null ) ; then
for i in $rce_files ; do
diff --git a/gas/as.c b/gas/as.c
index 0eebdd3..5d69aa3 100644
--- a/gas/as.c
+++ b/gas/as.c
@@ -144,12 +144,10 @@ parse_args (pargc, pargv)
char *shortopts;
extern CONST char *md_shortopts;
- /* -v takes an argument on VMS, so we don't make it a generic option
- in that case. */
-#ifdef OBJ_VMS
+#ifdef VMS
+ /* -v takes an argument on VMS, so we don't make it a generic option. */
CONST char *std_shortopts = "-JKLRWZfa::DI:o:wX";
#else
- /* Normal set of short options. */
CONST char *std_shortopts = "-JKLRWZfa::DI:o:vwX";
#endif
@@ -167,6 +165,8 @@ parse_args (pargc, pargv)
{"version", no_argument, NULL, OPTION_VERSION},
#define OPTION_DUMPCONFIG (OPTION_STD_BASE + 4)
{"dump-config", no_argument, NULL, OPTION_DUMPCONFIG},
+#define OPTION_VERBOSE (OPTION_STD_BASE + 5)
+ {"verbose", no_argument, NULL, OPTION_VERBOSE},
};
/* Construct the option lists from the standard list and the
@@ -203,9 +203,28 @@ parse_args (pargc, pargv)
default:
/* md_parse_option should return 1 if it recognizes optc,
0 if not. */
- if (md_parse_option (optc, optarg) == 0)
- exit (EXIT_FAILURE);
- break;
+ if (md_parse_option (optc, optarg) != 0)
+ break;
+ /* `-v' isn't included in the general short_opts list, so check for
+ it explicity here before deciding we've gotten a bad argument. */
+ if (optc == 'v')
+ {
+#ifdef VMS
+ /* Telling getopt to treat -v's value as optional can result
+ in it picking up a following filename argument here. The
+ VMS code in md_parse_option can return 0 in that case,
+ but it has no way of pushing the filename argument back. */
+ if (optarg && *optarg)
+ new_argv[new_argc++] = optarg, new_argv[new_argc] = NULL;
+ else
+#else
+ case 'v':
+#endif
+ case OPTION_VERBOSE:
+ print_version_id ();
+ break;
+ }
+ /*FALLTHRU*/
case '?':
exit (EXIT_FAILURE);
@@ -244,9 +263,6 @@ parse_args (pargc, pargv)
#endif
exit (EXIT_SUCCESS);
- case 'v':
- print_version_id ();
-
case 'J':
flag_signed_overflow_ok = 1;
break;
@@ -398,6 +414,11 @@ main (argc, argv)
#ifdef TC_I960
brtab_emit ();
#endif
+/* start-sanitize-rce */
+#ifdef TC_RCE
+ dump_literals(0);
+#endif
+/* end-sanitize-rce */
if (seen_at_least_1_file ()
&& !((had_warnings () && flag_always_generate_output)
diff --git a/gas/config/.Sanitize b/gas/config/.Sanitize
index 1a23079..0d46153 100644
--- a/gas/config/.Sanitize
+++ b/gas/config/.Sanitize
@@ -15,7 +15,7 @@
Do-first:
-r16_files="tc-r16.c tc-r16.h"
+r16_files="tc-r16.c tc-r16.h rce.mt"
if ( echo $* | grep keep\-r16 > /dev/null ) ; then
keep_these_too="${r16_files} ${keep_these_too}"
diff --git a/gas/config/rce.mt b/gas/config/rce.mt
new file mode 100644
index 0000000..5c82ab4
--- /dev/null
+++ b/gas/config/rce.mt
@@ -0,0 +1 @@
+TARG_CPU_DEPENDENTS=$(srcdir)/../opcodes/rce-opc.h
diff --git a/gas/config/tc-rce.c b/gas/config/tc-rce.c
index 2b4c50f..3a82265 100644
--- a/gas/config/tc-rce.c
+++ b/gas/config/tc-rce.c
@@ -30,6 +30,7 @@
#define DEFINE_TABLE
#include "../opcodes/rce-opc.h"
#include <ctype.h>
+#include <string.h>
#if 1 /**** TEMP ****/
#define R_PCRELIMM8BY4 23 /* 8 bit pc relative to long boundary shifted 4 */
@@ -148,7 +149,7 @@ parse_reg (s, reg)
char *s;
unsigned *reg;
{
- if (s[0] == 'r')
+ if ( tolower(s[0]) == 'r')
{
if (s[1] == '1' && s[2] >= '0' && s[2] <= '5')
{
@@ -165,14 +166,46 @@ unsigned *reg;
return s;
}
+static struct Cregs {
+ char *name;
+ unsigned int crnum;
+} cregs[] = {
+ {"psr", 0},
+ {"epsr", 1},
+ {"fpsr", 2},
+ {"epc", 3},
+ {"fpc", 4},
+ {"ss0", 5},
+ {"ss1", 6},
+ {"ss2", 7},
+ {"ss3", 8},
+ {"aar", 9},
+ {"gcr", 10},
+ {"gsr", 11},
+ {"", 0}
+};
+
static char *
parse_creg (s, reg)
char *s;
unsigned *reg;
{
- if (s[0] == 'c' && s[1] == 'r')
+ char buf[10];
+ int i,j,length;
+
+ if ( (tolower(s[0]) == 'c' && tolower(s[1]) == 'r') )
{
- if (s[2] == '1' && s[3] >= '0' && s[3] <= '5')
+ if (s[2] == '3' && s[3] >= '0' && s[3] <= '1')
+ {
+ *reg = 30 + s[3] - '0';
+ return s+4;
+ }
+ if (s[2] == '2' && s[3] >= '0' && s[3] <= '9')
+ {
+ *reg = 20 + s[3] - '0';
+ return s+4;
+ }
+ if (s[2] == '1' && s[3] >= '0' && s[3] <= '9')
{
*reg = 10 + s[3] - '0';
return s+4;
@@ -183,6 +216,15 @@ unsigned *reg;
return s+3;
}
}
+ /** look at alternate creg names before giving error **/
+ for(i=0; *(cregs[i].name)!='\0'; i++) {
+ length=strlen(cregs[i].name);
+ for(j=0; j<length; j++) buf[j]=tolower(s[j]);
+ if ( strncmp(cregs[i].name,buf,length)==0 ) {
+ *reg=cregs[i].crnum;
+ return( s+length );
+ }
+ }
as_bad("register expected");
return s;
}
@@ -229,11 +271,15 @@ unsigned *reg;
unsigned *off;
unsigned siz;
{ char *new;
+ char *parse_imm_notation();
if (*s == '(')
{ s = parse_reg(s+1, reg);
if (*s == ',')
- { s = parse_imm(s+1, off, 0, 63);
+ {
+ s = parse_imm_notation(s+1);
+ if( parse_imm_notation(NULL) ) siz=1;
+ s = parse_imm(s, off, 0, 63);
if (siz > 1)
{ if (siz > 2)
{
@@ -259,6 +305,25 @@ unsigned siz;
return s;
}
+/* look for immediate notation '#' */
+static char *
+parse_imm_notation(s)
+char *s;
+{
+ static int isa_imm;
+
+ if( s == (char *)(NULL) ) return( (char *)(isa_imm) );
+ isa_imm=0;
+ while( isspace(*s) )
+ s++;
+ if( *s=='#' ) {
+ isa_imm=1;
+ s++;
+ }
+ return(s);
+}
+
+
/* This is the guts of the machine-dependent assembler. STR points to a
@@ -310,7 +375,8 @@ char *str;
output = frag_more (2);
break;
case OT:
- op_end = parse_imm(op_end + 1, &reg, 0, 15);
+ op_end = parse_imm_notation(op_end + 1);
+ op_end = parse_imm(op_end, &reg, 0, 7);
inst |= reg;
output = frag_more (2);
break;
@@ -319,6 +385,13 @@ char *str;
inst |= reg;
output = frag_more (2);
break;
+ case JSR:
+ op_end = parse_reg (op_end + 1, &reg);
+ if(reg==15)
+ as_bad("invalid register specified -> r15");
+ inst |= reg;
+ output = frag_more (2);
+ break;
case OC:
op_end = parse_reg (op_end + 1, &reg);
inst |= reg;
@@ -339,12 +412,31 @@ char *str;
as_bad("second operand missing");
output = frag_more (2);
break;
+ case X1: /** handle both syntax-> xtrb- r1,rx OR xtrb- rx **/
+ op_end = parse_reg (op_end + 1, &reg);
+ if (*op_end == ',') { /** xtrb- r1,rx **/
+ if (reg != 1)
+ as_bad("destination register must be r1");
+ op_end = parse_reg(op_end + 1, &reg);
+ }
+ else { /** xtrb- rx **/
+ }
+ inst |= reg;
+ output = frag_more (2);
+ break;
case OI:
op_end = parse_reg (op_end + 1, &reg);
inst |= reg;
if (*op_end == ',')
- { op_end = parse_imm(op_end + 1, &reg, 1, 32);
- inst |= (reg-1)<<4;
+ { unsigned int maxval = 32;
+ unsigned int minval = 1;
+ op_end = parse_imm_notation(op_end + 1);
+ if( parse_imm_notation(NULL) ) {
+ maxval=31;
+ minval=0;
+ }
+ op_end = parse_imm(op_end, &reg, minval, maxval);
+ inst |= (reg-minval)<<4;
}
else
as_bad("second operand missing");
@@ -354,7 +446,35 @@ char *str;
op_end = parse_reg (op_end + 1, &reg);
inst |= reg;
if (*op_end == ',')
- { op_end = parse_imm(op_end + 1, &reg, 0, 31);
+ { unsigned upper = 31;
+ op_end = parse_imm_notation(op_end + 1);
+ op_end = parse_imm(op_end, &reg, 0, upper);
+ inst |= reg<<4;
+ }
+ else
+ as_bad("second operand missing");
+ output = frag_more (2);
+ break;
+ case SI:
+ op_end = parse_reg (op_end + 1, &reg);
+ inst |= reg;
+ if (*op_end == ',')
+ { unsigned upper = 31;
+ op_end = parse_imm_notation(op_end + 1);
+ op_end = parse_imm(op_end, &reg, 1, upper);
+ inst |= reg<<4;
+ }
+ else
+ as_bad("second operand missing");
+ output = frag_more (2);
+ break;
+ case I7:
+ op_end = parse_reg (op_end + 1, &reg);
+ inst |= reg;
+ if (*op_end == ',')
+ { unsigned upper = 0x7f;
+ op_end = parse_imm_notation(op_end + 1);
+ op_end = parse_imm(op_end, &reg, 0, upper);
inst |= reg<<4;
}
else
@@ -384,7 +504,8 @@ char *str;
op_end = parse_reg (op_end + 1, &reg);
if (*op_end == ',')
{ unsigned val;
- op_end = parse_imm(op_end + 1, &val, 0, 0x7FF);
+ op_end = parse_imm_notation(op_end + 1);
+ op_end = parse_imm(op_end, &val, 0, 0x7FF);
inst |= val&0x7FF;
}
else
@@ -395,32 +516,53 @@ char *str;
break;
case LR:
op_end = parse_reg(op_end + 1, &reg);
- if (reg == 3 || reg == 15)
- as_bad("register must not be r3 or r15");
+ if( reg==0 || reg==15 )
+ as_bad ("invalid register 'r0' and 'r15' illegal");
inst |= (reg<<8);
- output = frag_more (2);
if (*op_end++ == ',')
{
- if (*op_end++ != '[')
- as_bad ("second operand missing '['");
- input_line_pointer = parse_exp(op_end);
- if (*input_line_pointer++ != ']')
- as_bad ("second operand missing ']'");
- fix_new_exp(frag_now, output-frag_now->fr_literal, 2, &immediate,
+ /** look for # notation **/
+ op_end = parse_imm_notation(op_end);
+ if( parse_imm_notation(NULL) )
+ { unsigned val;
+ op_end = parse_imm(op_end, &val, 0, 0x0FF);
+ inst |= val&0x0FF;
+ output = frag_more (2);
+ }
+ else
+ {
+ output = frag_more (2);
+ if (*op_end++ != '[' )
+ as_bad ("second operand missing '['");
+ input_line_pointer = parse_exp(op_end);
+ if (*input_line_pointer++ != ']' )
+ as_bad ("second operand missing ']'");
+ fix_new_exp(frag_now, output-frag_now->fr_literal, 2, &immediate,
1, R_PCRELIMM8BY4);
+ }
}
else
as_bad("second operand missing");
break;
case LJ:
- output = frag_more (2);
- if (*++op_end != '[')
- as_bad ("operand missing '['");
- input_line_pointer = parse_exp(op_end+1);
- if (*input_line_pointer++ != ']')
- as_bad ("operand missing ']'");
- fix_new_exp(frag_now, output-frag_now->fr_literal, 2, &immediate,
- 1, R_PCRELIMM8BY4);
+ /** look for # notation **/
+ op_end = parse_imm_notation(op_end + 1) -1;
+ if( parse_imm_notation(NULL) )
+ { unsigned val;
+ op_end = parse_imm(op_end+1, &val, 0, 0x0FF);
+ inst |= val&0x0FF;
+ output = frag_more (2);
+ }
+ else
+ { output = frag_more (2);
+ if (*++op_end != '[')
+ as_bad ("operand missing '['");
+ input_line_pointer = parse_exp(op_end+1);
+ if (*input_line_pointer++ != ']')
+ as_bad ("operand missing ']'");
+ fix_new_exp(frag_now, output-frag_now->fr_literal,
+ 2, &immediate, 1, R_PCRELIMM8BY4);
+ }
break;
case OM:
op_end = parse_reg(op_end + 1, &reg);
@@ -434,8 +576,11 @@ char *str;
{ op_end = parse_reg(op_end + 1, &basereg);
if (*op_end == ')')
op_end++;
- if (endreg == 15 && basereg == 3)
- { inst |= 0x0080; /* list form */
+ if (endreg == 15 && basereg == 0)
+ {
+ if(reg==0 || reg==15)
+ as_bad("bad register list, r0 and r15 invalid as starting registers");
+ inst |= 0x0080; /* list form */
inst |= reg;
}
else if (endreg - reg == 3)
@@ -462,11 +607,56 @@ char *str;
as_bad("reg-reg expected");
output = frag_more (2);
break;
- case BR:
+ case OQ:
+ op_end = parse_reg(op_end + 1, &reg);
+ if (*op_end == '-')
+ { int endreg;
+ op_end = parse_reg(op_end + 1, &endreg);
+ if (*op_end == ',')
+ { int basereg;
+ op_end++;
+ if (*op_end == '(')
+ { op_end = parse_reg(op_end + 1, &basereg);
+ if (*op_end == ')')
+ op_end++;
+ if (endreg - reg == 3)
+ { inst |= basereg; /* quadrant form */
+ switch (reg)
+ { case 0: break;
+ case 4: inst |= (1<<5); break;
+ case 8: inst |= (2<<5); break;
+ case 12: inst |= (3<<5); break;
+ default:
+ as_bad("first register must be r0, r4, r8, or r12");
+ }
+ }
+ else
+ as_bad("bad register list or base register");
+ }
+ else
+ as_bad("base register expected");
+ }
+ else
+ as_bad("second operand missing");
+ }
+ else
+ as_bad("reg-reg expected");
output = frag_more (2);
- input_line_pointer = parse_exp(op_end+1);
- fix_new_exp (frag_now, output-frag_now->fr_literal, 2, &immediate,
- 1, R_PCRELIMM11BY2);
+ break;
+ case BR:
+ op_end = parse_imm_notation(op_end + 1);
+ if( parse_imm_notation(NULL) )
+ { unsigned val;
+ op_end = parse_imm(op_end, &val, 0, 0x7FF);
+ inst |= val&0x7FF;
+ output = frag_more (2);
+ }
+ else
+ { output = frag_more (2);
+ input_line_pointer = parse_exp(op_end);
+ fix_new_exp (frag_now, output-frag_now->fr_literal,
+ 2, &immediate, 1, R_PCRELIMM11BY2);
+ }
break;
default:
as_bad("cant deal with opcode \"%s\"", name);
@@ -791,9 +981,14 @@ md_apply_fix1 (fixP, val)
val /= 2;
if (((val & ~0x3ff) != 0) && ((val | 0x3ff) != -1))
as_warn ("pcrel for branch too far (0x%x) at 0x%x", val, addr);
+ /*****
+ BR no longer puts the sign-bit in bit0, leaves it in bit10
buf[0] |= ((val >> 7) & 0x7);
buf[1] |= ((val & 0x7f) << 1);
buf[1] |= ((val >> 10) & 0x1);
+ *****/
+ buf[0] |= ((val >> 8) & 0x7);
+ buf[1] |= (val & 0xff);
break;
case R_PCRELIMM8BY4: /* lower 8 bits of 2 byte opcode */
val += 3;
@@ -1040,4 +1235,3 @@ tc_aout_pre_write_hook (headers)
}
#endif
#endif /* !BFD_ASSEMBLER */
-
diff --git a/ld/emulparams/rce.sh b/ld/emulparams/rce.sh
index e32615e..7bc1f86 100644
--- a/ld/emulparams/rce.sh
+++ b/ld/emulparams/rce.sh
@@ -1,5 +1,6 @@
SCRIPT_NAME=rce
-OUTPUT_FORMAT="aout-rce"
-TEXT_START_ADDR=0x8000
-PAGE_SIZE=128
+OUTPUT_FORMAT="a.out-rce"
+PAGE_SIZE=0x1000
+TEXT_START_ADDR=0
+NONPAGED_TEXT_START_ADDR=0
ARCH=rce
diff --git a/ld/scripttempl/rce.sc b/ld/scripttempl/rce.sc
index bd763cb..0643925 100644
--- a/ld/scripttempl/rce.sc
+++ b/ld/scripttempl/rce.sc
@@ -2,53 +2,31 @@ cat <<EOF
OUTPUT_FORMAT("${OUTPUT_FORMAT}")
OUTPUT_ARCH(${ARCH})
-MEMORY {
- ram : o = 0x1000, l = 512k
- }
-
-SECTIONS
-{
-.text :
- {
- *(.text)
- *(.strings)
- ${RELOCATING+ _etext = . ; }
- } ${RELOCATING+ > ram}
-
-
-.tors : {
- ___ctors = . ;
- *(.ctors)
- ___ctors_end = . ;
- ___dtors = . ;
- *(.dtors)
- ___dtors_end = . ;
-} ${RELOCATING+ > ram}
-
-.data :
- {
- *(.data)
- ${RELOCATING+ _edata = . ; }
- } ${RELOCATING+ > ram}
-.bss :
- {
- ${RELOCATING+ _bss_start = . ; }
- *(.bss)
- *(COMMON)
- ${RELOCATING+ _end = . ; }
- } ${RELOCATING+ >ram}
-.stack ${RELOCATING+ 0x30000 } :
- {
- ${RELOCATING+ _stack = . ; }
- *(.stack)
- } ${RELOCATING+ > ram}
- .stab 0 ${RELOCATING+(NOLOAD)} :
+${RELOCATING+${LIB_SEARCH_DIRS}}
+${RELOCATING+__DYNAMIC = 0;}
+${STACKZERO+${RELOCATING+${STACKZERO}}}
+${SHLIB_PATH+${RELOCATING+${SHLIB_PATH}}}
+SECTIONS
+{
+ .text ${RELOCATING+${TEXT_START_ADDR}}:
+ {
+ CREATE_OBJECT_SYMBOLS
+ *(.text)
+ ${RELOCATING+_etext = ${DATA_ALIGNMENT};}
+ }
+ .data ${RELOCATING+${DATA_ALIGNMENT}} :
{
- [ .stab ]
+ *(.data)
+ ${CONSTRUCTING+CONSTRUCTORS}
+ ${RELOCATING+_edata = .;}
}
- .stabstr 0 ${RELOCATING+(NOLOAD)} :
+ .bss ${RELOCATING+SIZEOF(.data) + ADDR(.data)} :
{
- [ .stabstr ]
+ ${RELOCATING+ __bss_start = .};
+ *(.bss)
+ *(COMMON)
+ ${RELOCATING+_end = . };
+ ${RELOCATING+__end = . };
}
}
EOF
diff --git a/opcodes/rce-opc.h b/opcodes/rce-opc.h
index e9f697a..c1a9408 100644
--- a/opcodes/rce-opc.h
+++ b/opcodes/rce-opc.h
@@ -1,5 +1,5 @@
typedef enum {
- O0, OT, O1, OC, O2, OI, OB, LS, BR, LI, LR, LJ, OM
+ O0, OT, O1, OC, O2, X1, OI, OB, SI, I7, LS, BR, LI, LR, LJ, OM, OQ, JSR
} rce_opclass;
typedef struct inst
@@ -21,13 +21,15 @@ rce_opcode_info rce_table[]={
{ "mvc", O1, 0x0020 },
{ "mvcv", O1, 0x0030 },
{ "jmp", O1, 0x0040 },
-{ "jsr", O1, 0x0050 },
+{ "jsr", JSR, 0x0050 },
+/*****
{ "jmpt", O1, 0x0060 },
{ "jmpf", O1, 0x0070 },
-{ "tsteq", O1, 0x0080 },
+*****/
+{ "tstne", O1, 0x0080 },
{ "tstgt", O1, 0x0090 },
{ "tstlt", O1, 0x00A0 },
-{ "tstbz", O1, 0x00B0 },
+{ "tstnbz", O1, 0x00B0 },
{ "inct", O1, 0x00C0 },
{ "incf", O1, 0x00D0 },
{ "dect", O1, 0x00E0 },
@@ -36,23 +38,23 @@ rce_opcode_info rce_table[]={
{ "sextb", O1, 0x0110 },
{ "zexth", O1, 0x0120 },
{ "sexth", O1, 0x0130 },
-{ "xtrb3", O1, 0x0140 },
-{ "xtrb2", O1, 0x0150 },
-{ "xtrb1", O1, 0x0160 },
-{ "xtrb0", O1, 0x0170 },
+{ "xtrb3", X1, 0x0140 },
+{ "xtrb2", X1, 0x0150 },
+{ "xtrb1", X1, 0x0160 },
+{ "xtrb0", X1, 0x0170 },
{ "decgt", O1, 0x01C0 },
{ "declt", O1, 0x01D0 },
{ "brev", O1, 0x01E0 },
{ "not", O1, 0x01F0 },
-{ "mfcr", OC, 0x0200 },
-{ "mtcr", OC, 0x0300 },
-{ "mov", O2, 0x0400 },
-{ "movnc", O2, 0x0600 },
-{ "tst", O2, 0x0700 },
-{ "cmpeq", O2, 0x0800 },
-{ "cmpgt", O2, 0x0900 },
-{ "cmphi", O2, 0x0A00 },
+{ "mfcr", OC, 0x0400 },
+{ "mtcr", OC, 0x0600 },
+{ "mov", O2, 0x0200 },
+{ "movnc", O2, 0x0C00 },
+{ "tst", O2, 0x0B00 },
+{ "cmpne", O2, 0x0800 },
+{ "cmplt", O2, 0x0900 },
+{ "cmphs", O2, 0x0A00 },
{ "bgenr", O2, 0x0D00 },
{ "movt", O2, 0x0E00 },
{ "movf", O2, 0x0F00 },
@@ -71,8 +73,11 @@ rce_opcode_info rce_table[]={
{ "lsr", O2, 0x1C00 },
{ "asr", O2, 0x1D00 },
{ "lsl", O2, 0x1E00 },
+/*****
{ "rotl", O2, 0x1F00 },
-{ "movi", OB, 0x2000 },
+*****/
+
+{ "movi", I7, 0x6800 },
{ "andi", OB, 0x2200 },
{ "movit", OB, 0x2400 },
@@ -85,26 +90,30 @@ rce_opcode_info rce_table[]={
{ "rsubi", OB, 0x3200 },
{ "addi", OI, 0x3400 },
{ "subi", OI, 0x3600 },
-{ "lsri", OB, 0x3800 },
+{ "lsri", SI, 0x3800 },
{ "lsrc", O1, 0x3800 },
-{ "asri", OB, 0x3A00 },
+{ "asri", SI, 0x3A00 },
{ "asrc", O1, 0x3A00 },
-{ "lsli", OB, 0x3C00 },
+{ "lsli", SI, 0x3C00 },
{ "lslc", O1, 0x3C00 },
-{ "rotli", OB, 0x3E00 },
-{ "rotlc", O1, 0x3E00 },
+{ "rotli", SI, 0x3E00 },
+{ "xsr", O1, 0x3E00 },
{ "ldm", OM, 0x6000 },
{ "stm", OM, 0x6010 },
+{ "ldq", OQ, 0x6000 },
+{ "stq", OQ, 0x6010 },
{ "mult", O2, 0x6100 },
-{ "mvir1", LI, 0x6800 },
+/* { "mvir1", LI, 0x6800 }, */
{ "lrw", LR, 0x7000 },
-{ "jmpi", LJ, 0x7300 },
+{ "jmpi", LJ, 0x7000 },
{ "jsri", LJ, 0x7F00 },
{ "ld", LS, 0x8000 },
{ "st", LS, 0x9000 },
+{ "ld.w", LS, 0x8000 },
+{ "st.w", LS, 0x9000 },
{ "ld.b", LS, 0xA000 },
{ "st.b", LS, 0xB000 },
{ "ld.h", LS, 0xC000 },