From: Oleksij Rempel <o.rempel@pengutronix.de>
To: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Cc: Dan Carpenter <dan.carpenter@oracle.com>,
kbuild@lists.01.org, lkp@intel.com, kbuild-all@lists.01.org,
linux-input@vger.kernel.org,
Jonathan Cameron <Jonathan.Cameron@huawei.com>
Subject: Re: [input:next 2732/2735] drivers/input/touchscreen/resistive-adc-touch.c:84 grts_cb() error: uninitialized symbol 'z2'.
Date: Tue, 1 Jun 2021 12:27:15 +0200 [thread overview]
Message-ID: <20210601102715.uu2wflgzvrler6rt@pengutronix.de> (raw)
In-Reply-To: <YLXR2brkc4H54xtK@google.com>
Hi Dmitry,
> Input: resistive-adc-touch - rework mapping of channels
>
> From: Dmitry Torokhov <dmitry.torokhov@gmail.com>
>
> Instead of iterating over channels establish and use channel map to
> retrieve data. As a side effect this will silence "uninitialized variable"
> warnings.
>
> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
> ---
> drivers/input/touchscreen/resistive-adc-touch.c | 114 ++++++++++-------------
> 1 file changed, 51 insertions(+), 63 deletions(-)
>
> diff --git a/drivers/input/touchscreen/resistive-adc-touch.c b/drivers/input/touchscreen/resistive-adc-touch.c
> index ea1884fb49a1..2102916a37ea 100644
> --- a/drivers/input/touchscreen/resistive-adc-touch.c
> +++ b/drivers/input/touchscreen/resistive-adc-touch.c
> @@ -25,12 +25,12 @@
> #define GRTS_MAX_CHANNELS 4
>
> enum grts_ch_type {
> - GRTS_CH_NONE = 0,
> GRTS_CH_X,
> GRTS_CH_Y,
> GRTS_CH_PRESSURE,
> GRTS_CH_Z1,
> GRTS_CH_Z2,
> + GRTS_CH_MAX = GRTS_CH_Z2 + 1
> };
>
> /**
> @@ -42,7 +42,7 @@ enum grts_ch_type {
> * @iio_cb: iio_callback buffer for the data
> * @input: the input device structure that we register
> * @prop: touchscreen properties struct
> - * @ch: channels that are defined for the touchscreen
> + * @ch_map: map of channels that are defined for the touchscreen
> */
> struct grts_state {
> u32 x_plate_ohms;
> @@ -52,37 +52,25 @@ struct grts_state {
> struct iio_cb_buffer *iio_cb;
> struct input_dev *input;
> struct touchscreen_properties prop;
> - u8 ch[GRTS_MAX_CHANNELS];
> + u8 ch_map[GRTS_CH_MAX];
> };
>
> static int grts_cb(const void *data, void *private)
> {
> const u16 *touch_info = data;
> struct grts_state *st = private;
> - unsigned int x, y, press = 0, z1 = 0, z2;
> - unsigned int Rt, i;
> -
> - for (i = 0; i < ARRAY_SIZE(st->ch) && st->ch[i] != GRTS_CH_NONE; i++) {
> - switch (st->ch[i]) {
> - case GRTS_CH_X:
> - x = touch_info[i];
> - break;
> - case GRTS_CH_Y:
> - y = touch_info[i];
> - break;
> - case GRTS_CH_PRESSURE:
> - press = touch_info[i];
> - break;
> - case GRTS_CH_Z1:
> - z1 = touch_info[i];
> - break;
> - case GRTS_CH_Z2:
> - z2 = touch_info[i];
> - break;
> - }
> - }
> + unsigned int x, y, press;
> +
> + x = touch_info[st->ch_map[GRTS_CH_X]];
> + y = touch_info[st->ch_map[GRTS_CH_X]];
Here should be GRTS_CH_Y
With this fix:
Tested-by: Oleksij Rempel <o.rempel@pengutronix.de>
> +
> + if (st->ch_map[GRTS_CH_PRESSURE] < GRTS_MAX_CHANNELS) {
> + press = touch_info[st->ch_map[GRTS_CH_PRESSURE]];
> + } else if (st->ch_map[GRTS_CH_Z1] < GRTS_MAX_CHANNELS) {
> + unsigned int z1 = touch_info[st->ch_map[GRTS_CH_Z1]];
> + unsigned int z2 = touch_info[st->ch_map[GRTS_CH_Z2]];
> + unsigned int Rt;
>
> - if (z1) {
> Rt = z2;
> Rt -= z1;
> Rt *= st->x_plate_ohms;
> @@ -142,60 +130,59 @@ static void grts_disable(void *data)
> iio_channel_release_all_cb(data);
> }
>
> -static int grts_get_properties(struct grts_state *st, struct device *dev)
> +static int grts_map_channel(struct grts_state *st, struct device *dev,
> + enum grts_ch_type type, const char *name,
> + bool optional)
> {
> - int idx, error;
> -
> - idx = device_property_match_string(dev, "io-channel-names", "x");
> - if (idx < 0)
> - return idx;
> -
> - if (idx >= ARRAY_SIZE(st->ch))
> + int idx;
> +
> + idx = device_property_match_string(dev, "io-channel-names", name);
> + if (idx < 0) {
> + if (!optional)
> + return idx;
> + idx = GRTS_MAX_CHANNELS;
> + } else if (idx >= GRTS_MAX_CHANNELS) {
> return -EOVERFLOW;
> + }
>
> - st->ch[idx] = GRTS_CH_X;
> + st->ch_map[type] = idx;
> + return 0;
> +}
>
> - idx = device_property_match_string(dev, "io-channel-names", "y");
> - if (idx < 0)
> - return idx;
> +static int grts_get_properties(struct grts_state *st, struct device *dev)
> +{
> + int error;
>
> - if (idx >= ARRAY_SIZE(st->ch))
> - return -EOVERFLOW;
> + error = grts_map_channel(st, dev, GRTS_CH_X, "x", false);
> + if (error)
> + return error;
>
> - st->ch[idx] = GRTS_CH_Y;
> + error = grts_map_channel(st, dev, GRTS_CH_Y, "y", false);
> + if (error)
> + return error;
>
> /* pressure is optional */
> - idx = device_property_match_string(dev, "io-channel-names", "pressure");
> - if (idx >= 0) {
> - if (idx >= ARRAY_SIZE(st->ch))
> - return -EOVERFLOW;
> + error = grts_map_channel(st, dev, GRTS_CH_PRESSURE, "pressure", true);
> + if (error)
> + return error;
>
> - st->ch[idx] = GRTS_CH_PRESSURE;
> + if (st->ch_map[GRTS_CH_PRESSURE] < GRTS_MAX_CHANNELS) {
> st->pressure = true;
> -
> return 0;
> }
>
> /* if no pressure is defined, try optional z1 + z2 */
> - idx = device_property_match_string(dev, "io-channel-names", "z1");
> - if (idx < 0)
> - return 0;
> -
> - if (idx >= ARRAY_SIZE(st->ch))
> - return -EOVERFLOW;
> + error = grts_map_channel(st, dev, GRTS_CH_Z1, "z1", true);
> + if (error)
> + return error;
>
> - st->ch[idx] = GRTS_CH_Z1;
> + if (st->ch_map[GRTS_CH_Z1] >= GRTS_MAX_CHANNELS)
> + return 0;
>
> /* if z1 is provided z2 is not optional */
> - idx = device_property_match_string(dev, "io-channel-names", "z2");
> - if (idx < 0)
> - return idx;
> -
> - if (idx >= ARRAY_SIZE(st->ch))
> - return -EOVERFLOW;
> -
> - st->ch[idx] = GRTS_CH_Z2;
> - st->pressure = true;
> + error = grts_map_channel(st, dev, GRTS_CH_Z2, "z2", true);
> + if (error)
> + return error;
>
> error = device_property_read_u32(dev,
> "touchscreen-x-plate-ohms",
> @@ -205,6 +192,7 @@ static int grts_get_properties(struct grts_state *st, struct device *dev)
> return error;
> }
>
> + st->pressure = true;
> return 0;
> }
>
>
>
--
Pengutronix e.K. | |
Steuerwalder Str. 21 | http://www.pengutronix.de/ |
31137 Hildesheim, Germany | Phone: +49-5121-206917-0 |
Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |
next prev parent reply other threads:[~2021-06-01 10:27 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-05-27 9:30 [input:next 2732/2735] drivers/input/touchscreen/resistive-adc-touch.c:84 grts_cb() error: uninitialized symbol 'z2' Dan Carpenter
2021-05-27 10:19 ` Oleksij Rempel
2021-05-27 10:41 ` Dan Carpenter
2021-06-01 6:21 ` Dmitry Torokhov
2021-06-01 10:27 ` Oleksij Rempel [this message]
2021-06-02 4:16 ` Dmitry Torokhov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20210601102715.uu2wflgzvrler6rt@pengutronix.de \
--to=o.rempel@pengutronix.de \
--cc=Jonathan.Cameron@huawei.com \
--cc=dan.carpenter@oracle.com \
--cc=dmitry.torokhov@gmail.com \
--cc=kbuild-all@lists.01.org \
--cc=kbuild@lists.01.org \
--cc=linux-input@vger.kernel.org \
--cc=lkp@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).