Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp5993024pxb; Mon, 14 Feb 2022 12:36:54 -0800 (PST) X-Google-Smtp-Source: ABdhPJw6arPG5rkWQLyebRMdQpVL2NLMc98ZvKUn1pLxf0tvAD2PUkj75sxqJWOH+dJsGdiB1+fx X-Received: by 2002:a63:4b4a:: with SMTP id k10mr676125pgl.488.1644871013946; Mon, 14 Feb 2022 12:36:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644871013; cv=none; d=google.com; s=arc-20160816; b=BOPcjP7fyqQixck307CChZ0PmFAq/Zg0WEW9scfdt7oaZagz1p7oKAbyWVzYeONM/P E84C4DBnT2TPJ0QJJGrDZaZxzYtFXN5ZcAj6FG3rFNx4OHsApFlgAd7J6WeT660Q3H8K LlYv4O7l8d1tw28d/6vjD8srrDhRYfmZ//Fx3CL3g2tJIo2Ps2ycuVnDlSaAzRL5PdSg 1gDQhHk60lEs/aSITlvTpez6TBPkLZ0fb1LPhzeE4u4BLgSeStRZydVjHi8D8xrEYirL YZDmpsrs+fWErcBTcVEocPIBWzCD/K7FpDfu1Or0HGzJgjoisgnESZYxCcjJrgEJL1Mu zZ3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=GHEGfZ3YRrVciF6Oo6i+MibRKMrhVrq5kkV+eP8TiLk=; b=JD3ha6BIqBNZVeRvwPshgRC0KwoQqxm0K6kMRUTtFaA2KKyFIIz7EeaGaTyXhgnTMp Wdd01Ov5mlLb4Gfedh8cJiQOG/sGHmdTvJCda4aRO6ix7Q2dw5boICmJ7lIpFLBc7dsP eX70zbIn1GZVhfz7WCVomuNDeENY3549Fl09i6HhRdT8a4OU0Nnm/ZRUFqVTQWzgSUt/ gzqvBS0QvEYnXnoX1s8Tkyf5Q5n4kVmcmWdfbCCuQTaxR42b1FzmjyjxMK2TEMWxYJBC rFhElLWs8MouoAoOb5Rci8AyoMxASWuX3Z700mtKyOi6pHXr56XingqFYFuguT6Lns7z P/Jg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=TAOFGbHm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1: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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id qe10si3744334pjb.30.2022.02.14.12.36.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 14 Feb 2022 12:36:53 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=TAOFGbHm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1: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: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8A19E1516A2; Mon, 14 Feb 2022 12:06:09 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1354856AbiBNOFI (ORCPT + 99 others); Mon, 14 Feb 2022 09:05:08 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:44018 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232274AbiBNOFG (ORCPT ); Mon, 14 Feb 2022 09:05:06 -0500 Received: from mail-io1-xd2c.google.com (mail-io1-xd2c.google.com [IPv6:2607:f8b0:4864:20::d2c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1432EB7; Mon, 14 Feb 2022 06:04:59 -0800 (PST) Received: by mail-io1-xd2c.google.com with SMTP id 9so19982944iou.2; Mon, 14 Feb 2022 06:04:59 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=GHEGfZ3YRrVciF6Oo6i+MibRKMrhVrq5kkV+eP8TiLk=; b=TAOFGbHmG6Cx0rrMUNbeeEYtTCkUNLgBhBRu4cOqLqcE/ScrB523kOUeeQS1syouQj KxVY95pUUVjikxNMl1NEv/6faqgWJOCcBlGtKxgNsVbF45yo2Dof7/Z+q8UO+KKAPT7B QZEIPguA8QYO9ytJNBTtllbej2ItAF2BoX07tmUUSzRhPqQMJymrtCj9mCELnEvSIPeH 2CJqdcfPtxQdmuUCYnYpLe6EfUA+ddsWxOidIoeJS4OvpvIMImxCVjZe3oLqE0Tu1evR fw3VDnk2Wk3LyGYTzchLNrceZlrK5HZTm4nMIuBOAfN+ZsuMGBOwOAhZyh6aYgASHMIs 46Ow== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=GHEGfZ3YRrVciF6Oo6i+MibRKMrhVrq5kkV+eP8TiLk=; b=YRpXqUNhBqt2CGfXerbDUcG6zoGyithB/XHs/1wgR+gxpjzjOzF8f1aem6zvZRxPo0 16WrOFaTmFfth/GvblieZEToj+D84VPkHbZqI9hWCVg70SfQxYzJcW1HKDxIJ+jO/UMJ GowNc5yvmT3ffM3ONKwUdOlcAewUFBh3+PJgmgK5stzwGztKZPG5rWaE06am9jSflnr+ rsdYMNSfDcCdeL/WoVSU9vfmTwZKNjsd8pnlszhHVGIwTVMGPjawWxX0ExOC6/nTytOs JmaXWiOZAqu22/8DfweFX1YaWE45Me80xNwB/0cnHBz2ISvMel62BNk2ZEPtRiN8YNrr EgPg== X-Gm-Message-State: AOAM531hWtqr8L0a9RiOhkpbtT585v+Ljd65I977WeHXXjzYpYMK89zQ QZv2pznz/E6CEEjtFTlHSHYxy2lC51z/aqbSezE= X-Received: by 2002:a5d:941a:: with SMTP id v26mr7493818ion.64.1644847498530; Mon, 14 Feb 2022 06:04:58 -0800 (PST) MIME-Version: 1.0 References: <20220212130410.6901-1-ojeda@kernel.org> <20220212130410.6901-13-ojeda@kernel.org> <2a7dff8e0efb4142849802357284af51@AcuMS.aculab.com> In-Reply-To: <2a7dff8e0efb4142849802357284af51@AcuMS.aculab.com> From: Miguel Ojeda Date: Mon, 14 Feb 2022 15:04:47 +0100 Message-ID: Subject: Re: [PATCH v4 12/20] vsprintf: add new `%pA` format specifier To: David Laight Cc: Rasmus Villemoes , Andy Shevchenko , Miguel Ojeda , Linus Torvalds , Greg Kroah-Hartman , "rust-for-linux@vger.kernel.org" , "linux-kernel@vger.kernel.org" , Gary Guo , Alex Gaynor , Wedson Almeida Filho , Petr Mladek , Steven Rostedt , Sergey Senozhatsky Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 On Mon, Feb 14, 2022 at 12:37 PM David Laight wrote: > > Doesn't that stand a reasonable chance of blowing the kernel stack? > > vsnprintf() is likely to be on the 'worst case' stack path anyway. > Anything vaguely like a recursive call, or anything 'stack expensive' > inside vsnprintf() stands a real chance of overflowing the stack. There should be no recursion going on, but stack usage could be a concern depending on what the formatted types attempt to do (thus we need to be mindful when implementing `Display`) and what the compiler could possibly generate on a worst case (Gary, bjorn3 et. al. may want to give details about this). Cheers, Miguel