aboutsummaryrefslogtreecommitdiff
path: root/gas/config
diff options
context:
space:
mode:
authorJan Beulich <jbeulich@suse.com>2021-08-11 08:35:42 +0200
committerJan Beulich <jbeulich@suse.com>2021-08-11 08:35:42 +0200
commit7727283e512e9ff0b014092a483560afbf7dddfe (patch)
treee1edae1528d2be9a6dd0ffc0fac37482def2f1a3 /gas/config
parent2557e081af9fde5552b1b96df04166d1a2df620c (diff)
downloadgdb-7727283e512e9ff0b014092a483560afbf7dddfe.zip
gdb-7727283e512e9ff0b014092a483560afbf7dddfe.tar.gz
gdb-7727283e512e9ff0b014092a483560afbf7dddfe.tar.bz2
Arm64: leave .bfloat16 processing to common code
With x86 support having been implemented by extending atof-ieee.c, avoid unnecessary code duplication in md_atof(). This will then also allow to take advantage of adjustments made there without needing to mirror them here.
Diffstat (limited to 'gas/config')
-rw-r--r--gas/config/tc-aarch64.c50
1 files changed, 1 insertions, 49 deletions
diff --git a/gas/config/tc-aarch64.c b/gas/config/tc-aarch64.c
index 2eaad63..19a5d49 100644
--- a/gas/config/tc-aarch64.c
+++ b/gas/config/tc-aarch64.c
@@ -523,7 +523,7 @@ const char EXP_CHARS[] = "eE";
/* As in 0f12.456 */
/* or 0d1.2345e12 */
-const char FLT_CHARS[] = "rRsSfFdDxXeEpPhH";
+const char FLT_CHARS[] = "rRsSfFdDxXeEpPhHb";
/* Prefix character that indicates the start of an immediate value. */
#define is_immediate_prefix(C) ((C) == '#')
@@ -643,54 +643,6 @@ aarch64_get_expression (expressionS * ep,
const char *
md_atof (int type, char *litP, int *sizeP)
{
- /* If this is a bfloat16 type, then parse it slightly differently -
- as it does not follow the IEEE standard exactly. */
- if (type == 'b')
- {
- char * t;
- LITTLENUM_TYPE words[MAX_LITTLENUMS];
- FLONUM_TYPE generic_float;
-
- t = atof_ieee_detail (input_line_pointer, 1, 8, words, &generic_float);
-
- if (t)
- input_line_pointer = t;
- else
- return _("invalid floating point number");
-
- switch (generic_float.sign)
- {
- /* Is +Inf. */
- case 'P':
- words[0] = 0x7f80;
- break;
-
- /* Is -Inf. */
- case 'N':
- words[0] = 0xff80;
- break;
-
- /* Is NaN. */
- /* bfloat16 has two types of NaN - quiet and signalling.
- Quiet NaN has bit[6] == 1 && faction != 0, whereas
- signalling Nan's have bit[0] == 0 && fraction != 0.
- Chose this specific encoding as it is the same form
- as used by other IEEE 754 encodings in GAS. */
- case 0:
- words[0] = 0x7fff;
- break;
-
- default:
- break;
- }
-
- *sizeP = 2;
-
- md_number_to_chars (litP, (valueT) words[0], sizeof (LITTLENUM_TYPE));
-
- return NULL;
- }
-
return ieee_md_atof (type, litP, sizeP, target_big_endian);
}