Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp53681ybl; Tue, 7 Jan 2020 14:01:47 -0800 (PST) X-Google-Smtp-Source: APXvYqzwCEusvochaoObOMRbkzRrLuJu7z7MGMtAq3YuBNQk/aY4j6S809LE+kMF5l9DnXsh4Cxw X-Received: by 2002:a05:6830:18ed:: with SMTP id d13mr1842004otf.208.1578434507789; Tue, 07 Jan 2020 14:01:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578434507; cv=none; d=google.com; s=arc-20160816; b=D8J153jjyBFwMpJGrr7WkHgKXp1w/W+ypjcC2S3X/TNOuxaMKOJzDbImgDXo1AhD8T HeCVCd/UPSIqBYA5EV64RHY6B8egz81Lv4H5bpmde62ote8nKNYVmVSHvRYIChSmaLKL SCQtyQq85xMZtUN6f8v12LXl5s+cwGty7XZHDiqfVOZR6YI2SCKFfgrITAOeKKk93wOT jI3zkZLwp/XNw/WXK+xhqs0+deGI9BYZl7aBNdQFm8+LWYw069f0RmY7mGFuM7QbheNa LNegI3vD4PBOTp9HzY9ME/t6BPxccd+NYxcgFVdKzm12m1i6H3rVV2MOEdCCblrM8SJg dAxQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=Vo1GVmlwj7prVGPWgkVpafv5jNAgE1XymxFDDp9/8nI=; b=W1jN/+N48fH8Cz1QT0RUf5kYOoEosbM8kBGP1cYGTQjxAme5sZQ+JPwGHy/u2k/MqR /3kgDb/6xZsLlVo4jAos01n5lsamg9tAaFpbAhH1l+Rq54mtCX5201zrm/tMk+NdPR89 ykethV0QLjf0RjpkXjVWLcdkgESbNsp/a0hC3k1zAColbDAIhCcdCiYbxjLEaeMDkatE VRtmuR8/KhgJ02xzYwzOXsokkcLVUWX1aZq1TMZtC9HshSmLAewJ8e27p9b/C96mqLF6 ETRBzIYl8z1Xl4IPRdsPTQFIBhDTAMVDuaFdX0UNDryB4lohVT1V+FKt9bZb1J19azRU CtVg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=ep9L46Ku; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l26si674960otn.48.2020.01.07.14.01.34; Tue, 07 Jan 2020 14:01:47 -0800 (PST) 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 (test mode) header.i=@ideasonboard.com header.s=mail header.b=ep9L46Ku; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727174AbgAGWAd (ORCPT + 99 others); Tue, 7 Jan 2020 17:00:33 -0500 Received: from perceval.ideasonboard.com ([213.167.242.64]:47420 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726986AbgAGWAd (ORCPT ); Tue, 7 Jan 2020 17:00:33 -0500 Received: from pendragon.ideasonboard.com (81-175-216-236.bb.dnainternet.fi [81.175.216.236]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 5D8E152F; Tue, 7 Jan 2020 23:00:31 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1578434431; bh=4rS/DzJoC9Up5wTZWqf2LP3WkrbP09g2YoVYgICXsqQ=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=ep9L46KuB1PfRgMEZWiYAkvy5r9Mwi64ugX+k46uy60Kqy9KJRCUABNrPiRReTLQf ZPRBe2LFiSmYXD2J745DCv8glAt8sI1irYVERQQRJ8rTJJ0hLcSDm9y8ElvyBnr5zi OLXStA3GVB8Qydp+aOzS0tuIj/PIAZ+BKOwtiWsc= Date: Wed, 8 Jan 2020 00:00:19 +0200 From: Laurent Pinchart To: Arnd Bergmann Cc: Thierry Reding , David Airlie , Daniel Vetter , Oleksandr Natalenko , Sam Ravnborg , Linus Walleij , Boris Brezillon , Tomi Valkeinen , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] drm: panel: fix excessive stack usage in td028ttec1_prepare Message-ID: <20200107220019.GC7869@pendragon.ideasonboard.com> References: <20200107212747.4182515-1-arnd@arndb.de> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20200107212747.4182515-1-arnd@arndb.de> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Arnd, Thank you for the patch. On Tue, Jan 07, 2020 at 10:27:33PM +0100, Arnd Bergmann wrote: > With gcc -O3, the compiler can inline very aggressively, > leading to rather large stack usage: > > drivers/gpu/drm/panel/panel-tpo-td028ttec1.c: In function 'td028ttec1_prepare': > drivers/gpu/drm/panel/panel-tpo-td028ttec1.c:233:1: error: the frame size of 2768 bytes is larger than 2048 bytes [-Werror=frame-larger-than=] > } > > Marking jbt_reg_write_1() as noinline avoids the case where > multiple instances of this function get inlined into the same > stack frame and each one adds a copy of 'tx_buf'. > > Fixes: mmtom ("init/Kconfig: enable -O3 for all arches") > Signed-off-by: Arnd Bergmann Isn't this something that should be fixed at the compiler level ? > --- > drivers/gpu/drm/panel/panel-tpo-td028ttec1.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/panel/panel-tpo-td028ttec1.c b/drivers/gpu/drm/panel/panel-tpo-td028ttec1.c > index cf29405a2dbe..17ee5e87141f 100644 > --- a/drivers/gpu/drm/panel/panel-tpo-td028ttec1.c > +++ b/drivers/gpu/drm/panel/panel-tpo-td028ttec1.c > @@ -105,7 +105,7 @@ static int jbt_ret_write_0(struct td028ttec1_panel *lcd, u8 reg, int *err) > return ret; > } > > -static int jbt_reg_write_1(struct td028ttec1_panel *lcd, > +static int noinline_for_stack jbt_reg_write_1(struct td028ttec1_panel *lcd, > u8 reg, u8 data, int *err) > { > struct spi_device *spi = lcd->spi; -- Regards, Laurent Pinchart