linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems
@ 2011-10-12 20:57 Kumar Gala
  2011-10-13 14:37 ` Tabi Timur-B04825
  0 siblings, 1 reply; 7+ messages in thread
From: Kumar Gala @ 2011-10-12 20:57 UTC (permalink / raw)
  To: hjk; +Cc: linuxppc-dev, gregkh, Kai Jiang, linux-kernel

From: Kai Jiang <Kai.Jiang@freescale.com>

To support >32-bit physical addresses for UIO_MEM_PHYS type we need to
extend the width of 'addr' in struct uio_mem.  Numerous platforms like
embedded PPC, ARM, and X86 have support for systems with larger physical
address than logical.

Since 'addr' may contain a physical, logical, or virtual address the
easiest solution is to just change the type to 'unsigned long long'
regardless of which type is utilized.

For physical address we can support up to a 44-bit physical address on a
typical 32-bit system as we utilize remap_pfn_range() for the mapping of
the memory region and pfn's are represnted by shifting the address by
the page size (typically 4k).

Signed-off-by: Kai Jiang <Kai.Jiang@freescale.com>
Signed-off-by: Minghuan Lian <Minghuan.Lian@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
---
v2:
* Use phys_addr_t instead of 'unsigned long long'
* Updated DocBook detail in uio-howto.tmpl

 Documentation/DocBook/uio-howto.tmpl |    2 +-
 drivers/uio/uio.c                    |    8 ++++----
 include/linux/uio_driver.h           |    2 +-
 3 files changed, 6 insertions(+), 6 deletions(-)

diff --git a/Documentation/DocBook/uio-howto.tmpl b/Documentation/DocBook/uio-howto.tmpl
index 7c4b514d..54883de 100644
--- a/Documentation/DocBook/uio-howto.tmpl
+++ b/Documentation/DocBook/uio-howto.tmpl
@@ -529,7 +529,7 @@ memory (e.g. allocated with <function>kmalloc()</function>). There's also
 </para></listitem>
 
 <listitem><para>
-<varname>unsigned long addr</varname>: Required if the mapping is used.
+<varname>phys_addr_t addr</varname>: Required if the mapping is used.
 Fill in the address of your memory block. This address is the one that
 appears in sysfs.
 </para></listitem>
diff --git a/drivers/uio/uio.c b/drivers/uio/uio.c
index 88f4444..43b7096 100644
--- a/drivers/uio/uio.c
+++ b/drivers/uio/uio.c
@@ -69,7 +69,7 @@ static ssize_t map_name_show(struct uio_mem *mem, char *buf)
 
 static ssize_t map_addr_show(struct uio_mem *mem, char *buf)
 {
-	return sprintf(buf, "0x%lx\n", mem->addr);
+	return sprintf(buf, "0x%llx\n", (unsigned long long)mem->addr);
 }
 
 static ssize_t map_size_show(struct uio_mem *mem, char *buf)
@@ -79,7 +79,7 @@ static ssize_t map_size_show(struct uio_mem *mem, char *buf)
 
 static ssize_t map_offset_show(struct uio_mem *mem, char *buf)
 {
-	return sprintf(buf, "0x%lx\n", mem->addr & ~PAGE_MASK);
+	return sprintf(buf, "0x%llx\n", (unsigned long long)mem->addr & ~PAGE_MASK);
 }
 
 struct map_sysfs_entry {
@@ -634,8 +634,8 @@ static int uio_vma_fault(struct vm_area_struct *vma, struct vm_fault *vmf)
 	if (idev->info->mem[mi].memtype == UIO_MEM_LOGICAL)
 		page = virt_to_page(idev->info->mem[mi].addr + offset);
 	else
-		page = vmalloc_to_page((void *)idev->info->mem[mi].addr
-							+ offset);
+		page = vmalloc_to_page((void *)(unsigned long)
+				idev->info->mem[mi].addr + offset);
 	get_page(page);
 	vmf->page = page;
 	return 0;
diff --git a/include/linux/uio_driver.h b/include/linux/uio_driver.h
index 4c618cd..d9ce796 100644
--- a/include/linux/uio_driver.h
+++ b/include/linux/uio_driver.h
@@ -32,7 +32,7 @@ struct uio_map;
  */
 struct uio_mem {
 	const char		*name;
-	unsigned long		addr;
+	phys_addr_t		addr;
 	unsigned long		size;
 	int			memtype;
 	void __iomem		*internal_addr;
-- 
1.7.3.4

^ permalink raw reply related	[flat|nested] 7+ messages in thread

* Re: [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems
  2011-10-12 20:57 [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems Kumar Gala
@ 2011-10-13 14:37 ` Tabi Timur-B04825
  2011-10-13 15:32   ` Kumar Gala
  0 siblings, 1 reply; 7+ messages in thread
From: Tabi Timur-B04825 @ 2011-10-13 14:37 UTC (permalink / raw)
  To: Kumar Gala
  Cc: linuxppc-dev@ozlabs.org, hjk@hansjkoch.de, gregkh@suse.de,
	linux-kernel@vger.kernel.org, Jiang Kai-B18973

On Wed, Oct 12, 2011 at 3:57 PM, Kumar Gala <galak@kernel.crashing.org> wro=
te:
> From: Kai Jiang <Kai.Jiang@freescale.com>
>
> To support >32-bit physical addresses for UIO_MEM_PHYS type we need to
> extend the width of 'addr' in struct uio_mem. =A0Numerous platforms like
> embedded PPC, ARM, and X86 have support for systems with larger physical
> address than logical.
>
> Since 'addr' may contain a physical, logical, or virtual address the
> easiest solution is to just change the type to 'unsigned long long'
> regardless of which type is utilized.

You forgot to update this description.

> =A0struct uio_mem {
> =A0 =A0 =A0 =A0const char =A0 =A0 =A0 =A0 =A0 =A0 =A0*name;
> - =A0 =A0 =A0 unsigned long =A0 =A0 =A0 =A0 =A0 addr;
> + =A0 =A0 =A0 phys_addr_t =A0 =A0 =A0 =A0 =A0 =A0 addr;

Please add a comment here saying:

1) That 'addr' can be a virtual or physical address
2) That the kernel guarantees that sizeof(phys_addr_t) >=3D sizeof(void
*), so it's safe to use phys_addr_t for a virtual pointer.

--=20
Timur Tabi
Linux kernel developer at Freescale=

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems
  2011-10-13 14:37 ` Tabi Timur-B04825
@ 2011-10-13 15:32   ` Kumar Gala
  2011-10-13 15:34     ` Timur Tabi
  0 siblings, 1 reply; 7+ messages in thread
From: Kumar Gala @ 2011-10-13 15:32 UTC (permalink / raw)
  To: Tabi Timur-B04825
  Cc: linuxppc-dev@ozlabs.org, hjk@hansjkoch.de, gregkh@suse.de,
	linux-kernel@vger.kernel.org, Jiang Kai-B18973


On Oct 13, 2011, at 9:37 AM, Tabi Timur-B04825 wrote:

> On Wed, Oct 12, 2011 at 3:57 PM, Kumar Gala =
<galak@kernel.crashing.org> wrote:
>> From: Kai Jiang <Kai.Jiang@freescale.com>
>>=20
>> To support >32-bit physical addresses for UIO_MEM_PHYS type we need =
to
>> extend the width of 'addr' in struct uio_mem.  Numerous platforms =
like
>> embedded PPC, ARM, and X86 have support for systems with larger =
physical
>> address than logical.
>>=20
>> Since 'addr' may contain a physical, logical, or virtual address the
>> easiest solution is to just change the type to 'unsigned long long'
>> regardless of which type is utilized.
>=20
> You forgot to update this description.

will fix and update commit message

>=20
>>  struct uio_mem {
>>        const char              *name;
>> -       unsigned long           addr;
>> +       phys_addr_t             addr;
>=20
> Please add a comment here saying:
>=20
> 1) That 'addr' can be a virtual or physical address

The code and everything else makes that clear

> 2) That the kernel guarantees that sizeof(phys_addr_t) >=3D =
sizeof(void
> *), so it's safe to use phys_addr_t for a virtual pointer.

The commit message will cover that so I don't plan on add it.

- k=

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems
  2011-10-13 15:32   ` Kumar Gala
@ 2011-10-13 15:34     ` Timur Tabi
  2011-10-13 15:37       ` David Laight
  0 siblings, 1 reply; 7+ messages in thread
From: Timur Tabi @ 2011-10-13 15:34 UTC (permalink / raw)
  To: Kumar Gala
  Cc: linuxppc-dev@ozlabs.org, hjk@hansjkoch.de, gregkh@suse.de,
	linux-kernel@vger.kernel.org, Jiang Kai-B18973

Kumar Gala wrote:
>>> >> +       phys_addr_t             addr;
>> > 
>> > Please add a comment here saying:
>> > 
>> > 1) That 'addr' can be a virtual or physical address
> The code and everything else makes that clear

I'm sorry, but I have to strongly disagree here.  It is *NOT* clear that a
variable of type 'phys_addr_t' can hold something that is not a physical address.

-- 
Timur Tabi
Linux kernel developer at Freescale

^ permalink raw reply	[flat|nested] 7+ messages in thread

* RE: [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems
  2011-10-13 15:34     ` Timur Tabi
@ 2011-10-13 15:37       ` David Laight
  2011-10-13 15:41         ` Timur Tabi
  2011-10-13 15:50         ` Kumar Gala
  0 siblings, 2 replies; 7+ messages in thread
From: David Laight @ 2011-10-13 15:37 UTC (permalink / raw)
  To: Timur Tabi, Kumar Gala
  Cc: linuxppc-dev, hjk, Jiang Kai-B18973, gregkh, linux-kernel

=20
> Kumar Gala wrote:
> >>> >> +       phys_addr_t             addr;
> >> >=20
> >> > Please add a comment here saying:
> >> >=20
> >> > 1) That 'addr' can be a virtual or physical address
> > The code and everything else makes that clear
>=20
> I'm sorry, but I have to strongly disagree here.  It is *NOT*=20
> clear that a variable of type 'phys_addr_t' can hold something
> that is not a physical address.

Since there is a discriminating field, could a union be used?
At a guess the type of the address is constrained between
produces and consumer??

	David

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems
  2011-10-13 15:37       ` David Laight
@ 2011-10-13 15:41         ` Timur Tabi
  2011-10-13 15:50         ` Kumar Gala
  1 sibling, 0 replies; 7+ messages in thread
From: Timur Tabi @ 2011-10-13 15:41 UTC (permalink / raw)
  To: David Laight; +Cc: gregkh, linux-kernel, linuxppc-dev, hjk, Jiang Kai-B18973

David Laight wrote:
> Since there is a discriminating field, could a union be used?
> At a guess the type of the address is constrained between
> produces and consumer??

I don't think we need to complicate the code by changing that variable into a
union.  I just a want a short comment added to the structure definition.  I
don't think that's asking a lot.

-- 
Timur Tabi
Linux kernel developer at Freescale

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems
  2011-10-13 15:37       ` David Laight
  2011-10-13 15:41         ` Timur Tabi
@ 2011-10-13 15:50         ` Kumar Gala
  1 sibling, 0 replies; 7+ messages in thread
From: Kumar Gala @ 2011-10-13 15:50 UTC (permalink / raw)
  To: David Laight
  Cc: gregkh, linux-kernel, linuxppc-dev, hjk, Jiang Kai-B18973,
	Timur Tabi


On Oct 13, 2011, at 10:37 AM, David Laight wrote:

> 
>> Kumar Gala wrote:
>>>>>>> +       phys_addr_t             addr;
>>>>> 
>>>>> Please add a comment here saying:
>>>>> 
>>>>> 1) That 'addr' can be a virtual or physical address
>>> The code and everything else makes that clear
>> 
>> I'm sorry, but I have to strongly disagree here.  It is *NOT* 
>> clear that a variable of type 'phys_addr_t' can hold something
>> that is not a physical address.
> 
> Since there is a discriminating field, could a union be used?
> At a guess the type of the address is constrained between
> produces and consumer??

Uugh.

I'll add a comment to uio_mem.

- k

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2011-10-13 15:50 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-10-12 20:57 [PATCH][v2] uio: Support 36-bit physical addresses on 32-bit systems Kumar Gala
2011-10-13 14:37 ` Tabi Timur-B04825
2011-10-13 15:32   ` Kumar Gala
2011-10-13 15:34     ` Timur Tabi
2011-10-13 15:37       ` David Laight
2011-10-13 15:41         ` Timur Tabi
2011-10-13 15:50         ` Kumar Gala

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).