aboutsummaryrefslogtreecommitdiff
path: root/gas
diff options
context:
space:
mode:
Diffstat (limited to 'gas')
-rw-r--r--gas/ChangeLog7
-rw-r--r--gas/config/tc-ia64.c36
-rw-r--r--gas/testsuite/ChangeLog6
-rw-r--r--gas/testsuite/gas/ia64/regs.d4
-rw-r--r--gas/testsuite/gas/ia64/regs.pl2
-rw-r--r--gas/testsuite/gas/ia64/regs.s2
6 files changed, 30 insertions, 27 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 3441f75..897c916 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,10 @@
+2005-10-24 Jan Beulich <jbeulich@novell.com>
+
+ * config/tc-ia64.c (declare_register): Call symbol_create.
+ (md_begin): Remove local variables total, ar_base, and cr_base.
+ Start loops for registers at their respective first one. Don't
+ update md.regsym for alias names. Generate alias name tp for r13.
+
2005-10-21 DJ Delorie <dj@redhat.com>
* config/tc-m32c.c (md_cgen_lookup_reloc): Add more relocs. Print
diff --git a/gas/config/tc-ia64.c b/gas/config/tc-ia64.c
index 19b5769..5da3098 100644
--- a/gas/config/tc-ia64.c
+++ b/gas/config/tc-ia64.c
@@ -5599,7 +5599,7 @@ declare_register (name, regnum)
const char *err;
symbolS *sym;
- sym = symbol_new (name, reg_section, regnum, &zero_address_frag);
+ sym = symbol_create (name, reg_section, regnum, &zero_address_frag);
err = hash_insert (md.reg_hash, S_GET_NAME (sym), (PTR) sym);
if (err)
@@ -7366,7 +7366,7 @@ extra_goodness (int templ, int slot)
void
md_begin ()
{
- int i, j, k, t, total, ar_base, cr_base, goodness, best, regnum, ok;
+ int i, j, k, t, goodness, best, regnum, ok;
const char *err;
char name[8];
@@ -7541,51 +7541,42 @@ md_begin ()
md.entry_hash = hash_new ();
/* general registers: */
-
- total = 128;
- for (i = 0; i < total; ++i)
+ for (i = REG_GR; i < REG_GR + 128; ++i)
{
sprintf (name, "r%d", i - REG_GR);
md.regsym[i] = declare_register (name, i);
}
/* floating point registers: */
- total += 128;
- for (; i < total; ++i)
+ for (i = REG_FR; i < REG_FR + 128; ++i)
{
sprintf (name, "f%d", i - REG_FR);
md.regsym[i] = declare_register (name, i);
}
/* application registers: */
- total += 128;
- ar_base = i;
- for (; i < total; ++i)
+ for (i = REG_AR; i < REG_AR + 128; ++i)
{
sprintf (name, "ar%d", i - REG_AR);
md.regsym[i] = declare_register (name, i);
}
/* control registers: */
- total += 128;
- cr_base = i;
- for (; i < total; ++i)
+ for (i = REG_CR; i < REG_CR + 128; ++i)
{
sprintf (name, "cr%d", i - REG_CR);
md.regsym[i] = declare_register (name, i);
}
/* predicate registers: */
- total += 64;
- for (; i < total; ++i)
+ for (i = REG_P; i < REG_P + 64; ++i)
{
sprintf (name, "p%d", i - REG_P);
md.regsym[i] = declare_register (name, i);
}
/* branch registers: */
- total += 8;
- for (; i < total; ++i)
+ for (i = REG_BR; i < REG_BR + 8; ++i)
{
sprintf (name, "b%d", i - REG_BR);
md.regsym[i] = declare_register (name, i);
@@ -7606,17 +7597,16 @@ md_begin ()
}
/* define synonyms for application registers: */
- for (i = REG_AR; i < REG_AR + NELEMS (ar); ++i)
- md.regsym[i] = declare_register (ar[i - REG_AR].name,
- REG_AR + ar[i - REG_AR].regnum);
+ for (i = 0; i < NELEMS (ar); ++i)
+ declare_register (ar[i].name, REG_AR + ar[i].regnum);
/* define synonyms for control registers: */
- for (i = REG_CR; i < REG_CR + NELEMS (cr); ++i)
- md.regsym[i] = declare_register (cr[i - REG_CR].name,
- REG_CR + cr[i - REG_CR].regnum);
+ for (i = 0; i < NELEMS (cr); ++i)
+ declare_register (cr[i].name, REG_CR + cr[i].regnum);
declare_register ("gp", REG_GR + 1);
declare_register ("sp", REG_GR + 12);
+ declare_register ("tp", REG_GR + 13);
declare_register ("rp", REG_BR + 0);
/* pseudo-registers used to specify unwind info: */
diff --git a/gas/testsuite/ChangeLog b/gas/testsuite/ChangeLog
index 7260810..53f85f6 100644
--- a/gas/testsuite/ChangeLog
+++ b/gas/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2005-10-24 Jan Beulich <jbeulich@novell.com>
+
+ * gas/ia64/regs.pl: Also check tp alias of r13.
+ * gas/ia64/regs.s: Regenerate.
+ * gas/ia64/regs.d: Adjust.
+
2005-10-19 David Ung <davidu@mips.com>
* gas/mips/mips.exp: Run new test.
diff --git a/gas/testsuite/gas/ia64/regs.d b/gas/testsuite/gas/ia64/regs.d
index e51c500..1dbd137 100644
--- a/gas/testsuite/gas/ia64/regs.d
+++ b/gas/testsuite/gas/ia64/regs.d
@@ -1265,8 +1265,8 @@ Disassembly of section \.text:
1a26: 00 00 00 02 00 00 nop\.i 0x0
1a2c: 00 00 04 00 nop\.i 0x0;;
1a30: 01 08 00 00 00 21 \[MII\] mov r1=r0
- 1a36: c0 00 00 00 42 00 mov r12=r0
- 1a3c: 00 00 04 00 nop\.i 0x0;;
+ 1a36: c0 00 00 00 42 a0 mov r12=r0
+ 1a3c: 01 00 00 84 mov r13=r0;;
1a40: 0d 00 00 00 01 00 \[MFI\] nop\.m 0x0
1a46: 20 00 00 20 00 00 mov f2=f0
1a4c: 00 00 04 00 nop\.i 0x0;;
diff --git a/gas/testsuite/gas/ia64/regs.pl b/gas/testsuite/gas/ia64/regs.pl
index ca51cc0..1c7df5c 100644
--- a/gas/testsuite/gas/ia64/regs.pl
+++ b/gas/testsuite/gas/ia64/regs.pl
@@ -38,7 +38,7 @@ print "\n";
print "\t{ .mii;\n";
print "\tmov gp = r0\n";
print "\tmov sp = r0\n";
-print "\tnop.i 0;; }\n\n";
+print "\tmov tp = r0;; }\n\n";
print "// Floating point registers\n";
for ($i = 2; $i < 128; ++$i) {
diff --git a/gas/testsuite/gas/ia64/regs.s b/gas/testsuite/gas/ia64/regs.s
index 06226a5..8e77b0e 100644
--- a/gas/testsuite/gas/ia64/regs.s
+++ b/gas/testsuite/gas/ia64/regs.s
@@ -437,7 +437,7 @@ _start:
{ .mii;
mov gp = r0
mov sp = r0
- nop.i 0;; }
+ mov tp = r0;; }
// Floating point registers
{ .mfi; mov f2 = f0 ;; }