Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp2188202pxb; Tue, 12 Oct 2021 00:57:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwZYhQ12uShrRjnqoKB7IwtSHl09fjOzAKPIPYp9wxBkjOc9bb9nbirdH1HFMcG7XmPdVyM X-Received: by 2002:a17:90b:1c82:: with SMTP id oo2mr4386517pjb.53.1634025452574; Tue, 12 Oct 2021 00:57:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634025452; cv=none; d=google.com; s=arc-20160816; b=U+m5FsYSdOKf5dQDwSPngzo/IDdEmTTChDZTm7/6ZBK1S9ZMZ1pcInRzz19IFpc5Q6 wpQSldjbMsgWzpnL6FjWRoB1emTdNE0+vxb2mHHGXnwGi79TTo/ZOfju2I7zLbZCprnS 2hlXLFMo9WBiaAarB2NLwVwy6ecJnH7urJcZ/4sj3HJjCcFSnm5kthED3qZK/fT2WkhS cPQQ4VCZ3/cD/jVCLnrs4+zEESEImFyRvoUt8eQwgVTWvae7rTX0HLtIAziUhL59wro7 6jRxLP8nl9g+KK2tdUJoQ62UEM7RpRUKIFFGL+bSoewCthf4gxSAlavfMKB+QQpr4Ldc vjxw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=p11yGYuP43jEtCCJxdrtPPLV+wMPT2gjEZ/MUNwwZrM=; b=rTtCdng+aem3vyP3lOaIDVw1kpkswRDjEo88hPMSME1ywsUDfGXlVRgOLH5/uyWzi8 EI88grusRnT+f6npDtnlNY1Er8+to1mL8xn2NOMk/b/BKF531jqavH8DggqTiK8sgQQT +lffd9aGZBMDn9jUIQwIRy6KEos4oRu+ie0DBwNdaKPY1anGaI1Tn3VrJkHulxVBn0Kl GS8VbpBAkpxy0yDIAmKolxNrMAP1oCZ/HQFmUf8hABQPeFnoLXbUm/tRrG7yrxgfB8Ac mYX828PwdjL1ZEB/8DmuMPSCSZsXDMKj3mAUxp8GlyFLy0344up1i3/oMyPcxCinBZ1m sB/g== 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 ls6si3931190pjb.138.2021.10.12.00.57.20; Tue, 12 Oct 2021 00:57:32 -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 S234460AbhJLH6N (ORCPT + 99 others); Tue, 12 Oct 2021 03:58:13 -0400 Received: from mga07.intel.com ([134.134.136.100]:10457 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234071AbhJLH6M (ORCPT ); Tue, 12 Oct 2021 03:58:12 -0400 X-IronPort-AV: E=McAfee;i="6200,9189,10134"; a="290565900" X-IronPort-AV: E=Sophos;i="5.85,367,1624345200"; d="scan'208";a="290565900" Received: from orsmga007.jf.intel.com ([10.7.209.58]) by orsmga105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Oct 2021 00:56:10 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.85,367,1624345200"; d="scan'208";a="480237924" Received: from yilunxu-optiplex-7050.sh.intel.com (HELO localhost) ([10.239.159.162]) by orsmga007.jf.intel.com with ESMTP; 12 Oct 2021 00:56:08 -0700 Date: Tue, 12 Oct 2021 15:49:44 +0800 From: Xu Yilun To: Tom Rix Cc: Russ Weight , mdf@kernel.org, linux-fpga@vger.kernel.org, linux-kernel@vger.kernel.org, lgoncalv@redhat.com, hao.wu@intel.com, matthew.gerlach@intel.com Subject: Re: [PATCH v17 0/5] FPGA Image Load (previously Security Manager) Message-ID: <20211012074944.GC95330@yilunxu-OptiPlex-7050> References: <20210929230025.68961-1-russell.h.weight@intel.com> <20211009080859.GA85181@yilunxu-OptiPlex-7050> <450ed897-f726-9671-26b7-2a24bb046e89@redhat.com> <20211011014154.GA82360@yilunxu-OptiPlex-7050> <79350773-3629-2734-21c0-0314a762e722@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <79350773-3629-2734-21c0-0314a762e722@redhat.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Oct 11, 2021 at 05:35:03AM -0700, Tom Rix wrote: > > On 10/10/21 6:41 PM, Xu Yilun wrote: > > On Sat, Oct 09, 2021 at 05:11:20AM -0700, Tom Rix wrote: > > > On 10/9/21 1:08 AM, Xu Yilun wrote: > > > > On Wed, Sep 29, 2021 at 04:00:20PM -0700, Russ Weight wrote: > > > > > The FPGA Image Load framework provides an API to upload image > > > > > files to an FPGA device. Image files are self-describing. They could > > > > > contain FPGA images, BMC images, Root Entry Hashes, or other device > > > > > specific files. It is up to the lower-level device driver and the > > > > > target device to authenticate and disposition the file data. > > > > I've reconsider the FPGA persistent image update again, and think we > > > > may include it in FPGA manager framework. > > > > > > > > Sorry I raised this topic again when it is already at patch v17, but now > > > > I need to consider more seriously than before. > > > > > > > > We have consensus the FPGA persistent image update is just like a normal > > > > firmware update which finally writes the nvmem like flash or eeprom, > > > > while the current FPGA manager deals with the active FPGA region update > > > > and re-activation. Could we just expand the FPGA manager and let it handle > > > > the nvmem update as well? Many FPGA cards have nvmem and downloaders > > > > supports updating both FPGA region and nvmem. > > > > > > > > According to the patchset, the basic workflow of the 2 update types are > > > > quite similar, get the data, prepare for the HW, write and complete. > > > > They are already implemented in FPGA manager. We've discussed some > > > > differences like threading or canceling the update, which are > > > > not provided by FPGA manager but they may also nice to have for FPGA > > > > region update. An FPGA region update may also last for a long time?? > > > > So I think having 2 sets of similar frameworks in FPGA is unnecessary. > > > > > > > > My quick mind is that we add some flags in struct fpga_mgr & struct > > > > fpga_image_info to indicate the HW capability (support FPGA region > > > > update or nvmem update or both) of the download engine and the provided > > > > image type. Then the low-level driver knows how to download if it > > > > supports both image types. > > > > > > > > An char device could be added for each fpga manager dev, providing the > > > > user APIs for nvmem update. We may not use the char dev for FPGA region > > > > update cause it changes the system HW devices and needs device hotplug > > > > in FPGA region. We'd better leave it to FPGA region class, this is > > > > another topic. > > > > > > > > More discussion is appreciated. > > > I also think fpga_mgr could be extended. > > > > > > In this patchset, > > > > > > https://lore.kernel.org/linux-fpga/20210625195849.837976-1-trix@redhat.com/ > > > > > > A second, similar set of write ops was added to fpga_manger_ops, > > > > > > new bit/flag was added to fpga_image_info > > > > > > The intent was for dfl to add their specific ops to cover what is done in > > > this patchset. > > I think we don't have to add 2 ops for reconfig & reimage in framework, > > the 2 processes are almost the same. > > > > Just add the _REIMAGE (or something else, NVMEM?) flag for > > fpga_image_info, and low level drivers handle it as they do for other > > flags. > > > > How do you think? > > A single set is fine. > > A difficult part of is the length of? time to do the write. The existing > write should be improved to use a worker thread. Yes, we could have a flag and optionally threading the writing. Thanks, Yilun > > Tom > > > > > Thanks, > > Yilun > > > > > Any other driver would do similar. > > > > > > Is this close to what you are thinking ? > > > > > > Tom > > > > > > > Thanks, > > > > Yilun > > > >