* [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
@ 2007-08-21 19:38 Dave Hansen
2007-08-21 19:43 ` Matthew Wilcox
2007-08-22 9:06 ` David Howells
0 siblings, 2 replies; 10+ messages in thread
From: Dave Hansen @ 2007-08-21 19:38 UTC (permalink / raw)
To: linux-arch; +Cc: Dave Hansen
For the /proc/<pid>/pagemap code[1], we need to able to query how
much virtual address space a particular task has. The trick is
that we do it through /proc and can't use TASK_SIZE since it
references "current" on some arches. The process opening the
/proc file might be a 32-bit process opening a 64-bit process's
pagemap file.
x86_64 already has a TASK_SIZE_OF() macro:
#define TASK_SIZE_OF(child) ((test_tsk_thread_flag(child, TIF_IA32)) ? IA32_PAGE_OFFSET : TASK_SIZE64)
I'd like to have that for other architectures. So, add it
for all the architectures that actually use "current" in
their TASK_SIZE. For the others, just add a quick #define
in sched.h to use plain old TASK_SIZE.
1. http://www.linuxworld.com/news/2007/042407-kernel.html
Signed-off-by: Dave Hansen <haveblue@us.ibm.com>
---
lxc-dave/include/asm-ia64/processor.h | 3 ++-
lxc-dave/include/asm-parisc/processor.h | 3 ++-
lxc-dave/include/asm-powerpc/processor.h | 4 +++-
lxc-dave/include/asm-s390/processor.h | 2 ++
lxc-dave/include/linux/sched.h | 4 ++++
5 files changed, 13 insertions(+), 3 deletions(-)
diff -puN include/asm-ia64/processor.h~task_size_of include/asm-ia64/processor.h
--- lxc/include/asm-ia64/processor.h~task_size_of 2007-08-07 15:30:54.000000000 -0700
+++ lxc-dave/include/asm-ia64/processor.h 2007-08-07 15:30:54.000000000 -0700
@@ -31,7 +31,8 @@
* each (assuming 8KB page size), for a total of 8TB of user virtual
* address space.
*/
-#define TASK_SIZE (current->thread.task_size)
+#define TASK_SIZE_OF(tsk) ((tsk)->thread.task_size)
+#define TASK_SIZE TASK_SIZE_OF(current)
/*
* This decides where the kernel will search for a free chunk of vm
diff -puN include/asm-parisc/processor.h~task_size_of include/asm-parisc/processor.h
--- lxc/include/asm-parisc/processor.h~task_size_of 2007-08-07 15:30:54.000000000 -0700
+++ lxc-dave/include/asm-parisc/processor.h 2007-08-07 15:30:54.000000000 -0700
@@ -32,7 +32,8 @@
#endif
#define current_text_addr() ({ void *pc; current_ia(pc); pc; })
-#define TASK_SIZE (current->thread.task_size)
+#define TASK_SIZE_OF(tsk) ((tsk)->thread.task_size)
+#define TASK_SIZE (current->thread.task_size)
#define TASK_UNMAPPED_BASE (current->thread.map_base)
#define DEFAULT_TASK_SIZE32 (0xFFF00000UL)
diff -puN include/asm-powerpc/processor.h~task_size_of include/asm-powerpc/processor.h
--- lxc/include/asm-powerpc/processor.h~task_size_of 2007-08-07 15:30:54.000000000 -0700
+++ lxc-dave/include/asm-powerpc/processor.h 2007-08-07 15:30:54.000000000 -0700
@@ -107,7 +107,9 @@ extern struct task_struct *last_task_use
*/
#define TASK_SIZE_USER32 (0x0000000100000000UL - (1*PAGE_SIZE))
-#define TASK_SIZE (test_thread_flag(TIF_32BIT) ? \
+#define TASK_SIZE (test_thread_flag(TIF_32BIT) ? \
+ TASK_SIZE_USER32 : TASK_SIZE_USER64)
+#define TASK_SIZE_OF(tsk) (test_tsk_thread_flag(tsk, TIF_32BIT) ? \
TASK_SIZE_USER32 : TASK_SIZE_USER64)
/* This decides where the kernel will search for a free chunk of vm
diff -puN include/asm-s390/processor.h~task_size_of include/asm-s390/processor.h
--- lxc/include/asm-s390/processor.h~task_size_of 2007-08-07 15:30:54.000000000 -0700
+++ lxc-dave/include/asm-s390/processor.h 2007-08-07 15:30:54.000000000 -0700
@@ -75,6 +75,8 @@ extern struct task_struct *last_task_use
# define TASK_SIZE (test_thread_flag(TIF_31BIT) ? \
(0x80000000UL) : (0x40000000000UL))
+# define TASK_SIZE_OF(tsk) (test_tsk_thread_flag(tsk, TIF_31BIT) ? \
+ (0x80000000UL) : (0x40000000000UL))
# define TASK_UNMAPPED_BASE (TASK_SIZE / 2)
# define DEFAULT_TASK_SIZE (0x40000000000UL)
diff -puN include/linux/sched.h~task_size_of include/linux/sched.h
--- lxc/include/linux/sched.h~task_size_of 2007-08-07 15:30:54.000000000 -0700
+++ lxc-dave/include/linux/sched.h 2007-08-07 15:30:54.000000000 -0700
@@ -1712,6 +1712,10 @@ static inline void inc_syscw(struct task
}
#endif
+#ifndef TASK_SIZE_OF
+#define TASK_SIZE_OF(tsk) TASK_SIZE
+#endif
+
#endif /* __KERNEL__ */
#endif
_
^ permalink raw reply [flat|nested] 10+ messages in thread* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-21 19:38 [RFC][PATCH] introduce TASK_SIZE_OF() for all arches Dave Hansen
@ 2007-08-21 19:43 ` Matthew Wilcox
2007-08-22 17:30 ` Ralf Baechle
2007-08-22 9:06 ` David Howells
1 sibling, 1 reply; 10+ messages in thread
From: Matthew Wilcox @ 2007-08-21 19:43 UTC (permalink / raw)
To: Dave Hansen; +Cc: linux-arch
On Tue, Aug 21, 2007 at 12:38:35PM -0700, Dave Hansen wrote:
> I'd like to have that for other architectures. So, add it
> for all the architectures that actually use "current" in
> their TASK_SIZE. For the others, just add a quick #define
> in sched.h to use plain old TASK_SIZE.
MIPS seems to do things a little differently ... Ralf, what should Dave
be doing here?
#define TASK_SIZE32 0x7fff8000UL
#define TASK_SIZE 0x10000000000UL
--
"Bill, look, we understand that you're interested in selling us this
operating system, but compare it to ours. We can't possibly take such
a retrograde step."
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-21 19:43 ` Matthew Wilcox
@ 2007-08-22 17:30 ` Ralf Baechle
2007-08-22 23:10 ` Dave Hansen
0 siblings, 1 reply; 10+ messages in thread
From: Ralf Baechle @ 2007-08-22 17:30 UTC (permalink / raw)
To: Matthew Wilcox; +Cc: Dave Hansen, linux-arch
On Tue, Aug 21, 2007 at 01:43:09PM -0600, Matthew Wilcox wrote:
> On Tue, Aug 21, 2007 at 12:38:35PM -0700, Dave Hansen wrote:
> > I'd like to have that for other architectures. So, add it
> > for all the architectures that actually use "current" in
> > their TASK_SIZE. For the others, just add a quick #define
> > in sched.h to use plain old TASK_SIZE.
>
> MIPS seems to do things a little differently ... Ralf, what should Dave
> be doing here?
>
> #define TASK_SIZE32 0x7fff8000UL
> #define TASK_SIZE 0x10000000000UL
Indeed. Below patch should do the trick.
Ralf
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
diff --git a/include/asm-mips/processor.h b/include/asm-mips/processor.h
index 83bc945..0e79e03 100644
--- a/include/asm-mips/processor.h
+++ b/include/asm-mips/processor.h
@@ -45,6 +45,8 @@ extern unsigned int vced_count, vcei_count;
* space during mmap's.
*/
#define TASK_UNMAPPED_BASE (PAGE_ALIGN(TASK_SIZE / 3))
+#define TASK_SIZE_OF(tsk) \
+ (test_thread_flag(TIF_32BIT_ADDR) ? TASK_SIZE32 : TASK_SIZE)
#endif
#ifdef CONFIG_64BIT
@@ -65,6 +67,8 @@ extern unsigned int vced_count, vcei_count;
#define TASK_UNMAPPED_BASE \
(test_thread_flag(TIF_32BIT_ADDR) ? \
PAGE_ALIGN(TASK_SIZE32 / 3) : PAGE_ALIGN(TASK_SIZE / 3))
+#define TASK_SIZE_OF(tsk) \
+ (test_thread_flag(TIF_32BIT_ADDR) ? TASK_SIZE32 : TASK_SIZE)
#endif
#define NUM_FPU_REGS 32
^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-22 17:30 ` Ralf Baechle
@ 2007-08-22 23:10 ` Dave Hansen
0 siblings, 0 replies; 10+ messages in thread
From: Dave Hansen @ 2007-08-22 23:10 UTC (permalink / raw)
To: Ralf Baechle; +Cc: Matthew Wilcox, linux-arch
On Wed, 2007-08-22 at 18:30 +0100, Ralf Baechle wrote:
> On Tue, Aug 21, 2007 at 01:43:09PM -0600, Matthew Wilcox wrote:
>
> > On Tue, Aug 21, 2007 at 12:38:35PM -0700, Dave Hansen wrote:
> > > I'd like to have that for other architectures. So, add it
> > > for all the architectures that actually use "current" in
> > > their TASK_SIZE. For the others, just add a quick #define
> > > in sched.h to use plain old TASK_SIZE.
> >
> > MIPS seems to do things a little differently ... Ralf, what should Dave
> > be doing here?
> >
> > #define TASK_SIZE32 0x7fff8000UL
> > #define TASK_SIZE 0x10000000000UL
>
> Indeed. Below patch should do the trick.
Thanks for the patch. I'll roll it into my larger one.
-- Dave
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-21 19:38 [RFC][PATCH] introduce TASK_SIZE_OF() for all arches Dave Hansen
2007-08-21 19:43 ` Matthew Wilcox
@ 2007-08-22 9:06 ` David Howells
2007-08-22 22:55 ` Dave Hansen
` (2 more replies)
1 sibling, 3 replies; 10+ messages in thread
From: David Howells @ 2007-08-22 9:06 UTC (permalink / raw)
To: Dave Hansen; +Cc: dhowells, linux-arch
Dave Hansen <haveblue@us.ibm.com> wrote:
> For the /proc/<pid>/pagemap code[1], we need to able to query how
> much virtual address space a particular task has.
How does this relate to NOMMU conditions?
David
^ permalink raw reply [flat|nested] 10+ messages in thread* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-22 9:06 ` David Howells
@ 2007-08-22 22:55 ` Dave Hansen
2007-08-22 23:50 ` Matt Mackall
2007-08-22 23:15 ` Dave Hansen
2007-08-23 9:37 ` David Howells
2 siblings, 1 reply; 10+ messages in thread
From: Dave Hansen @ 2007-08-22 22:55 UTC (permalink / raw)
To: David Howells; +Cc: linux-arch, Matt Mackall
On Wed, 2007-08-22 at 10:06 +0100, David Howells wrote:
> Dave Hansen <haveblue@us.ibm.com> wrote:
>
> > For the /proc/<pid>/pagemap code[1], we need to able to query how
> > much virtual address space a particular task has.
>
> How does this relate to NOMMU conditions?
It probably doesn't make any sense to use the /proc/<pid>/pagemap
feature on NOMMU systems. There are no pagetables to dump, and no
shared pages, right?
-- Dave
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-22 22:55 ` Dave Hansen
@ 2007-08-22 23:50 ` Matt Mackall
0 siblings, 0 replies; 10+ messages in thread
From: Matt Mackall @ 2007-08-22 23:50 UTC (permalink / raw)
To: Dave Hansen; +Cc: David Howells, linux-arch
On Wed, Aug 22, 2007 at 03:55:50PM -0700, Dave Hansen wrote:
> On Wed, 2007-08-22 at 10:06 +0100, David Howells wrote:
> > Dave Hansen <haveblue@us.ibm.com> wrote:
> >
> > > For the /proc/<pid>/pagemap code[1], we need to able to query how
> > > much virtual address space a particular task has.
> >
> > How does this relate to NOMMU conditions?
>
> It probably doesn't make any sense to use the /proc/<pid>/pagemap
> feature on NOMMU systems. There are no pagetables to dump, and no
> shared pages, right?
Nor is there any present/not present to report. VSS == RSS on NOMMU,
right?
So we could provide pagemap, but it's not clear it'd be very
interesting. kpagemap might be interesting, simply because of the
flags though.
--
Mathematics is the supreme nostalgia of our time.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-22 9:06 ` David Howells
2007-08-22 22:55 ` Dave Hansen
@ 2007-08-22 23:15 ` Dave Hansen
2007-08-23 9:37 ` David Howells
2 siblings, 0 replies; 10+ messages in thread
From: Dave Hansen @ 2007-08-22 23:15 UTC (permalink / raw)
To: David Howells; +Cc: linux-arch
On Wed, 2007-08-22 at 10:06 +0100, David Howells wrote:
> Dave Hansen <haveblue@us.ibm.com> wrote:
> > For the /proc/<pid>/pagemap code[1], we need to able to query how
> > much virtual address space a particular task has.
>
> How does this relate to NOMMU conditions?
Were you asking about /proc/<pid>/pagemap, or about my TASK_SIZE_OF()
macro?
/proc/<pid>/pagemap is completely implemented in task_mmu.c, so it
shouldn't show up on NOMMU systems.
As far as TASK_SIZE_OF(), it still makes sense on those systems because
they (at least m68k) still has TASK_SIZE. Was there a particular
problem you're concerned about? I'm not very intimately familiar with
the NOMMU code.
-- Dave
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [RFC][PATCH] introduce TASK_SIZE_OF() for all arches
2007-08-22 9:06 ` David Howells
2007-08-22 22:55 ` Dave Hansen
2007-08-22 23:15 ` Dave Hansen
@ 2007-08-23 9:37 ` David Howells
2 siblings, 0 replies; 10+ messages in thread
From: David Howells @ 2007-08-23 9:37 UTC (permalink / raw)
To: Dave Hansen; +Cc: dhowells, linux-arch
Dave Hansen <haveblue@us.ibm.com> wrote:
> Were you asking about /proc/<pid>/pagemap, or about my TASK_SIZE_OF()
> macro?
TASK_SIZE_OF().
> As far as TASK_SIZE_OF(), it still makes sense on those systems because
> they (at least m68k) still has TASK_SIZE.
Fair enough.
> Was there a particular problem you're concerned about? I'm not very
> intimately familiar with the NOMMU code.
Since you were talking about virtual memory, I was wondering as to its
applicability for NOMMU.
David
^ permalink raw reply [flat|nested] 10+ messages in thread
[parent not found: <20070821132038.GA22254@ff.dom.local>]
end of thread, other threads:[~2007-08-23 9:37 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-08-21 19:38 [RFC][PATCH] introduce TASK_SIZE_OF() for all arches Dave Hansen
2007-08-21 19:43 ` Matthew Wilcox
2007-08-22 17:30 ` Ralf Baechle
2007-08-22 23:10 ` Dave Hansen
2007-08-22 9:06 ` David Howells
2007-08-22 22:55 ` Dave Hansen
2007-08-22 23:50 ` Matt Mackall
2007-08-22 23:15 ` Dave Hansen
2007-08-23 9:37 ` David Howells
[not found] <20070821132038.GA22254@ff.dom.local>
[not found] ` <20070821093103.3c097d4a.randy.dunlap@oracle.com>
2007-08-21 17:35 ` RFC: drop support for gcc < 4.0 Adrian Bunk
2007-08-21 19:19 ` Andi Kleen
2007-08-21 19:54 ` Adrian Bunk
2007-08-21 20:07 ` [RFC][PATCH] introduce TASK_SIZE_OF() for all arches Matthew Wilcox
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).