Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp2999394rdh; Wed, 27 Sep 2023 22:14:00 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHSD16PxettwHr1+19XpWIZwtwc+vmTJeB+Kl3ECCscV4jGkWpwlEujODvS7kxpK3B0vj6V X-Received: by 2002:a05:6808:2183:b0:3ab:83fe:e182 with SMTP id be3-20020a056808218300b003ab83fee182mr246645oib.1.1695878040238; Wed, 27 Sep 2023 22:14:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695878040; cv=none; d=google.com; s=arc-20160816; b=kiQMGH6+iPkB5cU3vJx1/wGoCVydwy+jyQKaZw4/m3AhbgAP/q+Mm9Xv7kL6hNZGHe o4Of3ZIlLAcrYzV32tsipeQKc8fCagFjpGBLf7Vcyj2kNyH4G5rW6684CkqRWpUZFRRZ qsEHEUCiQhl5ziAhmWWV+45jbe/lR5U/2jCufaQ7ushllnN/Yx2WqVKPYQRlBsFugujd NeZ8RQkuiYDZoBnfPNZqDni9kz6USzNlTavYFSG/o1c1RFfNTA0iNbGuPzfJ2mJ8ZPk6 UMmHRldfmN6YgpOzlGowTw/SmN1j6i5FcX59gmquqbaSReNdPhWtWQKQYR5iAdb4Fxr1 pn/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=0XMwldW6UN1I1dk3Azzb++qSe7rjgpsUk5mNX0JgewE=; fh=XRJi3aaYGDrWpsut60np4SClQ2ugsHwYon2h2ZXatd0=; b=nsy2egt0umHcmadKvLuGVWYjl+cMGN4s8nek74KVlMtdRwrG6JKIENgTAA3LuKfgax T5y/2vLn/3+39TMUthxcyZwTfynvuZa9/Af8r+UqU2VBbWuL2NajNLwWrGv463I2HybM sl2JQnt+7a2A9suEUykTDwAh1fpMHswi3K9V4qNFD4e9yffmTH8R7fNGlY2vVjH8zoUS Czx6jKSc6DU9ttwkNUrmfi72sic0ThM4RdZnCgDrH4k6pfBo/eGxAWIyK9NBIQ+yToFA TNIsQWPC/5BRPh+F1/D6+0M6Tmn9vCi1nr0SkDl/elec8O1Slswl6f94amL1zGT601e9 8GHg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=oJQRurvF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from howler.vger.email (howler.vger.email. [2620:137:e000::3:4]) by mx.google.com with ESMTPS id cd19-20020a056a00421300b0068fb6fc3ff1si17126849pfb.209.2023.09.27.22.13.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 Sep 2023 22:14:00 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) client-ip=2620:137:e000::3:4; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=oJQRurvF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id 95DA280C4D69; Wed, 27 Sep 2023 21:53:21 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230179AbjI1ExT (ORCPT + 99 others); Thu, 28 Sep 2023 00:53:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32934 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229445AbjI1ExS (ORCPT ); Thu, 28 Sep 2023 00:53:18 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E6F5EF9; Wed, 27 Sep 2023 21:53:13 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id DFC98C433C8; Thu, 28 Sep 2023 04:53:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1695876793; bh=DyqeGBOHGNaWTSNuZKS3eruzn0IVxu339Um+OpsmcQc=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=oJQRurvFgSyAFtD69d8AsZCHW3JzWkQ9SWCp82zAqU5iyGAyNnoaJIGuAAUH/9RR3 Mx0tPQQ4YPtw2NQ8Wf8ig+pnebTl3HmwhbclJEEi7O/PNFacLZ+Fv8sFBFT2WiBTMt DkQaOiPSDx8adBuJ7S2W69TTNg3y4sUc8HPQ8oWdizW/xz7CF3z/qaY6vleqVJ9cC3 Yz716Egi/FoPoyjWRH3BHhMjSwdbndjk1YDCN5d54AxjJYhQtB3gJzQJvn9YISD6Kq OsO6U0dEVCHAwdYTSRC7GN2lGyQKqhRqe+RJYec8A7O6IyDjXM/5MJNxqPFFTbwNXD b7n42/AsKS2fA== Message-ID: <9e4cf2c9-a1a9-43a8-3f72-2824301bbc98@kernel.org> Date: Thu, 28 Sep 2023 14:53:09 +1000 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.15.1 Subject: Re: [PATCH] binfmt_elf_fdpic: clean up debug warnings Content-Language: en-US To: Kees Cook Cc: linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, palmer@rivosinc.com, ebiederm@xmission.com, brauner@kernel.org, viro@zeniv.linux.org.uk References: <20230927132933.3290734-1-gerg@kernel.org> <202309270858.680FCD9A85@keescook> From: Greg Ungerer In-Reply-To: <202309270858.680FCD9A85@keescook> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Wed, 27 Sep 2023 21:53:21 -0700 (PDT) Hi Kees, On 28/9/23 01:59, Kees Cook wrote: > On Wed, Sep 27, 2023 at 11:29:33PM +1000, Greg Ungerer wrote: >> The binfmt_elf_fdpic loader has some debug trace that can be enabled at >> build time. The recent 64-bit additions cause some warnings if that >> debug is enabled, such as: >> >> fs/binfmt_elf_fdpic.c: In function ‘elf_fdpic_map_file’: >> fs/binfmt_elf_fdpic.c:46:33: warning: format ‘%x’ expects argument of type ‘unsigned int’, but argument 3 has type ‘Elf64_Addr’ {aka ‘long long unsigned int’} [-Wformat=] >> 46 | #define kdebug(fmt, ...) printk("FDPIC "fmt"\n" ,##__VA_ARGS__ ) >> | ^~~~~~~~ >> ./include/linux/printk.h:427:25: note: in definition of macro ‘printk_index_wrap’ >> 427 | _p_func(_fmt, ##__VA_ARGS__); \ >> | ^~~~ >> >> Cast values to the largest possible type (which is equivilent to unsigned >> long long in this case) and use appropriate format specifiers to match. > > It seems like these should all just be "unsigned long", yes? Some of them yes, but not all. For example trying to use unsigned long in the last chunk of this patch: fs/binfmt_elf_fdpic.c: In function ‘elf_fdpic_map_file_by_direct_mmap’: fs/binfmt_elf_fdpic.c:46:33: warning: format ‘%lx’ expects argument of type ‘long unsigned int’, but argument 3 has type ‘long long unsigned int’ [-Wformat=] 46 | #define kdebug(fmt, ...) printk("FDPIC "fmt"\n" ,##__VA_ARGS__ ) | ^~~~~~~~ ./include/linux/printk.h:427:25: note: in definition of macro ‘printk_index_wrap’ 427 | _p_func(_fmt, ##__VA_ARGS__); \ | ^~~~ fs/binfmt_elf_fdpic.c:46:26: note: in expansion of macro ‘printk’ 46 | #define kdebug(fmt, ...) printk("FDPIC "fmt"\n" ,##__VA_ARGS__ ) | ^~~~~~ fs/binfmt_elf_fdpic.c:1152:25: note: in expansion of macro ‘kdebug’ 1152 | kdebug("clear[%d] ad=%lx sz=%lx", loop, | ^~~~~~ Regards Greg > -Kees > >> >> Fixes: b922bf04d2c1 ("binfmt_elf_fdpic: support 64-bit systems") >> Signed-off-by: Greg Ungerer >> --- >> fs/binfmt_elf_fdpic.c | 20 ++++++++++++-------- >> 1 file changed, 12 insertions(+), 8 deletions(-) >> >> diff --git a/fs/binfmt_elf_fdpic.c b/fs/binfmt_elf_fdpic.c >> index 43b2a2851ba3..97c3e8551aac 100644 >> --- a/fs/binfmt_elf_fdpic.c >> +++ b/fs/binfmt_elf_fdpic.c >> @@ -900,10 +900,12 @@ static int elf_fdpic_map_file(struct elf_fdpic_params *params, >> kdebug("- DYNAMIC[]: %lx", params->dynamic_addr); >> seg = loadmap->segs; >> for (loop = 0; loop < loadmap->nsegs; loop++, seg++) >> - kdebug("- LOAD[%d] : %08x-%08x [va=%x ms=%x]", >> + kdebug("- LOAD[%d] : %08llx-%08llx [va=%llx ms=%llx]", >> loop, >> - seg->addr, seg->addr + seg->p_memsz - 1, >> - seg->p_vaddr, seg->p_memsz); >> + (unsigned long long) seg->addr, >> + (unsigned long long) seg->addr + seg->p_memsz - 1, >> + (unsigned long long) seg->p_vaddr, >> + (unsigned long long) seg->p_memsz); >> >> return 0; >> >> @@ -1082,9 +1084,10 @@ static int elf_fdpic_map_file_by_direct_mmap(struct elf_fdpic_params *params, >> maddr = vm_mmap(file, maddr, phdr->p_memsz + disp, prot, flags, >> phdr->p_offset - disp); >> >> - kdebug("mmap[%d] sz=%lx pr=%x fl=%x of=%lx --> %08lx", >> - loop, phdr->p_memsz + disp, prot, flags, >> - phdr->p_offset - disp, maddr); >> + kdebug("mmap[%d] sz=%llx pr=%x fl=%x of=%llx --> %08lx", >> + loop, (unsigned long long) phdr->p_memsz + disp, >> + prot, flags, (unsigned long long) phdr->p_offset - disp, >> + maddr); >> >> if (IS_ERR_VALUE(maddr)) >> return (int) maddr; >> @@ -1146,8 +1149,9 @@ static int elf_fdpic_map_file_by_direct_mmap(struct elf_fdpic_params *params, >> >> #else >> if (excess > 0) { >> - kdebug("clear[%d] ad=%lx sz=%lx", >> - loop, maddr + phdr->p_filesz, excess); >> + kdebug("clear[%d] ad=%llx sz=%lx", loop, >> + (unsigned long long) maddr + phdr->p_filesz, >> + excess); >> if (clear_user((void *) maddr + phdr->p_filesz, excess)) >> return -EFAULT; >> } >> -- >> 2.25.1 >> >