From: Dmitry Torokhov <dmitry.torokhov@gmail.com>
To: Christopher Hudson <chris.hudson.comp.eng@gmail.com>
Cc: Jonathan Cameron <jic23@cam.ac.uk>, linux-input@vger.kernel.org
Subject: Re: [PATCH] input:Misc changes against kxtj9 v5 patch
Date: Wed, 6 Jul 2011 22:19:20 -0700 [thread overview]
Message-ID: <20110707051920.GA7658@core.coreip.homeip.net> (raw)
In-Reply-To: <CAB7Re7Vfu4dk+mizH=fzTsYW69MpFi-WeKFocH8t8AuFR7vW3w@mail.gmail.com>
On Wed, Jul 06, 2011 at 11:58:41AM -0400, Christopher Hudson wrote:
> On Wed, Jul 6, 2011 at 11:42 AM, Christopher Hudson
> <chris.hudson.comp.eng@gmail.com> wrote:
> > On Tue, Jul 5, 2011 at 4:35 PM, Dmitry Torokhov
> > <dmitry.torokhov@gmail.com> wrote:
> >> On Tue, Jul 05, 2011 at 04:19:32PM -0400, Christopher Hudson wrote:
> >>> On Tue, Jul 5, 2011 at 4:05 PM, Dmitry Torokhov
> >>> <dmitry.torokhov@gmail.com> wrote:
> >>> > On Tue, Jul 05, 2011 at 03:55:54PM -0400, chris.hudson.comp.eng@gmail.com wrote:
> >>> >> From: Chris Hudson <chudson@kionix.com>
> >>> >>
> >>> >> As requested, miscellaneous changes originally suggested by Jonathan Cameron,
> >>> >> patched against the original kxtj9 v5 patch.
> >>> >>
> >>> >> Signed-off-by: Chris Hudson <chudson@kionix.com>
> >>> >> ---
> >>> >> drivers/input/misc/kxtj9.c | 38 +++++++++++++-------------------------
> >>> >> include/linux/input/kxtj9.h | 10 +---------
> >>> >> 2 files changed, 14 insertions(+), 34 deletions(-)
> >>> >>
> >>> >> diff --git a/drivers/input/misc/kxtj9.c b/drivers/input/misc/kxtj9.c
> >>> >> index 7faf155..b2da841 100644
> >>> >> --- a/drivers/input/misc/kxtj9.c
> >>> >> +++ b/drivers/input/misc/kxtj9.c
> >>> >> @@ -71,6 +71,15 @@ static const struct {
> >>> >> { 0, ODR12_5F},
> >>> >> };
> >>> >>
> >>> >> +static const struct {
> >>> >> + u8 g_range;
> >>> >> + u8 shift;
> >>> >> +} kxtj9_range[] = {
> >>> >> + { 0, 4 }, /* +/-2g */
> >>> >> + { (1 << 3), 3 }, /* +/-4g */
> >>> >> + { (1 << 4), 2 }, /* +/-8g */
> >>> >> +};
> >>> >> +
> >>> >> struct kxtj9_data {
> >>> >> struct i2c_client *client;
> >>> >> struct kxtj9_platform_data pdata;
> >>> >> @@ -129,25 +138,9 @@ static void kxtj9_report_acceleration_data(struct kxtj9_data *tj9)
> >>> >>
> >>> >> static int kxtj9_update_g_range(struct kxtj9_data *tj9, u8 new_g_range)
> >>> >> {
> >>> >> - switch (new_g_range) {
> >>> >> - case KXTJ9_G_2G:
> >>> >> - tj9->shift = SHIFT_ADJ_2G;
> >>> >> - break;
> >>> >> -
> >>> >> - case KXTJ9_G_4G:
> >>> >> - tj9->shift = SHIFT_ADJ_4G;
> >>> >> - break;
> >>> >> -
> >>> >> - case KXTJ9_G_8G:
> >>> >> - tj9->shift = SHIFT_ADJ_8G;
> >>> >> - break;
> >>> >> -
> >>> >> - default:
> >>> >> - return -EINVAL;
> >>> >> - }
> >>> >> -
> >>> >> + tj9->shift = kxtj9_range[new_g_range].shift;
> >>> >
> >>> > This is not safe, you still need to sanitize input to make sure you do
> >>> > not go beyond array boundaries.
> >>>
> >>> Oops...would a simple
> >>> if (new_g_range > 2)
> >>> return -EINVAL;
> >>> do the trick?
> >>
> >> Or "if (new_g_range >= ARRAY_SIZE(kxtj9_range)) ..."
> >>
> >> However, why do we use indices instead of values? I.e. why don't we
> >> allow users to specify 2, 4 and 8 in platform data and use array to
> >> validate the supplied value and return -EINVAL if this value is not
> >> found?
> >
> > Before we were allowing the user to specify KXTJ9_G_2G, etc, which
> > were bitmasks that represented each available g-range. I think
> > Jonathan's intent was to optimize/clean up the update_g_range
> > function, but I just couldn't figure out the most efficient way to do
> > this. It seems that just replacing the globally defined shift
> > variables with their numerical counterparts within the update_g_range
> > function probably gives us the best combination of efficiency and
> > ease-of-use.
>
> My apologies I meant to include the following revised version:
>
> Signed-off-by: Chris Hudson <chudson@kionix.com>
All folded and applied. Thanks Chris.
--
Dmitry
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
prev parent reply other threads:[~2011-07-07 5:19 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-07-05 19:55 [PATCH] input:Misc changes against kxtj9 v5 patch chris.hudson.comp.eng
2011-07-05 20:05 ` Dmitry Torokhov
[not found] ` <CAB7Re7XDB6Rmckxidgr+90Br5LhYk_5Pi_JQXTLd9QS2V+Vm0A@mail.gmail.com>
[not found] ` <20110705203502.GC15876@core.coreip.homeip.net>
2011-07-06 15:42 ` Christopher Hudson
2011-07-06 15:58 ` Christopher Hudson
2011-07-07 5:19 ` Dmitry Torokhov [this message]
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=20110707051920.GA7658@core.coreip.homeip.net \
--to=dmitry.torokhov@gmail.com \
--cc=chris.hudson.comp.eng@gmail.com \
--cc=jic23@cam.ac.uk \
--cc=linux-input@vger.kernel.org \
/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).