From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 2153) id 509973943429; Fri, 14 May 2021 14:57:18 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 509973943429 Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: Jakub Jelinek To: gcc-cvs@gcc.gnu.org Subject: [gcc(refs/vendors/redhat/heads/gcc-8-branch)] PR rtl-optimization/100263: Ensure register can change mode X-Act-Checkin: gcc X-Git-Author: Stefan Schulze Frielinghaus X-Git-Refname: refs/vendors/redhat/heads/gcc-8-branch X-Git-Oldrev: 8f9f9d6065d1906b37a0dc1f2407124dcb09ee27 X-Git-Newrev: ac6f0ee3638ebd1f7eee988af71bd5a5e835c647 Message-Id: <20210514145718.509973943429@sourceware.org> Date: Fri, 14 May 2021 14:57:18 +0000 (GMT) X-BeenThere: gcc-cvs@gcc.gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Gcc-cvs mailing list List-Unsubscribe: , List-Archive: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 14 May 2021 14:57:18 -0000 https://gcc.gnu.org/g:ac6f0ee3638ebd1f7eee988af71bd5a5e835c647 commit ac6f0ee3638ebd1f7eee988af71bd5a5e835c647 Author: Stefan Schulze Frielinghaus Date: Wed May 5 17:12:35 2021 +0200 PR rtl-optimization/100263: Ensure register can change mode For move2add_valid_value_p we also have to ask the target whether a register can be accessed in a different mode than it was set before. gcc/ChangeLog: PR rtl-optimization/100263 * postreload.c (move2add_valid_value_p): Ensure register can change mode. (cherry picked from commit bb283170e7a1f39bf533651418daf10ad18eccfc) Diff: --- gcc/postreload.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/gcc/postreload.c b/gcc/postreload.c index 184b158bb05..b97392337e7 100644 --- a/gcc/postreload.c +++ b/gcc/postreload.c @@ -1704,7 +1704,8 @@ move2add_valid_value_p (int regno, scalar_int_mode mode) { scalar_int_mode old_mode; if (!is_a (reg_mode[regno], &old_mode) - || !MODES_OK_FOR_MOVE2ADD (mode, old_mode)) + || !MODES_OK_FOR_MOVE2ADD (mode, old_mode) + || !REG_CAN_CHANGE_MODE_P (regno, old_mode, mode)) return false; /* The value loaded into regno in reg_mode[regno] is also valid in mode after truncation only if (REG:mode regno) is the lowpart of