Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3412247pxf; Mon, 22 Mar 2021 06:01:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwvqS01bvUmxLU2RoL/bky65iSIJWarmOJ3CARUfisWowLilFuILbD7P2GpwV8qEX3v6coY X-Received: by 2002:ac8:5313:: with SMTP id t19mr9406411qtn.148.1616418063910; Mon, 22 Mar 2021 06:01:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616418063; cv=none; d=google.com; s=arc-20160816; b=W46FFHFXW2JTb4gzvNjFP7WV6RxhrqjH4v9uznmngpdln/kcQ2r10LnMS9+C96DC+K I0jDf6+wIPxzmArMCp+K+LiyuBTtymWKUkYidEeJ6ASSDDEIW9TcAVhPlD7WiUBZLV4O AmieabdP6fs6ABPDTw+hTERqqLf8kXW48HoNNslsFvLYpdMeHcjk/lhYAb5cA7+ULu27 7HMf5MZy3Cddtj7aaaivMaALhrHVk8ARgaAVTmt1g4YfMQEyZLxTfixsZTHgpUKajFpo ET6sc0HRSb/WhxENFQ2ICTK5qQVDQ+VdQC/ezFfus41RN++wOkzQQ6mf41SJPs8+gi53 uC/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:ironport-sdr:ironport-sdr; bh=4AHJyn3YCwGlxUvVbhUuJp9cG7t3mE8YWJZZyqrkEwc=; b=zGyzix8EFwKLbMNLIo57+LKITMK1dm2cvvoa4q8Ez5ioZw7eUtTgQJtDP7VtbgdZHK wI8Lb2Ki62H32GaYSMSEWLjPrkQPjLnYiBLrJNiuFKbt+WMGMq8Usc2hsCEmnXaMkpjy Jsm/mqYtV9G6nd1/5w//2pe+/cgzsMtfE/aHD40wC1AsWPsKNfTEyN/rWbX3Nfdbw335 Er+uBIg5HHbdy6HQBl68u4hkufY29xiUfN+IOGdtf69Tq2pcQTm94Kr990ShNG5vAj4D LEuecWrIh07R7OXFq1dFpPRxYCcnSk6TLINmE117mrdOQ0UQRlJDvXTIPzmB7HBU9y46 B+ew== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id mm23si11259084ejb.540.2021.03.22.06.00.39; Mon, 22 Mar 2021 06:01:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232680AbhCVM4S (ORCPT + 99 others); Mon, 22 Mar 2021 08:56:18 -0400 Received: from mga01.intel.com ([192.55.52.88]:27268 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229786AbhCVMpM (ORCPT ); Mon, 22 Mar 2021 08:45:12 -0400 IronPort-SDR: 7SEbucVxbgex2/jMHx9fLYjhKcFdFKlKiHoujLEOgi8T6EhcjUHy0EWKht3wUbhUXMlODGpNOf c+kZ/YUXaLPg== X-IronPort-AV: E=McAfee;i="6000,8403,9930"; a="210328167" X-IronPort-AV: E=Sophos;i="5.81,268,1610438400"; d="scan'208";a="210328167" Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Mar 2021 05:38:30 -0700 IronPort-SDR: ws/NYUrdF9RDhSUtWKuljteG3WLbdgnXUNDdqCezp7/dqCqStpBygn6tF9hLGX3ogxpF0gDjC/ vK96jcytVz0w== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.81,268,1610438400"; d="scan'208";a="441154134" Received: from marshy.an.intel.com (HELO [10.122.105.143]) ([10.122.105.143]) by fmsmga002.fm.intel.com with ESMTP; 22 Mar 2021 05:38:29 -0700 Subject: Re: [PATCH] firmware: stratix10-svc: build only on 64-bit ARM To: Krzysztof Kozlowski , Arnd Bergmann Cc: Linux Kernel Mailing List , Dinh Nguyen , kbuild-all@lists.01.org, Linux ARM , kernel test robot , Lorenzo Pieralisi , Jens Wiklander References: <20210321184650.10926-1-krzysztof.kozlowski@canonical.com> <2ae8379f-c79f-3257-e54c-fa17c576e929@canonical.com> From: Richard Gong Message-ID: <26fe4358-4ebd-7346-8944-13b13da75c6f@linux.intel.com> Date: Mon, 22 Mar 2021 07:58:19 -0500 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <2ae8379f-c79f-3257-e54c-fa17c576e929@canonical.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/22/21 3:26 AM, Krzysztof Kozlowski wrote: > > On 21/03/2021 22:09, Arnd Bergmann wrote: >> On Sun, Mar 21, 2021 at 7:46 PM Krzysztof Kozlowski >> wrote: >>> >>> The Stratix10 service layer and RCU drivers are useful only on >>> Stratix10, so on ARMv8. Compile testing the RCU driver on 32-bit ARM >>> fails: >>> >>> drivers/firmware/stratix10-rsu.c: In function 'rsu_status_callback': >>> include/linux/compiler_types.h:320:38: error: call to '__compiletime_assert_179' >>> declared with attribute error: FIELD_GET: type of reg too small for mask >>> _compiletime_assert(condition, msg, __compiletime_assert_, __COUNTER__) >>> ... >>> drivers/firmware/stratix10-rsu.c:96:26: note: in expansion of macro 'FIELD_GET' >>> priv->status.version = FIELD_GET(RSU_VERSION_MASK, >>> >>> Signed-off-by: Krzysztof Kozlowski >>> Reported-by: kernel test robot >> >> While I agree that one shouldn't run 32-bit kernels on this, we should also try >> to write drivers portably, and in theory any SoC that can run a 64-bit >> Arm kernel >> should also be able to run a 32-bit kernel if you include the same drivers. >> >> It seems that the problem here is in the smccc definition >> >> struct arm_smccc_res { >> unsigned long a0; >> unsigned long a1; >> unsigned long a2; >> unsigned long a3; >> }; >> >> so the result of >> >> #define RSU_VERSION_MASK GENMASK_ULL(63, 32) >> priv->status.version = FIELD_GET(RSU_VERSION_MASK, res->a2); >> >> tries to access bits that are just not returned by the firmware here, >> which indicates that it probably won't work in this case. >> >> What I'm not entirely sure about is whether this is a problem in >> the Intel firmware implementation requiring the smccc caller to >> run in a 64-bit context, or if it's a mistake in the way the driver >> extracts the information if the firmware can actually pass it down >> correctly. > > The SMC has two calling conventions - SMC32/HVC32 and SMC64/HVC64. The > Stratix 10 driver uses the 64-bit calling convention (see > INTEL_SIP_SMC_FAST_CALL_VAL in > include/linux/firmware/intel/stratix10-smc.h), so it should not run in > aarch32 (regardless of type of hardware). > > I think that my patch limiting the support to 64-bit makes sense. > The stratix10 service layer and RSU driver are only used in Intel 64-bit SoCFPGA platforms. > Best regards, > Krzysztof >