Received: by 10.213.65.68 with SMTP id h4csp1690976imn; Mon, 19 Mar 2018 10:39:56 -0700 (PDT) X-Google-Smtp-Source: AG47ELvTfvPLm3LyyL6P0l/9vFlNIri79cpnGZ19gh2/YMdJqaJktHemrntZhbckqfd3ilHAvYIy X-Received: by 10.101.75.12 with SMTP id r12mr423892pgq.36.1521481196023; Mon, 19 Mar 2018 10:39:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521481196; cv=none; d=google.com; s=arc-20160816; b=Z0Xmgaz59Mc1X54t2nwm9MahZ+7Gmn+lXgBy3ceIr2bU6dKf2xr/cnFNZGlEHuT410 n/w1CAPQuFBPJjnGSK5OFnVT2xtM/6UMK1tJAOo6gdFJ31TVxR4LqiIuigGx3xL+IdYe 7mNnszCBgJ+RN3tWCf24Hjlz0wF92hzSSmMjN7rAzoqNXRRe+L54+KE+horfhWVWsIpe gu72SScrkveKpB+faDnXkvngSFRuVQJI+fEzKv258GEcsBs66z4EJJMZmAQN+YKx9GVX iwbFY/wAibyqJR+xNV+dBOmYuSeqJaPuzvpWsqoe1jm5sqDQRJZIcxqTVM1yMfekonSu c56g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :spamdiagnosticmetadata:spamdiagnosticoutput:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=EfvriCeqJJOpvyLlfcMx3nZTr14RoPpCxa0HZlT39T0=; b=NY9esWLsv+CERyUXT7nEYNJ7oYCKdkOyGzXHT42Xp68o5slj8EyVtVSodTc9SqF5LB F6qcs1Vp/hw34IDgIv+HOd0jWset87DGKY7tXg+ZhhQZHzyx/vImRUtwFsQ4qv7In9HD 2yoxGtkhPtxosjmluXRr/e6zEhQo5DLd0jxgG9ANLlDtLlDEXtKz2Og9pihLa8mlS9t4 Lnah8ECOT/ti2KRc74tGuWN2LCiE753H2yJFDNoCH9Qe8JCwjbw1tQF92PpoyyH5DXNM bdMnZSvCFwtYN2ZDZiR9j1S/SmUswZ7Juc4Gozs/aKfK0A96ne0UFyQ6Sks8kQ5IKrvE H8qQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=S1jFJe9W; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i84si269965pfk.233.2018.03.19.10.39.41; Mon, 19 Mar 2018 10:39:55 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=S1jFJe9W; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S967224AbeCSRhL (ORCPT + 99 others); Mon, 19 Mar 2018 13:37:11 -0400 Received: from mail-by2nam03on0113.outbound.protection.outlook.com ([104.47.42.113]:31931 "EHLO NAM03-BY2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S965980AbeCSQGo (ORCPT ); Mon, 19 Mar 2018 12:06:44 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=EfvriCeqJJOpvyLlfcMx3nZTr14RoPpCxa0HZlT39T0=; b=S1jFJe9Wh2/OiYKULkGyu3Q6QdIv6kY+eM02zzfqPGEsqRp0md2dswXIVfgmIJiegtP7NnHMWgv3QV+B75VoXxr57c6n0lf9vYuw86LxtVpfKIPwOigcoS0RFOlpo/HzSqR3bb4CQLZd2439o0LnwaTYbyfvjGcK+nc6TOftkAI= Received: from DM5PR2101MB1032.namprd21.prod.outlook.com (52.132.128.13) by DM5PR2101MB0920.namprd21.prod.outlook.com (52.132.132.165) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.631.0; Mon, 19 Mar 2018 16:06:40 +0000 Received: from DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::3d9b:79e7:94eb:5d62]) by DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::3d9b:79e7:94eb:5d62%5]) with mapi id 15.20.0631.004; Mon, 19 Mar 2018 16:06:40 +0000 From: Sasha Levin To: "linux-kernel@vger.kernel.org" , "stable@vger.kernel.org" CC: Josh Poimboeuf , Cong Wang , "David S . Miller" , Dmitry Vyukov , Eric Dumazet , Kostya Serebryany , Linus Torvalds , Marcelo Ricardo Leitner , Neil Horman , Peter Zijlstra , Thomas Gleixner , Vlad Yasevich , "linux-sctp@vger.kernel.org" , netdev , syzkaller , Ingo Molnar , Sasha Levin Subject: [PATCH AUTOSEL for 4.4 004/167] x86/asm: Don't use RBP as a temporary register in csum_partial_copy_generic() Thread-Topic: [PATCH AUTOSEL for 4.4 004/167] x86/asm: Don't use RBP as a temporary register in csum_partial_copy_generic() Thread-Index: AQHTv5wXKNHIHaUiw0ykqgvjDJHxEw== Date: Mon, 19 Mar 2018 16:05:24 +0000 Message-ID: <20180319160513.16384-4-alexander.levin@microsoft.com> References: <20180319160513.16384-1-alexander.levin@microsoft.com> In-Reply-To: <20180319160513.16384-1-alexander.levin@microsoft.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [52.168.54.252] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1;DM5PR2101MB0920;7:Kb7lO5saU4QVYDcdez1rIhwh9fGbuivRqqXGr7ZfAkFXB9HzCMsssdooYuK9zBnNkF/AX5nOX6PXAgOvTeL2vD09hH4Q+SqArZVZGvc4p/MHJAGDvpgLnimRsJhg3yMfDqgTfaUoUY+Fy+45MXdFwBZGnw2PBIBKOeLMf5uaAwWnUY+TddiN16zSwgraIH5VZ9hFvL+JLx2jWFftbzVJdhYJeJf3WgE5ZIuqVZvfr2Ws6S4yRu8aiiYhggJGAj3e;20:9lxZn9xWdpnfVWKfldPxQd3qEr6ygQ5ijvQTyvSkwx+Bzn300Crn9bNRbfdVzlz8v3dYN0ig/9qhP1kiFgsyDE5+oU/kC8xhfC3uYwJg/EvEPbRmCsi5tH5eyLYvbzI0ofr3gtWdhcF0/pA5TCWkKfFC0xKwJZYHV94Db7/Jz7s= x-ms-office365-filtering-ht: Tenant x-ms-office365-filtering-correlation-id: f0eb2823-4cb7-48b9-0816-08d58db366f7 x-microsoft-antispam: UriScan:(215639381216008);BCL:0;PCL:0;RULEID:(7020095)(4652020)(48565401081)(5600026)(4604075)(3008032)(4534165)(4627221)(201703031133081)(201702281549075)(2017052603328)(7193020);SRVR:DM5PR2101MB0920; x-ms-traffictypediagnostic: DM5PR2101MB0920: authentication-results: spf=none (sender IP is ) smtp.mailfrom=Alexander.Levin@microsoft.com; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:(28532068793085)(215639381216008)(89211679590171)(9452136761055)(85827821059158)(788757137089)(211936372134217)(42068640409301)(153496737603132); x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(8211001083)(61425038)(6040522)(2401047)(5005006)(8121501046)(3231221)(944501300)(52105095)(3002001)(93006095)(93001095)(10201501046)(6055026)(61426038)(61427038)(6041310)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123560045)(20161123562045)(20161123564045)(20161123558120)(6072148)(201708071742011);SRVR:DM5PR2101MB0920;BCL:0;PCL:0;RULEID:;SRVR:DM5PR2101MB0920; x-forefront-prvs: 06167FAD59 x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(346002)(39380400002)(396003)(376002)(39860400002)(366004)(189003)(199004)(6512007)(14454004)(2906002)(2900100001)(8936002)(186003)(86362001)(5250100002)(316002)(966005)(97736004)(2501003)(6116002)(1076002)(3846002)(81166006)(6436002)(6506007)(59450400001)(6486002)(26005)(72206003)(81156014)(53936002)(102836004)(478600001)(10290500003)(6306002)(8676002)(107886003)(6666003)(39060400002)(4326008)(3660700001)(66066001)(25786009)(2950100002)(86612001)(36756003)(54906003)(110136005)(3280700002)(7736002)(305945005)(5660300001)(7416002)(76176011)(68736007)(22452003)(10090500001)(105586002)(106356001)(99286004)(22906009)(41533002)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:DM5PR2101MB0920;H:DM5PR2101MB1032.namprd21.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;MX:1;A:1; received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: haGbrXLNU8I9dLZ0Y1caV/0orcV1hvx46WbscQHgrv/tUqzXdxEUuDuSal5ZotJuxy9HoVsn3eDFZjhQQpF1HYPqhboaUeI4iHmO7bFs9YwDhXCEvQnIAkQM9PLUvQU6zENCwsAAYMfMW7hlcWNeF15SHO+n3G5ulvYK1qOuxCiNsrpTqfcTqqDO1Nslgdu2E9mBhxEo/yhMLQMDvn6Vph0OIF8vuyttREDmf8ca5dUbpYnMCeCog2iGSFJzrQw289QhMzpj5crl9oMwFzlNyA2q/An7AhJoM8X2WbYlZptwSDQhVJA4NAru4nyMrjUAyAZ0wxo7d1Xqa1VF/XQ7kA== spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: microsoft.com X-MS-Exchange-CrossTenant-Network-Message-Id: f0eb2823-4cb7-48b9-0816-08d58db366f7 X-MS-Exchange-CrossTenant-originalarrivaltime: 19 Mar 2018 16:05:24.7461 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47 X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM5PR2101MB0920 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Josh Poimboeuf [ Upstream commit 42fc6c6cb1662ba2fa727dd01c9473c63be4e3b6 ] Andrey Konovalov reported the following warning while fuzzing the kernel with syzkaller: WARNING: kernel stack regs at ffff8800686869f8 in a.out:4933 has bad 'bp'= value c3fc855a10167ec0 The unwinder dump revealed that RBP had a bad value when an interrupt occurred in csum_partial_copy_generic(). That function saves RBP on the stack and then overwrites it, using it as a scratch register. That's problematic because it breaks stack traces if an interrupt occurs in the middle of the function. Replace the usage of RBP with another callee-saved register (R15) so stack traces are no longer affected. Reported-by: Andrey Konovalov Tested-by: Andrey Konovalov Signed-off-by: Josh Poimboeuf Cc: Cong Wang Cc: David S . Miller Cc: Dmitry Vyukov Cc: Eric Dumazet Cc: Kostya Serebryany Cc: Linus Torvalds Cc: Marcelo Ricardo Leitner Cc: Neil Horman Cc: Peter Zijlstra Cc: Thomas Gleixner Cc: Vlad Yasevich Cc: linux-sctp@vger.kernel.org Cc: netdev Cc: syzkaller Link: http://lkml.kernel.org/r/4b03a961efda5ec9bfe46b7b9c9ad72d1efad343.149= 3909486.git.jpoimboe@redhat.com Signed-off-by: Ingo Molnar Signed-off-by: Sasha Levin --- arch/x86/lib/csum-copy_64.S | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/arch/x86/lib/csum-copy_64.S b/arch/x86/lib/csum-copy_64.S index 7e48807b2fa1..45a53dfe1859 100644 --- a/arch/x86/lib/csum-copy_64.S +++ b/arch/x86/lib/csum-copy_64.S @@ -55,7 +55,7 @@ ENTRY(csum_partial_copy_generic) movq %r12, 3*8(%rsp) movq %r14, 4*8(%rsp) movq %r13, 5*8(%rsp) - movq %rbp, 6*8(%rsp) + movq %r15, 6*8(%rsp) =20 movq %r8, (%rsp) movq %r9, 1*8(%rsp) @@ -74,7 +74,7 @@ ENTRY(csum_partial_copy_generic) /* main loop. clear in 64 byte blocks */ /* r9: zero, r8: temp2, rbx: temp1, rax: sum, rcx: saved length */ /* r11: temp3, rdx: temp4, r12 loopcnt */ - /* r10: temp5, rbp: temp6, r14 temp7, r13 temp8 */ + /* r10: temp5, r15: temp6, r14 temp7, r13 temp8 */ .p2align 4 .Lloop: source @@ -89,7 +89,7 @@ ENTRY(csum_partial_copy_generic) source movq 32(%rdi), %r10 source - movq 40(%rdi), %rbp + movq 40(%rdi), %r15 source movq 48(%rdi), %r14 source @@ -103,7 +103,7 @@ ENTRY(csum_partial_copy_generic) adcq %r11, %rax adcq %rdx, %rax adcq %r10, %rax - adcq %rbp, %rax + adcq %r15, %rax adcq %r14, %rax adcq %r13, %rax =20 @@ -121,7 +121,7 @@ ENTRY(csum_partial_copy_generic) dest movq %r10, 32(%rsi) dest - movq %rbp, 40(%rsi) + movq %r15, 40(%rsi) dest movq %r14, 48(%rsi) dest @@ -203,7 +203,7 @@ ENTRY(csum_partial_copy_generic) movq 3*8(%rsp), %r12 movq 4*8(%rsp), %r14 movq 5*8(%rsp), %r13 - movq 6*8(%rsp), %rbp + movq 6*8(%rsp), %r15 addq $7*8, %rsp ret =20 --=20 2.14.1