Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp3122760ybi; Thu, 18 Jul 2019 21:28:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqx6cvUQSny88iZevFp77cdN7Mnpw6sYABSQJC8BhZsjxYaSsAD5kq0/WZ9oEKUjQ6LqNrBd X-Received: by 2002:a63:1455:: with SMTP id 21mr8317614pgu.116.1563510507309; Thu, 18 Jul 2019 21:28:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563510507; cv=none; d=google.com; s=arc-20160816; b=OZCuRILwhzkNKzyKeYlonkRYo1uFtaZ3rl7cJEJvk590HOeqA2w26rtqfMa44+B+In dpR2j87BoyX01hrYedFwT0lwuLyPtki/uKqv5xmRBP8ukD3jpUYAwfQdozZs3qnXOvYX poNd4Sf5QeLQW8DM5D7OJ+1MQ3IxDil9ogT0+KjgCR5qVoisW/Z/6DwWki2vQMe0NkFl k6z8R0m80480cWeE4pNutzkDZlJ04EfsQBI1OLJKvM/hOoeKV3YUx8Jcd4azJOZWMUKG 0L1FiiqfOvjzV2Dvz1rKNqFEouLrvixXPSzSqWt4/Jvf+mcTxbTg5OKtxAegrJNfVL7W vtfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=7uWL+i7vfn1a0W9tVd/zenJ9uWf1rLml+3w8K7MqpfU=; b=MCq4xR2/BMOisPTY0U7wtD+8JgFFICFK30OlfBejIEwfak47VmiT2/kehik6WqPlIz DWf6SJpQa5WoCMmq+hP+7olORhrHmOOHpskL6xSEpkwKjDICei4WviDcJViGNheHpA3R B99e3om1LvSbxdV37TLVHjoC0MMUw/Xxfhz0Xw5c6Fqc5zAkPMEsZgKCinXq1h0XXpQG 233XLsj63RwyufcOGbTdKyZqu3Ms6sXX4ZzP49PpNnSXaOFRhQ6gZDZksPufd7GxgEaC i2SCz3XdIwRgTHTkLGg4NU+0MyIzDh2yHrmWU6z/l5lfXl1RX7GJbgfARUZwGY0/PQr6 bKEQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s7zHFC+c; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z7si417819pgi.257.2019.07.18.21.28.12; Thu, 18 Jul 2019 21:28:27 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s7zHFC+c; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732623AbfGSEHQ (ORCPT + 99 others); Fri, 19 Jul 2019 00:07:16 -0400 Received: from mail.kernel.org ([198.145.29.99]:40786 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732551AbfGSEHM (ORCPT ); Fri, 19 Jul 2019 00:07:12 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 7667521849; Fri, 19 Jul 2019 04:07:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1563509231; bh=GGtnxza6M96hkoXhVgukfMNF5MC+orMZlHkzv8mh1Wg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=s7zHFC+csuej6l803i4cZDZeLsBhybQ82ptTv6xmyxi27wRJexeFrWFMvaLptKbRs LgTcdpXmPdGpGMB9GFXh3vu1ulxHWEv1MSdK3G/8O8FXRRk6U/U7zakQjuqI1dF2Di mO5tJ9WocNMJNOts8+Fm2ziuyubmdHMe8mcbBfr0= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Arnd Bergmann , "David S . Miller" , Sasha Levin , netdev@vger.kernel.org, clang-built-linux@googlegroups.com Subject: [PATCH AUTOSEL 5.1 137/141] cxgb4: reduce kernel stack usage in cudbg_collect_mem_region() Date: Fri, 19 Jul 2019 00:02:42 -0400 Message-Id: <20190719040246.15945-137-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190719040246.15945-1-sashal@kernel.org> References: <20190719040246.15945-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Arnd Bergmann [ Upstream commit 752c2ea2d8e7c23b0f64e2e7d4337f3604d44c9f ] The cudbg_collect_mem_region() and cudbg_read_fw_mem() both use several hundred kilobytes of kernel stack space. One gets inlined into the other, which causes the stack usage to be combined beyond the warning limit when building with clang: drivers/net/ethernet/chelsio/cxgb4/cudbg_lib.c:1057:12: error: stack frame size of 1244 bytes in function 'cudbg_collect_mem_region' [-Werror,-Wframe-larger-than=] Restructuring cudbg_collect_mem_region() lets clang do the same optimization that gcc does and reuse the stack slots as it can see that the large variables are never used together. A better fix might be to avoid using cudbg_meminfo on the stack altogether, but that requires a larger rewrite. Fixes: a1c69520f785 ("cxgb4: collect MC memory dump") Signed-off-by: Arnd Bergmann Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- .../net/ethernet/chelsio/cxgb4/cudbg_lib.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/drivers/net/ethernet/chelsio/cxgb4/cudbg_lib.c b/drivers/net/ethernet/chelsio/cxgb4/cudbg_lib.c index 7c5bfc931128..f46202288837 100644 --- a/drivers/net/ethernet/chelsio/cxgb4/cudbg_lib.c +++ b/drivers/net/ethernet/chelsio/cxgb4/cudbg_lib.c @@ -1066,14 +1066,12 @@ static void cudbg_t4_fwcache(struct cudbg_init *pdbg_init, } } -static int cudbg_collect_mem_region(struct cudbg_init *pdbg_init, - struct cudbg_buffer *dbg_buff, - struct cudbg_error *cudbg_err, - u8 mem_type) +static unsigned long cudbg_mem_region_size(struct cudbg_init *pdbg_init, + struct cudbg_error *cudbg_err, + u8 mem_type) { struct adapter *padap = pdbg_init->adap; struct cudbg_meminfo mem_info; - unsigned long size; u8 mc_idx; int rc; @@ -1087,7 +1085,16 @@ static int cudbg_collect_mem_region(struct cudbg_init *pdbg_init, if (rc) return rc; - size = mem_info.avail[mc_idx].limit - mem_info.avail[mc_idx].base; + return mem_info.avail[mc_idx].limit - mem_info.avail[mc_idx].base; +} + +static int cudbg_collect_mem_region(struct cudbg_init *pdbg_init, + struct cudbg_buffer *dbg_buff, + struct cudbg_error *cudbg_err, + u8 mem_type) +{ + unsigned long size = cudbg_mem_region_size(pdbg_init, cudbg_err, mem_type); + return cudbg_read_fw_mem(pdbg_init, dbg_buff, mem_type, size, cudbg_err); } -- 2.20.1