From nobody Mon Jun 8 06:36:14 2026 Received: from mail-wr1-f42.google.com (mail-wr1-f42.google.com [209.85.221.42]) (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 320F643D50D for ; Fri, 5 Jun 2026 19:33:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.42 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780688010; cv=none; b=gVNzi2Nc+mNwyPwZHd5qxRbrVro7fn1uke1UJZjlVMKW4Kw0VhniFbgKY9RlSE9HuMOux8YGx9n4Canmfcelu9B8gOs+/BTrQDXjApA4gatFCvMWH98jjDSlvCuUCYg0wJPF+pcfpELcTmLVZGVaPm9dRzYd+5vC8EgNHO3LEfs= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780688010; c=relaxed/simple; bh=GUDsSnSpwDj2maWrAQsgu4r9TY3KspdS34xPLDZRLOQ=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=q0AmOMh5kAvatyEeVX719LCaE1l3LC11YoVXSzuOJkp/vRn6qcn+uEKLzGeUPXae8czhscth9FU6cBnLyl6cB3LohO6sFC7b/bxFrAMip8Vwst1RhKYdiR6xKGI8syN1SOc5rawMzalirv7UwAPCX6ajTEDCTSXKvZ3xC57DehA= 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=C6W1Ttq0; arc=none smtp.client-ip=209.85.221.42 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="C6W1Ttq0" Received: by mail-wr1-f42.google.com with SMTP id ffacd0b85a97d-45eedcdaeaaso1713316f8f.3 for ; Fri, 05 Jun 2026 12:33:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1780688008; x=1781292808; 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=pEZDD9TlhQlFNvL79/mxsSDb2Yxob9rJ9xhLRrOMmv4=; b=C6W1Ttq05nG+qQnnIcTeTbtZrhKDkeMUXA2Dt9RmJX13SUFGKTA47fwJWTYDAboB1P L8TVwJaDcC0qReK2Ov5eY16J/gLVIyjI5zVmrSchsC+EP404R29zEQYGsSfQiod5dz/G GLFhcOvEosAUhW6sS8JqUFyH/rtw+qQXS8yrkQxDUDJpWrBgHplDTxF9R0by9wR551+U wtIAziGtAUqjUg7BhRvng9LHc3ljFTIxkD7BoZ/iL9ynPpsIC+8Y2V08Iin8Nkbmr3J1 TOVbTquAsV8HmByCYSU3FyTDWqopecm3re3ASpriuzFz6ZmR0MhpD8JyPR9aRjL5NB6z +Osg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1780688008; x=1781292808; 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=pEZDD9TlhQlFNvL79/mxsSDb2Yxob9rJ9xhLRrOMmv4=; b=T/8345aCI9LXO3S+UbLXQRWDg4vUFtcD9pxWElPzvexN+L7g5rmGRSgtsK1M7kHX/y 4w7P0SN3KiBZSyxQIkeOsuCBCCDKWAIER4e47TFSiQaoK3RyvyhEz5xMPove7jswNgld b3JOkvlZSU4GxEgXwqPFBywHYOlvDp16adtxsQj+PdQYSIPbU0earXIz0A4qpfJ2Vl53 oZo/SqDy4AbUnk9FNTk6sfXEZVYFNQ/ZRRHK6Zgj3Eh+ZnNkQqxSKNUHNcs7sES/KdbK ti6GgjifBZqCBbh+8rKpYqS5Efj8lxRkavaavZj8eKfapg7JTqkeMWSz9i2nt9VgDMTV YwvQ== X-Forwarded-Encrypted: i=1; AFNElJ/o/mXmacsNPeevGHKovmfUSvxeqH7tlvxJdJ8gLGOHMJs+P9x6+z2GuSQ7Tn0medmHYUThjKLbSgZ7m4s=@vger.kernel.org X-Gm-Message-State: AOJu0YxhTZRMh8RM5uKR/+ZX98q+Vi9tDxuYWnq0dtAIJQUJDUXTmwGl fge/Wsu5f3sUG1XYeEUw52ORKFvUevmEt2lZGlzvu5dzBmQRhr0AZ5ZH X-Gm-Gg: Acq92OEusSh420+oqcGrROta4cjmXlj7YuzaftW24MS6vlBPIB914dewmYzbNRipUtA m3NY5pk17ushQS/1vSN6ulOas0zIBrEbrJdaddiFZYzeAwPzkfM0qaTmWKv9QuTag8GejMX7UER RXfp7Zr93aM/O/h+v2fwdRm5XTVtnR+EhiVap821SpV3akN+B2iBVpr76vcxr0YvlWtnhKP/OcR ouWEwgOqsuCt/2oaksWVW/Y+fr9a9w5IiKDegLVzxQ99xyoMs7gmk1SjMK4a4J1oqsAuZ7FHUJP Tx4sMtK+cJl1tNtFWB5vW0Iqh3cyfXtBszeQcvTQMdq7+OHP8OzEjEJZ/UrwzhDl5uFAxlJ+9pk O33sjQpUQ7YVObR+VZK2e9zwQg+M5BT7+gat2AnBROOdJKP+fRu0ZDlgOKwQ+xvby37zcQAXybd G5by19dhrH3qYSHHABHkDsq9K/lTUUpJozSOP5B5/AmMtYX07mpKu3N9y8nWnkF47LKVIX+qj3o pllOLZwSixI X-Received: by 2002:adf:e68f:0:b0:45f:f142:d55d with SMTP id ffacd0b85a97d-460307761e2mr6539957f8f.39.1780688007512; Fri, 05 Jun 2026 12:33:27 -0700 (PDT) Received: from node ([202.47.63.86]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-4601f345209sm28025464f8f.17.2026.06.05.12.33.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 05 Jun 2026 12:33:27 -0700 (PDT) From: Muhammad Bilal To: robh@kernel.org Cc: tomeu@tomeuvizoso.net, ogabbay@kernel.org, tzimmermann@suse.de, Frank.Li@nxp.com, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, stable@vger.kernel.org, Muhammad Bilal Subject: [PATCH] accel/ethosu: include secondary weight/scale extents in region_size[] accounting Date: Sat, 6 Jun 2026 00:33:11 +0500 Message-ID: <20260605193311.48008-1-meatuni001@gmail.com> X-Mailer: git-send-email 2.54.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" calc_sizes() updates region_size[] with the extent of weight[0] and scale[0] within their hardware regions, but omits weight[1..3] and scale[1]. Since no NPU_SET_WEIGHT1_REGION, NPU_SET_WEIGHT2_REGION, NPU_SET_WEIGHT3_REGION, or NPU_SET_SCALE1_REGION commands exist in the command set, secondary buffers implicitly share the same hardware region as weight[0] and scale[0] respectively. The omission means region_size[] reflects only the primary buffer extent. If a secondary weight or scale buffer extends beyond the primary one, region_size[] may underestimate the required GEM buffer size. Fix by extending the region_size[] update in calc_sizes() to cover weight[1..3] and scale[1], skipping entries that still hold the U64_MAX/U32_MAX sentinel values written by cmd_state_init(). Fixes: 5a5e9c0228e6 ("accel: Add Arm Ethos-U NPU driver") Cc: stable@vger.kernel.org Suggested-by: Rob Herring Signed-off-by: Muhammad Bilal --- drivers/accel/ethosu/ethosu_gem.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/drivers/accel/ethosu/ethosu_gem.c b/drivers/accel/ethosu/ethos= u_gem.c index 7994e7073..152733b6a 100644 --- a/drivers/accel/ethosu/ethosu_gem.c +++ b/drivers/accel/ethosu/ethosu_gem.c @@ -271,6 +271,8 @@ static int calc_sizes(struct drm_device *ddev, } =20 if (weight) { + int i; + dev_dbg(ddev->dev, "op %d: W:%d:0x%llx-0x%llx\n", op, st->weight[0].region, st->weight[0].base, st->weight[0].base + st->weight[0].length - 1); @@ -280,6 +282,14 @@ static int calc_sizes(struct drm_device *ddev, info->region_size[st->weight[0].region] =3D max(info->region_size[st->weight[0].region], st->weight[0].base + st->weight[0].length); + for (i =3D 1; i < ARRAY_SIZE(st->weight); i++) { + if (st->weight[i].base =3D=3D U64_MAX || + st->weight[i].length =3D=3D U32_MAX) + continue; + info->region_size[st->weight[0].region] =3D + max(info->region_size[st->weight[0].region], + st->weight[i].base + st->weight[i].length); + } } =20 if (scale) { @@ -292,6 +302,11 @@ static int calc_sizes(struct drm_device *ddev, info->region_size[st->scale[0].region] =3D max(info->region_size[st->scale[0].region], st->scale[0].base + st->scale[0].length); + if (st->scale[1].base !=3D U64_MAX && + st->scale[1].length !=3D U32_MAX) + info->region_size[st->scale[0].region] =3D + max(info->region_size[st->scale[0].region], + st->scale[1].base + st->scale[1].length); } =20 len =3D feat_matrix_length(info, &st->ofm, st->ofm.width, --=20 2.54.0