From: Jason Eckhardt Date: Thu, 7 Aug 2003 19:20:45 +0000 (+0000) Subject: 2003-08-07 Jason Eckhardt X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=14d3f36402b9a80ef66aa9a66b722f40617cde9f;p=binutils-gdb.git 2003-08-07 Jason Eckhardt * config/tc-i860.c (i860_check_label): New function. * config/tc-i860.h (i860_check_label): New prototype. (tc_check_label): Define macro as i860_check_label. --- diff --git a/gas/ChangeLog b/gas/ChangeLog index 34e88007e8a..bc9f7513c0d 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,9 @@ +2003-08-07 Jason Eckhardt + + * config/tc-i860.c (i860_check_label): New function. + * config/tc-i860.h (i860_check_label): New prototype. + (tc_check_label): Define macro as i860_check_label. + 2003-08-06 Jason Eckhardt * config/tc-i860.c (s_align_wrapper): New function and prototype. diff --git a/gas/config/tc-i860.c b/gas/config/tc-i860.c index f5e44574f36..8ee4c074df6 100644 --- a/gas/config/tc-i860.c +++ b/gas/config/tc-i860.c @@ -1527,3 +1527,19 @@ i860_handle_align (fragS *fragp) fragp->fr_var = 4; } +/* This is called after a user-defined label is seen. We check + if the label has a double colon (valid in Intel syntax mode only), + in which case it should be externalized. */ + +void +i860_check_label (symbolS *labelsym) +{ + /* At this point, the current line pointer is sitting on the character + just after the first colon on the label. */ + if (target_intel_syntax && *input_line_pointer == ':') + { + S_SET_EXTERNAL (labelsym); + input_line_pointer++; + } +} + diff --git a/gas/config/tc-i860.h b/gas/config/tc-i860.h index c5c39b45c01..4d0229d2e90 100644 --- a/gas/config/tc-i860.h +++ b/gas/config/tc-i860.h @@ -86,6 +86,11 @@ extern int target_big_endian; visible symbols can be overridden. */ #define EXTERN_FORCE_RELOC 0 +/* Bits for post-processing of a user defined label to check if + it has a double colon (Intel syntax only). */ +extern void i860_check_label (symbolS *labelsym); +#define tc_check_label(ls) i860_check_label (ls) + /* Bits for filling in rs_align_code fragments with NOPs. */ extern void i860_handle_align (struct frag *); #define HANDLE_ALIGN(fragp) i860_handle_align (fragp)