Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp1006613rwb; Thu, 18 Aug 2022 16:55:39 -0700 (PDT) X-Google-Smtp-Source: AA6agR5TmUfs+Hszujys3EniYHF/X61IajrmEMmcarzabTi2Cz+EE08LY6yXdoCJakILO7FvmsNT X-Received: by 2002:aa7:838a:0:b0:536:101a:9ccf with SMTP id u10-20020aa7838a000000b00536101a9ccfmr209571pfm.18.1660866939199; Thu, 18 Aug 2022 16:55:39 -0700 (PDT) Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b13-20020a056a00114d00b0052fac3954e9si2559644pfm.227.2022.08.18.16.55.28; Thu, 18 Aug 2022 16:55:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=hhxpZyiF; arc=fail (signature failed); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345936AbiHRXis (ORCPT + 99 others); Thu, 18 Aug 2022 19:38:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51678 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344679AbiHRXiq (ORCPT ); Thu, 18 Aug 2022 19:38:46 -0400 Received: from mga06.intel.com (mga06b.intel.com [134.134.136.31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F2A9274BB0; Thu, 18 Aug 2022 16:38:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1660865925; x=1692401925; h=message-id:date:subject:to:cc:references:from: in-reply-to:content-transfer-encoding:mime-version; bh=9qGkkCQteYOzYMwFkPvYJY4fdbfyzLOYq3LmqRM/NKU=; b=hhxpZyiFOvZAodopc66BPVJGx3jMS52JiZs7TXTiPEMX34/WhPVxh5gP q9cbg2kMfVdZ5wH8FWGHpukLnYtHWgVL3/N5pSLwnFvHZ/ToVOFPnDGDQ 77vzDlqkbJxl8jEfehx7Dnh8U1kQM2SZW3zh3AavUItnbis8MBRevhMvZ 1nicVU66hQmVhQzeqOfr3P1yTAcHDUw5g/PL/JOa7Ba0cUOLg1+cpqzuR sTO/eEsqXFaiFSJ261ISccC1CdjWJzS4zBbDEOvRdNDQQKpKaB4Zv6Eh8 TCtRXMVUWnTKdmzavWPNAWyY1Qv+sMcI+iofjRH5iJk/R6uF/cYZpY94z g==; X-IronPort-AV: E=McAfee;i="6500,9779,10443"; a="354633366" X-IronPort-AV: E=Sophos;i="5.93,247,1654585200"; d="scan'208";a="354633366" Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 18 Aug 2022 16:38:43 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.93,247,1654585200"; d="scan'208";a="676257891" Received: from fmsmsx603.amr.corp.intel.com ([10.18.126.83]) by fmsmga004.fm.intel.com with ESMTP; 18 Aug 2022 16:38:43 -0700 Received: from fmsmsx610.amr.corp.intel.com (10.18.126.90) by fmsmsx603.amr.corp.intel.com (10.18.126.83) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Thu, 18 Aug 2022 16:38:42 -0700 Received: from fmsmsx611.amr.corp.intel.com (10.18.126.91) by fmsmsx610.amr.corp.intel.com (10.18.126.90) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Thu, 18 Aug 2022 16:38:42 -0700 Received: from FMSEDG603.ED.cps.intel.com (10.1.192.133) by fmsmsx611.amr.corp.intel.com (10.18.126.91) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28 via Frontend Transport; Thu, 18 Aug 2022 16:38:42 -0700 Received: from NAM10-BN7-obe.outbound.protection.outlook.com (104.47.70.104) by edgegateway.intel.com (192.55.55.68) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2375.28; Thu, 18 Aug 2022 16:38:41 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=KJ//ULvAIKdpnKBFxtX/BZmkAr+O6TlK03/uRE9GVVjGes3SUFfBeLdn6QAuU/dg/ap6R8KW2TpTxgiD7jfLrLyFBddQcEoINRBB9DqaFsH/wDsUkOvXRKG1CCZxslcINJoh3GnQKvf8vtjtfvPmYLW/XnViupo89DfvAPE+nJoRWgPNxbM9Y+wO7JrscTy4AbE+v9wTGD+eZbh5QbRsVTu/98qdTCFvc6PAhe7Sxsd6nTGXK7hECA+PKmrMlTXxR9k/aOgERvpqwEHLLzEIkMUalDuZtNkOHIYJj1Eh2Q40UanMgJCWWCBxZsePKaQLAUH7SSUaIAP1AcXYVMi/cg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=Yks/1ZDXo328p4Y8JyqrWwFNIhkvfYI4Tic96c7eBu8=; b=CWb7S+pffUY+rp/T+0C1UhGRihmAnxPtX5XwcSSr/1IkZLgzyi2c2W4dLMstZ1V4BuTU/BKL2OPzbfWiRPmuC0x6Ab4U5+iFm56UKObBQLaClOmAC5IDDN+0R5fyQcANXfXwFf6ale5UXrMyCA/MqiYsnrTZg+EVOj+N6nCnOCRm7sW6RMFySmf5D8RcPogzYyJQl9TfuEmk+Wuog3PHRxtg0ydRfXZdhYlz5iMWumoHpSnmasNHVii3gKi88LSzfFT6MVGDL/63dhCGQBxeUpwTsg9dofQbYikPjgXsG7g9XMgFTWPgiI2D2nbov6p3IgwVNF01BLy66u8oatEGbA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=intel.com; dmarc=pass action=none header.from=intel.com; dkim=pass header.d=intel.com; arc=none Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=intel.com; Received: from DM5PR11MB1899.namprd11.prod.outlook.com (2603:10b6:3:10b::14) by CO1PR11MB4769.namprd11.prod.outlook.com (2603:10b6:303:95::10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5525.11; Thu, 18 Aug 2022 23:38:39 +0000 Received: from DM5PR11MB1899.namprd11.prod.outlook.com ([fe80::e5bc:d418:aa62:955c]) by DM5PR11MB1899.namprd11.prod.outlook.com ([fe80::e5bc:d418:aa62:955c%10]) with mapi id 15.20.5546.016; Thu, 18 Aug 2022 23:38:39 +0000 Message-ID: Date: Thu, 18 Aug 2022 17:38:35 -0600 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Firefox/91.0 Thunderbird/91.11.0 Subject: Re: [PATCH v1] uio: dfl: add IOPLL user-clock feature id Content-Language: en-US To: Xu Yilun , Peter Colberg CC: Wu Hao , Tom Rix , Greg Kroah-Hartman , , , , , , , References: <20220817213746.4986-1-peter.colberg@intel.com> From: Russ Weight In-Reply-To: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-ClientProxiedBy: MW4PR03CA0293.namprd03.prod.outlook.com (2603:10b6:303:b5::28) To DM5PR11MB1899.namprd11.prod.outlook.com (2603:10b6:3:10b::14) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 93cd6d3a-6551-4bfa-d808-08da8172c6ee X-MS-TrafficTypeDiagnostic: CO1PR11MB4769:EE_ X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: txxKmpT++vwA8/FOPW9lJ2JPXnZEV1GTlw4H6gXIbw8v3zK1oMMNDAIsiKSZQ3wf9nxkLGn3Ng1fIEEPr0JHO4+TJjUZvm1T9K7Evf+4mynyat3JjvNLzG7cEuU2uuV3dBPUIOoJaGwl4Bnv8990hu3Fo5gvFszTIjqjuWKvrltbSXFv070Xm6WAPcMwvBh3r+50rdep+C/pgDDG+eTX2OOAAuI9gl9JLdn7jXLmWqUZB5MAr34HLi3W88o+6OLOS06aGdOjV1Jqg7oCezKWa3HPXNxMgjjQ3TNPiOQZbYBRIEjIk/yjnuhacLFwKk68mgKITC4zmdcje7AeHKsZSmVM5sf44IPWTNGlkjPZBaIH5sT0RdL9TINK3zCHVn+TcP7YuCUeObuXLkn/HIU11IyQ4/nsDXi0uErmpAubPsGrvY92eKrTb8t0RqOWONnTkoDmz54Pi/87mceoUHc1pETGnJIFzag8eNqSlRtOUwfaEv2srxFBSOee1TVbUT5j3wrsoGA2p/0WgmOvYcCjIDJmzImhNXHClR6X4vRHPf3DQbMNBI42MTzwoLG4ciHCR3d+sigqwPNO0jMD1P3TErVoUOP2e5l6XrZAL3gdwE240/4bjKLkkY+6T+JLU5turEMWwCm/egEyzRB7aEEGhE9gGSnAsjZhNVQzMAcnT5557gCTg41fv3igZXqsEwZuh5kSDAqqwcSQHH6hAKWmNlEvLZMLmAE9oaXNMqDCGeJvUkOxz7xqjEgR0ki4i6O46ZaGTpDkQ8aBoeH0CxGiOxAbaSIwIfz3TAuEm1rGeSA35lB23ggeb0FT1YlYl422gZWB3UcNe0Gx0RwFWeWsdqYx9PG6a9PoDYOFe2qe7IM= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:DM5PR11MB1899.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230016)(136003)(366004)(346002)(376002)(396003)(39860400002)(41300700001)(966005)(54906003)(478600001)(5660300002)(38100700002)(316002)(6486002)(66946007)(110136005)(66556008)(66476007)(8936002)(8676002)(4326008)(6636002)(2906002)(31686004)(36756003)(31696002)(53546011)(26005)(186003)(86362001)(6506007)(82960400001)(6666004)(2616005)(6512007)(83380400001)(45980500001)(43740500002);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?YnIzSkNHRmZobWVJZFdtL0Y3SnB4OEczcWJxUnMvTmVldEMvWFh4NUI2Yk5R?= =?utf-8?B?c2V2U25kYVZ0aUFWOEZuT3ZKYUZnaTBIdzVZajR2ZnJxNXpQLzZKWXU2ZDFN?= =?utf-8?B?OXV0dnN0RXpNUCtxZ042RXhKU3d1TExKeDFCUkpXckJhY1QzQlkva2FxTk5u?= =?utf-8?B?NkJQVEI4NFJqRC9VV0E2NkU2UTVYbGZoTnRJT0MvKzRtQ2psQlNxbU1zQjdh?= =?utf-8?B?U3YyM09nUXJaSzZWMUROQTRnUXV6ZjZBK3prVmUxWE1JV0Y0QWZ2cExsb1hK?= =?utf-8?B?NWV5bUdQeEM0OFhxczRJSXROc05pNnhETnRHbS9MYlVjUHkzQkJiU3BrM3Vj?= =?utf-8?B?TWdLMCtpejBHQjJWMmdjT2VCZjVWZ0RadVZzUlJiNk1TcUNpcUVGUTZvZFhT?= =?utf-8?B?dmxQdEZsby94QmFydGRDbmRyM2ppOWlVb0hTaFZZS0xDc0tJRGdXQmxzclFt?= =?utf-8?B?eHZ2ZUFJUEFyMVAzZTZoT3F1VWk2SlBma0dyYTBzQXl5K1QybVB4RGNLdHF1?= =?utf-8?B?RFRDbm1oUStZT3NIL0lkeEsraE1iQ0xpeGtvRTFJMC9pQmRkL0hnVVZGVEo3?= =?utf-8?B?c051SC9JYXJadHpCK0wyQVRhV1JKT0tsNXhjbllXWGNoK05HM0pMRFJhMUNn?= =?utf-8?B?Sk5XRGNmbE9SSmsza1JwVlJ3eEJUWnAxTGJKd2Vab1lqSHBGQkxWQkRXVjU4?= =?utf-8?B?TnNrZDk1Wnp4NUZlUjJMcXdPaFlxWUtZc0lLNG0wOFJxQjBlZWNmUDBXOWR4?= =?utf-8?B?V3dGeUZ0MWE2cGlJdnQ2Sy84UFRPY3E3bko1NGdmWU1KY2EvTVhSTFRZaHp4?= =?utf-8?B?SWVCVXZpM1JkV2VDRHBid2s4Qytndzd1RGlZTWFlRWVrZHFMeG9XWERDaUdu?= =?utf-8?B?N1pQaEFMOGoxZG5OS2o2eTZDWDJxYkthbllxWlRtQStjVEZNMmNzR0xaT0lH?= =?utf-8?B?d0JmaXcxUWpDU2pPVmxZL3JBRHhESEw3aXJPaXRlTERFSjl3TEQyL0VmMnBV?= =?utf-8?B?YXpBSHdubnZWc2VFWS9hWUQ5dDhpZGRNTGwyeURVSVliYkloUXFnK2Mxcmd6?= =?utf-8?B?VWZRUnlLTTRhTnkwWFBGUkdRR29hcWVjWlUrdGppakNVOWo5NHpFQ1JtVmJW?= =?utf-8?B?cWtNQ2psc0VPUlYzY0orYWFab3RGZkxmZ0xEM2xSMnZhNXJRWFFYVFpnMzM4?= =?utf-8?B?WFBNN3J1SHp2QitXVjVxQkJhdUQ5ejM1ekg5ZTJ1d0NmcGhGK1RSWFFqS3RP?= =?utf-8?B?N2RBdVdoc3ZBcUlibXV5dzFRNUplTTJueFhZanZhV2d5Sk1pdWVrbmQybDZi?= =?utf-8?B?K2dUcDZEd3lzTjZta1hreHh1LzMvclkzWE4wc0tBUVdCY09aS2M5U0ZVTk0x?= =?utf-8?B?ejJaSm5lZmxqajhSenFMUE1OMzZGU0NnSWFuVkhSUVVGdVEvb3dSWUg5TlI2?= =?utf-8?B?ZkNzc1l0aW4rQmVhdFhpUllORVRhY1h0elBWTjJkeHh3ZkxRUWFQbjNacUVD?= =?utf-8?B?cEtzUm04NDFHV3hGL3pERWcxNlhiaTVZMVNGbFRPWkxBZ1pyWFBuOXh0cHBR?= =?utf-8?B?MzNsK0RydTliK3lRK2JZYW14T2lmeXNJbHhGODhaL1NkaytPN1NXcEFYbEtt?= =?utf-8?B?bEp4YzJJNndTN0F5VWFCVG82RmJNYmhuSURFODRSb3QxalpjZzNoTTh5azE4?= =?utf-8?B?UWoxMkUzejcrSUs4N2phbHVvdXVQNFJNTVV3dU1PR0EvYlJva3V6YzQ3UGtn?= =?utf-8?B?MmpDOU9mQ1VxM29xaWdjTllLcWRlbmV2UzFYbllMblBrTnpTNUlMM0FtVDlH?= =?utf-8?B?SFgweCtBais3WWxZN1BqQlRWdW4weE56VFBrSmxHMHhEVmNhSEljZXEzSHg0?= =?utf-8?B?Qm5HVG1QMlR5MDltVCtmcDJWZzg2aEh2WGxFNFVSa2lDa2Z3b2UxSmFIWU1O?= =?utf-8?B?VnRLcFo0SUQxZHdaODlPbjZ1WWF0MVo1QmJqVHRvLzlIbzJEb2lrN0tGb1lD?= =?utf-8?B?cURTMFFWdmZ1dGYyc0VmQ0pWQ2FFL0hpaEJaNzlPSUlMSVo3Sms1ZUFSUWhJ?= =?utf-8?B?QlE3MTBLYThYeDQrKzlnQjNQb3hhWjIyYlJWTUYyZkFOQ2lDOXRoTGx4YjRp?= =?utf-8?B?U1pnUmFoT0FQT1EzMnNmbFR4d0JSZGNBYWk5VHRWamZPNDkzWFZlcEdGb3hn?= =?utf-8?B?dVE9PQ==?= X-MS-Exchange-CrossTenant-Network-Message-Id: 93cd6d3a-6551-4bfa-d808-08da8172c6ee X-MS-Exchange-CrossTenant-AuthSource: DM5PR11MB1899.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Aug 2022 23:38:39.1861 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 46c98d88-e344-4ed4-8496-4ed7712e255d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 3OzRnGwjw5szO52fPhxglAM8Ytt2uy5Y6viBvMXt8SzAwwadBryYNzX17mHqb2N+4ejpQvx37thmlt+y8SJVzacE4F5rMVjYf1h1a15kuVo= X-MS-Exchange-Transport-CrossTenantHeadersStamped: CO1PR11MB4769 X-OriginatorOrg: intel.com X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE, URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/17/22 21:18, Xu Yilun wrote: > On 2022-08-17 at 17:37:46 -0400, Peter Colberg wrote: >> Add a Device Feature List (DFL) feature id for the configurable >> IOPLL user clock source, which can be used to configure the clock >> speeds that are used for RTL logic that is programmed into the >> Partial Reconfiguration (PR) region of an FPGA. > Why not use linux clock framework for this IOPLL? And let the PR > driver set it togeter with the RTL logic reporgramming? Hi Yilun, We previously explored the possibility of plugging into the linux clock framework. For this device, setting a desired frequency is heavily dependent on a table of values that must be programmed in order to achieve the desired clock speeds. Here is an example table, indexed by frequency. The first element in each entry is the frequency in kHz: https://github.com/OPAE/opae-sdk/blob/master/libraries/plugins/xfpga/usrclk/fpga_user_clk_freq.h We previously experimented with a kernel-space driver. The implementation exported a sysfs node into which the table values for the desired frequency would be written in order to set the desired frequency. The function of the driver was to execute the logic required to program the device. We did not think this implementation should be up-streamed. It isn't practical to upstream the frequency tables as they are subject to change for future devices. For example, if the reference frequency changed in a future device, a whole new table of values would have to be added for the new device. In a recent transition to a new device, the range of frequencies was increased which required an extension to an existing table. A previous implementation of the user clock was also implemented in user-space. The kernel driver exported each of the registers, but all of the logic was implemented in user-space. The kernel portion can be viewed here: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/fpga/dfl-afu-main.c#n380 This is our reasoning in choosing to implement this driver in user-space. Would you consider a uio based user-space driver to be acceptable for in this case? - Russ > > Thanks, > Yilun > >> The DFL feature id table can be found at: >> https://github.com/OPAE/dfl-feature-id >> >> Signed-off-by: Peter Colberg >> --- >> drivers/uio/uio_dfl.c | 2 ++ >> 1 file changed, 2 insertions(+) >> >> diff --git a/drivers/uio/uio_dfl.c b/drivers/uio/uio_dfl.c >> index 8f39cc8bb034..69e93f3e7faf 100644 >> --- a/drivers/uio/uio_dfl.c >> +++ b/drivers/uio/uio_dfl.c >> @@ -46,10 +46,12 @@ static int uio_dfl_probe(struct dfl_device *ddev) >> >> #define FME_FEATURE_ID_ETH_GROUP 0x10 >> #define FME_FEATURE_ID_HSSI_SUBSYS 0x15 >> +#define PORT_FEATURE_ID_IOPLL_USRCLK 0x14 >> >> static const struct dfl_device_id uio_dfl_ids[] = { >> { FME_ID, FME_FEATURE_ID_ETH_GROUP }, >> { FME_ID, FME_FEATURE_ID_HSSI_SUBSYS }, >> + { PORT_ID, PORT_FEATURE_ID_IOPLL_USRCLK }, >> { } >> }; >> MODULE_DEVICE_TABLE(dfl, uio_dfl_ids); >> -- >> 2.28.0 >>