From: Richard Leitner <richard.leitner@skidata.com> To: Dmitry Torokhov <dmitry.torokhov@gmail.com> Cc: <robh+dt@kernel.org>, <mark.rutland@arm.com>, <linux-input@vger.kernel.org>, <devicetree@vger.kernel.org>, <linux-kernel@vger.kernel.org>, Richard Leitner <richard.leitner@skidata.com> Subject: Re: [PATCH 6/7] Input: sx8654 - add sx8650 support Date: Tue, 16 Oct 2018 21:34:26 +0200 [thread overview] Message-ID: <575f935b-e082-7d19-30c1-4db36ed6114d@skidata.com> (raw) In-Reply-To: <20181016174838.GD230131@dtor-ws> On 10/16/18 7:48 PM, Dmitry Torokhov wrote: > On Tue, Oct 16, 2018 at 11:22:48AM +0200, Richard Leitner wrote: >> The sx8654 and sx8650 are quite similar, therefore add support for the >> sx8650 within the sx8654 driver. >> ... >> >> /* bits for I2C_REG_CHANMASK */ >> -#define CONV_X 0x80 >> -#define CONV_Y 0x40 >> +#define CONV_X BIT(7) >> +#define CONV_Y BIT(6) > > If you are using BIT() you need to include include/linux/bitops.h > > I also would prefer conversion to using BIT() as a separate patch. OK. I'll take it out of this patch. Should I convert them (and the other #defines where it makes sense) to BIT() at all? > >> >> /* coordinates rate: higher nibble of CTRL0 register */ >> #define RATE_MANUAL 0x00 >> @@ -71,14 +75,110 @@ >> /* power delay: lower nibble of CTRL0 register */ >> #define POWDLY_1_1MS 0x0b >> >> +/* for sx8650, as we have no pen release IRQ there: timeout in ns following the >> + * last PENIRQ after which we assume the pen is lifted. >> + */ >> +#define SX8650_PENIRQ_TIMEOUT (80 * 1100 * 1000) >> + >> #define MAX_12BIT ((1 << 12) - 1) >> +#define MAX_I2C_READ_LEN 10 /* see datasheet section 5.1.5 */ >> + >> +/* channel definition */ >> +#define CH_X 0x00 >> +#define CH_Y 0x01 >> + >> +struct sx865x_data { >> + u8 cmd_manual; >> + u8 chan_mask; >> + u8 has_irq_penrelease; >> + u8 has_reg_irqmask; >> + irq_handler_t irqh; >> +}; >> >> struct sx8654 { >> struct input_dev *input; >> struct i2c_client *client; >> struct gpio_desc *gpio_reset; >> + struct hrtimer timer; > > Does this have to be hrtimer? Can regular timer be used? I'll check again if it's feasible to reduce the timer delay to something below the "normal" jiffy. If not I'll replace the hrtimer with a timer. > >> + >> + const struct sx865x_data *data; >> }; >> >> +static enum hrtimer_restart sx865x_penrelease_timer_handler(struct hrtimer *h) >> +{ >> + struct sx8654 *ts = container_of(h, struct sx8654, timer); >> + >> + input_report_key(ts->input, BTN_TOUCH, 0); >> + input_sync(ts->input); >> + dev_dbg(&ts->client->dev, "penrelease by timer\n"); >> + >> + return HRTIMER_NORESTART; >> +} >> + ... >> @@ -196,10 +312,30 @@ static void sx8654_close(struct input_dev *dev) >> } >> >> #ifdef CONFIG_OF >> +static const struct of_device_id sx8654_of_match[] = { >> + { >> + .compatible = "semtech,sx8650", >> + .data = &sx8650_data, >> + }, { >> + .compatible = "semtech,sx8654", >> + .data = &sx8654_data, >> + }, { >> + .compatible = "semtech,sx8655", >> + .data = &sx8654_data, >> + }, { >> + .compatible = "semtech,sx8656", >> + .data = &sx8654_data, >> + }, {}, >> +}; >> +MODULE_DEVICE_TABLE(of, sx8654_of_match); >> + >> static int sx8654_get_ofdata(struct sx8654 *ts) >> { >> struct device *dev = &ts->client->dev; >> struct device_node *node = dev->of_node; >> + const struct of_device_id *of_id = of_match_device(sx8654_of_match, >> + dev); > > If you use of_device_get_match_data() you do not need to move device > table around. Thanks for that hint. I haven't known there's something like this ;-) > >> + const struct sx865x_data *data = (struct sx865x_data *)of_id->data; >> int err; >> >> if (!node) { ... >> @@ -327,6 +466,7 @@ static int sx8654_probe(struct i2c_client *client, >> } >> >> static const struct i2c_device_id sx8654_id_table[] = { >> + { "semtech_sx8650", 0 }, > > Can we add the data here as well? Does it generate any benefit if we add it? Who should be using it? I found in other drivers that it's used as a fallback when of_device_get_match_data() returns NULL... Should I also implement it that way? > >> { "semtech_sx8654", 0 }, >> { "semtech_sx8655", 0 }, >> { "semtech_sx8656", 0 }, >> -- >> 2.11.0 >> > > Thanks. > thanks®ards;Richard.L
WARNING: multiple messages have this Message-ID (diff)
From: Richard Leitner <richard.leitner@skidata.com> To: Dmitry Torokhov <dmitry.torokhov@gmail.com> Cc: robh+dt@kernel.org, mark.rutland@arm.com, linux-input@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Richard Leitner <richard.leitner@skidata.com> Subject: Re: [PATCH 6/7] Input: sx8654 - add sx8650 support Date: Tue, 16 Oct 2018 21:34:26 +0200 [thread overview] Message-ID: <575f935b-e082-7d19-30c1-4db36ed6114d@skidata.com> (raw) In-Reply-To: <20181016174838.GD230131@dtor-ws> On 10/16/18 7:48 PM, Dmitry Torokhov wrote: > On Tue, Oct 16, 2018 at 11:22:48AM +0200, Richard Leitner wrote: >> The sx8654 and sx8650 are quite similar, therefore add support for the >> sx8650 within the sx8654 driver. >> ... >> >> /* bits for I2C_REG_CHANMASK */ >> -#define CONV_X 0x80 >> -#define CONV_Y 0x40 >> +#define CONV_X BIT(7) >> +#define CONV_Y BIT(6) > > If you are using BIT() you need to include include/linux/bitops.h > > I also would prefer conversion to using BIT() as a separate patch. OK. I'll take it out of this patch. Should I convert them (and the other #defines where it makes sense) to BIT() at all? > >> >> /* coordinates rate: higher nibble of CTRL0 register */ >> #define RATE_MANUAL 0x00 >> @@ -71,14 +75,110 @@ >> /* power delay: lower nibble of CTRL0 register */ >> #define POWDLY_1_1MS 0x0b >> >> +/* for sx8650, as we have no pen release IRQ there: timeout in ns following the >> + * last PENIRQ after which we assume the pen is lifted. >> + */ >> +#define SX8650_PENIRQ_TIMEOUT (80 * 1100 * 1000) >> + >> #define MAX_12BIT ((1 << 12) - 1) >> +#define MAX_I2C_READ_LEN 10 /* see datasheet section 5.1.5 */ >> + >> +/* channel definition */ >> +#define CH_X 0x00 >> +#define CH_Y 0x01 >> + >> +struct sx865x_data { >> + u8 cmd_manual; >> + u8 chan_mask; >> + u8 has_irq_penrelease; >> + u8 has_reg_irqmask; >> + irq_handler_t irqh; >> +}; >> >> struct sx8654 { >> struct input_dev *input; >> struct i2c_client *client; >> struct gpio_desc *gpio_reset; >> + struct hrtimer timer; > > Does this have to be hrtimer? Can regular timer be used? I'll check again if it's feasible to reduce the timer delay to something below the "normal" jiffy. If not I'll replace the hrtimer with a timer. > >> + >> + const struct sx865x_data *data; >> }; >> >> +static enum hrtimer_restart sx865x_penrelease_timer_handler(struct hrtimer *h) >> +{ >> + struct sx8654 *ts = container_of(h, struct sx8654, timer); >> + >> + input_report_key(ts->input, BTN_TOUCH, 0); >> + input_sync(ts->input); >> + dev_dbg(&ts->client->dev, "penrelease by timer\n"); >> + >> + return HRTIMER_NORESTART; >> +} >> + ... >> @@ -196,10 +312,30 @@ static void sx8654_close(struct input_dev *dev) >> } >> >> #ifdef CONFIG_OF >> +static const struct of_device_id sx8654_of_match[] = { >> + { >> + .compatible = "semtech,sx8650", >> + .data = &sx8650_data, >> + }, { >> + .compatible = "semtech,sx8654", >> + .data = &sx8654_data, >> + }, { >> + .compatible = "semtech,sx8655", >> + .data = &sx8654_data, >> + }, { >> + .compatible = "semtech,sx8656", >> + .data = &sx8654_data, >> + }, {}, >> +}; >> +MODULE_DEVICE_TABLE(of, sx8654_of_match); >> + >> static int sx8654_get_ofdata(struct sx8654 *ts) >> { >> struct device *dev = &ts->client->dev; >> struct device_node *node = dev->of_node; >> + const struct of_device_id *of_id = of_match_device(sx8654_of_match, >> + dev); > > If you use of_device_get_match_data() you do not need to move device > table around. Thanks for that hint. I haven't known there's something like this ;-) > >> + const struct sx865x_data *data = (struct sx865x_data *)of_id->data; >> int err; >> >> if (!node) { ... >> @@ -327,6 +466,7 @@ static int sx8654_probe(struct i2c_client *client, >> } >> >> static const struct i2c_device_id sx8654_id_table[] = { >> + { "semtech_sx8650", 0 }, > > Can we add the data here as well? Does it generate any benefit if we add it? Who should be using it? I found in other drivers that it's used as a fallback when of_device_get_match_data() returns NULL... Should I also implement it that way? > >> { "semtech_sx8654", 0 }, >> { "semtech_sx8655", 0 }, >> { "semtech_sx8656", 0 }, >> -- >> 2.11.0 >> > > Thanks. > thanks®ards;Richard.L
next prev parent reply other threads:[~2018-10-16 19:34 UTC|newest] Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top 2018-10-16 9:16 [PATCH 0/7] Input: sx8654 - reset-gpio, sx865[056] support, etc Richard Leitner 2018-10-16 9:16 ` Richard Leitner 2018-10-16 9:16 ` [PATCH 1/7] dt-bindings: input: touchscreen: sx8654: add reset-gpio property Richard Leitner 2018-10-16 9:16 ` Richard Leitner 2018-10-16 9:16 ` [PATCH 2/7] Input: sx8654 - add reset-gpio support Richard Leitner 2018-10-16 9:16 ` Richard Leitner 2018-10-16 17:39 ` Dmitry Torokhov 2018-10-16 19:32 ` Richard Leitner 2018-10-16 19:32 ` Richard Leitner 2018-10-16 9:16 ` [PATCH 3/7] dt-bindings: input: touchscreen: sx8654: add compatible models Richard Leitner 2018-10-16 9:16 ` Richard Leitner 2018-10-16 9:16 ` [PATCH 4/7] Input: sx8654 - add sx8655 and sx8656 to compatibles Richard Leitner 2018-10-16 9:16 ` Richard Leitner 2018-10-16 9:22 ` [PATCH 5/7] dt-bindings: input: touchscreen: sx8654: add sx8650 to comatibles Richard Leitner 2018-10-16 9:22 ` Richard Leitner 2018-10-16 9:22 ` [PATCH 6/7] Input: sx8654 - add sx8650 support Richard Leitner 2018-10-16 9:22 ` Richard Leitner 2018-10-16 17:48 ` Dmitry Torokhov 2018-10-16 19:34 ` Richard Leitner [this message] 2018-10-16 19:34 ` Richard Leitner 2018-10-16 20:18 ` Dmitry Torokhov 2018-10-16 9:23 ` [PATCH 7/7] Input: sx8654 - use common of_touchscreen functions Richard Leitner 2018-10-16 9:23 ` Richard Leitner 2018-10-16 17:52 ` 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=575f935b-e082-7d19-30c1-4db36ed6114d@skidata.com \ --to=richard.leitner@skidata.com \ --cc=devicetree@vger.kernel.org \ --cc=dmitry.torokhov@gmail.com \ --cc=linux-input@vger.kernel.org \ --cc=linux-kernel@vger.kernel.org \ --cc=mark.rutland@arm.com \ --cc=robh+dt@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: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.