From nobody Fri Dec 19 20:36:11 2025 Received: from mail-wr1-f50.google.com (mail-wr1-f50.google.com [209.85.221.50]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id AE57732E735 for ; Wed, 3 Dec 2025 16:59:07 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.50 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764781150; cv=none; b=f7u8qY55PoV5l+WtZCL0JSqQ5Fs+w6JyZZloLUVXxI770cuTj42do+4yn1BwP03omS8v672Wg0rAoJNCShhuFZYRI6VFLJ2nRgMuA50s45ii0/VIpszfNKerhZxPVP9tyxdrQIk7YJ0wjdQQCGD1V42xme9sLkqIXp5fbz3PoSg= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764781150; c=relaxed/simple; bh=uFoNWaar646Dx22SgB2BnS2gYCYkO6ZUycFbMTuvIkc=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=B+pTEB34w+4rqgla6PmR/scG01HgrKsZFVkiaN00oOG0FDx0B+wZUv/3kTS1Em5NmsNc4SbBUwO+Ks7ThruwSuSk+uhiG+lBXHx1Wh+ZRmBsFM1VdQzJ38nFwHC0Rqz5naDjoDm29+wQ+CB2kUzsl3ua00YRUZEPL7HPAgAAHZI= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=YYsah921; arc=none smtp.client-ip=209.85.221.50 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="YYsah921" Received: by mail-wr1-f50.google.com with SMTP id ffacd0b85a97d-42b30bf0feaso3095f8f.1 for ; Wed, 03 Dec 2025 08:59:06 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1764781144; x=1765385944; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=f9y+7yd373GhPOUzL9/gOcUvFamZcV6u4OWWAkEESak=; b=YYsah921n0Aw0Dj2MkM8Ygb5Jz6gTugbjpKzaUaoXCpDMta6XqIUO1PpdIb7fVd/uv R6hfWZUAC+2ORASZZdPVJBTC6jf7b1oBMdc+jDxkyHVR+Dw+LQIYWS0U7RO88oCRkbaH 179YTQHbCYel6pNg/sIjsckWUk1BH3B2yw9J8uhSNviQ6RcVSQ1yrmgsRb9KPs4Kq6pz hfIfHCs+4boXSL/ShQ87TI7k9rYy4mfVhb5PsufoPMWRa70WC4iAxrwF0vvgLupoL/BR hc9kJpYobBnul3u5wDdLQKmdHooif1iOvxikNjlXT5M/elSifVhXPpcIOErsoUi0RQrb KqSg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1764781144; x=1765385944; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=f9y+7yd373GhPOUzL9/gOcUvFamZcV6u4OWWAkEESak=; b=HDEdThtx+1/mDfeTyas0AoflIoyX2EJvUwcGP3l72EKWtB3Lf4Srip2TTfGZiqK2AP Xe8UQrjv21B7iCBkDVypXMd+OiSTRskZ1Byy7JWYAhvhr4tbfCoLAEUMKLz83J27QE8L kclMEraDF4DiiDeuCo2m7dIJv3MmSl8tsxx1W5G0r05ihfA0TAr4SgnVBGikGIPRzgIa wFsVA1xc2qxo/35m5WYDcstbO57MecJPtrMLt7OHvKlxbpLzq8viBoGryMj/T3QcmcHh hhdZDDLvwZQeY5j8GQee4svn7KHcOT2+qMpFzp45+YexXKiuWtkgxzK5ehs6NI+6EUAZ /UjQ== X-Forwarded-Encrypted: i=1; AJvYcCVemquLV6DL6Hmd5XLSOzi5zj8UAU/ozVHpaFSY5LCNtKjmNbRAxmx1ZF+5TXyGJ4uQt07QFQpyCj+O2Ec=@vger.kernel.org X-Gm-Message-State: AOJu0Yw6Yg0kndIJc4+dE06JRlegL8cGCNl5CNatuvNRjAcNxX3Ub/Mf iRNW931gIchClpqaJqzo79jy6v3e1s2drMfZ/RLIsaO5+6b+kjvibs3+K+rq3F6+ X-Gm-Gg: ASbGncvq8SmUStAMefNUscWu34XGeKevKGIROvQooEQOMBV0YDjnhkbR20aMecnteUR S4eImEEmGcQnEllqY802W6S9tBr2fb0rpmhLmjLn+DY9O/noa03EstF4GgPHUgCvMPIZR+4DZVq xoiOHTEY+NQzOhrq+VVjqAEEJQR+3FcU6Cx10oeNceG3UKn58kJpDSnjrtOt8/KFlDgDXIuFapw iWl6DWxRbjk4A0xNkgX9Ay26mBEcE2+sWY+z7HnzJx9YbLQd6of8rYb6sLofAbHAv3sIUmBrQuu UrsW2/FQ1saoHU2h6KHk+vkBfUul6jOUqLt60nTknVsZlJzcXU54LE40Jb+pmm3LD3uMgscBSA0 DHzgefHcVjh/Vj1luZjw6HibvCXkojYvpDj8/1V51AiG/JkjTzDhLibVKippzghr719stuQIdY7 qkIt2LsvrhbN7ieoy/0YkTADEcRIrJWRhXZGjpN9/fu8RxH8lzDVEgVrHoXOdHmnRkubwRMP03e xOclb3fA2Qln8XRdQ== X-Google-Smtp-Source: AGHT+IEyFhvtUoyTIgYHtE052oP4uEJA/8Atajbc84gCrHHu25B8tkaKcNlP5rQT2EY5asBq1BfdIA== X-Received: by 2002:a05:600c:45cd:b0:477:5b01:7d49 with SMTP id 5b1f17b1804b1-4792c909a62mr12104775e9.4.1764781144299; Wed, 03 Dec 2025 08:59:04 -0800 (PST) Received: from thomas-precision3591.paris.inria.fr (wifi-pro-83-215.paris.inria.fr. [128.93.83.215]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-4792b157783sm22811695e9.5.2025.12.03.08.59.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 03 Dec 2025 08:59:03 -0800 (PST) From: Thomas Fourier To: Cc: Thomas Fourier , Even Xu , Xinpeng Sun , Jiri Kosina , Benjamin Tissoires , Andy Shevchenko , Mark Pearson , Srinivas Pandruvada , linux-input@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] HID: Intel-thc-hid: Intel-thc: fix dma_unmap_sg() nents value Date: Wed, 3 Dec 2025 17:56:35 +0100 Message-ID: <20251203165651.69215-2-fourier.thomas@gmail.com> X-Mailer: git-send-email 2.43.0 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" The `dma_unmap_sg()` functions should be called with the same nents as the `dma_map_sg()`, not the value the map function returned. Save the number of entries in struct thc_dma_configuration. Fixes: a688404b2e20 ("HID: intel-thc-hid: intel-thc: Add THC DMA interfaces= ") Signed-off-by: Thomas Fourier Reviewed-by: Andy Shevchenko Reviewed-by: Even Xu --- drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.c | 4 +++- drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.h | 2 ++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.c b/drivers/= hid/intel-thc-hid/intel-thc/intel-thc-dma.c index 82b8854843e0..a0c368aa7979 100644 --- a/drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.c +++ b/drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.c @@ -232,6 +232,7 @@ static int setup_dma_buffers(struct thc_device *dev, return 0; =20 memset(config->sgls, 0, sizeof(config->sgls)); + memset(config->sgls_nent_pages, 0, sizeof(config->sgls_nent_pages)); memset(config->sgls_nent, 0, sizeof(config->sgls_nent)); =20 cpu_addr =3D dma_alloc_coherent(dev->dev, prd_tbls_size, @@ -254,6 +255,7 @@ static int setup_dma_buffers(struct thc_device *dev, } count =3D dma_map_sg(dev->dev, config->sgls[i], nent, dir); =20 + config->sgls_nent_pages[i] =3D nent; config->sgls_nent[i] =3D count; } =20 @@ -299,7 +301,7 @@ static void release_dma_buffers(struct thc_device *dev, continue; =20 dma_unmap_sg(dev->dev, config->sgls[i], - config->sgls_nent[i], + config->sgls_nent_pages[i], config->dir); =20 sgl_free(config->sgls[i]); diff --git a/drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.h b/drivers/= hid/intel-thc-hid/intel-thc/intel-thc-dma.h index 78917400492c..541d33995baf 100644 --- a/drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.h +++ b/drivers/hid/intel-thc-hid/intel-thc/intel-thc-dma.h @@ -91,6 +91,7 @@ struct thc_prd_table { * @dir: Direction of DMA for this config * @prd_tbls: PRD tables for current DMA * @sgls: Array of pointers to scatter-gather lists + * @sgls_nent_pages: Number of pages per scatter-gather list * @sgls_nent: Actual number of entries per scatter-gather list * @prd_tbl_num: Actual number of PRD tables * @max_packet_size: Size of the buffer needed for 1 DMA message (1 PRD ta= ble) @@ -107,6 +108,7 @@ struct thc_dma_configuration { =20 struct thc_prd_table *prd_tbls; struct scatterlist *sgls[PRD_TABLES_NUM]; + u8 sgls_nent_pages[PRD_TABLES_NUM]; u8 sgls_nent[PRD_TABLES_NUM]; u8 prd_tbl_num; =20 --=20 2.43.0