Archive-only list for patches
 help / color / mirror / Atom feed
From: Sasha Levin <sashal@kernel.org>
To: patches@lists.linux.dev, stable@vger.kernel.org
Cc: Dave Penkler <dpenkler@gmail.com>,
	Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	Sasha Levin <sashal@kernel.org>,
	matchstick@neverthere.org, dan.carpenter@linaro.org,
	tglx@linutronix.de, everestkc@everestkc.com.np
Subject: [PATCH AUTOSEL 6.15 02/80] staging: gpib: Add init response codes for new ni-usb-hs+
Date: Sun,  3 Aug 2025 20:26:29 -0400	[thread overview]
Message-ID: <20250804002747.3617039-2-sashal@kernel.org> (raw)
In-Reply-To: <20250804002747.3617039-1-sashal@kernel.org>

From: Dave Penkler <dpenkler@gmail.com>

[ Upstream commit f50d5e0c1f80d004510bf77cb0e1759103585c00 ]

A new version of a bona fide genuine NI-USB-HS+ adaptor
sends new response codes to the initialization sequence.

Add the checking for these response codes to suppress
console warning messages.

Signed-off-by: Dave Penkler <dpenkler@gmail.com>
Link: https://lore.kernel.org/r/20250722164810.2621-1-dpenkler@gmail.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
---

LLM Generated explanations, may be completely bogus:

Based on my analysis, I'll now provide my assessment of whether this
commit should be backported to stable kernel trees.

**Backport Status: YES**

This commit should be backported to stable kernel trees. Here's my
extensive analysis:

## Commit Analysis

The commit adds support for new response codes from newer NI-USB-HS+
hardware adaptors. Looking at the specific code changes:

1. **Lines 2082-2086**: The comment is updated from "NI-USB-HS+ sends
   0xf here" to "NI-USB-HS+ sends 0xf or 0x19 here", and the check is
   expanded to accept 0x19 as a valid response code.

2. **Lines 2113-2119**: The comment is updated to indicate that new HS+
   hardware sends 0x59 at position [10], and the check is expanded to
   accept 0x59 as a valid response code.

## Rationale for Backporting

1. **Fixes a Real User Issue**: This fixes a bug where newer NI-USB-HS+
   hardware generates console warning messages due to unrecognized
   response codes. Without this fix, users with newer hardware see error
   messages like "unexpected data: buffer[x]=0x19, expected..." when the
   hardware is actually functioning correctly.

2. **Minimal Risk**: The change is extremely contained - it only adds
   two additional valid response codes (0x19 and 0x59) to existing
   validation checks. No logic changes, no structural modifications,
   just expanding the set of accepted values.

3. **Hardware Compatibility**: This is a hardware enablement fix that
   allows Linux to properly support newer versions of existing hardware
   without generating spurious warnings.

4. **Staging Driver Context**: While this is in staging, the gpib
   subsystem appears to be actively maintained (based on recent commit
   history), and hardware compatibility fixes are important for users of
   this specialized equipment.

5. **Clear Bug Fix**: The commit message explicitly states it
   "suppress[es] console warning messages" - this is fixing incorrect
   error reporting, not adding new features.

6. **No Architectural Changes**: The patch doesn't change any APIs, data
   structures, or driver architecture. It's purely adding two constants
   to existing validation logic.

7. **Tested Hardware**: The commit message indicates this was tested
   with "a bona fide genuine NI-USB-HS+ adaptor", suggesting real
   hardware validation.

## Stable Tree Criteria Met

- ✓ Fixes a bug that affects users (spurious warnings with newer
  hardware)
- ✓ Small and contained change (4 lines modified)
- ✓ No side effects beyond the intended fix
- ✓ No architectural changes
- ✓ Hardware enablement for existing driver

The commit clearly meets the stable tree criteria as a minimal hardware
compatibility fix that resolves user-visible warnings without any risk
of regression.

 drivers/staging/gpib/ni_usb/ni_usb_gpib.c | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)

diff --git a/drivers/staging/gpib/ni_usb/ni_usb_gpib.c b/drivers/staging/gpib/ni_usb/ni_usb_gpib.c
index 9f1b9927f025..56d3b62249b8 100644
--- a/drivers/staging/gpib/ni_usb/ni_usb_gpib.c
+++ b/drivers/staging/gpib/ni_usb/ni_usb_gpib.c
@@ -2069,10 +2069,10 @@ static int ni_usb_hs_wait_for_ready(struct ni_usb_priv *ni_priv)
 		}
 		if (buffer[++j] != 0x0) { // [6]
 			ready = 1;
-			// NI-USB-HS+ sends 0xf here
+			// NI-USB-HS+ sends 0xf or 0x19 here
 			if (buffer[j] != 0x2 && buffer[j] != 0xe && buffer[j] != 0xf &&
-			    buffer[j] != 0x16)	{
-				dev_err(&usb_dev->dev, "unexpected data: buffer[%i]=0x%x, expected 0x2, 0xe, 0xf or 0x16\n",
+			    buffer[j] != 0x16 && buffer[j] != 0x19) {
+				dev_err(&usb_dev->dev, "unexpected data: buffer[%i]=0x%x, expected 0x2, 0xe, 0xf, 0x16 or 0x19\n",
 					j, (int)buffer[j]);
 				unexpected = 1;
 			}
@@ -2100,11 +2100,11 @@ static int ni_usb_hs_wait_for_ready(struct ni_usb_priv *ni_priv)
 				j, (int)buffer[j]);
 			unexpected = 1;
 		}
-		if (buffer[++j] != 0x0) {
+		if (buffer[++j] != 0x0) { // [10] MC usb-488 sends 0x7 here, new HS+ sends 0x59
 			ready = 1;
-			if (buffer[j] != 0x96 && buffer[j] != 0x7 && buffer[j] != 0x6e) {
-// [10] MC usb-488 sends 0x7 here
-				dev_err(&usb_dev->dev, "unexpected data: buffer[%i]=0x%x, expected 0x96, 0x07 or 0x6e\n",
+			if (buffer[j] != 0x96 && buffer[j] != 0x7 && buffer[j] != 0x6e &&
+			    buffer[j] != 0x59) {
+				dev_err(&usb_dev->dev, "unexpected data: buffer[%i]=0x%x, expected 0x96, 0x07, 0x6e or 0x59\n",
 					j, (int)buffer[j]);
 				unexpected = 1;
 			}
-- 
2.39.5


  reply	other threads:[~2025-08-04  0:27 UTC|newest]

Thread overview: 82+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-08-04  0:26 [PATCH AUTOSEL 6.15 01/80] usb: xhci: print xhci->xhc_state when queue_command failed Sasha Levin
2025-08-04  0:26 ` Sasha Levin [this message]
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 03/80] platform/x86/amd: pmc: Add Lenovo Yoga 6 13ALC6 to pmc quirk list Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 04/80] cpufreq: CPPC: Mark driver with NEED_UPDATE_LIMITS flag Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 05/80] selftests/futex: Define SYS_futex on 32-bit architectures with 64-bit time_t Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 06/80] usb: typec: ucsi: psy: Set current max to 100mA for BC 1.2 and Default Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 07/80] bus: mhi: host: pci_generic: Add Telit FN990B40 modem support Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 08/80] regulator: core: repeat voltage setting request for stepped regulators Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 09/80] bus: mhi: host: pci_generic: Disable runtime PM for QDU100 Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 10/80] usb: xhci: Avoid showing warnings for dying controller Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 11/80] usb: xhci: Set avg_trb_len = 8 for EP0 during Address Device Command Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 12/80] usb: xhci: Avoid showing errors during surprise removal Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 13/80] firmware: qcom: scm: initialize tzmem before marking SCM as available Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 14/80] soc: qcom: rpmh-rsc: Add RSC version 4 support Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 15/80] ACPI: APEI: send SIGBUS to current task if synchronous memory error not recovered Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 16/80] remoteproc: imx_rproc: skip clock enable when M-core is managed by the SCU Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 17/80] binder: Fix selftest page indexing Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 18/80] gpio: loongson-64bit: Extend GPIO irq support Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 19/80] usb: typec: ucsi: Add poll_cci operation to cros_ec_ucsi Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 20/80] usb: typec: tcpm/tcpci_maxim: fix irq wake usage Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 21/80] pmdomain: ti: Select PM_GENERIC_DOMAINS Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 22/80] gpio: wcd934x: check the return value of regmap_update_bits() Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 23/80] cpufreq: Exit governor when failed to start old governor Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 24/80] cpufreq: intel_pstate: Add Granite Rapids support in no-HWP mode Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 25/80] ARM: rockchip: fix kernel hang during smp initialization Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 26/80] PM / devfreq: governor: Replace sscanf() with kstrtoul() in set_freq_store() Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 27/80] EDAC/synopsys: Clear the ECC counters on init Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 28/80] ASoC: soc-dapm: set bias_level if snd_soc_dapm_set_bias_level() was successed Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 29/80] thermal/drivers/qcom-spmi-temp-alarm: Enable stage 2 shutdown when required Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 30/80] tools/nolibc: define time_t in terms of __kernel_old_time_t Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 31/80] iio: adc: ad_sigma_delta: don't overallocate scan buffer Sasha Levin
2025-08-04  0:26 ` [PATCH AUTOSEL 6.15 32/80] gpio: tps65912: check the return value of regmap_update_bits() Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 33/80] mfd: tps6594: Add TI TPS652G1 support Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 34/80] ARM: tegra: Use I/O memcpy to write to IRAM Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 35/80] tools/build: Fix s390(x) cross-compilation with clang Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 36/80] selftests: tracing: Use mutex_unlock for testing glob filter Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 37/80] ACPI: PRM: Reduce unnecessary printing to avoid user confusion Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 38/80] firmware: arm_scmi: power_control: Ensure SCMI_SYSPOWER_IDLE is set early during resume Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 39/80] firmware: tegra: Fix IVC dependency problems Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 40/80] pwm: sifive: Fix PWM algorithm and clarify inverted compare behavior Sasha Levin
2025-08-04 10:40   ` Uwe Kleine-König
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 41/80] ALSA: hda: add MODULE_FIRMWARE for cs35l41/cs35l56 Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 42/80] PM: runtime: Clear power.needs_force_resume in pm_runtime_reinit() Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 43/80] thermal: sysfs: Return ENODATA instead of EAGAIN for reads Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 44/80] PM: sleep: console: Fix the black screen issue Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 45/80] ACPI: processor: fix acpi_object initialization Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 46/80] mmc: sdhci-msm: Ensure SD card power isn't ON when card removed Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 47/80] ACPI: APEI: GHES: add TAINT_MACHINE_CHECK on GHES panic path Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 48/80] irqchip/renesas-rzv2h: Enable SKIP_SET_WAKE and MASK_ON_SUSPEND Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 49/80] selftests: vDSO: vdso_test_getrandom: Always print TAP header Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 50/80] pps: clients: gpio: fix interrupt handling order in remove path Sasha Levin
2025-08-04  6:55   ` Rodolfo Giometti
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 51/80] reset: brcmstb: Enable reset drivers for ARCH_BCM2835 Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 52/80] ASoC: SDCA: Add flag for unused IRQs Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 53/80] char: misc: Fix improper and inaccurate error code returned by misc_init() Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 54/80] mei: bus: Check for still connected devices in mei_cl_bus_dev_release() Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 55/80] mmc: rtsx_usb_sdmmc: Fix error-path in sd_set_power_mode() Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 56/80] platform/chrome: cros_ec_sensorhub: Retries when a sensor is not ready Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 57/80] ALSA: hda: Handle the jack polling always via a work Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 58/80] ALSA: hda: Disable jack polling at shutdown Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 59/80] x86/bugs: Avoid warning when overriding return thunk Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 60/80] ASoC: hdac_hdmi: Rate limit logging on connection and disconnection Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 61/80] ALSA: intel8x0: Fix incorrect codec index usage in mixer for ICH4 Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 62/80] irqchip/mips-gic: Allow forced affinity Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 63/80] ASoC: SOF: topology: Parse the dapm_widget_tokens in case of DSPless mode Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 64/80] tty: serial: fix print format specifiers Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 65/80] ASoC: core: Check for rtd == NULL in snd_soc_remove_pcm_runtime() Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 66/80] usb: typec: intel_pmc_mux: Defer probe if SCU IPC isn't present Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 67/80] usb: core: usb_submit_urb: downgrade type check Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 68/80] usb: typec: fusb302: fix scheduling while atomic when using virtio-gpio Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 69/80] usb: dwc3: xilinx: add shutdown callback Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 70/80] pm: cpupower: Fix the snapshot-order of tsc,mperf, clock in mperf_stop() Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 71/80] imx8m-blk-ctrl: set ISI panic write hurry level Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 72/80] soc: qcom: mdt_loader: Actually use the e_phoff Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 73/80] platform/x86: thinkpad_acpi: Handle KCOV __init vs inline mismatches Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 74/80] platform/chrome: cros_ec_typec: Defer probe on missing EC parent Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 75/80] ALSA: hda/ca0132: Fix buffer overflow in add_tuning_control Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 76/80] ALSA: pcm: Rewrite recalculate_boundary() to avoid costly loop Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 77/80] ALSA: usb-audio: Avoid precedence issues in mixer_quirks macros Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 78/80] iio: adc: ad7768-1: Ensure SYNC_IN pulse minimum timing requirement Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 79/80] ASoC: codecs: rt5640: Retry DEVICE_ID verification Sasha Levin
2025-08-04  0:27 ` [PATCH AUTOSEL 6.15 80/80] ASoC: qcom: use drvdata instead of component to keep id Sasha Levin

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=20250804002747.3617039-2-sashal@kernel.org \
    --to=sashal@kernel.org \
    --cc=dan.carpenter@linaro.org \
    --cc=dpenkler@gmail.com \
    --cc=everestkc@everestkc.com.np \
    --cc=gregkh@linuxfoundation.org \
    --cc=matchstick@neverthere.org \
    --cc=patches@lists.linux.dev \
    --cc=stable@vger.kernel.org \
    --cc=tglx@linutronix.de \
    /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