Re: Patch "gpio: cdev: sanitize the label before requesting the interrupt" has been added to the 6.1-sta

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Apr 04, 2024 at 03:20:05AM +0200, Pascal Ernster wrote:
> [2024-04-03 19:58] gregkh linuxfoundation ! org:
> > This is a note to let you know that I've just added the patch titled
> > 
> >      gpio: cdev: sanitize the label before requesting the interrupt
> > 
> > to the 6.1-stable tree which can be found at:
> >      http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary
> > 
> > The filename of the patch is:
> >       gpio-cdev-sanitize-the-label-before-requesting-the-interrupt.patch
> > and it can be found in the queue-6.1 subdirectory.
> > 
> > If you, or anyone else, feels it should not be added to the stable tree,
> > please let <stable@xxxxxxxxxxxxxxx> know about it.
> > 
> > 
> >  From b34490879baa847d16fc529c8ea6e6d34f004b38 Mon Sep 17 00:00:00 2001
> > From: Bartosz Golaszewski <bartosz.golaszewski@xxxxxxxxxx>
> > Date: Mon, 25 Mar 2024 10:02:42 +0100
> > Subject: gpio: cdev: sanitize the label before requesting the interrupt
> > 
> > From: Bartosz Golaszewski <bartosz.golaszewski@xxxxxxxxxx>
> > 
> > commit b34490879baa847d16fc529c8ea6e6d34f004b38 upstream.
> > 
> > When an interrupt is requested, a procfs directory is created under
> > "/proc/irq/<irqnum>/<label>" where <label> is the string passed to one of
> > the request_irq() variants.
> > 
> > What follows is that the string must not contain the "/" character or
> > the procfs mkdir operation will fail. We don't have such constraints for
> > GPIO consumer labels which are used verbatim as interrupt labels for
> > GPIO irqs. We must therefore sanitize the consumer string before
> > requesting the interrupt.
> > 
> > Let's replace all "/" with ":".
> > 
> > Cc: stable@xxxxxxxxxxxxxxx
> > Reported-by: Stefan Wahren <wahrenst@xxxxxxx>
> > Closes: https://lore.kernel.org/linux-gpio/39fe95cb-aa83-4b8b-8cab-63947a726754@xxxxxxx/
> > Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@xxxxxxxxxx>
> > Reviewed-by: Kent Gibson <warthog618@xxxxxxxxx>
> > Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
> > ---
> >   drivers/gpio/gpiolib-cdev.c |   38 ++++++++++++++++++++++++++++++++------
> >   1 file changed, 32 insertions(+), 6 deletions(-)
> > 
> > --- a/drivers/gpio/gpiolib-cdev.c
> > +++ b/drivers/gpio/gpiolib-cdev.c
> > @@ -999,10 +999,20 @@ static u32 gpio_v2_line_config_debounce_
> >   	return 0;
> >   }
> > +static inline char *make_irq_label(const char *orig)
> > +{
> > +	return kstrdup_and_replace(orig, '/', ':', GFP_KERNEL);
> > +}
> > +
> > +static inline void free_irq_label(const char *label)
> > +{
> > +	kfree(label);
> > +}
> > +
> >   static void edge_detector_stop(struct line *line)
> >   {
> >   	if (line->irq) {
> > -		free_irq(line->irq, line);
> > +		free_irq_label(free_irq(line->irq, line));
> >   		line->irq = 0;
> >   	}
> > @@ -1027,6 +1037,7 @@ static int edge_detector_setup(struct li
> >   	unsigned long irqflags = 0;
> >   	u64 eflags;
> >   	int irq, ret;
> > +	char *label;
> >   	eflags = edflags & GPIO_V2_LINE_EDGE_FLAGS;
> >   	if (eflags && !kfifo_initialized(&line->req->events)) {
> > @@ -1063,11 +1074,17 @@ static int edge_detector_setup(struct li
> >   			IRQF_TRIGGER_RISING : IRQF_TRIGGER_FALLING;
> >   	irqflags |= IRQF_ONESHOT;
> > +	label = make_irq_label(line->req->label);
> > +	if (!label)
> > +		return -ENOMEM;
> > +
> >   	/* Request a thread to read the events */
> >   	ret = request_threaded_irq(irq, edge_irq_handler, edge_irq_thread,
> > -				   irqflags, line->req->label, line);
> > -	if (ret)
> > +				   irqflags, label, line);
> > +	if (ret) {
> > +		free_irq_label(label);
> >   		return ret;
> > +	}
> >   	line->irq = irq;
> >   	return 0;
> > @@ -1910,7 +1927,7 @@ static ssize_t lineevent_read(struct fil
> >   static void lineevent_free(struct lineevent_state *le)
> >   {
> >   	if (le->irq)
> > -		free_irq(le->irq, le);
> > +		free_irq_label(free_irq(le->irq, le));
> >   	if (le->desc)
> >   		gpiod_free(le->desc);
> >   	kfree(le->label);
> > @@ -2058,6 +2075,7 @@ static int lineevent_create(struct gpio_
> >   	int fd;
> >   	int ret;
> >   	int irq, irqflags = 0;
> > +	char *label;
> >   	if (copy_from_user(&eventreq, ip, sizeof(eventreq)))
> >   		return -EFAULT;
> > @@ -2138,15 +2156,23 @@ static int lineevent_create(struct gpio_
> >   	INIT_KFIFO(le->events);
> >   	init_waitqueue_head(&le->wait);
> > +	label = make_irq_label(le->label);
> > +	if (!label) {
> > +		ret = -ENOMEM;
> > +		goto out_free_le;
> > +	}
> > +
> >   	/* Request a thread to read the events */
> >   	ret = request_threaded_irq(irq,
> >   				   lineevent_irq_handler,
> >   				   lineevent_irq_thread,
> >   				   irqflags,
> > -				   le->label,
> > +				   label,
> >   				   le);
> > -	if (ret)
> > +	if (ret) {
> > +		free_irq_label(label);
> >   		goto out_free_le;
> > +	}
> >   	le->irq = irq;
> > 
> > 
> > Patches currently in stable-queue which might be from bartosz.golaszewski@xxxxxxxxxx are
> > 
> > queue-6.1/gpio-cdev-sanitize-the-label-before-requesting-the-interrupt.patch
> 
> 
> Hi,
> 
> 
> this breaks the build because kstrdup_and_replace() does not exist in
> version branch 6.1.

Yes, my fault, I committed it and then walked away from the computer as
it was a long day.  I'll go fix it up now, thanks

greg k-h




[Index of Archives]     [Linux Kernel]     [Kernel Development Newbies]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Hiking]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux