aboutsummaryrefslogtreecommitdiff
path: root/gas/config/tc-mips.c
diff options
context:
space:
mode:
authorKen Raeburn <raeburn@cygnus>1997-11-08 02:44:22 +0000
committerKen Raeburn <raeburn@cygnus>1997-11-08 02:44:22 +0000
commitb3ed1af38cf124ba195bad7eb0bd2a49a5af0a56 (patch)
tree791aced6199b703a41ab7ae1640c73edbc83b630 /gas/config/tc-mips.c
parent4aa424c7a73608b514fc441e231e435d9c33c02d (diff)
downloadgdb-b3ed1af38cf124ba195bad7eb0bd2a49a5af0a56.zip
gdb-b3ed1af38cf124ba195bad7eb0bd2a49a5af0a56.tar.gz
gdb-b3ed1af38cf124ba195bad7eb0bd2a49a5af0a56.tar.bz2
* config/tc-mips.c (mips_ip): Added cases for "e", "%", and "P" operand types.
(hilo_interlocks): VR5400 has interlocks. (md_begin): Expect mips64vr5400, not mips64r5400. * config/tc-mips.c (mips_ip): In default case, call as_bad instead of fprintf, to get "assembler messages:" message output before instead of after.
Diffstat (limited to 'gas/config/tc-mips.c')
-rw-r--r--gas/config/tc-mips.c50
1 files changed, 46 insertions, 4 deletions
diff --git a/gas/config/tc-mips.c b/gas/config/tc-mips.c
index 0f63db5..2a9c39b 100644
--- a/gas/config/tc-mips.c
+++ b/gas/config/tc-mips.c
@@ -229,6 +229,9 @@ static int mips_3900 = -1;
/* start-sanitize-tx49 */ \
|| mips_cpu == 4900 \
/* end-sanitize-tx49 */ \
+ /* start-sanitize-vr5400 */ \
+ || mips_cpu == 5400 \
+ /* end-sanitize-vr5400 */ \
)
/* Whether the processor uses hardware interlocks to protect reads
@@ -880,8 +883,8 @@ md_begin ()
/* start-sanitize-vr5400 */
else if (strcmp (cpu, "r5400") == 0
- || strcmp (cpu, "mips64r5400") == 0)
- mips_cpu = 5400;
+ || strcmp (cpu, "mips64vr5400") == 0)
+ mips_cpu = 5400;
/* end-sanitize-vr5400 */
/* start-sanitize-r5900 */
@@ -6945,6 +6948,9 @@ mips_ip (str, ip)
case 'G': /* coprocessor destination register */
case 'x': /* ignore register name */
case 'z': /* must be zero register */
+ /* start-sanitize-vr5400 */
+ case 'P': /* performance register */
+ /* end-sanitize-vr5400 */
s_reset = s;
if (s[0] == '$')
{
@@ -7552,8 +7558,38 @@ mips_ip (str, ip)
ip->insn_opcode |= regno << OP_SH_CCC;
continue;
+ /* start-sanitize-vr5400 */
+ case 'e': /* must be at least one digit */
+ my_getExpression (&imm_expr, s);
+ check_absolute_expr (ip, &imm_expr);
+ if ((unsigned long) imm_expr.X_add_number > (unsigned long) OP_MASK_VECBYTE)
+ {
+ as_bad ("bad byte vector index (%ld)",
+ (long) imm_expr.X_add_number);
+ imm_expr.X_add_number = imm_expr.X_add_number;
+ }
+ ip->insn_opcode |= imm_expr.X_add_number << OP_SH_VECBYTE;
+ imm_expr.X_op = O_absent;
+ s = expr_end;
+ continue;
+
+ case '%':
+ my_getExpression (&imm_expr, s);
+ check_absolute_expr (ip, &imm_expr);
+ if ((unsigned long) imm_expr.X_add_number > (unsigned long) OP_MASK_VECALIGN)
+ {
+ as_bad ("bad byte vector index (%ld)",
+ (long) imm_expr.X_add_number);
+ imm_expr.X_add_number = imm_expr.X_add_number;
+ }
+ ip->insn_opcode |= imm_expr.X_add_number << OP_SH_VECALIGN;
+ imm_expr.X_op = O_absent;
+ s = expr_end;
+ continue;
+
+ /* end-sanitize-vr5400 */
default:
- fprintf (stderr, "bad char = '%c'\n", *args);
+ as_bad ("bad char = '%c'\n", *args);
internalError ();
}
break;
@@ -8722,7 +8758,13 @@ md_parse_option (c, arg)
break;
}
- if (sv && mips_cpu != 4300 && mips_cpu != 4100 && mips_cpu != 5000)
+ if (sv
+ && (mips_cpu != 4300
+ && mips_cpu != 4100
+ /* start-sanitize-vr5400 */
+ && mips_cpu != 5400
+ /* end-sanitize-vr5400 */
+ && mips_cpu != 5000))
{
as_bad ("ignoring invalid leading 'v' in -mcpu=%s switch", arg);
return 0;