From nobody Fri Apr 17 09:21:55 2026 Received: from mail-pl1-f182.google.com (mail-pl1-f182.google.com [209.85.214.182]) (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 E769736F428 for ; Wed, 4 Mar 2026 04:14:18 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.214.182 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772597660; cv=none; b=DCTLH/CPsi9E+P+OysEl1D0EjjInkPWTblUOYRhkRSowAIOL/4qssIlwwvRgYXyvh1YuLt49o6H7LThXNOB1FvvDwQvpmvCrQ4t6zvm8FW1MfLjLSHIk+wkuNF69GjaDacmndRet99U8lP00pk0gsWKJ8UStOaKQK2sHiyQJQVg= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772597660; c=relaxed/simple; bh=uoSf/yWTQAEcMzTLff+c+Dblvpst/fEZl2MGCo7pz4A=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=ZGerQi1iPEPpuOyIBEPPFLxFss+jy9Vc7ykAA3fbAPfl+ajMU7tNBL3qxWO6D8lkSVHktew87t/PFjlFNobpUeHZ6aklJ0NbVK5Hw8pDHkxHR/1SP07gl4qOYa7fgFs3Ijm0XPeQfpwVkmpt4MWCYaj4lx4wfGO+253KUzQRzeQ= 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=PjgchP0G; arc=none smtp.client-ip=209.85.214.182 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="PjgchP0G" Received: by mail-pl1-f182.google.com with SMTP id d9443c01a7336-2aae4816912so43178135ad.2 for ; Tue, 03 Mar 2026 20:14:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1772597658; x=1773202458; 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=YNQEOfz/uaj72zFc2OfYhyedqZgPJsuVowB3OOH5Yjk=; b=PjgchP0G6loX3a8YCvDLYAV0eQXZIg7EYp2gf7JMP3qUXRJPDZ5DOhJOgofGm7gPJO 9qgUsOlsMFfCL22K6ct/xqLqfHpZdsaRqAKoyDOyplBiJ7AGIhJiz2pSaT/QgCWBANxH 6hC1QscnDyp9C8bELQuXE/hXtbdEziKQNOusXBqbt4g3kNzwgxUSb6jHv3k5tIr/E6UD J7V4lDdgcNr/nT9FvRpxUfOTTWiM22soq+WRaEE4UGMTVng2Z2FWPUwd9Nl8viwlZIQA n3r1fje+npA4P0Cf5g3H7x1/pXRjQBLkuFgiwrjcmFEXelJJQDOv7cE0czLqk8Yzpr++ jIrw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772597658; x=1773202458; 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=YNQEOfz/uaj72zFc2OfYhyedqZgPJsuVowB3OOH5Yjk=; b=Dx3+5AbSXVdcpfoAQWGofuq/eQwZbnibtVTah4VInnmlpuvEupXMd0OaWtlhz1h+Qf 5GHl6CbPcpMffs5ry2GtjysvKpM8N1sfHSvWhzbYwZFjJebPHyKEmyz1oa7JEzOkfVxX F1meo3hUaKoKKaa3eO2hlEmeeaNZB+MUSlmdmFh4aw7wUoOiubyT703179qAuSgQ+GLx lkCcGOB1jM9lbUm6p2MMfUBtXuIB8Vb03/dkrUTuQQMXsw1kFkFZvx7wOvmLDkPqC6ku amzhfeBEh2DXPPJtUwNvwArQJSYZLyAKQ9bnMD1NMtPryUJH65DBK7z9aKu6DhdQzPN+ ta8g== X-Forwarded-Encrypted: i=1; AJvYcCV9z6GMjx3gQnIq49r1Da2tKov8H6shkSK3bVu5a8MZStP4SLUxKWMdofC3OwNOLT7NyjKGwTkyx81frDQ=@vger.kernel.org X-Gm-Message-State: AOJu0YwhVX9tEfvFLofKALReDteKtnd3X8y6wpAqfeX9LUlMTFKIjaqw 7HaFZdBdmfGB0lyNqar21lUDTk3XA/wQYH5Qb8sUiRCw4QRC/BsAvyPa X-Gm-Gg: ATEYQzyO+H6cDYy6/HRdt1j61XjbZbzHL+Fm9k0ZDz8Xy2vAAtkbiAOcIfr/6KwdFg0 xuXEXz6sptn1mj8oCkDOpIfLy3qgFHiSKRqAsDmTOX96+EPAWloigUj5Q3gbi9/FY30J0dhwJs2 3p/vNj5W/p/pdEXc3PMSdHF7fQvsBXvg0B0tw2pe0THqcVn0733EDNBM0PI3J16Fpqd44hPr0eW H2BmEI1cYWsmfSJODPVykQc7deudyHhAVpNPLKngjhaoZwclZ9ywxlcMRnVh0UHZmMlEkDNFGXi P86HHijcgztMrfUwhtxO4/Wfla1HCwKo4TEeGojakBsLjdFaDLmpsU2GHBqHIRzAvnGFDKEtdp8 FrdYEYyxRkt2v4wYsdlmMMX4DWLY4my+AXxhhQ+f84oSzD50VczL4tcgwiyuKGKVmj5wR3cq9e8 Rk+Dnz8cER40jTCtvVZPhpuYahdWNUlb7FZHQcqjzmmw6FP9dzhnqZ4g== X-Received: by 2002:a17:902:d50e:b0:2ae:673b:6a3 with SMTP id d9443c01a7336-2ae6ab8e78emr8091365ad.49.1772597658095; Tue, 03 Mar 2026 20:14:18 -0800 (PST) Received: from ryzen ([2601:644:8000:56f5::8bd]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-2adfb5c183bsm188270585ad.24.2026.03.03.20.14.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Mar 2026 20:14:17 -0800 (PST) From: Rosen Penev To: linux-phy@lists.infradead.org Cc: Chunfeng Yun , Vinod Koul , Neil Armstrong , Matthias Brugger , AngeloGioacchino Del Regno , Kees Cook , "Gustavo A. R. Silva" , linux-arm-kernel@lists.infradead.org (moderated list:ARM/Mediatek USB3 PHY DRIVER), linux-mediatek@lists.infradead.org (moderated list:ARM/Mediatek USB3 PHY DRIVER), linux-kernel@vger.kernel.org (open list:ARM/Mediatek SoC support), linux-hardening@vger.kernel.org (open list:KERNEL HARDENING (not covered by other areas):Keyword:\b__counted_by(_le|_be)?\b) Subject: [PATCH] phy: mediatek: tphy: simplify main allocation Date: Tue, 3 Mar 2026 20:14:00 -0800 Message-ID: <20260304041400.7236-1-rosenp@gmail.com> X-Mailer: git-send-email 2.53.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" Use a flexible array member to replace kzalloc + kcalloc with a single kzalloc. Shuffled some code around as __counted_by requires the counting variable to be assigned first. Removed NULL check from of_get_match_data as it's never NULL per the device table. Signed-off-by: Rosen Penev --- drivers/phy/mediatek/phy-mtk-tphy.c | 19 +++++++------------ 1 file changed, 7 insertions(+), 12 deletions(-) diff --git a/drivers/phy/mediatek/phy-mtk-tphy.c b/drivers/phy/mediatek/phy= -mtk-tphy.c index acf506529507..3a6d61cf1cd0 100644 --- a/drivers/phy/mediatek/phy-mtk-tphy.c +++ b/drivers/phy/mediatek/phy-mtk-tphy.c @@ -340,10 +340,10 @@ struct mtk_tphy { struct device *dev; void __iomem *sif_base; /* only shared sif */ const struct mtk_phy_pdata *pdata; - struct mtk_phy_instance **phys; - int nphys; int src_ref_clk; /* MHZ, reference clock for slew rate calibrate */ int src_coef; /* coefficient for slew rate calibrate */ + int nphys; + struct mtk_phy_instance *phys[] __counted_by(nphys); }; =20 #if IS_ENABLED(CONFIG_DEBUG_FS) @@ -1572,22 +1572,17 @@ static int mtk_tphy_probe(struct platform_device *p= dev) struct mtk_tphy *tphy; struct resource res; int port, ret; + size_t nphys; =20 - tphy =3D devm_kzalloc(dev, sizeof(*tphy), GFP_KERNEL); + nphys =3D of_get_child_count(np); + tphy =3D devm_kzalloc(dev, struct_size(tphy, phys, nphys), GFP_KERNEL); if (!tphy) return -ENOMEM; =20 + tphy->nphys =3D nphys; + tphy->dev =3D dev; tphy->pdata =3D of_device_get_match_data(dev); - if (!tphy->pdata) - return -EINVAL; =20 - tphy->nphys =3D of_get_child_count(np); - tphy->phys =3D devm_kcalloc(dev, tphy->nphys, - sizeof(*tphy->phys), GFP_KERNEL); - if (!tphy->phys) - return -ENOMEM; - - tphy->dev =3D dev; platform_set_drvdata(pdev, tphy); =20 sif_res =3D platform_get_resource(pdev, IORESOURCE_MEM, 0); --=20 2.53.0