Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp4367065pxv; Tue, 20 Jul 2021 01:58:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyWOtHkOYCj8X138m6hkdxV25kUlQVJjKb/xvgUtq8I9AWz4vg1PwjA4Fowcpr557mSk2TH X-Received: by 2002:aa7:c907:: with SMTP id b7mr38745750edt.148.1626771525257; Tue, 20 Jul 2021 01:58:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626771525; cv=none; d=google.com; s=arc-20160816; b=sv7FYxzbZAr2B3wRI8TE1BBNRzBDZtp/Ov7HtLoK52oVIFcnjUnN8b0vfFw2a+FAKp lzZ3LzIcPwRAjSgzlsUKQ1foUlgwWlg5gi9a7FXp+9ElexSkL7DdjYoq8UDJIAmFAMdy 2AleoaTAGe9qZFwoYteJat7Dc83DSEo4nDoI8sHnkGFwECX90SsPu8Iu9hPbqcrf0KHN hUq6s8PZBI+JyejPtrPxc8txXCPxo6KfJFM5lyEKvk6+M4HBfSUr/ycSmRdYmuwBbJd7 TQ6dQ3e9E3+UiMRFu1wum3TgkdEIvyFRaFbDDm67nxqvX/c8cRFvebghyuXn+QbSIsRG xkhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :to:subject:dkim-signature; bh=hyHfreQCGU1n08jflxUm3GD5Es1OvyJ8VlqC19lqeQY=; b=FT8rrSAKRQKtoz/mrcWk2VVRcS7d+hXhpyvJuHzJx669cGcMwW1aHavLaav6iRNJ/2 JSRYKjUxKi182cUGoabRvW3L90sIu5g4ry7p1wc/OtceqOmvJIcmdJtwNmbFAsKp2G2t MuZB3xnoSI3LBEGYotCLjUSx3DeSdmWmJFz3C5beJIm44lVAzvDzcl0CzMwHeMwU+EEA G8Y23q10EWzpgEWI9f8DfXOz1ZIrfnblE1XqQE0dYbckS7sGs/9DcLpZDP1OhTTvCWvH Xk+qPQ9uahrDJPYR7a7a+WORjXzAD9UOrd+847C01BtyK5IeCzqtJl2iOrhVihX341QA vkOw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=FbegROJ9; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bl4si29386198ejb.17.2021.07.20.01.58.20; Tue, 20 Jul 2021 01:58:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=FbegROJ9; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234997AbhGTIQE (ORCPT + 99 others); Tue, 20 Jul 2021 04:16:04 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50388 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234817AbhGTIKU (ORCPT ); Tue, 20 Jul 2021 04:10:20 -0400 Received: from mail-pf1-x434.google.com (mail-pf1-x434.google.com [IPv6:2607:f8b0:4864:20::434]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5D995C061762 for ; Tue, 20 Jul 2021 01:50:59 -0700 (PDT) Received: by mail-pf1-x434.google.com with SMTP id d9so7781330pfv.4 for ; Tue, 20 Jul 2021 01:50:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-language:content-transfer-encoding; bh=hyHfreQCGU1n08jflxUm3GD5Es1OvyJ8VlqC19lqeQY=; b=FbegROJ90Iif54xm+O2OALn405pyfAJ8145JLRjkETF6hKetoYcN0nnEQ5/AjABZWW 6rZp7tgx2uBFBfBMrmRllXU0Igs7FKFLMVgxFexiOUiEs9sz3WKjb27K+zfbwjdMw4rI kxKq92ERO02d7NXieZ6mDNNe514vyrET7Ju2BJX6rn4v1tsIXVmmB5bA16d0Nzg8ivYQ 4ijlXfz7a7lIuyF8spDdmsM5QHnnmUm17Rref03RXj6Yopo38nW+pqJdZSBgzyjXK1fH O2ut3/96E27HBd4yokYh/917EnXg4GgTG/41FlbesLf+GrLDmLjZV35mSXMpxajqmFFm RsNA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=hyHfreQCGU1n08jflxUm3GD5Es1OvyJ8VlqC19lqeQY=; b=rwtrbX3A+DBvf5t9kyzx5F3VWhnm8HqdKLf+i5prt2snu4hGKxbIxSrlmCZAZESKce sYtx1Sr6MpQORcmKK2k8SLAJDQ/S3HfN/ymNW0n9nIzVQU+8bis/yYrtwKhtz2QnIgNN fwM6MBQY+E0Re9CdgqMG6jMpYEr6SXBNm5cGgQhbJQeNyPpsQkWvO6fZPpOHxP1KGBWW NozMDSIwTi4mY7HRwi2IR3FU7Q0wI/ZgP3y3JxIzM0Jc4L9zd8qSzuO4WwYdEHOsLrZY yZL2hsAFAdgQbyGOIYu8ed+no30Jj594nHbPg4I14oBUFkLdlyUNGIrcMeeIDvXy1YYh mgGQ== X-Gm-Message-State: AOAM530qCsVXJeSGAzwYgx/5uL+Fur2jZal2NdMr8w80zkspknAG/NJI 0LOfdJL/PGGYuROKA6cPXPlB8vYiJG4= X-Received: by 2002:a65:5284:: with SMTP id y4mr10889779pgp.19.1626771058139; Tue, 20 Jul 2021 01:50:58 -0700 (PDT) Received: from [192.168.1.153] (M106072041033.v4.enabler.ne.jp. [106.72.41.33]) by smtp.gmail.com with ESMTPSA id n5sm22829381pfv.29.2021.07.20.01.50.56 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 20 Jul 2021 01:50:57 -0700 (PDT) Subject: [PATCH 1/4] riscv: __asm_copy_to-from_user: Fix: overrun copy To: Paul Walmsley , Palmer Dabbelt , Guenter Roeck , Geert Uytterhoeven , Albert Ou , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org References: <37097718-c472-025a-2058-55667badc5b9@gmail.com> From: Akira Tsukamoto Message-ID: <415f9adf-8dd6-2467-8e74-0ed9d5cdfed9@gmail.com> Date: Tue, 20 Jul 2021 17:50:52 +0900 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.12.0 MIME-Version: 1.0 In-Reply-To: <37097718-c472-025a-2058-55667badc5b9@gmail.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There were two causes for the overrun memory access. The threshold size was too small. The aligning dst require one SZREG and unrolling word copy requires 8*SZREG, total have to be at least 9*SZREG. Inside the unrolling copy, the subtracting -(8*SZREG-1) would make iteration happening one extra loop. Proper value is -(8*SZREG). Signed-off-by: Akira Tsukamoto --- arch/riscv/lib/uaccess.S | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/arch/riscv/lib/uaccess.S b/arch/riscv/lib/uaccess.S index bceb0629e440..8bbeca89a93f 100644 --- a/arch/riscv/lib/uaccess.S +++ b/arch/riscv/lib/uaccess.S @@ -35,7 +35,7 @@ ENTRY(__asm_copy_from_user) /* * Use byte copy only if too small. */ - li a3, 8*SZREG /* size must be larger than size in word_copy */ + li a3, 9*SZREG /* size must be larger than size in word_copy */ bltu a2, a3, .Lbyte_copy_tail /* @@ -75,7 +75,7 @@ ENTRY(__asm_copy_from_user) * a3 - a1 & mask:(SZREG-1) * t0 - end of aligned dst */ - addi t0, t0, -(8*SZREG-1) /* not to over run */ + addi t0, t0, -(8*SZREG) /* not to over run */ 2: fixup REG_L a4, 0(a1), 10f fixup REG_L a5, SZREG(a1), 10f @@ -97,7 +97,7 @@ ENTRY(__asm_copy_from_user) addi a1, a1, 8*SZREG bltu a0, t0, 2b - addi t0, t0, 8*SZREG-1 /* revert to original value */ + addi t0, t0, 8*SZREG /* revert to original value */ j .Lbyte_copy_tail .Lshift_copy: -- 2.17.1