From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 8E25B2C15A0 for ; Tue, 17 Feb 2026 07:40:27 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1771314028; cv=none; b=WcnvQDf+ptPKeg6keyLbw7sCai7V+3qgsmXsh9mQZax9+FTZaoed7GEphOvqXZGrqlfxRPAX7sjpxvoq+W3ioc+21FIe3ubvvgg3fXZKEXffXEegFydVXG/ufHFnw+dOx0fZRq9NplArLJykEbkJ+COAXyr7bWH6h30Xu2fit0A= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1771314028; c=relaxed/simple; bh=hDLQGKM9dIV7RFkC9uJgukv9AYJktOn4LBDGaacvpSw=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=Ji0/O5zozY4VA6BJFTE5g55TH1wP0TfeFupNeQLzI8xM6oBc9Igf2GZwgPQys+l7NxcnYc8enauAVsEGaHAYnh4rj1MkvwPb2YfdEdZ4RxZyss+x8bi0Opk+o0u7SjHCcJVMfmBZdGvBSvwZxmVwmV+Q7OPmu57F7rcrHSsY44g= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=Xdw3wVqR; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=atEC8APd; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="Xdw3wVqR"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="atEC8APd" Received: from pps.filterd (m0279864.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 61GH4Fpw1544910 for ; Tue, 17 Feb 2026 07:40:27 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= 5iaSBmIn1qyUfIvnkWdm89QHe25+Xo3VgYMyraXjMpw=; b=Xdw3wVqRjNStiYAN fJXtCuVeq75AayRe0DlqOivANILY6hTr3gvLMfJuCMr1U7ntSS/CjGqj44TRP3GL DntUeCvNij15y8WZwr2m5cEfkqHWLHdt9tjPRWxjxb1Wfa1VD+Qm2OEi+2GUV/dE zByFq6FMw3YyWk8AkMSafg0cKgmApWrtP96Ic2o9nTBYqa2ddxQgFk9Mn45ioyOu 8tmciFjZD+pbTQIRIQuWPYUnUcWGhBWxg1L+M5b2hS1KL/GzlTCEzTuKSV+oSu8s lo617Nvn6BY7JpwSvGAg8nccBqKdCFkitJrhlYBgQxy+/xS2kmLmAIuVEQchVYuG lKaR3Q== Received: from mail-pl1-f199.google.com (mail-pl1-f199.google.com [209.85.214.199]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4cc7ajsd1v-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Tue, 17 Feb 2026 07:40:26 +0000 (GMT) Received: by mail-pl1-f199.google.com with SMTP id d9443c01a7336-2aaf0dbd073so48363685ad.3 for ; Mon, 16 Feb 2026 23:40:26 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1771314026; x=1771918826; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=5iaSBmIn1qyUfIvnkWdm89QHe25+Xo3VgYMyraXjMpw=; b=atEC8APd44ar3KBdZM8cqyJPw+cDiAhstTv1SaqYYcwzos+Nm+L+5keyYqcWpqqGZp eFPaR6DrX5krtVUcvQlpTfq3ouFBdeOwQV6/itF5q7LLyMLHfRYFCapRCNf7p0ToYPqR /Pi+4ivi7BTBYtZUswCEm7s289MgJtMu5kPTkZrFsWQbZ/kFADz7bi62LkpAry0rIK8Y UMeDMgZaNxhoEGg2cCf+BSndAKpDBTLryUoBzPCHHDK9lAAvcCjGfmEHEHfxsJ7+ham/ uqWyYy4u9cFEgOtW9uPKIKcxz/7nT83L+RKSWFR0YKUre486ivk2jtL6d3uxcsTmGbWO +iuQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1771314026; x=1771918826; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-gg:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=5iaSBmIn1qyUfIvnkWdm89QHe25+Xo3VgYMyraXjMpw=; b=l0f0m+tyIMLO4sW8UqG3/ejPC0oMqoKr4KyoJ7Gj+0I7E1NQSyAaC3Qw2RD41qkuFA wN6vzLOVtoCLqCuXVCiQKYtWeNPK35bKt36oLlenqhVLASine0D1xfsAZooAVBzUE+uD usZ8yMFSB6Emgnoz+mnBmAyM7BjJ7yIHspNj+WIuYNGlmc1iXF3uyNHc/W3VkAI7Ji1B 3ndUE+a/joGzjV/2v3vaAuidgA0+8ZP/fEts2p6JM6zlk5ECtGBAo0VFgH7who0O0f8i yec3kxOaWpJYX1rdM8kaUCV1tYPxfstezv6wobQtDQwalW3m2/HlxIvWEA72NWez/fif Nbbg== X-Forwarded-Encrypted: i=1; AJvYcCUofiS8nYHAf9o9XlJ2BVRwxFrGTcJoLNo+bNZWFl5e5W+ynGgupfadrvc9OiWjlD4WnymguQr8Bqg+ykxd@vger.kernel.org X-Gm-Message-State: AOJu0YzprLUZcabfTQbuBSe/TLGz22HqgL2R44Xu5OnTm7EeSj9oh3PO U4LWDj+rXuqlQUW8GUdryIHquaCLVvWU0T2ni8ABV8SMfZ2In2aC5881kuVwPldtTtAcKccwEaR gnlmi/+K53HsSBffQ9paSYJtjiZYA/S6ZN7hg4kWSAf7ybrE5aZjLxx6UHkBNc+/ePd2I X-Gm-Gg: AZuq6aIXLuaOr9g/naHUpWmJZqfSpjhuf1hfwXvhNV1zeS2ANKLjwzhv32xU7c0qjNn bXA0c4EaQ0t3XDjL0JkcyIUtQqzPfzMvY4KzlTkUtckggVha9mey1u8Ecggvra3RlatZ7LX2NsK fJdxCSCCJ7rxr2V77DfDYiTaTNGqfhkHNHEB8K7TS5GNF08/c9bWxIXHMZYSmm6C2d3lcVAtPMY odPictpvAVTomur+e6TzN5pgxfTiY8Cdq8qxQC5sbIGip7UUT/EvMlxOi7AQA81GVLeemsucfKE C0qMcDv76JjP+IKYeKPjYAW/UEoJ0w0Wz+fVlz7yPql0COY9VsqeolDFotvFSlOmaPJtzO4ma6H SlTJJUHW+H9UpSBgTicAlti3C9JVQwbLvK1CJfRygFYABI28MTlMH X-Received: by 2002:a17:902:d552:b0:2a0:823f:4da6 with SMTP id d9443c01a7336-2ab506101c6mr136269685ad.50.1771314026043; Mon, 16 Feb 2026 23:40:26 -0800 (PST) X-Received: by 2002:a17:902:d552:b0:2a0:823f:4da6 with SMTP id d9443c01a7336-2ab506101c6mr136269515ad.50.1771314025549; Mon, 16 Feb 2026 23:40:25 -0800 (PST) Received: from [10.0.0.3] ([106.222.232.28]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-2ad1a7138e1sm124543145ad.25.2026.02.16.23.40.22 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 16 Feb 2026 23:40:25 -0800 (PST) Message-ID: <2f85b131-2167-838c-152a-03be689b0b29@oss.qualcomm.com> Date: Tue, 17 Feb 2026 13:10:21 +0530 Precedence: bulk X-Mailing-List: linux-arm-msm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.15.1 Subject: Re: [PATCH 2/2] media: iris: Enable Gen2 HFI on SC7280 Content-Language: en-US To: Dmitry Baryshkov Cc: Konrad Dybcio , Vikash Garodia , Abhinav Kumar , Bryan O'Donoghue , Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org References: <20260209-iris_sc7280_gen2_support-v1-0-390000a4fa39@oss.qualcomm.com> <20260209-iris_sc7280_gen2_support-v1-2-390000a4fa39@oss.qualcomm.com> <0da582a6-5bba-4450-99ec-cf57b67915e6@oss.qualcomm.com> <0a324898-092b-3e44-c35c-15de20b50f40@oss.qualcomm.com> <2uih6xdzarkwnvhlhv5kznmdwo4jorqvsrb7xxrxgr6vprx3ey@4kx45k5i3c4y> <6b9042c8-767e-0fdb-9012-f3790899509e@oss.qualcomm.com> From: Dikshita Agarwal In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwMjE3MDA2MiBTYWx0ZWRfXzEFNoJXwYrEu Ong5ymFkYcweY7DM3/BTB7s9F9h6Z2QpqEsG2TiPCPy73irY4DpkKuANw7Id5iUIDvaqUoOF+ch MVErvKV/7LSjxbk1PEoIkyREh3aYfjXuaxqLkSUSnFJOuhG3AmJwoK/evd9t1dBL0oNQSpSPogS tNMTzO9eGaZJFFi05pFf+i5nYQcG4U3FAH8Wxn2Nq/i97nZ0MzTJcUXCboQd5PifxISERcNUrRw TJpDvheCvFFNmBoKIh6O1zNbmlhJyE0/uQXkHgHl5N0J1Y2cMNjhoX6S0e/+s/aUWaRQyRT2Nwq lD72S6skU++V+EgpZEEkhEcExi5iaCu0uZzEK7GWhGlG3pfnteiVjgSs4hbPOFlOk0MPNkkrxP1 xDrLkS+3NHm842yrI+h1Y0EaO2ZqLR2PDy9hLiDX/JUUI3nMygkFfrLTD8/r2tnnIIsn/UMseuS qHd32/GOG14K0bzJLXA== X-Proofpoint-ORIG-GUID: -9PToF-IjyCir70w_QohxZMgy5N8oAoj X-Authority-Analysis: v=2.4 cv=BryQAIX5 c=1 sm=1 tr=0 ts=69941b6a cx=c_pps a=JL+w9abYAAE89/QcEU+0QA==:117 a=wLlKp180pkOCiHd7nYENcw==:17 a=IkcTkHD0fZMA:10 a=HzLeVaNsDn8A:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=Mpw57Om8IfrbqaoTuvik:22 a=GgsMoib0sEa3-_RKJdDe:22 a=P-IC7800AAAA:8 a=EUspDBNiAAAA:8 a=P2x2pnpvN4DjWuG0SLoA:9 a=3ZKOabzyN94A:10 a=QEXdDO2ut3YA:10 a=324X-CrmTo6CU4MGRt3R:22 a=d3PnA9EDa4IxuAV0gXij:22 X-Proofpoint-GUID: -9PToF-IjyCir70w_QohxZMgy5N8oAoj X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1121,Hydra:6.1.51,FMLib:17.12.100.49 definitions=2026-02-17_01,2026-02-16_04,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 impostorscore=0 spamscore=0 lowpriorityscore=0 suspectscore=0 phishscore=0 clxscore=1015 adultscore=0 bulkscore=0 priorityscore=1501 malwarescore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2601150000 definitions=main-2602170062 On 2/13/2026 5:34 PM, Dmitry Baryshkov wrote: > On Thu, Feb 12, 2026 at 06:35:19PM +0530, Dikshita Agarwal wrote: >> >> >> On 2/12/2026 5:13 PM, Konrad Dybcio wrote: >>> On 2/12/26 12:16 PM, Dikshita Agarwal wrote: >>>> >>>> >>>> On 2/9/2026 6:05 PM, Dmitry Baryshkov wrote: >>>>> On Mon, Feb 09, 2026 at 05:04:48PM +0530, Dikshita Agarwal wrote: >>>>>> >>>>>> >>>>>> On 2/9/2026 3:32 PM, Konrad Dybcio wrote: >>>>>>> On 2/9/26 10:45 AM, Dikshita Agarwal wrote: >>>>>>>> SC7280 supports both Gen1 and Gen2 HFI firmware. The driver continues to >>>>>>>> use Gen1 by default, but boards that intend to use Gen2 firmware can >>>>>>>> opt‑in by specifying a Gen2 image through the Device Tree >>>>>>>> 'firmware-name' property. >>>>>>>> >>>>>>>> Based on this property and the availability of the referenced >>>>>>>> firmware binary, the driver selects the appropriate HFI generation and >>>>>>>> updates its platform data accordingly. Boards that do not >>>>>>>> specify a Gen2 firmware, or where the firmware is not present, >>>>>>>> automatically fall back to Gen1. >>>>>>>> >>>>>>>> Signed-off-by: Dikshita Agarwal >>>>>>>> --- >>> >>> [...] >>> >>>>>> To avoid accidental matches, I can switch to an exact filename match >>>>>> instead. That way, only the specific Gen2 image (for example >>>>>> "qcom/vpu/vpu20_p1_gen2.mbn") will trigger the Gen2 path, and boards that >>>>> >>>>> How do you detect that for the OEM-signed firmware, which can have >>>>> random name? >>>>> >>>>>> want to use Gen2 can opt in by naming the firmware accordingly. >>>> >>>> I Explored on suggested alternative approaches and seeing some limitation >>>> with the both of them: >>>> >>>> 1. Detecting Gen1/Gen2 by scanning the firmware blob (fw->data) >>>> It is possible to parse QC_IMAGE_VERSION_STRING from the .mbn and extract >>>> the version string. The issues with this approach : >>>> >>>> - the version string has no explicit marker that identifies Gen1 vs Gen2. >>>> >>>> - This prefix is not a formal ABI, and it is not consistent across SoCs. >>>> Each SoC family uses different naming patterns in the version string. >>>> >>>> Example : For SC7280 Gen1 we currently see: >>>> QC_IMAGE_VERSION_STRING=video-firmware.1.0- while SM8250 has >>>> QC_IMAGE_VERSION_STRING=VIDEO.VPU.1.0-00119-<> >>>> >>>> So the driver would need SoC‑specific string‑matching rules, which is hard >>>> to maintain if we are looking for a design to address all available SOCs. >>> >>> The only SoC with such distinction today is kodiak. So we can simply check: >>> >>> if (kodiak && strstr(fw->data, "VIDEO.VPU.1.0.") >>> hfi = gen2; >> >> Agree, this works for Kodiak. However, Dmitry was also referring to other >> SoCs that may support both Gen1 and Gen2, and at the moment there isn’t a >> generic way to handle that check. >> >> Also, please note that the Kodiak Gen1 firmware uses the string >> video-firmware.1.0, whereas Gen2 uses VIDEO.VPU.3.4. > > This is not quite true. Kodiak Gen2 uses: > > $ strings /lib/firmware/qcom/vpu/vpu20_p1_gen2.mbn | grep VERSION_S > QC_IMAGE_VERSION_STRING=video-firmware.2.4.2-d7a3d5386743efb16b828e08695bea7722cafadd > > A collection of versions quickly captured from what I have here (for > different chips, but for the overall picture): > > HFI Gen1: > > [skipping prehistorical / museum data] > VIDEO.VE.5.2-00023-PROD-2 > VIDEO.VE.5.4-00059-PROD-1 > VIDEO.VE.6.0-00055-PROD-1 > VIDEO.IR.1.0-00005-PROD-4 > VIDEO.VPU.1.0-00119-PROD-2 > video-firmware.1.0-6804c210603073037fb32640a3dd6a46fe04edd6 > video-firmware.1.0-7da9db401e417a006ef915d6c4323f00cdbcf40a > video-firmware.1.0-ed457c183307eff1737608763ca0f23656c95b53 > video-firmware.1.1-84a8080bf84fa9ab15b353bf03bea6e548d89d2f > > > HFI Gen2: > vfw-0:rel0095-d1a9e7c4a274aa13e4136500d19262f87ef2c921 > vfw-3.1:rel0085-070fa3311d9ef968015fee7fea07198d7eb208a1 > vfw-3.1:rel0093-7925621ff52ecb7b1565341042c4e5ffd4fc76ce > vfw-3.5:rel0040-1ded01d0e6dcaef08b8155fd5a02f5b57248d5ca > vfw-4.0:rel0045-25b39e81446baf48716df98dd37099a2103d36ee > video-firmware.2.4-48ec04082362ef1922fec5e20e22f7954b11d736 > video-firmware.2.4.2-d7a3d5386743efb16b828e08695bea7722cafadd > video-firmware.3.1-e5aea20c64cb6df9a1c9be99e206053b36424939 > video-firmware.3.4-e299f99ffcd086b43a2ccc7c3279ce5df404d693 > > It seems we can assume that Gen2 is: > - vfw-0 > - vfw-N.M > - video-firmware.N.M where N >= 2 > > All other binaries are Gen1. > > Also, we don't even have to query the binary firmware blob. > After the firmware is started, you can read the version string from > smem, saving us from strstr over the firmware image. AFAIK the video/iris firmware doesn't populates its version string into SMEM by default. On venus, the version string appears in SMEM only once the driver explicitly writes it after receiving the version info from the firmware as part of an HFI response. https://elixir.bootlin.com/linux/v6.18-rc5/source/drivers/media/platform/qcom/venus/hfi_msgs.c#L289 Iris does not implement this SMEM population path today, and the firmware itself does not publish its version into SMEM automatically. Because of that, reading the version from SMEM is not currently possible for iris. Also, relying on HFI to retrieve the version is not viable for detection because we cannot issue a protocol‑specific HFI command until we already know which HFI generation (Gen1 or Gen2) the currently loaded firmware supports. Due to these constraints, I think, the only possible way is to extract the version from the firmware binary blob itself. Thanks, Dikshita > >> >>> >>> >>> Can we agree that VIDEO.VPU.x firmwares are hfigen2? If so, problem also >>> solved for <=8450 >>> >> >> Nope. that's not true for all, SM8250 uses VIDEO.VPU.1.0 which is gen1. >> >> Thanks, >> Dikshita >> >>> Konrad >