diff options
Diffstat (limited to 'gas/config/tc-vax.c')
-rw-r--r-- | gas/config/tc-vax.c | 53 |
1 files changed, 27 insertions, 26 deletions
diff --git a/gas/config/tc-vax.c b/gas/config/tc-vax.c index 299746b..4112b09 100644 --- a/gas/config/tc-vax.c +++ b/gas/config/tc-vax.c @@ -291,9 +291,12 @@ md_apply_fix (fixS *fixP, valueT *valueP, segT seg ATTRIBUTE_UNUSED) fixP->fx_done = 1; } +/* Convert a number from VAX byte order (little endian) + into host byte order. + con is the buffer to convert, + nbytes is the length of the given buffer. */ long -md_chars_to_number (unsigned char con[], /* Low order byte 1st. */ - int nbytes) /* Number of bytes in the input. */ +md_chars_to_number (unsigned char con[], int nbytes) { long retval; @@ -803,13 +806,11 @@ static const short int vax_operand_width_size[256] = cases, we do the same idea. JACBxxx are all marked with a 'b!' JAOBxxx & JSOBxxx are marked with a 'b:'. */ #if (VIT_OPCODE_SYNTHETIC != 0x80000000) -You have just broken the encoding below, which assumes the sign bit - means 'I am an imaginary instruction'. +#error "You have just broken the encoding below, which assumes the sign bit means 'I am an imaginary instruction'." #endif #if (VIT_OPCODE_SPECIAL != 0x40000000) - You have just broken the encoding below, which assumes the 0x40 M bit means - 'I am not to be "optimised" the way normal branches are'. +#error "You have just broken the encoding below, which assumes the 0x40 M bit means 'I am not to be "optimised" the way normal branches are'." #endif static const struct vot @@ -998,18 +999,18 @@ vip_begin (int synthetic_too, /* 1 means include jXXX op-codes. */ R14 SP R15 PC */ -#define AP (12) -#define FP (13) -#define SP (14) -#define PC (15) +#define AP 12 +#define FP 13 +#define SP 14 +#define PC 15 -static int /* Return -1 or 0:15. */ -vax_reg_parse (char c1, char c2, /* 3 chars of register name. */ - char c3, char c4) /* c3 == 0 if 2-character reg name. */ +/* Returns the register number of something like '%r15' or 'ap', supplied + in four single chars. Returns -1 if the register isn't recognized, + 0..15 otherwise. */ +static int +vax_reg_parse (char c1, char c2, char c3, char c4) { - int retval; - - retval = -1; + int retval = -1; #ifdef OBJ_ELF if (c1 != '%') /* Register prefixes are mandatory for ELF. */ @@ -1229,12 +1230,12 @@ vax_reg_parse (char c1, char c2, /* 3 chars of register name. */ {@}#foo, no S^ 8+@ PC " i" optional {@}{q^}{(Rn)} 10+@+q option " bwl" optional */ +/* Dissect user-input 'optext' (which is something like "@B^foo@bar(AP)[FP]:") + using the vop in vopP. vopP's vop_access and vop_width. We fill _ndx, _reg, + _mode, _short, _warn, _error, _expr_begin, _expr_end and _nbytes. */ + static void -vip_op (char *optext, /* user's input string e.g.: "@B^foo@bar(AP)[FP]:" */ - struct vop *vopP) /* Input fields: vop_access, vop_width. - Output fields: _ndx, _reg, _mode, _short, _warn, - _error _expr_begin, _expr_end, _nbytes. - vop_nbytes : number of bytes in a datum. */ +vip_op (char *optext, struct vop *vopP) { /* Track operand text forward. */ char *p; @@ -2142,9 +2143,8 @@ main (void) } } -mumble (text, value) - char *text; - int value; +void +mumble (char *text, int value) { printf ("%s:", text); if (value >= 0) @@ -2204,9 +2204,9 @@ struct option md_longopts[] = { #ifdef OBJ_ELF #define OPTION_PIC (OPTION_MD_BASE) - {"pic", no_argument, NULL, OPTION_PIC}, + { "pic", no_argument, NULL, OPTION_PIC }, #endif - {NULL, no_argument, NULL, 0} + { NULL, no_argument, NULL, 0 } }; size_t md_longopts_size = sizeof (md_longopts); @@ -2408,6 +2408,7 @@ tc_gen_reloc (asection *section ATTRIBUTE_UNUSED, fixS *fixp) return reloc; } +/* vax:md_assemble() emit frags for 1 instruction given in textual form. */ void md_assemble (char *instruction_string) { |