[<prev] [next>] [day] [month] [year] [list]
Message-ID: <send-serie.davidel@xmailserver.org.22229.1183076257.1>
Date: Thu, 28 Jun 2007 17:17:37 -0700
From: Davide Libenzi <davidel@...ilserver.org>
To: Linux Kernel Mailing List <linux-kernel@...r.kernel.org>
Cc: Andrew Morton <akpm@...ux-foundation.org>,
Linus Torvalds <torvalds@...ux-foundation.org>
Subject: [patch 1/1] compat_alloc_user
I noticed that is not possible ATM to allocate two or more blocks
of userspace memory. Would a compat_alloc_user() like the one below
make sense (patch untested)?
Signed-off-by: Davide Libenzi <davidel@...ilserver.org>
- Davide
---
include/asm-ia64/compat.h | 8 ++++++++
include/asm-mips/compat.h | 8 ++++++++
include/asm-parisc/compat.h | 8 ++++++++
include/asm-powerpc/compat.h | 8 ++++++++
include/asm-s390/compat.h | 8 ++++++++
include/asm-sparc64/compat.h | 8 ++++++++
include/asm-x86_64/compat.h | 8 ++++++++
7 files changed, 56 insertions(+)
Index: linux-2.6.mod/include/asm-x86_64/compat.h
===================================================================
--- linux-2.6.mod.orig/include/asm-x86_64/compat.h 2007-06-13 17:48:27.000000000 -0700
+++ linux-2.6.mod/include/asm-x86_64/compat.h 2007-06-13 17:48:32.000000000 -0700
@@ -202,6 +202,14 @@
return (void __user *)regs->rsp - len;
}
+static __inline__ void __user *compat_alloc_user(void __user **prev, long len)
+{
+ void __user *data;
+ data = *prev ? (*prev - len): compat_alloc_user_space(len);
+ *prev = (void __user *) ((unsigned long) data & ~0x7UL);
+ return *prev;
+}
+
static inline int is_compat_task(void)
{
return current_thread_info()->status & TS_COMPAT;
Index: linux-2.6.mod/include/asm-sparc64/compat.h
===================================================================
--- linux-2.6.mod.orig/include/asm-sparc64/compat.h 2007-06-13 17:48:27.000000000 -0700
+++ linux-2.6.mod/include/asm-sparc64/compat.h 2007-06-13 17:48:32.000000000 -0700
@@ -180,6 +180,14 @@
return (void __user *) usp;
}
+static inline void __user *compat_alloc_user(void __user **prev, long len)
+{
+ void __user *data;
+ data = *prev ? (*prev - len): compat_alloc_user_space(len);
+ *prev = (void __user *) ((unsigned long) data & ~0x7UL);
+ return *prev;
+}
+
struct compat_ipc64_perm {
compat_key_t key;
__compat_uid32_t uid;
Index: linux-2.6.mod/include/asm-s390/compat.h
===================================================================
--- linux-2.6.mod.orig/include/asm-s390/compat.h 2007-06-13 17:48:27.000000000 -0700
+++ linux-2.6.mod/include/asm-s390/compat.h 2007-06-13 17:48:32.000000000 -0700
@@ -171,6 +171,14 @@
return (void __user *) (stack - len);
}
+static inline void __user *compat_alloc_user(void __user **prev, long len)
+{
+ void __user *data;
+ data = *prev ? (*prev - len): compat_alloc_user_space(len);
+ *prev = (void __user *) ((unsigned long) data & ~0x7UL);
+ return *prev;
+}
+
struct compat_ipc64_perm {
compat_key_t key;
__compat_uid32_t uid;
Index: linux-2.6.mod/include/asm-powerpc/compat.h
===================================================================
--- linux-2.6.mod.orig/include/asm-powerpc/compat.h 2007-06-13 17:48:27.000000000 -0700
+++ linux-2.6.mod/include/asm-powerpc/compat.h 2007-06-13 17:48:32.000000000 -0700
@@ -146,6 +146,14 @@
return (void __user *) (usp - len);
}
+static inline void __user *compat_alloc_user(void __user **prev, long len)
+{
+ void __user *data;
+ data = *prev ? (*prev - len): compat_alloc_user_space(len);
+ *prev = (void __user *) ((unsigned long) data & ~0x7UL);
+ return *prev;
+}
+
/*
* ipc64_perm is actually 32/64bit clean but since the compat layer refers to
* it we may as well define it.
Index: linux-2.6.mod/include/asm-parisc/compat.h
===================================================================
--- linux-2.6.mod.orig/include/asm-parisc/compat.h 2007-06-13 17:48:27.000000000 -0700
+++ linux-2.6.mod/include/asm-parisc/compat.h 2007-06-13 17:48:32.000000000 -0700
@@ -150,6 +150,14 @@
return (void __user *)regs->gr[30];
}
+static __inline__ void __user *compat_alloc_user(void __user **prev, long len)
+{
+ void __user *data;
+ data = *prev ? : compat_alloc_user_space(len);
+ *prev = data + ((len + 0x7UL) & ~0x7UL);
+ return data;
+}
+
static inline int __is_compat_task(struct task_struct *t)
{
return test_ti_thread_flag(task_thread_info(t), TIF_32BIT);
Index: linux-2.6.mod/include/asm-mips/compat.h
===================================================================
--- linux-2.6.mod.orig/include/asm-mips/compat.h 2007-06-13 17:48:27.000000000 -0700
+++ linux-2.6.mod/include/asm-mips/compat.h 2007-06-13 17:48:32.000000000 -0700
@@ -148,6 +148,14 @@
return (void __user *) (regs->regs[29] - len);
}
+static inline void __user *compat_alloc_user(void __user **prev, long len)
+{
+ void __user *data;
+ data = *prev ? (*prev - len): compat_alloc_user_space(len);
+ *prev = (void __user *) ((unsigned long) data & ~0x7UL);
+ return *prev;
+}
+
struct compat_ipc64_perm {
compat_key_t key;
__compat_uid32_t uid;
Index: linux-2.6.mod/include/asm-ia64/compat.h
===================================================================
--- linux-2.6.mod.orig/include/asm-ia64/compat.h 2007-06-13 17:48:27.000000000 -0700
+++ linux-2.6.mod/include/asm-ia64/compat.h 2007-06-13 17:48:32.000000000 -0700
@@ -202,4 +202,12 @@
return (void __user *) (((regs->r12 & 0xffffffff) & -16) - len);
}
+static __inline__ void __user *compat_alloc_user(void __user **prev, long len)
+{
+ void __user *data;
+ data = *prev ? (*prev - len): compat_alloc_user_space(len);
+ *prev = (void __user *) ((unsigned long) data & ~0xfUL;
+ return *prev;
+}
+
#endif /* _ASM_IA64_COMPAT_H */
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists