Patch "Revert "serial: stm32: Merge hard IRQ and threaded IRQ handling into single IRQ handler"" has been added to the 6.1-stable tree

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

 



This is a note to let you know that I've just added the patch titled

    Revert "serial: stm32: Merge hard IRQ and threaded IRQ handling into single IRQ handler"

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:
     revert-serial-stm32-merge-hard-irq-and-threaded-irq-handling-into-single-irq-handler.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 2cbafffbf69addd7509072f4be5917f81d238cf6 Mon Sep 17 00:00:00 2001
From: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
Date: Fri, 20 Jan 2023 11:16:59 +0100
Subject: Revert "serial: stm32: Merge hard IRQ and threaded IRQ handling into single IRQ handler"

From: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>

commit 2cbafffbf69addd7509072f4be5917f81d238cf6 upstream.

This reverts commit f24771b62a83239f0dce816bddf0f6807f436235 as it is
reported to break the build.

Reported-by: kernel test robot <lkp@xxxxxxxxx>
Link: https://lore.kernel.org/r/202301200130.ttBiTzfO-lkp@xxxxxxxxx
Fixes: f24771b62a83 ("serial: stm32: Merge hard IRQ and threaded IRQ handling into single IRQ handler")
Cc: Sebastian Andrzej Siewior <bigeasy@xxxxxxxxxxxxx>
Cc: Valentin Caron <valentin.caron@xxxxxxxxxxx> # V3
Cc: Marek Vasut <marex@xxxxxxx>
Cc: Johan Hovold <johan@xxxxxxxxxx>
Cc: stable@xxxxxxxxxxxxxxx
Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
---
 drivers/tty/serial/stm32-usart.c |   31 +++++++++++++++++++++++++++----
 1 file changed, 27 insertions(+), 4 deletions(-)

--- a/drivers/tty/serial/stm32-usart.c
+++ b/drivers/tty/serial/stm32-usart.c
@@ -798,9 +798,23 @@ static irqreturn_t stm32_usart_interrupt
 		spin_unlock(&port->lock);
 	}
 
+	if (stm32_usart_rx_dma_enabled(port))
+		return IRQ_WAKE_THREAD;
+	else
+		return IRQ_HANDLED;
+}
+
+static irqreturn_t stm32_usart_threaded_interrupt(int irq, void *ptr)
+{
+	struct uart_port *port = ptr;
+	struct tty_port *tport = &port->state->port;
+	struct stm32_port *stm32_port = to_stm32_port(port);
+	unsigned int size;
+	unsigned long flags;
+
 	/* Receiver timeout irq for DMA RX */
-	if (stm32_usart_rx_dma_enabled(port) && !stm32_port->throttled) {
-		spin_lock(&port->lock);
+	if (!stm32_port->throttled) {
+		spin_lock_irqsave(&port->lock, flags);
 		size = stm32_usart_receive_chars(port, false);
 		uart_unlock_and_check_sysrq_irqrestore(port, flags);
 		if (size)
@@ -1002,8 +1016,10 @@ static int stm32_usart_startup(struct ua
 	u32 val;
 	int ret;
 
-	ret = request_irq(port->irq, stm32_usart_interrupt,
-			  IRQF_NO_SUSPEND, name, port);
+	ret = request_threaded_irq(port->irq, stm32_usart_interrupt,
+				   stm32_usart_threaded_interrupt,
+				   IRQF_ONESHOT | IRQF_NO_SUSPEND,
+				   name, port);
 	if (ret)
 		return ret;
 
@@ -1586,6 +1602,13 @@ static int stm32_usart_of_dma_rx_probe(s
 	struct dma_slave_config config;
 	int ret;
 
+	/*
+	 * Using DMA and threaded handler for the console could lead to
+	 * deadlocks.
+	 */
+	if (uart_console(port))
+		return -ENODEV;
+
 	stm32port->rx_buf = dma_alloc_coherent(dev, RX_BUF_L,
 					       &stm32port->rx_dma_buf,
 					       GFP_KERNEL);


Patches currently in stable-queue which might be from gregkh@xxxxxxxxxxxxxxxxxxx are

queue-6.1/nommu-fix-do_munmap-error-path.patch
queue-6.1/usb-acpi-add-helper-to-check-port-lpm-capability-using-acpi-_dsm.patch
queue-6.1/staging-vchiq_arm-fix-enum-vchiq_status-return-types.patch
queue-6.1/usb-serial-option-add-quectel-em05cn-modem.patch
queue-6.1/misc-fastrpc-don-t-remove-map-on-creater_process-and-device_release.patch
queue-6.1/serial-stm32-merge-hard-irq-and-threaded-irq-handling-into-single-irq-handler.patch
queue-6.1/add-exception-protection-processing-for-vd-in-axi_chan_handle_err-function.patch
queue-6.1/misc-fastrpc-fix-use-after-free-race-condition-for-maps.patch
queue-6.1/usb-serial-option-add-quectel-em05-g-rs-modem.patch
queue-6.1/usb-serial-option-add-quectel-em05-g-cs-modem.patch
queue-6.1/wifi-brcmfmac-fix-regression-for-broadcom-pcie-wifi-devices.patch
queue-6.1/xhci-fix-null-pointer-dereference-when-host-dies.patch
queue-6.1/usb-misc-onboard_hub-invert-driver-registration-order.patch
queue-6.1/nilfs2-fix-general-protection-fault-in-nilfs_btree_insert.patch
queue-6.1/loongarch-add-hwcap_loongarch_cpucfg-to-elf_hwcap.patch
queue-6.1/xhci-pci-set-the-dma-max_seg_size.patch
queue-6.1/usb-serial-option-add-quectel-ec200u-modem.patch
queue-6.1/usb-xhci-check-endpoint-is-valid-before-dereferencing-it.patch
queue-6.1/wifi-mac80211-reset-multiple-bssid-options-in-stop_ap.patch
queue-6.1/usb-misc-iowarrior-fix-up-header-size-for-usb_device_id_codemercs_iow100.patch
queue-6.1/usb-serial-option-add-quectel-em05-g-gr-modem.patch
queue-6.1/comedi-adv_pci1760-fix-pwm-instruction-handling.patch
queue-6.1/zonefs-detect-append-writes-at-invalid-locations.patch
queue-6.1/nommu-fix-memory-leak-in-do_mmap-error-path.patch
queue-6.1/wifi-mac80211-sdata-can-be-null-during-ampdu-start.patch
queue-6.1/usb-core-hub-disable-autosuspend-for-ti-tusb8041.patch
queue-6.1/proc-fix-pie-proc-empty-vm-proc-pid-vm-tests.patch
queue-6.1/revert-serial-stm32-merge-hard-irq-and-threaded-irq-handling-into-single-irq-handler.patch
queue-6.1/usb-misc-onboard_hub-move-attach-work-to-the-driver.patch
queue-6.1/wifi-mac80211-fix-initialization-of-rx-link-and-rx-link_sta.patch
queue-6.1/xhci-add-update_hub_device-override-for-pci-xhci-hosts.patch
queue-6.1/prlimit-do_prlimit-needs-to-have-a-speculation-check.patch
queue-6.1/usb-serial-option-add-quectel-em05cn-sg-modem.patch
queue-6.1/hugetlb-unshare-some-pmds-when-splitting-vmas.patch
queue-6.1/xhci-detect-lpm-incapable-xhc-usb3-roothub-ports-from-acpi-tables.patch
queue-6.1/acpi-prm-check-whether-efi-runtime-is-available.patch
queue-6.1/wifi-mac80211-fix-mlo-ap_vlan-check.patch
queue-6.1/nommu-fix-split_vma-map_count-error.patch
queue-6.1/mm-khugepaged-fix-collapse_pte_mapped_thp-to-allow-anon_vma.patch
queue-6.1/bluetooth-hci_qca-fix-driver-shutdown-on-closed-serdev.patch
queue-6.1/bluetooth-hci_sync-fix-use-hci_op_le_read_buffer_size_v2.patch
queue-6.1/misc-fastrpc-fix-use-after-free-and-race-in-fastrpc_map_find.patch
queue-6.1/xhci-add-a-flag-to-disable-usb3-lpm-on-a-xhci-root-port-level.patch
queue-6.1/mm-shmem-restore-shmem_huge_deny-precedence-over-madv_collapse.patch



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux