Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp2977971imm; Sun, 16 Sep 2018 07:11:22 -0700 (PDT) X-Google-Smtp-Source: ANB0VdY/xHE9Mr4zncs+O6tCiKsB6NSVenR7L6ItzJjG+6tvj+9XeloOkaujYacK1nUj/yYP44JA X-Received: by 2002:a63:6604:: with SMTP id a4-v6mr19837788pgc.404.1537107082406; Sun, 16 Sep 2018 07:11:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537107082; cv=none; d=google.com; s=arc-20160816; b=aODiYfNRvpp0H1QRic8+Nvudse+9qWsymwGkdSBYZvtuSr/TQSrx64QzJ69y/iIv/6 TmY7M9yhYx53S/dgpyjUBY7Px9TIFy3A5cRZxco3DS8xbF8m3aCktRUnHuMJMRSCbBhG LOYgB8ysdi5xGkOqtSxyW2XS+Q0CxnOwIJVFXgDiivBCWchDM1HQH3cWIbYCVnCYuf3+ vtoY44jMZ2QECxgxntPXjH/Rnc2SR0NdOtV9ZshguaPguNwEyjnkEFrL+MRVpPyxltGG ic5mfB1fJrxNh31JIfH50ZcRTjwH7W3zpD4wi+5hpcXPqzs04YDQnBeTZYHnzjByF6CY uqQg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:to:subject:dkim-signature; bh=AjGGWq5tS557RcNcS95QB4LLiVqGwuSHOSTUDvFij4Q=; b=zCDvBKd8AihiA0vN9U5naw/q3kY3lijw4/p5wS61ad2fZKM2HQ+ZI2TwZiRlSBA7d6 F/NJ/jUotcLxglzflMabiPXAAZSZk7XNvB4mDXTYvISH+Qu0GCrxJp56o+FzloxNtn4U Ypth7L41bjw3f1AfUocxOZZjCQA0qjFxs8IC9V+IH62UwqlbjO2F/UuMfW6VLUgkd+S8 BxxIzHJqCSsaWHPQCnk4Li9bs/m4UMrw9RGrNbkJO1Aa1Ypgso1EG25+UtvShObVKwnL uLvNndI5hrpREK8xPZqTGmYYR6IDH72fA4EF9UwZhjzdcjFebItQ4iGEygeUMctt7szv M5hA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=al+vHY9U; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r6-v6si11910081pgp.591.2018.09.16.07.11.07; Sun, 16 Sep 2018 07:11:22 -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; dkim=pass header.i=@linaro.org header.s=google header.b=al+vHY9U; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728531AbeIPTdq (ORCPT + 99 others); Sun, 16 Sep 2018 15:33:46 -0400 Received: from mail-io1-f68.google.com ([209.85.166.68]:37409 "EHLO mail-io1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728175AbeIPTdp (ORCPT ); Sun, 16 Sep 2018 15:33:45 -0400 Received: by mail-io1-f68.google.com with SMTP id v14-v6so9492869iob.4 for ; Sun, 16 Sep 2018 07:10:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-language:content-transfer-encoding; bh=AjGGWq5tS557RcNcS95QB4LLiVqGwuSHOSTUDvFij4Q=; b=al+vHY9UtWNw94E+Pah251il8TO3T4OBwMNCtgVnSgYFOVMiOqU64zShV0ada+7kIC bWVCWEMeOuv7X3aYZlm+PW126+OFoQnBhnPB5s7mKyL3QaXPCYPz10520J34Wc/vOfqq TOCmwRcN39Y6+Y+Txlh7tfNCrxWZ8FZ7icwvY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=AjGGWq5tS557RcNcS95QB4LLiVqGwuSHOSTUDvFij4Q=; b=IApSHiE9Y+VDI33bge6ZbdIcJQg1VNJokBT/kTCzDORZd7J29mXuBEJM++tcgJbBJK 6jUPI/7V44WPCQ0yzsAl73AXv7ubAL86/WQmXrVlJCf1H2BU3TFf5LRT0O/Gla51zRkl f7AM8Us3vbuIHNDI4T7sXqMl1pyg/7y+VvoihDhqHwsfJJnwxLjAsQppaHGhR1Irx4f7 pwaihy9j0BP5E/bC2TPiN5Zu7gkgN4NbiAcmO/yaioOo3ZmlRl9L1rSipkxxlj4qDj6J IX/RLqc1bmBOF5NN4MFa80hVwMVzyNyS/ePcbSvqaclCtBZTaTVv+5KQ7fwpOVxfBKXZ +I+A== X-Gm-Message-State: APzg51DoH0yS58BpZC26QuEaBsN/8ODqc3q/Y4z8VmK3BVkxrVpQxMTO MRqp7zlVtJDZt8QCVfuzvyKaM7bnjkB2mw== X-Received: by 2002:a6b:5505:: with SMTP id j5-v6mr17789795iob.106.1537107039217; Sun, 16 Sep 2018 07:10:39 -0700 (PDT) Received: from [10.199.96.233] ([209.82.80.116]) by smtp.googlemail.com with ESMTPSA id w196-v6sm2168199itb.9.2018.09.16.07.10.38 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 16 Sep 2018 07:10:38 -0700 (PDT) Subject: Re: [RFC PATCH v2 3/3] nvmem: zynqmp: Added zynqmp nvmem firmware driver To: Nava kishore Manne , robh+dt@kernel.org, mark.rutland@arm.com, michal.simek@xilinx.com, rajanv@xilinx.com, jollys@xilinx.com, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <1536054754-3119-1-git-send-email-nava.manne@xilinx.com> <1536054754-3119-4-git-send-email-nava.manne@xilinx.com> From: Srinivas Kandagatla Message-ID: Date: Sun, 16 Sep 2018 15:10:37 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <1536054754-3119-4-git-send-email-nava.manne@xilinx.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Few minor Nits... I remember asking about this in the last review! On 04/09/18 10:52, Nava kishore Manne wrote: > This patch adds zynqmp nvmem firmware driver to access the > SoC revision information from the hardware register. > > Signed-off-by: Nava kishore Manne > --- > diff --git a/drivers/nvmem/zynqmp_nvmem.c b/drivers/nvmem/zynqmp_nvmem.c > new file mode 100644 > index 0000000..e377900 > --- /dev/null > +++ b/drivers/nvmem/zynqmp_nvmem.c > @@ -0,0 +1,84 @@ > +// SPDX-License-Identifier: GPL-2.0+ > +/* > + * Copyright (C) 2018 Xilinx, Inc. > + */ > + > +#include > +#include > +#include > +#include > +#include > + > +#define SILICON_REVISION_MASK 0xF > + > +static int zynqmp_nvmem_read(void *context, unsigned int offset, > + void *val, size_t bytes) > +{ > + int ret; > + int idcode, version; > + const struct zynqmp_eemi_ops *eemi_ops = zynqmp_pm_get_eemi_ops(); > + > + if (!eemi_ops || !eemi_ops->get_chipid) > + return -ENXIO; > + > + ret = eemi_ops->get_chipid(&idcode, &version); > + if (ret < 0) > + return ret; > + > + pr_debug("Read chipid val %x %x\n", idcode, version); > + *(int *)val = version & SILICON_REVISION_MASK; Use dev_dbg here. > + > + return 0; > +} > + > +static struct nvmem_config econfig = { > + .name = "zynqmp-nvmem", > + .owner = THIS_MODULE, > + .word_size = 1, > + .size = 1, > + .read_only = true, > +}; > + > +static const struct of_device_id zynqmp_nvmem_match[] = { > + { .compatible = "xlnx,zynqmp-nvmem-fw", }, > + { /* sentinel */ }, > +}; > +MODULE_DEVICE_TABLE(of, zynqmp_nvmem_match); > + > +static int zynqmp_nvmem_probe(struct platform_device *pdev) > +{ > + struct nvmem_device *nvmem; > + > + econfig.dev = &pdev->dev; > + econfig.reg_read = zynqmp_nvmem_read; > + > + nvmem = nvmem_register(&econfig); You can use devm_ variant and remove the zynqmp_nvmem_remove() totally > + if (IS_ERR(nvmem)) > + return PTR_ERR(nvmem); > + > + platform_set_drvdata(pdev, nvmem); > + > + return 0; > +} > + > +static int zynqmp_nvmem_remove(struct platform_device *pdev) > +{ > + struct nvmem_device *nvmem = platform_get_drvdata(pdev); > + > + return nvmem_unregister(nvmem); > +} > +