All of lore.kernel.org
 help / color / mirror / Atom feed
From: varkabhadram@gmail.com (Varka Bhadram)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v3 4/6] uio: Add X-Gene QMTM UIO driver
Date: Tue, 21 Oct 2014 11:47:03 +0530	[thread overview]
Message-ID: <5445FA5F.8010407@gmail.com> (raw)
In-Reply-To: <CAPTm99U7ugS3=__4A2HSzhhcUVpP0cPg6E8DRHaNgoS4Kr6vbw@mail.gmail.com>

On 10/21/2014 11:46 AM, Ankit Jindal wrote:
> On 21 October 2014 11:34, Varka Bhadram <varkabhadram@gmail.com> wrote:
>> On 10/21/2014 11:26 AM, Ankit Jindal wrote:
>>> The Applied Micro X-Gene SOC has on-chip QMTM (Queue manager
>>> and Traffic manager) which is hardware based Queue or Ring
>>> manager. This QMTM device can be used in conjunction with
>>> other devices such as DMA Engine, Ethernet, Security Engine,
>>> etc to assign work based on queues or rings.
>>>
>>> This patch allows user space access to X-Gene QMTM device.
>>>
>>> Signed-off-by: Ankit Jindal <ankit.jindal@linaro.org>
>>> Signed-off-by: Tushar Jagad <tushar.jagad@linaro.org>
>>
>> (...)
>>
>>
>>> +
>>> +static int qmtm_probe(struct platform_device *pdev)
>>> +{
>>> +       struct uio_info *info;
>>> +       struct uio_qmtm_dev *qmtm_dev;
>>> +       struct resource *csr;
>>> +       struct resource *fabric;
>>> +       struct resource qpool;
>>> +       unsigned int num_queues;
>>> +       unsigned int devid;
>>> +       phandle qpool_phandle;
>>> +       struct device_node *qpool_node;
>>> +       int ret;
>>> +
>>> +       qmtm_dev = devm_kzalloc(&pdev->dev, sizeof(struct uio_qmtm_dev),
>>> +                               GFP_KERNEL);
>>> +       if (!qmtm_dev)
>>> +               return -ENOMEM;
>>> +
>>> +       qmtm_dev->info = devm_kzalloc(&pdev->dev, sizeof(*info),
>>> GFP_KERNEL);
>>> +       if (!qmtm_dev->info)
>>> +               return -ENOMEM;
>>> +
>>> +       /* Power on qmtm in case its not done as part of boot-loader */
>>> +       qmtm_dev->qmtm_clk = devm_clk_get(&pdev->dev, NULL);
>>> +       if (IS_ERR(qmtm_dev->qmtm_clk)) {
>>> +               dev_err(&pdev->dev, "Failed to get clock\n");
>>> +               ret = PTR_ERR(qmtm_dev->qmtm_clk);
>>> +               return ret;
>>> +       }
>>> +
>>> +       csr = platform_get_resource(pdev, IORESOURCE_MEM, 0);
>>> +       if (!csr) {
>>> +               ret = -ENODEV;
>>> +               dev_err(&pdev->dev, "No QMTM CSR resource specified\n");
>>> +               goto out_err;
>>> +       }
>>> +
>>
>> This error check is not required. *csr* is checked in
>> devm_ioremap_resource().
> I think its better to do sanity check before calling any function.

It will be the duplication of code for sanity check. This sanity check is happening
with devm_ioremap_resource(). No need to check it explicitly.

>>> +       if (!csr->start) {
>>> +               ret = -EINVAL;
>>> +               dev_err(&pdev->dev, "Invalid CSR resource\n");
>>> +               goto out_err;
>>> +       }
>>> +
>>> +       fabric = platform_get_resource(pdev, IORESOURCE_MEM, 1);
>>> +       if (!fabric) {
>>> +               ret = -ENODEV;
>>> +               dev_err(&pdev->dev, "No QMTM Fabric resource
>>> specified\n");
>>> +               goto out_err;
>>> +       }
>>> +
>>
>> same
> We do not ioremap this address.

Ok..

-- 
Regards,
Varka Bhadram.

WARNING: multiple messages have this Message-ID (diff)
From: Varka Bhadram <varkabhadram@gmail.com>
To: Ankit Jindal <ankit.jindal@linaro.org>
Cc: "linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
	"Hans J. Koch" <hjk@hansjkoch.de>,
	Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	"patches@apm.com" <patches@apm.com>,
	"linux-arm-kernel@lists.infradead.org"
	<linux-arm-kernel@lists.infradead.org>,
	Rob Herring <robh+dt@kernel.org>,
	Tushar Jagad <tushar.jagad@linaro.org>,
	Russell King - ARM Linux <linux@arm.linux.org.uk>,
	"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
	Guenter Roeck <linux@roeck-us.net>
Subject: Re: [PATCH v3 4/6] uio: Add X-Gene QMTM UIO driver
Date: Tue, 21 Oct 2014 11:47:03 +0530	[thread overview]
Message-ID: <5445FA5F.8010407@gmail.com> (raw)
In-Reply-To: <CAPTm99U7ugS3=__4A2HSzhhcUVpP0cPg6E8DRHaNgoS4Kr6vbw@mail.gmail.com>

On 10/21/2014 11:46 AM, Ankit Jindal wrote:
> On 21 October 2014 11:34, Varka Bhadram <varkabhadram@gmail.com> wrote:
>> On 10/21/2014 11:26 AM, Ankit Jindal wrote:
>>> The Applied Micro X-Gene SOC has on-chip QMTM (Queue manager
>>> and Traffic manager) which is hardware based Queue or Ring
>>> manager. This QMTM device can be used in conjunction with
>>> other devices such as DMA Engine, Ethernet, Security Engine,
>>> etc to assign work based on queues or rings.
>>>
>>> This patch allows user space access to X-Gene QMTM device.
>>>
>>> Signed-off-by: Ankit Jindal <ankit.jindal@linaro.org>
>>> Signed-off-by: Tushar Jagad <tushar.jagad@linaro.org>
>>
>> (...)
>>
>>
>>> +
>>> +static int qmtm_probe(struct platform_device *pdev)
>>> +{
>>> +       struct uio_info *info;
>>> +       struct uio_qmtm_dev *qmtm_dev;
>>> +       struct resource *csr;
>>> +       struct resource *fabric;
>>> +       struct resource qpool;
>>> +       unsigned int num_queues;
>>> +       unsigned int devid;
>>> +       phandle qpool_phandle;
>>> +       struct device_node *qpool_node;
>>> +       int ret;
>>> +
>>> +       qmtm_dev = devm_kzalloc(&pdev->dev, sizeof(struct uio_qmtm_dev),
>>> +                               GFP_KERNEL);
>>> +       if (!qmtm_dev)
>>> +               return -ENOMEM;
>>> +
>>> +       qmtm_dev->info = devm_kzalloc(&pdev->dev, sizeof(*info),
>>> GFP_KERNEL);
>>> +       if (!qmtm_dev->info)
>>> +               return -ENOMEM;
>>> +
>>> +       /* Power on qmtm in case its not done as part of boot-loader */
>>> +       qmtm_dev->qmtm_clk = devm_clk_get(&pdev->dev, NULL);
>>> +       if (IS_ERR(qmtm_dev->qmtm_clk)) {
>>> +               dev_err(&pdev->dev, "Failed to get clock\n");
>>> +               ret = PTR_ERR(qmtm_dev->qmtm_clk);
>>> +               return ret;
>>> +       }
>>> +
>>> +       csr = platform_get_resource(pdev, IORESOURCE_MEM, 0);
>>> +       if (!csr) {
>>> +               ret = -ENODEV;
>>> +               dev_err(&pdev->dev, "No QMTM CSR resource specified\n");
>>> +               goto out_err;
>>> +       }
>>> +
>>
>> This error check is not required. *csr* is checked in
>> devm_ioremap_resource().
> I think its better to do sanity check before calling any function.

It will be the duplication of code for sanity check. This sanity check is happening
with devm_ioremap_resource(). No need to check it explicitly.

>>> +       if (!csr->start) {
>>> +               ret = -EINVAL;
>>> +               dev_err(&pdev->dev, "Invalid CSR resource\n");
>>> +               goto out_err;
>>> +       }
>>> +
>>> +       fabric = platform_get_resource(pdev, IORESOURCE_MEM, 1);
>>> +       if (!fabric) {
>>> +               ret = -ENODEV;
>>> +               dev_err(&pdev->dev, "No QMTM Fabric resource
>>> specified\n");
>>> +               goto out_err;
>>> +       }
>>> +
>>
>> same
> We do not ioremap this address.

Ok..

-- 
Regards,
Varka Bhadram.

  reply	other threads:[~2014-10-21  6:17 UTC|newest]

Thread overview: 51+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-10-21  5:56 [PATCH v3 0/6] UIO driver for APM X-Gene QMTM Ankit Jindal
2014-10-21  5:56 ` Ankit Jindal
2014-10-21  5:56 ` [PATCH v3 1/6] uio: code style cleanup Ankit Jindal
2014-10-21  5:56   ` Ankit Jindal
2014-10-21  5:56 ` [PATCH v3 2/6] uio: Add new UIO_MEM_PHYS_CACHE type for mem regions Ankit Jindal
2014-10-21  5:56   ` Ankit Jindal
2014-10-21  6:38   ` Kumar Gala
2014-10-21  6:38     ` Kumar Gala
2014-10-31  9:30     ` Ankit Jindal
2014-10-31  9:30       ` Ankit Jindal
2014-10-31 13:39       ` Kumar Gala
2014-10-31 13:39         ` Kumar Gala
2014-10-31 13:39         ` Kumar Gala
2014-11-05 12:55         ` Ankit Jindal
2014-11-05 12:55           ` Ankit Jindal
2014-11-05 12:55           ` Ankit Jindal
2014-11-05 15:09           ` Kumar Gala
2014-11-05 15:09             ` Kumar Gala
2014-11-05 15:09             ` Kumar Gala
2014-11-10 11:53             ` Ankit Jindal
2014-11-10 11:53               ` Ankit Jindal
2014-10-31  9:35     ` Russell King - ARM Linux
2014-10-31  9:35       ` Russell King - ARM Linux
2014-10-21  5:56 ` [PATCH v3 3/6] Documentation: Update documentation for UIO_MEM_PHYS_CACHE Ankit Jindal
2014-10-21  5:56   ` Ankit Jindal
2014-10-21  5:56 ` [PATCH v3 4/6] uio: Add X-Gene QMTM UIO driver Ankit Jindal
2014-10-21  5:56   ` Ankit Jindal
2014-10-21  6:04   ` Varka Bhadram
2014-10-21  6:04     ` Varka Bhadram
2014-10-21  6:16     ` Ankit Jindal
2014-10-21  6:16       ` Ankit Jindal
2014-10-21  6:17       ` Varka Bhadram [this message]
2014-10-21  6:17         ` Varka Bhadram
2014-10-21  6:23         ` Ankit Jindal
2014-10-21  6:23           ` Ankit Jindal
2014-10-21  5:56 ` [PATCH v3 5/6] Documentation: dt-bindings: Add binding info for " Ankit Jindal
2014-10-21  5:56   ` Ankit Jindal
2014-10-21  9:14   ` Mark Rutland
2014-10-21  9:14     ` Mark Rutland
2014-10-21  9:14     ` Mark Rutland
2014-10-21 10:05     ` Arnd Bergmann
2014-10-21 10:05       ` Arnd Bergmann
2014-10-31 10:04     ` Ankit Jindal
2014-10-31 10:04       ` Ankit Jindal
2014-10-31 10:09       ` Mark Rutland
2014-10-31 10:09         ` Mark Rutland
2014-10-31 10:09         ` Mark Rutland
2014-10-31 10:15         ` Ankit Jindal
2014-10-31 10:15           ` Ankit Jindal
2014-10-21  5:56 ` [PATCH v3 6/6] MAINTAINERS: Add entry for APM " Ankit Jindal
2014-10-21  5:56   ` Ankit Jindal

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=5445FA5F.8010407@gmail.com \
    --to=varkabhadram@gmail.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.