All of lore.kernel.org
 help / color / mirror / Atom feed
From: Andy Shevchenko <andriy.shevchenko@intel.com>
To: Mathieu Dubois-Briand <mathieu.dubois-briand@bootlin.com>
Cc: "Lee Jones" <lee@kernel.org>, "Rob Herring" <robh@kernel.org>,
	"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
	"Conor Dooley" <conor+dt@kernel.org>,
	"Kamel Bouhara" <kamel.bouhara@bootlin.com>,
	"Linus Walleij" <linus.walleij@linaro.org>,
	"Bartosz Golaszewski" <brgl@bgdev.pl>,
	"Dmitry Torokhov" <dmitry.torokhov@gmail.com>,
	"Uwe Kleine-König" <ukleinek@kernel.org>,
	"Michael Walle" <mwalle@kernel.org>,
	"Mark Brown" <broonie@kernel.org>,
	"Greg Kroah-Hartman" <gregkh@linuxfoundation.org>,
	"Rafael J. Wysocki" <rafael@kernel.org>,
	"Danilo Krummrich" <dakr@kernel.org>,
	devicetree@vger.kernel.org, linux-kernel@vger.kernel.org,
	linux-gpio@vger.kernel.org, linux-input@vger.kernel.org,
	linux-pwm@vger.kernel.org,
	"Grégory Clement" <gregory.clement@bootlin.com>,
	"Thomas Petazzoni" <thomas.petazzoni@bootlin.com>
Subject: Re: [PATCH v7 10/11] input: misc: Add support for MAX7360 rotary
Date: Fri, 2 May 2025 13:52:58 +0300	[thread overview]
Message-ID: <aBSkCsw3GJ6RHeJV@smile.fi.intel.com> (raw)
In-Reply-To: <20250428-mdb-max7360-support-v7-10-4e0608d0a7ff@bootlin.com>

On Mon, Apr 28, 2025 at 01:57:28PM +0200, Mathieu Dubois-Briand wrote:
> Add driver for Maxim Integrated MAX7360 rotary encoder controller,
> supporting a single rotary switch.

...

> +struct max7360_rotary {
> +	struct input_dev *input;
> +	unsigned int debounce_ms;
> +	struct regmap *regmap;
> +
> +	u32 steps;
> +	u32 axis;
> +	bool relative_axis;
> +	bool rollover;
> +
> +	unsigned int pos;
> +};

I believe `pahole` can recommend better layout (look for the better position
of debounce_ms).

...

> +static void max7360_rotaty_report_event(struct max7360_rotary *max7360_rotary, int steps)
> +{
> +	if (max7360_rotary->relative_axis) {
> +		input_report_rel(max7360_rotary->input, max7360_rotary->axis, steps);
> +	} else {
> +		unsigned int pos = max7360_rotary->pos;
> +
> +		if (steps < 0) {
> +			/* turning counter-clockwise */
> +			if (max7360_rotary->rollover)
> +				pos += max7360_rotary->steps + steps;
> +			else

> +				pos = max(0, (int)pos + steps);

Please, no castings for min()/max()/clamp(). It diminishes the use of those
macros.

> +		} else {
> +			/* turning clockwise */
> +			if (max7360_rotary->rollover)
> +				pos += steps;
> +			else
> +				pos = min(max7360_rotary->steps, pos + steps);
> +		}
> +
> +		if (max7360_rotary->rollover)
> +			pos %= max7360_rotary->steps;
> +
> +		max7360_rotary->pos = pos;
> +		input_report_abs(max7360_rotary->input, max7360_rotary->axis, max7360_rotary->pos);
> +	}
> +
> +	input_sync(max7360_rotary->input);
> +}

...

> +static irqreturn_t max7360_rotary_irq(int irq, void *data)
> +{
> +	struct max7360_rotary *max7360_rotary = data;
> +	struct device *dev = max7360_rotary->input->dev.parent;
> +	unsigned int val;
> +	int error;
> +
> +	error = regmap_read(max7360_rotary->regmap, MAX7360_REG_RTR_CNT, &val);
> +	if (error < 0) {
> +		dev_err(dev, "Failed to read rotary counter\n");
> +		return IRQ_NONE;
> +	}
> +
> +	if (val == 0) {

> +		dev_dbg(dev, "Got a spurious interrupt\n");

This contradicts with the IRQF_SHARED. Drop one of them.

> +		return IRQ_NONE;
> +	}
> +
> +	max7360_rotaty_report_event(max7360_rotary, sign_extend32(val, 7));
> +
> +	return IRQ_HANDLED;
> +}

...

> +static int max7360_rotary_hw_init(struct max7360_rotary *max7360_rotary)
> +{
> +	struct device *dev = max7360_rotary->input->dev.parent;
> +	int val;
> +	int error;
> +
> +	val = FIELD_PREP(MAX7360_ROT_DEBOUNCE, max7360_rotary->debounce_ms) |
> +		FIELD_PREP(MAX7360_ROT_INTCNT, 1) | MAX7360_ROT_INTCNT_DLY;

Indentation is incorrect.

> +	error = regmap_write(max7360_rotary->regmap, MAX7360_REG_RTRCFG, val);
> +	if (error)
> +		dev_err(dev, "Failed to set max7360 rotary encoder configuration\n");
> +
> +	return error;
> +}

...

> +static int max7360_rotary_probe(struct platform_device *pdev)
> +{
> +	struct max7360_rotary *max7360_rotary;
> +	struct device *dev = &pdev->dev;
> +	struct input_dev *input;
> +	struct regmap *regmap;
> +	int irq;
> +	int error;
> +
> +	regmap = dev_get_regmap(dev->parent, NULL);
> +	if (!regmap)
> +		dev_err_probe(dev, -ENODEV, "Could not get parent regmap\n");

Missing return. Copy'n'paste error over all drivers?

> +	irq = fwnode_irq_get_byname(dev_fwnode(dev->parent), "inti");
> +	if (irq < 0)
> +		return dev_err_probe(dev, irq, "Failed to get IRQ\n");
> +
> +	max7360_rotary = devm_kzalloc(dev, sizeof(*max7360_rotary), GFP_KERNEL);
> +	if (!max7360_rotary)
> +		return -ENOMEM;
> +
> +	max7360_rotary->regmap = regmap;
> +
> +	device_property_read_u32(dev->parent, "linux,axis", &max7360_rotary->axis);
> +	max7360_rotary->rollover = device_property_read_bool(dev->parent,
> +							     "rotary-encoder,rollover");
> +	max7360_rotary->relative_axis =
> +		device_property_read_bool(dev->parent, "rotary-encoder,relative-axis");
> +
> +	error = device_property_read_u32(dev->parent, "rotary-encoder,steps",
> +					 &max7360_rotary->steps);
> +	if (error)
> +		max7360_rotary->steps = MAX7360_ROTARY_DEFAULT_STEPS;
> +
> +	device_property_read_u32(dev->parent, "rotary-debounce-delay-ms",
> +				 &max7360_rotary->debounce_ms);
> +	if (max7360_rotary->debounce_ms > MAX7360_ROT_DEBOUNCE_MAX)
> +		return dev_err_probe(dev, -EINVAL, "Invalid debounce timing: %u\n",
> +				     max7360_rotary->debounce_ms);
> +
> +	input = devm_input_allocate_device(dev);
> +	if (!input)
> +		return -ENOMEM;
> +
> +	max7360_rotary->input = input;
> +
> +	input->id.bustype = BUS_I2C;
> +	input->name = pdev->name;
> +
> +	if (max7360_rotary->relative_axis)
> +		input_set_capability(input, EV_REL, max7360_rotary->axis);
> +	else
> +		input_set_abs_params(input, max7360_rotary->axis, 0, max7360_rotary->steps, 0, 1);
> +
> +	error = devm_request_threaded_irq(dev, irq, NULL, max7360_rotary_irq,
> +					  IRQF_ONESHOT | IRQF_SHARED,
> +					  "max7360-rotary", max7360_rotary);
> +	if (error)
> +		return dev_err_probe(dev, error, "Failed to register interrupt\n");
> +
> +	error = input_register_device(input);
> +	if (error)
> +		return dev_err_probe(dev, error, "Could not register input device\n");
> +
> +	error = max7360_rotary_hw_init(max7360_rotary);
> +	if (error)
> +		return dev_err_probe(dev, error, "Failed to initialize max7360 rotary\n");
> +
> +	device_init_wakeup(dev, true);
> +	error = dev_pm_set_wake_irq(dev, irq);
> +	if (error)
> +		dev_warn(dev, "Failed to set up wakeup irq: %d\n", error);
> +
> +	return 0;
> +}
> +
> +static void max7360_rotary_remove(struct platform_device *pdev)
> +{
> +	dev_pm_clear_wake_irq(&pdev->dev);

Shouldn't be here

	device_init_wakeup(dev, false);

?

> +}

-- 
With Best Regards,
Andy Shevchenko



  reply	other threads:[~2025-05-02 10:53 UTC|newest]

Thread overview: 36+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-04-28 11:57 [PATCH v7 00/11] Add support for MAX7360 Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 01/11] dt-bindings: mfd: gpio: Add MAX7360 Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 02/11] mfd: Add max7360 support mathieu.dubois-briand
2025-05-01 12:59   ` Lee Jones
2025-05-02  7:35     ` Mathieu Dubois-Briand
2025-05-02  8:26       ` Lee Jones
2025-05-02  9:13     ` Andy Shevchenko
2025-05-02 10:10   ` Andy Shevchenko
2025-04-28 11:57 ` [PATCH v7 03/11] pinctrl: Add MAX7360 pinctrl driver Mathieu Dubois-Briand
2025-05-02 10:15   ` Andy Shevchenko
2025-05-02 12:07     ` Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 04/11] pwm: max7360: Add MAX7360 PWM support mathieu.dubois-briand
2025-05-02 10:19   ` Andy Shevchenko
2025-05-02 12:13     ` Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 05/11] regmap: irq: Add support for chips without separate IRQ status Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 06/11] gpio: regmap: Allow to allocate regmap-irq device Mathieu Dubois-Briand
2025-05-02 10:20   ` Andy Shevchenko
2025-04-28 11:57 ` [PATCH v7 07/11] gpio: regmap: Allow to provide init_valid_mask callback Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 08/11] gpio: max7360: Add MAX7360 gpio support Mathieu Dubois-Briand
2025-05-02 10:39   ` Andy Shevchenko
2025-05-02 12:31     ` Mathieu Dubois-Briand
2025-05-02 13:03       ` Andy Shevchenko
2025-05-07  7:07   ` kernel test robot
2025-04-28 11:57 ` [PATCH v7 09/11] input: keyboard: Add support for MAX7360 keypad Mathieu Dubois-Briand
2025-05-02 10:46   ` Andy Shevchenko
2025-05-02 13:15     ` Mathieu Dubois-Briand
2025-05-02 13:32       ` Andy Shevchenko
2025-05-06  5:11         ` Dmitry Torokhov
2025-05-06  5:14     ` Dmitry Torokhov
2025-05-06 12:41       ` Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 10/11] input: misc: Add support for MAX7360 rotary Mathieu Dubois-Briand
2025-05-02 10:52   ` Andy Shevchenko [this message]
2025-05-02 13:58     ` Mathieu Dubois-Briand
2025-05-02 14:09       ` Andy Shevchenko
2025-05-05 11:52         ` Mathieu Dubois-Briand
2025-04-28 11:57 ` [PATCH v7 11/11] MAINTAINERS: Add entry on MAX7360 driver Mathieu Dubois-Briand

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=aBSkCsw3GJ6RHeJV@smile.fi.intel.com \
    --to=andriy.shevchenko@intel.com \
    --cc=brgl@bgdev.pl \
    --cc=broonie@kernel.org \
    --cc=conor+dt@kernel.org \
    --cc=dakr@kernel.org \
    --cc=devicetree@vger.kernel.org \
    --cc=dmitry.torokhov@gmail.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=gregory.clement@bootlin.com \
    --cc=kamel.bouhara@bootlin.com \
    --cc=krzk+dt@kernel.org \
    --cc=lee@kernel.org \
    --cc=linus.walleij@linaro.org \
    --cc=linux-gpio@vger.kernel.org \
    --cc=linux-input@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pwm@vger.kernel.org \
    --cc=mathieu.dubois-briand@bootlin.com \
    --cc=mwalle@kernel.org \
    --cc=rafael@kernel.org \
    --cc=robh@kernel.org \
    --cc=thomas.petazzoni@bootlin.com \
    --cc=ukleinek@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 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.