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=-10.3 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,MAILING_LIST_MULTI, NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_SANE_1 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 A094BC433DB for ; Tue, 16 Mar 2021 08:32:44 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id D09EA64FF9 for ; Tue, 16 Mar 2021 08:32:43 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org D09EA64FF9 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=csgroup.eu Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 5A3BD6B006C; Tue, 16 Mar 2021 04:32:43 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 55FB06B006E; Tue, 16 Mar 2021 04:32:43 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 3CCC36B0070; Tue, 16 Mar 2021 04:32:43 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0111.hostedemail.com [216.40.44.111]) by kanga.kvack.org (Postfix) with ESMTP id 1FC6D6B006C for ; Tue, 16 Mar 2021 04:32:43 -0400 (EDT) Received: from smtpin27.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay02.hostedemail.com (Postfix) with ESMTP id D5D672C8F for ; Tue, 16 Mar 2021 08:32:42 +0000 (UTC) X-FDA: 77925071364.27.E7FCEC9 Received: from pegase1.c-s.fr (pegase1.c-s.fr [93.17.236.30]) by imf03.hostedemail.com (Postfix) with ESMTP id EFD88C0007CC for ; Tue, 16 Mar 2021 08:32:41 +0000 (UTC) Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 4F063n3w10z9v02D; Tue, 16 Mar 2021 09:32:37 +0100 (CET) X-Virus-Scanned: Debian amavisd-new at c-s.fr Received: from pegase1.c-s.fr ([192.168.12.234]) by localhost (pegase1.c-s.fr [192.168.12.234]) (amavisd-new, port 10024) with ESMTP id l5wHRkQBPkSS; Tue, 16 Mar 2021 09:32:37 +0100 (CET) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase1.c-s.fr (Postfix) with ESMTP id 4F063n0rlPz9v02C; Tue, 16 Mar 2021 09:32:37 +0100 (CET) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id E4E128B789; Tue, 16 Mar 2021 09:32:37 +0100 (CET) X-Virus-Scanned: amavisd-new at c-s.fr Received: from messagerie.si.c-s.fr ([127.0.0.1]) by localhost (messagerie.si.c-s.fr [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id jhvqrq-uzdBC; Tue, 16 Mar 2021 09:32:37 +0100 (CET) Received: from [192.168.4.90] (unknown [192.168.4.90]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 3ADBD8B782; Tue, 16 Mar 2021 09:32:37 +0100 (CET) Subject: Re: [PATCH mm] kfence: fix printk format for ptrdiff_t To: Alexander Potapenko , Marco Elver , Segher Boessenkool Cc: Andrew Morton , Dmitriy Vyukov , Andrey Konovalov , Jann Horn , LKML , Linux Memory Management List , kasan-dev References: <20210303121157.3430807-1-elver@google.com> From: Christophe Leroy Message-ID: Date: Tue, 16 Mar 2021 09:32:32 +0100 User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: fr X-Stat-Signature: 35dqawat3qwcrnmy6uoan78abod4ht9a X-Rspamd-Server: rspam02 X-Rspamd-Queue-Id: EFD88C0007CC Received-SPF: none (csgroup.eu>: No applicable sender policy available) receiver=imf03; identity=mailfrom; envelope-from=""; helo=pegase1.c-s.fr; client-ip=93.17.236.30 X-HE-DKIM-Result: none/none X-HE-Tag: 1615883561-391037 Content-Transfer-Encoding: quoted-printable 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: +segher Le 03/03/2021 =C3=A0 13:27, Alexander Potapenko a =C3=A9crit=C2=A0: > On Wed, Mar 3, 2021 at 1:12 PM Marco Elver wrote: >> >> Use %td for ptrdiff_t. >> >> Link: https://lkml.kernel.org/r/3abbe4c9-16ad-c168-a90f-087978ccd8f7@c= sgroup.eu >> Reported-by: Christophe Leroy >> Signed-off-by: Marco Elver > Reviewed-by: Alexander Potapenko >=20 Still a problem. I don't understand, gcc bug ? The offending argument is 'const ptrdiff_t object_index' We have: arch/powerpc/include/uapi/asm/posix_types.h:typedef long __kernel_ptrdif= f_t; include/linux/types.h:typedef __kernel_ptrdiff_t ptrdiff_t; And get: CC mm/kfence/report.o In file included from ./include/linux/printk.h:7, from ./include/linux/kernel.h:16, from mm/kfence/report.c:10: mm/kfence/report.c: In function 'kfence_report_error': ./include/linux/kern_levels.h:5:18: warning: format '%td' expects argumen= t of type 'ptrdiff_t', but=20 argument 6 has type 'long int' [-Wformat=3D] 5 | #define KERN_SOH "\001" /* ASCII Start Of Header */ | ^~~~~~ ./include/linux/kern_levels.h:11:18: note: in expansion of macro 'KERN_SO= H' 11 | #define KERN_ERR KERN_SOH "3" /* error conditions */ | ^~~~~~~~ ./include/linux/printk.h:343:9: note: in expansion of macro 'KERN_ERR' 343 | printk(KERN_ERR pr_fmt(fmt), ##__VA_ARGS__) | ^~~~~~~~ mm/kfence/report.c:213:3: note: in expansion of macro 'pr_err' 213 | pr_err("Out-of-bounds %s at 0x%p (%luB %s of kfence-#%td):\n", | ^~~~~~ ./include/linux/kern_levels.h:5:18: warning: format '%td' expects argumen= t of type 'ptrdiff_t', but=20 argument 4 has type 'long int' [-Wformat=3D] 5 | #define KERN_SOH "\001" /* ASCII Start Of Header */ | ^~~~~~ ./include/linux/kern_levels.h:11:18: note: in expansion of macro 'KERN_SO= H' 11 | #define KERN_ERR KERN_SOH "3" /* error conditions */ | ^~~~~~~~ ./include/linux/printk.h:343:9: note: in expansion of macro 'KERN_ERR' 343 | printk(KERN_ERR pr_fmt(fmt), ##__VA_ARGS__) | ^~~~~~~~ mm/kfence/report.c:222:3: note: in expansion of macro 'pr_err' 222 | pr_err("Use-after-free %s at 0x%p (in kfence-#%td):\n", | ^~~~~~ ./include/linux/kern_levels.h:5:18: warning: format '%td' expects argumen= t of type 'ptrdiff_t', but=20 argument 2 has type 'long int' [-Wformat=3D] 5 | #define KERN_SOH "\001" /* ASCII Start Of Header */ | ^~~~~~ ./include/linux/kern_levels.h:24:19: note: in expansion of macro 'KERN_SO= H' 24 | #define KERN_CONT KERN_SOH "c" | ^~~~~~~~ ./include/linux/printk.h:385:9: note: in expansion of macro 'KERN_CONT' 385 | printk(KERN_CONT fmt, ##__VA_ARGS__) | ^~~~~~~~~ mm/kfence/report.c:229:3: note: in expansion of macro 'pr_cont' 229 | pr_cont(" (in kfence-#%td):\n", object_index); | ^~~~~~~ ./include/linux/kern_levels.h:5:18: warning: format '%td' expects argumen= t of type 'ptrdiff_t', but=20 argument 3 has type 'long int' [-Wformat=3D] 5 | #define KERN_SOH "\001" /* ASCII Start Of Header */ | ^~~~~~ ./include/linux/kern_levels.h:11:18: note: in expansion of macro 'KERN_SO= H' 11 | #define KERN_ERR KERN_SOH "3" /* error conditions */ | ^~~~~~~~ ./include/linux/printk.h:343:9: note: in expansion of macro 'KERN_ERR' 343 | printk(KERN_ERR pr_fmt(fmt), ##__VA_ARGS__) | ^~~~~~~~ mm/kfence/report.c:239:3: note: in expansion of macro 'pr_err' 239 | pr_err("Invalid free of 0x%p (in kfence-#%td):\n", (void *)add= ress, | ^~~~~~ Christophe