Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp4015865ybg; Tue, 29 Oct 2019 00:29:30 -0700 (PDT) X-Google-Smtp-Source: APXvYqzZxDCTipDHDgRmgHV6Uooh55JyTZwmkuPCq99gbRXhAZAp3vou0IdQhiDgyG3ssWovP30d X-Received: by 2002:a50:eb42:: with SMTP id z2mr23935710edp.291.1572334170384; Tue, 29 Oct 2019 00:29:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572334170; cv=none; d=google.com; s=arc-20160816; b=gGC5kPZ0m3z46g6GhTKO8NCCDt6M7WXOj5sMtFsxyQlget2tq9OIDJX0sm20UHtSh2 e4dxycvhB+qXtYcsMX9+T2OfptUCcH8d98s7tT48SuYF2f4B7LRNlwUGHLumR438c+Ba qXFfh7mdFsVwxz6CkLkSlvi7i14HDzF4Afk2LvwrhUDnAVarPuISFuddDGs+NToaWZ4u DK5Kyyq8bZzq2Rjxinx6LhGXH/ZgzhWvVg1uNxH7rpw7Brj4LCOCPzpizk7vVEA9WG/E eu6z0ppT8hScPZ0ZeAsgrpddZLrNP346w1yL+vbstVaz3aeeZD9XMyPW/hYiW/D937+b ZQZw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=6FhDbluzCIyKIhxpNonV9jzTaiaGhJNtjkTNxLyn02U=; b=Ka6cava7NiAhVRj11GQJuuSkwCH4KB7LJCcpnQgVFcc985b4nktytU7ZsJWB9Or5By v5P7QHZW7/Sg1VDiy2ae9o/V4FcKNNQTaFkNLsRc3ctH3yrbXiOx1fB9penfhH6MMV7v FT9VxGaczG1a8NSZrP7dBGC8It31up+G6Vu3LaOm6+CuvhB3ZI9ReWF8aY91Zkxd3euX 8Ye/RnJp/Io/Fbvnme1Q60gfgnAos+p4+81uEfk4r/pyf17+bmRCTjPJme2pMEiFiEF2 YT3FvB8t9yDe2Jov8ZBzISrkB4rdgHZFd7EHRZ7AqPWtRq96jDJO0so2QhU1qVpak+8n //pg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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. [209.132.180.67]) by mx.google.com with ESMTP id b2si7917165eja.89.2019.10.29.00.29.06; Tue, 29 Oct 2019 00:29:30 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S1732356AbfJ2GOh (ORCPT + 99 others); Tue, 29 Oct 2019 02:14:37 -0400 Received: from mga01.intel.com ([192.55.52.88]:8598 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727462AbfJ2GOh (ORCPT ); Tue, 29 Oct 2019 02:14:37 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga101.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Oct 2019 23:14:36 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.68,242,1569308400"; d="scan'208";a="211040815" Received: from linux.intel.com ([10.54.29.200]) by fmsmga001.fm.intel.com with ESMTP; 28 Oct 2019 23:14:35 -0700 Received: from [10.226.39.46] (ekotax-MOBL.gar.corp.intel.com [10.226.39.46]) by linux.intel.com (Postfix) with ESMTP id 1A5BF580372; Mon, 28 Oct 2019 23:14:29 -0700 (PDT) Subject: Re: [PATCH v4 2/3] dwc: PCI: intel: PCIe RC controller driver To: "andriy.shevchenko@intel.com" Cc: Gustavo Pimentel , "jingoohan1@gmail.com" , "lorenzo.pieralisi@arm.com" , "andrew.murray@arm.com" , "robh@kernel.org" , "martin.blumenstingl@googlemail.com" , "linux-pci@vger.kernel.org" , "hch@infradead.org" , "devicetree@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "cheol.yong.kim@intel.com" , "chuanhua.lei@linux.intel.com" , "qi-ming.wu@intel.com" References: <28b5a21b-b636-f7e4-2d27-23c5d900b0d3@linux.intel.com> <20191022114413.GG32742@smile.fi.intel.com> From: Dilip Kota Message-ID: <1ac70f92-c148-ca88-a2c1-ec90741ac123@linux.intel.com> Date: Tue, 29 Oct 2019 14:14:28 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: <20191022114413.GG32742@smile.fi.intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/22/2019 7:44 PM, andriy.shevchenko@intel.com wrote: > On Tue, Oct 22, 2019 at 06:18:57PM +0800, Dilip Kota wrote: >> On 10/21/2019 6:44 PM, Dilip Kota wrote: >>> On 10/21/2019 4:29 PM, Gustavo Pimentel wrote: >>>> On Mon, Oct 21, 2019 at 7:39:19, Dilip Kota >>>> >>>> wrote: > First of all, it's a good behaviour to avoid way long quoting. (Sorry for the late reply, I am back today from sick leave.) Noted. Will take care of it. > >>>>> +static void pcie_update_bits(void __iomem *base, u32 mask, u32 >>>>> val, u32 ofs) >>>>> +{ >>>>> +    u32 orig, tmp; >>>>> + >>>>> +    orig = readl(base + ofs); >>>>> + >>>>> +    tmp = (orig & ~mask) | (val & mask); >>>>> + >>>>> +    if (tmp != orig) >>>>> +        writel(tmp, base + ofs); >>>>> +} >>>> I'd suggest to the a take on FIELD_PREP() and FIELD_GET() and use more >>>> intuitive names such as new and old, instead of orig and tmp. >>> Sure, i will update it. >> I tried using FIELD_PREP and FIELD_GET but it is failing because FIELD_PREP >> and FIELD_GET >> are expecting mask should be constant macro. u32 or u32 const are not >> accepted. > If you look at bitfield.h carefully you may find in particular > u32_replace_bits(). Thanks for pointing it. But, I found bitfields are not contiguous during few function calls, so cannot use them here. Regards, Dilip >