Commit e1f5e848 authored by Jeff LaBundy's avatar Jeff LaBundy Committed by Dmitry Torokhov
Browse files

Input: iqs626a - prohibit inlining of channel parsing functions



Some automated builds report a stack frame size in excess of 2 kB for
iqs626_probe(); the culprit appears to be the call to iqs626_parse_prop().

To solve this problem, specify noinline_for_stack for all of the
iqs626_parse_*() helper functions which are called inside a for loop
within iqs626_parse_prop().

As a result, a build with '-Wframe-larger-than' as low as 512 is free of
any such warnings.

Reported-by: default avatarkernel test robot <lkp@intel.com>
Signed-off-by: default avatarJeff LaBundy <jeff@labundy.com>
Link: https://lore.kernel.org/r/20211129004104.453930-1-jeff@labundy.com


Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent 9222ba68
Loading
Loading
Loading
Loading
+12 −9
Original line number Diff line number Diff line
@@ -456,7 +456,8 @@ struct iqs626_private {
	unsigned int suspend_mode;
};

static int iqs626_parse_events(struct iqs626_private *iqs626,
static noinline_for_stack int
iqs626_parse_events(struct iqs626_private *iqs626,
		    const struct fwnode_handle *ch_node,
		    enum iqs626_ch_id ch_id)
{
@@ -604,7 +605,8 @@ static int iqs626_parse_events(struct iqs626_private *iqs626,
	return 0;
}

static int iqs626_parse_ati_target(struct iqs626_private *iqs626,
static noinline_for_stack int
iqs626_parse_ati_target(struct iqs626_private *iqs626,
			const struct fwnode_handle *ch_node,
			enum iqs626_ch_id ch_id)
{
@@ -885,7 +887,8 @@ static int iqs626_parse_trackpad(struct iqs626_private *iqs626,
	return 0;
}

static int iqs626_parse_channel(struct iqs626_private *iqs626,
static noinline_for_stack int
iqs626_parse_channel(struct iqs626_private *iqs626,
		     const struct fwnode_handle *ch_node,
		     enum iqs626_ch_id ch_id)
{