From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.5 required=3.0 tests=BAYES_00, DKIM_ADSP_CUSTOM_MED,DKIM_INVALID,DKIM_SIGNED,HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8EE8CC388F2 for ; Thu, 22 Oct 2020 13:20:22 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 10DF7222E9 for ; Thu, 22 Oct 2020 13:20:22 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=fail reason="signature verification failed" (2048-bit key) header.d=google.com header.i=@google.com header.b="ChsOlRrZ" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 10DF7222E9 Authentication-Results: mail.kernel.org; dmarc=fail (p=reject dis=none) header.from=google.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 8DF446B00A4; Thu, 22 Oct 2020 09:20:12 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 839AA6B00A5; Thu, 22 Oct 2020 09:20:12 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 704426B00A6; Thu, 22 Oct 2020 09:20:12 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0134.hostedemail.com [216.40.44.134]) by kanga.kvack.org (Postfix) with ESMTP id 386AB6B00A4 for ; Thu, 22 Oct 2020 09:20:12 -0400 (EDT) Received: from smtpin03.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay02.hostedemail.com (Postfix) with ESMTP id B88923625 for ; Thu, 22 Oct 2020 13:20:11 +0000 (UTC) X-FDA: 77399619822.03.hand64_39024de27251 Received: from filter.hostedemail.com (10.5.16.251.rfc1918.com [10.5.16.251]) by smtpin03.hostedemail.com (Postfix) with ESMTP id 87AC628A4E8 for ; Thu, 22 Oct 2020 13:20:11 +0000 (UTC) X-HE-Tag: hand64_39024de27251 X-Filterd-Recvd-Size: 5575 Received: from mail-wm1-f73.google.com (mail-wm1-f73.google.com [209.85.128.73]) by imf39.hostedemail.com (Postfix) with ESMTP for ; Thu, 22 Oct 2020 13:20:10 +0000 (UTC) Received: by mail-wm1-f73.google.com with SMTP id s25so583603wmj.7 for ; Thu, 22 Oct 2020 06:20:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=sender:date:in-reply-to:message-id:mime-version:references:subject :from:to:cc; bh=YuCr19yY32x7rWFAvs+3N7JOh1jAyp/iY7KfCFpXvOQ=; b=ChsOlRrZcpMoNGFYVgPoeVQg4Og5D+L7BbXiRVwpiZdViVq24qE3ZXqD3tQKH1FVJ7 HPd8FiV4pgtZUpYsxjl4hjAI/chk6N6P7ZOwFJUSMDGqaZlGN3Hx2rCtgiR2Spdsr11A 3RijHVED0ZEakIzCCu8/+3wIW9zFSUQ1BdGEpmQt/saJo1CR2tEUDMT1zxXdSJBvnLiS 5+2dw/bqnsJNllMA9jtkCYiE9XPytCZ2yg+rSNEse1oRsbObLdRtoFTJYWV+BND/RPsk pbKBGe+3Ar4H6vvSgqCb8RcHo/nToy4mNwHFBvnAXbW5hdwoTVk4JYy0UyQMOuTBOAbB 3krg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=YuCr19yY32x7rWFAvs+3N7JOh1jAyp/iY7KfCFpXvOQ=; b=YxceieHekpdWCAb5BI0hjiQPVjlC/fh9FKj4/ofGNd6CweoE0owH51G1acDuAyYCPm NeuH9Jrm8PU6sxl+iL8ylgU495j1UyOs7I7cHJdQczEEK5hy+gvtriNHBdZduER4Xk7C 3gGNRTJ1fnowkK6w2RG+CeORqvKwTLxs4zx32vMKkbq/NHFfkr4kpqeTz3igLkZmx6Z4 K2jDtbg5F1WJvrXXG8vtErGcUOOKFHe3fKh/VaFXOC15vovnAv8fDZKx2rZhHG80+Z+e drUwmL/23T2ByxMqS1by0MV1HCRRvohwj0Mn5/B6+2RzNlQclfT3FBPQi+bRv8ZUF01p 9iZA== X-Gm-Message-State: AOAM531MtUqlGaTL38Ykb/pl+aLQ9arUs67BmoXgOMoeHB9rPuN07ta7 BUWSRWszIZlJrxBhZRLFi514iekK9AFz2vTr X-Google-Smtp-Source: ABdhPJwWNBYBHEv7lNZy893nJ+RAAVNZlsa6c03VHyI91VlaLfFFNpC5caS3U7BZ/Z95iIq4PIHypm2N0XWIka41 X-Received: from andreyknvl3.muc.corp.google.com ([2a00:79e0:15:13:7220:84ff:fe09:7e9d]) (user=andreyknvl job=sendgmr) by 2002:a7b:c04a:: with SMTP id u10mr2667777wmc.83.1603372809904; Thu, 22 Oct 2020 06:20:09 -0700 (PDT) Date: Thu, 22 Oct 2020 15:19:11 +0200 In-Reply-To: Message-Id: Mime-Version: 1.0 References: X-Mailer: git-send-email 2.29.0.rc1.297.gfa9743e501-goog Subject: [PATCH RFC v2 19/21] kasan: don't round_up too much From: Andrey Konovalov To: Catalin Marinas , Will Deacon , Vincenzo Frascino , Dmitry Vyukov , Alexander Potapenko , Marco Elver Cc: Evgenii Stepanov , Kostya Serebryany , Peter Collingbourne , Serban Constantinescu , Andrey Ryabinin , Elena Petrova , Branislav Rankov , Kevin Brodsky , Andrew Morton , kasan-dev@googlegroups.com, linux-arm-kernel@lists.infradead.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, Andrey Konovalov Content-Type: text/plain; charset="UTF-8" X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: For tag-based mode kasan_poison_memory() already rounds up the size. Do the same for software modes and remove round_up() from common code. Signed-off-by: Andrey Konovalov Link: https://linux-review.googlesource.com/id/Ib397128fac6eba874008662b4964d65352db4aa4 --- mm/kasan/common.c | 8 ++------ mm/kasan/shadow.c | 1 + 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/mm/kasan/common.c b/mm/kasan/common.c index 5622b0ec0907..983383ebe32a 100644 --- a/mm/kasan/common.c +++ b/mm/kasan/common.c @@ -215,9 +215,7 @@ void __kasan_unpoison_object_data(struct kmem_cache *cache, void *object) void __kasan_poison_object_data(struct kmem_cache *cache, void *object) { - kasan_poison_memory(object, - round_up(cache->object_size, KASAN_GRANULE_SIZE), - KASAN_KMALLOC_REDZONE); + kasan_poison_memory(object, cache->object_size, KASAN_KMALLOC_REDZONE); } /* @@ -290,7 +288,6 @@ static bool ____kasan_slab_free(struct kmem_cache *cache, void *object, { u8 tag; void *tagged_object; - unsigned long rounded_up_size; tag = get_tag(object); tagged_object = object; @@ -311,8 +308,7 @@ static bool ____kasan_slab_free(struct kmem_cache *cache, void *object, return true; } - rounded_up_size = round_up(cache->object_size, KASAN_GRANULE_SIZE); - kasan_poison_memory(object, rounded_up_size, KASAN_KMALLOC_FREE); + kasan_poison_memory(object, cache->object_size, KASAN_KMALLOC_FREE); if (static_branch_unlikely(&kasan_stack)) { if ((IS_ENABLED(CONFIG_KASAN_GENERIC) && !quarantine) || diff --git a/mm/kasan/shadow.c b/mm/kasan/shadow.c index 616ac64c4a21..ab1d39c566b9 100644 --- a/mm/kasan/shadow.c +++ b/mm/kasan/shadow.c @@ -82,6 +82,7 @@ void kasan_poison_memory(const void *address, size_t size, u8 value) * addresses to this function. */ address = reset_tag(address); + size = round_up(size, KASAN_GRANULE_SIZE); shadow_start = kasan_mem_to_shadow(address); shadow_end = kasan_mem_to_shadow(address + size); -- 2.29.0.rc1.297.gfa9743e501-goog