blob: 97422aeaf8aec9963e29175d3f7541f79e21fd21 [file] [log] [blame]
Brad Bishop286d45c2018-10-02 15:21:57 -04001From 34049c9fcaa256befad032cbcd8aa74beecf13dc Mon Sep 17 00:00:00 2001
2From: Mahesh Bodapati <mbodapat@xilinx.com>
3Date: Sat, 26 Aug 2017 19:21:47 -0700
4Subject: [PATCH] Fix the calculation of high word in a long long 64-bit
5
6This patch will change the calculation of high word in a long long 64-bit.
7Earlier to this patch the high word of long long word (0xF0000000ULL) is
8coming to be 0xFFFFFFFF and low word is 0xF0000000. Instead the high word
9should be 0x00000000 and the low word should be 0xF0000000. This patch
10removes the condition of checking high word = 0 & low word < 0.
11This check is not required for the correctness of calculating 32-bit high
12and low words in a 64-bit long long.
13
14ChangeLog:
15
162016-03-01 Nagaraju Mekala <nagaraju.mekala@xilinx.com>
17 Ajit Agarwal <ajitkum@xilinx.com>
18
19 * config/microblaze/microblaze.c (print_operand): Remove the
20 condition of checking high word = 0 & low word < 0.
21 * testsuite/gcc.target/microblaze/others/long.c: Add -O0 option.
22
23Signed-off-by: Nagaraju Mekala <nagaraju.mekala@xilinx.com>
24Signed-off-by: Ajit Agarwal <ajitkum@xilinx.com>
25Signed-off-by: Mahesh Bodapati <mbodapat@xilinx.com>
26Signed-off-by: Manjukumar Matha <manjukumar.harthikote-matha@xilinx.com>
27Upstream-Status: Pending
28---
29 gcc/config/microblaze/microblaze.c | 3 ---
30 1 file changed, 3 deletions(-)
31
32diff --git a/gcc/config/microblaze/microblaze.c b/gcc/config/microblaze/microblaze.c
33index a41121264e..2ed64971fb 100644
34--- a/gcc/config/microblaze/microblaze.c
35+++ b/gcc/config/microblaze/microblaze.c
36@@ -2509,9 +2509,6 @@ print_operand (FILE * file, rtx op, int letter)
37 {
38 val[0] = (INTVAL (op) & 0xffffffff00000000LL) >> 32;
39 val[1] = INTVAL (op) & 0x00000000ffffffffLL;
40- if (val[0] == 0 && val[1] < 0)
41- val[0] = -1;
42-
43 }
44 fprintf (file, "0x%8.8lx", (letter == 'h') ? val[0] : val[1]);
45 }
46--
472.14.2
48