forked from devyte/esp-quick-toolchain
-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
GCC: xtensa: backport patch from upstream
this PR relieves the problem (see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=102115): b552c4e601c7fdc4d341e29cc1ed6081d42b00d0 "gcc: xtensa: fix PR target/102115"
- Loading branch information
1 parent
6468f61
commit ed86506
Showing
4 changed files
with
116 additions
and
0 deletions.
There are no files selected for viewing
29 changes: 29 additions & 0 deletions
29
patches/gcc10.1/gcc-xtensa-0005-fix-PR-target-102115.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
From b552c4e601c7fdc4d341e29cc1ed6081d42b00d0 Mon Sep 17 00:00:00 2001 | ||
From: Max Filippov <[email protected]> | ||
Date: Tue, 7 Sep 2021 15:40:00 -0700 | ||
Subject: [PATCH] gcc: xtensa: fix PR target/102115 | ||
|
||
2021-09-07 Takayuki 'January June' Suwa <[email protected]> | ||
gcc/ | ||
PR target/102115 | ||
* config/xtensa/xtensa.c (xtensa_emit_move_sequence): Add | ||
'CONST_INT_P (src)' to the condition of the block that tries to | ||
eliminate literal when loading integer contant. | ||
--- | ||
gcc/config/xtensa/xtensa.c | 3 ++- | ||
1 file changed, 2 insertions(+), 1 deletion(-) | ||
|
||
diff --git a/gcc/config/xtensa/xtensa.c b/gcc/config/xtensa/xtensa.c | ||
index f4f8f1975c55a..8d6755144c120 100644 | ||
--- a/gcc/config/xtensa/xtensa.c | ||
+++ b/gcc/config/xtensa/xtensa.c | ||
@@ -1084,7 +1084,8 @@ xtensa_emit_move_sequence (rtx *operands, machine_mode mode) | ||
{ | ||
/* Try to emit MOVI + SLLI sequence, that is smaller | ||
than L32R + literal. */ | ||
- if (optimize_size && mode == SImode && register_operand (dst, mode)) | ||
+ if (optimize_size && mode == SImode && CONST_INT_P (src) | ||
+ && register_operand (dst, mode)) | ||
{ | ||
HOST_WIDE_INT srcval = INTVAL (src); | ||
int shift = ctz_hwi (srcval); |
29 changes: 29 additions & 0 deletions
29
patches/gcc10.2/gcc-xtensa-0005-fix-PR-target-102115.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
From b552c4e601c7fdc4d341e29cc1ed6081d42b00d0 Mon Sep 17 00:00:00 2001 | ||
From: Max Filippov <[email protected]> | ||
Date: Tue, 7 Sep 2021 15:40:00 -0700 | ||
Subject: [PATCH] gcc: xtensa: fix PR target/102115 | ||
|
||
2021-09-07 Takayuki 'January June' Suwa <[email protected]> | ||
gcc/ | ||
PR target/102115 | ||
* config/xtensa/xtensa.c (xtensa_emit_move_sequence): Add | ||
'CONST_INT_P (src)' to the condition of the block that tries to | ||
eliminate literal when loading integer contant. | ||
--- | ||
gcc/config/xtensa/xtensa.c | 3 ++- | ||
1 file changed, 2 insertions(+), 1 deletion(-) | ||
|
||
diff --git a/gcc/config/xtensa/xtensa.c b/gcc/config/xtensa/xtensa.c | ||
index f4f8f1975c55a..8d6755144c120 100644 | ||
--- a/gcc/config/xtensa/xtensa.c | ||
+++ b/gcc/config/xtensa/xtensa.c | ||
@@ -1084,7 +1084,8 @@ xtensa_emit_move_sequence (rtx *operands, machine_mode mode) | ||
{ | ||
/* Try to emit MOVI + SLLI sequence, that is smaller | ||
than L32R + literal. */ | ||
- if (optimize_size && mode == SImode && register_operand (dst, mode)) | ||
+ if (optimize_size && mode == SImode && CONST_INT_P (src) | ||
+ && register_operand (dst, mode)) | ||
{ | ||
HOST_WIDE_INT srcval = INTVAL (src); | ||
int shift = ctz_hwi (srcval); |
29 changes: 29 additions & 0 deletions
29
patches/gcc10.3/gcc-xtensa-0005-fix-PR-target-102115.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
From b552c4e601c7fdc4d341e29cc1ed6081d42b00d0 Mon Sep 17 00:00:00 2001 | ||
From: Max Filippov <[email protected]> | ||
Date: Tue, 7 Sep 2021 15:40:00 -0700 | ||
Subject: [PATCH] gcc: xtensa: fix PR target/102115 | ||
|
||
2021-09-07 Takayuki 'January June' Suwa <[email protected]> | ||
gcc/ | ||
PR target/102115 | ||
* config/xtensa/xtensa.c (xtensa_emit_move_sequence): Add | ||
'CONST_INT_P (src)' to the condition of the block that tries to | ||
eliminate literal when loading integer contant. | ||
--- | ||
gcc/config/xtensa/xtensa.c | 3 ++- | ||
1 file changed, 2 insertions(+), 1 deletion(-) | ||
|
||
diff --git a/gcc/config/xtensa/xtensa.c b/gcc/config/xtensa/xtensa.c | ||
index f4f8f1975c55a..8d6755144c120 100644 | ||
--- a/gcc/config/xtensa/xtensa.c | ||
+++ b/gcc/config/xtensa/xtensa.c | ||
@@ -1084,7 +1084,8 @@ xtensa_emit_move_sequence (rtx *operands, machine_mode mode) | ||
{ | ||
/* Try to emit MOVI + SLLI sequence, that is smaller | ||
than L32R + literal. */ | ||
- if (optimize_size && mode == SImode && register_operand (dst, mode)) | ||
+ if (optimize_size && mode == SImode && CONST_INT_P (src) | ||
+ && register_operand (dst, mode)) | ||
{ | ||
HOST_WIDE_INT srcval = INTVAL (src); | ||
int shift = ctz_hwi (srcval); |
29 changes: 29 additions & 0 deletions
29
patches/gcc11.1/gcc-xtensa-0005-fix-PR-target-102115.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
From b552c4e601c7fdc4d341e29cc1ed6081d42b00d0 Mon Sep 17 00:00:00 2001 | ||
From: Max Filippov <[email protected]> | ||
Date: Tue, 7 Sep 2021 15:40:00 -0700 | ||
Subject: [PATCH] gcc: xtensa: fix PR target/102115 | ||
|
||
2021-09-07 Takayuki 'January June' Suwa <[email protected]> | ||
gcc/ | ||
PR target/102115 | ||
* config/xtensa/xtensa.c (xtensa_emit_move_sequence): Add | ||
'CONST_INT_P (src)' to the condition of the block that tries to | ||
eliminate literal when loading integer contant. | ||
--- | ||
gcc/config/xtensa/xtensa.c | 3 ++- | ||
1 file changed, 2 insertions(+), 1 deletion(-) | ||
|
||
diff --git a/gcc/config/xtensa/xtensa.c b/gcc/config/xtensa/xtensa.c | ||
index f4f8f1975c55a..8d6755144c120 100644 | ||
--- a/gcc/config/xtensa/xtensa.c | ||
+++ b/gcc/config/xtensa/xtensa.c | ||
@@ -1084,7 +1084,8 @@ xtensa_emit_move_sequence (rtx *operands, machine_mode mode) | ||
{ | ||
/* Try to emit MOVI + SLLI sequence, that is smaller | ||
than L32R + literal. */ | ||
- if (optimize_size && mode == SImode && register_operand (dst, mode)) | ||
+ if (optimize_size && mode == SImode && CONST_INT_P (src) | ||
+ && register_operand (dst, mode)) | ||
{ | ||
HOST_WIDE_INT srcval = INTVAL (src); | ||
int shift = ctz_hwi (srcval); |