Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp92264iof; Sun, 5 Jun 2022 22:07:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxiROjIyNhM8XJthScflhOru+scA7fRGVDw9pENlAVfMX2qPPL0+wJfKCDvwCfg/2Rxy2DC X-Received: by 2002:a17:903:c3:b0:163:bfde:eec3 with SMTP id x3-20020a17090300c300b00163bfdeeec3mr22856754plc.152.1654492024567; Sun, 05 Jun 2022 22:07:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654492024; cv=none; d=google.com; s=arc-20160816; b=KzEHYX8WdwqeUl9or3SHTGfVYk6kGzBkd3Lw58HJmez+Bj5RUcylPBmQqFJv7+7h9+ 6QtfapXtE1nAeIc2clyTBkOFVufdR9Ih6zUyvymWa+jYqUEjbX7xb9terIwc6xanYRQu iRS412mkT4BGWPBBBxeXN7w4UY5HpvMUQITyR8rwdn52ZfFArcxNKMFUku2c8eAwekjQ GU5kwIyzicKNr5/5KfkmGcznjJ6jIcjTUBXzAclFbUiYuFvZ7ri+kFyjAoSu0wX2sq1F ON2volBnIO13eeBv5znkbOrxFDfiJYzEB07NT6zjL1LLspv3wIt0V+vPtGBaRS5xNcwV q/YA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=VJKGBDexodWWi3v7d8CIP7nDbDAKpXAShXjsyM+XqYo=; b=RWBPZ8f84p4mbnK18m9jPHAHlk7+1PR3PPX8cWWe7KM9FQDklwl7uYlB4RpliGox6q DDSKE+t34ZSnYbwhmi7tKh7nHsbE7pYxo/za7YKcIikQhIWWsapOX3A1SszyJfvbQKKo piVM+43oIBayKw+w4BZUgZiewTct4ReyLHRxB6vaGy+tRgVzb/+ZcHGm6gjWcO1PsMlC hgz7JRXWuPu8RMOStIDutSyp6M+LtCuIs5lA+CVsGEl2O0zmjCjBvgrU4Q6z4CRHqpeg 5d8kjUizV8nlbrM02JaUO2YGuB+OFF8I7dVU6+RTIffabmsp5QvJNlZsTB7I8gwQoq7/ T3EA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=L2aTCNAm; 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 n19-20020a635c53000000b003fd41012235si10812538pgm.803.2022.06.05.22.07.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 05 Jun 2022 22:07:04 -0700 (PDT) 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=L2aTCNAm; 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 25F4F138918; Sun, 5 Jun 2022 21:16:11 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240665AbiFDTdJ (ORCPT + 99 others); Sat, 4 Jun 2022 15:33:09 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47510 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240589AbiFDTbp (ORCPT ); Sat, 4 Jun 2022 15:31:45 -0400 Received: from mail-qk1-x730.google.com (mail-qk1-x730.google.com [IPv6:2607:f8b0:4864:20::730]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8F8A95006A for ; Sat, 4 Jun 2022 12:31:31 -0700 (PDT) Received: by mail-qk1-x730.google.com with SMTP id x75so4967012qkb.12 for ; Sat, 04 Jun 2022 12:31:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=VJKGBDexodWWi3v7d8CIP7nDbDAKpXAShXjsyM+XqYo=; b=L2aTCNAmvIeV+mmoBcGrwRVseEMQ39fJ5n8rwtdgsPesbbN4QJaLLyAyaaJEAZ1eGr bZcRZK/rri1uLE2KV3EOsQ9SizakITASmJSCRTRrcj9zKU+zJwrnveRiUR8fRe6NUBeG HawmFj4dJB6TflzYC+208jPJ1c0mI/IN/IE3KQYwS/dP8czbRj5pRCUTdzIA3hLmTRa7 SED/W4SYB8WGPmR6HUBBcWQPJuXh/GyI5VcFnRJhcgMbHlhrkZuL/3A1rr9hs9D2fPof Y2l4JGEeDSPIvCMuQpCV5xMGBF29JV8mozNwUHvqE2wKYS3ofK0WrWyL9sPxwiuVQLFq Y5xw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=VJKGBDexodWWi3v7d8CIP7nDbDAKpXAShXjsyM+XqYo=; b=v/heGYP763+BzTcYkfwD5aNu9uO6CuscPz+J8oay1uRKS+H3WqohXOzK9XHgIM79aV hZV3HOcsjkty20WzlJ8oWor+kFZ9JevVPotYsB78g9ytX/1pBvSNBY1Dgr5QMQnhLL3J /wiZXfPN9f+69Ky3DX7cPWJ2MIRVAXmYVJTvarzLQdnrY06O/oZk5CiS+uOYtR94ZV4x W8Y+Mq3RX8k7tfbZAgS1aoyT01/JLU3gittyNufJz4nsU+3J1q7D7v6q7lpdBrk7Lp4u /5MEfEWu/nR8z/3zzMnS1JOdA70T7/Sd1np6PktMPSqipTE1zwGoX15nEkZweUDFdpIY ptWA== X-Gm-Message-State: AOAM531LiZa2nfhzU/2b2cBImu7y0yMSQlkTNCtOWZ5kXoddfDKtHJx3 hYS8cm0G+RQlWgFWQiK7i55KyO3aTBKd X-Received: by 2002:a37:a683:0:b0:6a6:ae13:7df8 with SMTP id p125-20020a37a683000000b006a6ae137df8mr2473713qke.385.1654371088085; Sat, 04 Jun 2022 12:31:28 -0700 (PDT) Received: from moria.home.lan (c-73-219-103-14.hsd1.vt.comcast.net. [73.219.103.14]) by smtp.gmail.com with ESMTPSA id o17-20020ac84291000000b00304defdb1b3sm3537426qtl.85.2022.06.04.12.31.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 04 Jun 2022 12:31:27 -0700 (PDT) From: Kent Overstreet To: linux-kernel@vger.kernel.org Cc: Kent Overstreet , pmladek@suse.com, rostedt@goodmis.org Subject: [PATCH v3 25/33] clk: tegra: bpmp: Convert to printbuf Date: Sat, 4 Jun 2022 15:30:34 -0400 Message-Id: <20220604193042.1674951-26-kent.overstreet@gmail.com> X-Mailer: git-send-email 2.36.0 In-Reply-To: <20220604193042.1674951-1-kent.overstreet@gmail.com> References: <20220604193042.1674951-1-kent.overstreet@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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 This converts from seq_buf to printbuf, which is similar but heap allocates the string buffer. Previously in this code the string buffer was allocated on the stack; this means we've added a new potential memory allocation failure. This is fine though since it's only for a dev_printk() message. Memory allocation context: printbuf doesn't take gfp flags, instead we prefer the new memalloc_no*_(save|restore) interfaces to be used. Here the surrounding code is already allocating with GFP_KERNEL, so everything is fine. Signed-off-by: Kent Overstreet --- drivers/clk/tegra/clk-bpmp.c | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/drivers/clk/tegra/clk-bpmp.c b/drivers/clk/tegra/clk-bpmp.c index 6ecf18f71c..301551174c 100644 --- a/drivers/clk/tegra/clk-bpmp.c +++ b/drivers/clk/tegra/clk-bpmp.c @@ -5,7 +5,7 @@ #include #include -#include +#include #include #include @@ -360,39 +360,38 @@ static void tegra_bpmp_clk_info_dump(struct tegra_bpmp *bpmp, const struct tegra_bpmp_clk_info *info) { const char *prefix = ""; - struct seq_buf buf; + struct printbuf buf = PRINTBUF; unsigned int i; - char flags[64]; - - seq_buf_init(&buf, flags, sizeof(flags)); if (info->flags) - seq_buf_printf(&buf, "("); + prt_printf(&buf, "("); if (info->flags & TEGRA_BPMP_CLK_HAS_MUX) { - seq_buf_printf(&buf, "%smux", prefix); + prt_printf(&buf, "%smux", prefix); prefix = ", "; } if ((info->flags & TEGRA_BPMP_CLK_HAS_SET_RATE) == 0) { - seq_buf_printf(&buf, "%sfixed", prefix); + prt_printf(&buf, "%sfixed", prefix); prefix = ", "; } if (info->flags & TEGRA_BPMP_CLK_IS_ROOT) { - seq_buf_printf(&buf, "%sroot", prefix); + prt_printf(&buf, "%sroot", prefix); prefix = ", "; } if (info->flags) - seq_buf_printf(&buf, ")"); + prt_printf(&buf, ")"); dev_printk(level, bpmp->dev, "%03u: %s\n", info->id, info->name); - dev_printk(level, bpmp->dev, " flags: %lx %s\n", info->flags, flags); + dev_printk(level, bpmp->dev, " flags: %lx %s\n", info->flags, printbuf_str(&buf)); dev_printk(level, bpmp->dev, " parents: %u\n", info->num_parents); for (i = 0; i < info->num_parents; i++) dev_printk(level, bpmp->dev, " %03u\n", info->parents[i]); + + printbuf_exit(&buf); } static int tegra_bpmp_probe_clocks(struct tegra_bpmp *bpmp, -- 2.36.0