From: santosh.shilimkar@ti.com (Santosh Shilimkar)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v3 5/7] ARM: dma: Use dma_pfn_offset for dma address translation
Date: Fri, 2 May 2014 11:05:16 -0400 [thread overview]
Message-ID: <5363B42C.4010404@ti.com> (raw)
In-Reply-To: <20140502145852.GC3693@n2100.arm.linux.org.uk>
On Friday 02 May 2014 10:58 AM, Russell King - ARM Linux wrote:
> On Thu, Apr 24, 2014 at 11:30:05AM -0400, Santosh Shilimkar wrote:
>> diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h
>> index e701a4d..424fda9 100644
>> --- a/arch/arm/include/asm/dma-mapping.h
>> +++ b/arch/arm/include/asm/dma-mapping.h
>> @@ -58,22 +58,35 @@ static inline int dma_set_mask(struct device *dev, u64 mask)
>> #ifndef __arch_pfn_to_dma
>> static inline dma_addr_t pfn_to_dma(struct device *dev, unsigned long pfn)
>> {
>> - return (dma_addr_t)__pfn_to_bus(pfn);
>> + if (!dev)
>> + return (dma_addr_t)__pfn_to_bus(pfn);
>> + else
>> + return (dma_addr_t)__pfn_to_bus(pfn - dev->dma_pfn_offset);
>
> I really don't trust gcc to do this right, so I think it would be better
> to make life easier on the compiler:
>
> if (dev)
> pfn -= dev->dma_pfn_offset;
> return (dma_addr_t)__pfn_to_bus(pfn);
>
This looks better. Will udpate with above.
>> static inline unsigned long dma_to_pfn(struct device *dev, dma_addr_t addr)
>> {
>> - return __bus_to_pfn(addr);
>> + if (!dev)
>> + return __bus_to_pfn(addr);
>> + else
>> + return __bus_to_pfn(addr) + dev->dma_pfn_offset;
>
> and:
>
> unsigned long pfn = __bus_to_pfn(addr);
>
> if (dev)
> pfn += dev->dma_pfn_offset;
>
> return pfn;
>
Ok..
>> }
>>
>> static inline void *dma_to_virt(struct device *dev, dma_addr_t addr)
>> {
>> - return (void *)__bus_to_virt((unsigned long)addr);
>> + if (!dev)
>> + return (void *)__bus_to_virt((unsigned long)addr);
>> + else
>> + return (void *)__bus_to_virt(__pfn_to_bus(dma_to_pfn(dev, addr)));
>
> This is quite horrendous. There's easier ways to do this... I assume
> you haven't looked at the assembler resulting from this at all with
> stuff like the p2v patching enabled?
>
I haven't. Will check.
>> }
>>
>> static inline dma_addr_t virt_to_dma(struct device *dev, void *addr)
>> {
>> - return (dma_addr_t)__virt_to_bus((unsigned long)(addr));
>> + if (!dev)
>> + return (dma_addr_t)__virt_to_bus((unsigned long)(addr));
>> + else
>> + return pfn_to_dma(dev,
>> + __bus_to_pfn(__virt_to_bus((unsigned long)(addr))));
>
> Same here.
>
ok.
Thanks !!
Regards,
Santosh
WARNING: multiple messages have this Message-ID (diff)
From: Santosh Shilimkar <santosh.shilimkar@ti.com>
To: Russell King - ARM Linux <linux@arm.linux.org.uk>
Cc: linux-kernel@vger.kernel.org,
linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org,
Grygorii Strashko <grygorii.strashko@ti.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Arnd Bergmann <arnd@arndb.de>, Olof Johansson <olof@lixom.net>,
Grant Likely <grant.likely@linaro.org>,
Rob Herring <robh+dt@kernel.org>,
Catalin Marinas <catalin.marinas@arm.com>,
Linus Walleij <linus.walleij@linaro.org>
Subject: Re: [PATCH v3 5/7] ARM: dma: Use dma_pfn_offset for dma address translation
Date: Fri, 2 May 2014 11:05:16 -0400 [thread overview]
Message-ID: <5363B42C.4010404@ti.com> (raw)
In-Reply-To: <20140502145852.GC3693@n2100.arm.linux.org.uk>
On Friday 02 May 2014 10:58 AM, Russell King - ARM Linux wrote:
> On Thu, Apr 24, 2014 at 11:30:05AM -0400, Santosh Shilimkar wrote:
>> diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h
>> index e701a4d..424fda9 100644
>> --- a/arch/arm/include/asm/dma-mapping.h
>> +++ b/arch/arm/include/asm/dma-mapping.h
>> @@ -58,22 +58,35 @@ static inline int dma_set_mask(struct device *dev, u64 mask)
>> #ifndef __arch_pfn_to_dma
>> static inline dma_addr_t pfn_to_dma(struct device *dev, unsigned long pfn)
>> {
>> - return (dma_addr_t)__pfn_to_bus(pfn);
>> + if (!dev)
>> + return (dma_addr_t)__pfn_to_bus(pfn);
>> + else
>> + return (dma_addr_t)__pfn_to_bus(pfn - dev->dma_pfn_offset);
>
> I really don't trust gcc to do this right, so I think it would be better
> to make life easier on the compiler:
>
> if (dev)
> pfn -= dev->dma_pfn_offset;
> return (dma_addr_t)__pfn_to_bus(pfn);
>
This looks better. Will udpate with above.
>> static inline unsigned long dma_to_pfn(struct device *dev, dma_addr_t addr)
>> {
>> - return __bus_to_pfn(addr);
>> + if (!dev)
>> + return __bus_to_pfn(addr);
>> + else
>> + return __bus_to_pfn(addr) + dev->dma_pfn_offset;
>
> and:
>
> unsigned long pfn = __bus_to_pfn(addr);
>
> if (dev)
> pfn += dev->dma_pfn_offset;
>
> return pfn;
>
Ok..
>> }
>>
>> static inline void *dma_to_virt(struct device *dev, dma_addr_t addr)
>> {
>> - return (void *)__bus_to_virt((unsigned long)addr);
>> + if (!dev)
>> + return (void *)__bus_to_virt((unsigned long)addr);
>> + else
>> + return (void *)__bus_to_virt(__pfn_to_bus(dma_to_pfn(dev, addr)));
>
> This is quite horrendous. There's easier ways to do this... I assume
> you haven't looked at the assembler resulting from this at all with
> stuff like the p2v patching enabled?
>
I haven't. Will check.
>> }
>>
>> static inline dma_addr_t virt_to_dma(struct device *dev, void *addr)
>> {
>> - return (dma_addr_t)__virt_to_bus((unsigned long)(addr));
>> + if (!dev)
>> + return (dma_addr_t)__virt_to_bus((unsigned long)(addr));
>> + else
>> + return pfn_to_dma(dev,
>> + __bus_to_pfn(__virt_to_bus((unsigned long)(addr))));
>
> Same here.
>
ok.
Thanks !!
Regards,
Santosh
WARNING: multiple messages have this Message-ID (diff)
From: Santosh Shilimkar <santosh.shilimkar@ti.com>
To: Russell King - ARM Linux <linux@arm.linux.org.uk>
Cc: <linux-kernel@vger.kernel.org>,
<linux-arm-kernel@lists.infradead.org>,
<devicetree@vger.kernel.org>,
Grygorii Strashko <grygorii.strashko@ti.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Arnd Bergmann <arnd@arndb.de>, Olof Johansson <olof@lixom.net>,
Grant Likely <grant.likely@linaro.org>,
Rob Herring <robh+dt@kernel.org>,
Catalin Marinas <catalin.marinas@arm.com>,
Linus Walleij <linus.walleij@linaro.org>
Subject: Re: [PATCH v3 5/7] ARM: dma: Use dma_pfn_offset for dma address translation
Date: Fri, 2 May 2014 11:05:16 -0400 [thread overview]
Message-ID: <5363B42C.4010404@ti.com> (raw)
In-Reply-To: <20140502145852.GC3693@n2100.arm.linux.org.uk>
On Friday 02 May 2014 10:58 AM, Russell King - ARM Linux wrote:
> On Thu, Apr 24, 2014 at 11:30:05AM -0400, Santosh Shilimkar wrote:
>> diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h
>> index e701a4d..424fda9 100644
>> --- a/arch/arm/include/asm/dma-mapping.h
>> +++ b/arch/arm/include/asm/dma-mapping.h
>> @@ -58,22 +58,35 @@ static inline int dma_set_mask(struct device *dev, u64 mask)
>> #ifndef __arch_pfn_to_dma
>> static inline dma_addr_t pfn_to_dma(struct device *dev, unsigned long pfn)
>> {
>> - return (dma_addr_t)__pfn_to_bus(pfn);
>> + if (!dev)
>> + return (dma_addr_t)__pfn_to_bus(pfn);
>> + else
>> + return (dma_addr_t)__pfn_to_bus(pfn - dev->dma_pfn_offset);
>
> I really don't trust gcc to do this right, so I think it would be better
> to make life easier on the compiler:
>
> if (dev)
> pfn -= dev->dma_pfn_offset;
> return (dma_addr_t)__pfn_to_bus(pfn);
>
This looks better. Will udpate with above.
>> static inline unsigned long dma_to_pfn(struct device *dev, dma_addr_t addr)
>> {
>> - return __bus_to_pfn(addr);
>> + if (!dev)
>> + return __bus_to_pfn(addr);
>> + else
>> + return __bus_to_pfn(addr) + dev->dma_pfn_offset;
>
> and:
>
> unsigned long pfn = __bus_to_pfn(addr);
>
> if (dev)
> pfn += dev->dma_pfn_offset;
>
> return pfn;
>
Ok..
>> }
>>
>> static inline void *dma_to_virt(struct device *dev, dma_addr_t addr)
>> {
>> - return (void *)__bus_to_virt((unsigned long)addr);
>> + if (!dev)
>> + return (void *)__bus_to_virt((unsigned long)addr);
>> + else
>> + return (void *)__bus_to_virt(__pfn_to_bus(dma_to_pfn(dev, addr)));
>
> This is quite horrendous. There's easier ways to do this... I assume
> you haven't looked at the assembler resulting from this at all with
> stuff like the p2v patching enabled?
>
I haven't. Will check.
>> }
>>
>> static inline dma_addr_t virt_to_dma(struct device *dev, void *addr)
>> {
>> - return (dma_addr_t)__virt_to_bus((unsigned long)(addr));
>> + if (!dev)
>> + return (dma_addr_t)__virt_to_bus((unsigned long)(addr));
>> + else
>> + return pfn_to_dma(dev,
>> + __bus_to_pfn(__virt_to_bus((unsigned long)(addr))));
>
> Same here.
>
ok.
Thanks !!
Regards,
Santosh
next prev parent reply other threads:[~2014-05-02 15:05 UTC|newest]
Thread overview: 172+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-04-24 15:30 [PATCH v3 0/7] of: setup dma parameters using dma-ranges and dma-coherent Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` [PATCH v3 1/7] device: introduce per device dma_pfn_offset Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-05-02 1:01 ` Rob Herring
2014-05-02 1:01 ` Rob Herring
2014-04-24 15:30 ` [PATCH v3 2/7] of: introduce of_dma_get_range() helper Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-05-02 1:06 ` Rob Herring
2014-05-02 1:06 ` Rob Herring
2014-05-02 1:06 ` Rob Herring
2014-04-24 15:30 ` [PATCH v3 3/7] of: introduce of_dma_is_coherent() helper Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-05-02 0:56 ` Rob Herring
2014-05-02 0:56 ` Rob Herring
2014-05-02 0:56 ` Rob Herring
2014-05-05 21:45 ` Santosh Shilimkar
2014-05-05 21:45 ` Santosh Shilimkar
2014-05-05 22:06 ` Rob Herring
2014-05-05 22:06 ` Rob Herring
2014-05-05 22:06 ` Rob Herring
2014-04-24 15:30 ` [PATCH v3 4/7] of: configure the platform device dma parameters Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-29 14:41 ` Grant Likely
2014-04-29 14:41 ` Grant Likely
2014-04-29 14:41 ` Grant Likely
2014-04-30 14:19 ` Santosh Shilimkar
2014-04-30 14:19 ` Santosh Shilimkar
2014-04-30 14:19 ` Santosh Shilimkar
2014-05-01 13:12 ` Grant Likely
2014-05-01 13:12 ` Grant Likely
2014-05-01 13:12 ` Grant Likely
2014-05-01 13:16 ` Santosh Shilimkar
2014-05-01 13:16 ` Santosh Shilimkar
2014-05-01 13:16 ` Santosh Shilimkar
2014-05-02 9:58 ` Arnd Bergmann
2014-05-02 9:58 ` Arnd Bergmann
2014-05-02 9:58 ` Arnd Bergmann
2014-05-02 13:13 ` Santosh Shilimkar
2014-05-02 13:13 ` Santosh Shilimkar
2014-05-02 13:13 ` Santosh Shilimkar
2014-05-02 15:13 ` Arnd Bergmann
2014-05-02 15:13 ` Arnd Bergmann
2014-05-02 15:13 ` Arnd Bergmann
2014-05-27 12:56 ` Grant Likely
2014-05-27 12:56 ` Grant Likely
2014-05-27 12:56 ` Grant Likely
2014-05-27 13:30 ` Arnd Bergmann
2014-05-27 13:30 ` Arnd Bergmann
2014-05-28 8:23 ` Linus Walleij
2014-05-28 8:23 ` Linus Walleij
2014-05-28 13:29 ` Arnd Bergmann
2014-05-28 13:29 ` Arnd Bergmann
2014-05-28 13:29 ` Arnd Bergmann
2014-05-28 13:32 ` Linus Walleij
2014-05-28 13:32 ` Linus Walleij
2014-05-28 13:32 ` Linus Walleij
2014-05-28 14:04 ` Santosh Shilimkar
2014-05-28 14:04 ` Santosh Shilimkar
2014-05-28 14:04 ` Santosh Shilimkar
2014-05-29 14:01 ` Linus Walleij
2014-05-29 14:01 ` Linus Walleij
2014-05-29 14:08 ` Santosh Shilimkar
2014-05-29 14:08 ` Santosh Shilimkar
2014-05-29 19:24 ` Arnd Bergmann
2014-05-29 19:24 ` Arnd Bergmann
2014-05-29 19:24 ` Arnd Bergmann
2014-05-29 20:04 ` Santosh Shilimkar
2014-05-29 20:04 ` Santosh Shilimkar
2014-05-29 20:04 ` Santosh Shilimkar
2014-05-02 0:49 ` Rob Herring
2014-05-02 0:49 ` Rob Herring
2014-05-02 0:49 ` Rob Herring
2014-05-05 21:47 ` Santosh Shilimkar
2014-05-05 21:47 ` Santosh Shilimkar
2014-05-05 21:47 ` Santosh Shilimkar
2014-05-05 22:08 ` Rob Herring
2014-05-05 22:08 ` Rob Herring
2014-05-06 9:40 ` Arnd Bergmann
2014-05-06 9:40 ` Arnd Bergmann
2014-05-06 9:40 ` Arnd Bergmann
2014-05-06 20:44 ` Santosh Shilimkar
2014-05-06 20:44 ` Santosh Shilimkar
2014-05-06 20:44 ` Santosh Shilimkar
2014-05-07 13:24 ` Santosh Shilimkar
2014-05-07 13:24 ` Santosh Shilimkar
2014-05-02 16:54 ` Bjorn Helgaas
2014-05-02 16:54 ` Bjorn Helgaas
2014-05-02 16:54 ` Bjorn Helgaas
2014-05-02 18:59 ` Arnd Bergmann
2014-05-02 18:59 ` Arnd Bergmann
2014-05-05 20:45 ` Bjorn Helgaas
2014-05-05 20:45 ` Bjorn Helgaas
2014-05-05 20:45 ` Bjorn Helgaas
2014-05-05 20:55 ` Arnd Bergmann
2014-05-05 20:55 ` Arnd Bergmann
2014-05-05 20:55 ` Arnd Bergmann
2014-05-05 22:28 ` Bjorn Helgaas
2014-05-05 22:28 ` Bjorn Helgaas
2014-05-05 22:28 ` Bjorn Helgaas
2014-05-06 3:44 ` Benjamin Herrenschmidt
2014-05-06 3:44 ` Benjamin Herrenschmidt
2014-05-06 9:54 ` Arnd Bergmann
2014-05-06 9:54 ` Arnd Bergmann
2014-05-06 9:54 ` Arnd Bergmann
2014-05-06 13:32 ` Santosh Shilimkar
2014-05-06 13:32 ` Santosh Shilimkar
2014-05-06 13:32 ` Santosh Shilimkar
2014-04-24 15:30 ` [PATCH v3 5/7] ARM: dma: Use dma_pfn_offset for dma address translation Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-05-02 14:32 ` Rob Herring
2014-05-02 14:32 ` Rob Herring
2014-05-02 14:32 ` Rob Herring
2014-05-02 14:58 ` Russell King - ARM Linux
2014-05-02 14:58 ` Russell King - ARM Linux
2014-05-02 15:05 ` Santosh Shilimkar [this message]
2014-05-02 15:05 ` Santosh Shilimkar
2014-05-02 15:05 ` Santosh Shilimkar
2014-05-05 19:50 ` Russell King - ARM Linux
2014-05-05 19:50 ` Russell King - ARM Linux
2014-05-05 21:43 ` Santosh Shilimkar
2014-05-05 21:43 ` Santosh Shilimkar
2014-05-05 21:43 ` Santosh Shilimkar
2014-04-24 15:30 ` [PATCH v3 6/7] ARM: dma: implement set_arch_dma_coherent_ops() Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-05-02 0:58 ` Rob Herring
2014-05-02 0:58 ` Rob Herring
2014-05-02 0:58 ` Rob Herring
2014-04-24 15:30 ` [PATCH v3 7/7] ARM: dma: use phys_addr_t in __dma_page_[cpu_to_dev/dev_to_cpu] Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:30 ` Santosh Shilimkar
2014-04-24 15:45 ` Will Deacon
2014-04-24 15:45 ` Will Deacon
2014-05-01 13:19 ` [PATCH v3 0/7] of: setup dma parameters using dma-ranges and dma-coherent Santosh Shilimkar
2014-05-01 13:19 ` Santosh Shilimkar
2014-05-01 13:19 ` Santosh Shilimkar
2014-05-01 13:25 ` Russell King - ARM Linux
2014-05-01 13:25 ` Russell King - ARM Linux
2014-05-01 14:06 ` Santosh Shilimkar
2014-05-01 14:06 ` Santosh Shilimkar
2014-05-01 14:06 ` Santosh Shilimkar
2014-05-02 14:41 ` Rob Herring
2014-05-02 14:41 ` Rob Herring
2014-05-02 14:41 ` Rob Herring
2014-05-02 16:41 ` Santosh Shilimkar
2014-05-02 16:41 ` Santosh Shilimkar
2014-05-14 10:12 ` Grant Likely
2014-05-14 10:12 ` Grant Likely
2014-05-14 10:12 ` Grant Likely
2014-06-02 6:37 ` Shawn Guo
2014-06-02 6:37 ` Shawn Guo
2014-06-02 6:37 ` Shawn Guo
2014-06-02 13:24 ` Santosh Shilimkar
2014-06-02 13:24 ` Santosh Shilimkar
2014-06-02 15:06 ` Arnd Bergmann
2014-06-02 15:06 ` Arnd Bergmann
2014-06-02 15:06 ` Arnd Bergmann
2014-06-02 15:54 ` Santosh Shilimkar
2014-06-02 15:54 ` Santosh Shilimkar
2014-06-02 15:54 ` Santosh Shilimkar
2014-06-02 19:00 ` Arnd Bergmann
2014-06-02 19:00 ` Arnd Bergmann
2014-06-02 19:08 ` Santosh Shilimkar
2014-06-02 19:08 ` Santosh Shilimkar
2014-06-02 19:08 ` Santosh Shilimkar
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=5363B42C.4010404@ti.com \
--to=santosh.shilimkar@ti.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.