All of lore.kernel.org
 help / color / mirror / Atom feed
* [uml-devel] [PATCH] uml compile fixes
@ 2008-03-17 15:38 Alexander van Heukelum
  2008-03-18 15:33 ` Jeff Dike
  2008-03-31 14:03 ` Jeff Dike
  0 siblings, 2 replies; 4+ messages in thread
From: Alexander van Heukelum @ 2008-03-17 15:38 UTC (permalink / raw)
  To: user-mode-linux-devel, Jeff Dike; +Cc: heukelum

Hi all,

I need the following two changes to get my favourite uml config
to compile (and run):

make ARCH=um SUBARCH=i386 KCONFIG_ALLCONFIG=mini.config allnoconfig

with mini.config:
CONFIG_BINFMT_ELF=y
CONFIG_BLK_DEV_INITRD=y
CONFIG_INITRAMFS_SOURCE="../initramfs"
CONFIG_EMBEDDED=y
CONFIG_KALLSYMS=y
CONFIG_PRINTK=y
CONFIG_BUG=y
CONFIG_SLOB=y
CONFIG_MODULES=y
CONFIG_MODULE_UNLOAD=y
CONFIG_XTERM_CHAN=y
CONFIG_PROC_FS=y
CONFIG_SYSFS=y

Please review/comment (or create a better patch for this yourself!).

(If you need one:) 
Signed-off-by: Alexander van Heukelum <heukelum@fastmail.fm>

diff --git a/arch/um/include/um_malloc.h b/arch/um/include/um_malloc.h
index 0ad17cb..e5b09fa 100644
--- a/arch/um/include/um_malloc.h
+++ b/arch/um/include/um_malloc.h
@@ -8,11 +8,19 @@
 
 #include "kern_constants.h"
 
+#ifdef UML_CONFIG_SLOB
+extern void *__kmalloc_node(int size, int flags, int node);
+static inline void *kmalloc(int size, int flags)
+{
+	return __kmalloc_node(size, flags, -1);
+}
+#else
 extern void *__kmalloc(int size, int flags);
 static inline void *kmalloc(int size, int flags)
 {
 	return __kmalloc(size, flags);
 }
+#endif
 
 extern void kfree(const void *ptr);
 
diff --git a/arch/um/kernel/ksyms.c b/arch/um/kernel/ksyms.c
diff --git a/arch/um/os-Linux/helper.c b/arch/um/os-Linux/helper.c
diff --git a/include/asm-um/tlb.h b/include/asm-um/tlb.h
index 39fc475..7febf85 100644
--- a/include/asm-um/tlb.h
+++ b/include/asm-um/tlb.h
@@ -2,6 +2,7 @@
 #define __UM_TLB_H
 
 #include <linux/swap.h>
+#include <linux/pagemap.h>
 #include <asm/percpu.h>
 #include <asm/pgalloc.h>
 #include <asm/tlbflush.h>


-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

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

* Re: [uml-devel] [PATCH] uml compile fixes
  2008-03-17 15:38 [uml-devel] [PATCH] uml compile fixes Alexander van Heukelum
@ 2008-03-18 15:33 ` Jeff Dike
  2008-03-31 14:03 ` Jeff Dike
  1 sibling, 0 replies; 4+ messages in thread
From: Jeff Dike @ 2008-03-18 15:33 UTC (permalink / raw)
  To: Alexander van Heukelum; +Cc: heukelum, user-mode-linux-devel

On Mon, Mar 17, 2008 at 04:38:00PM +0100, Alexander van Heukelum wrote:
> Please review/comment (or create a better patch for this yourself!).

Yeah, this needs fixing, but I think we need a different fix.

      	   	 	 Jeff

-- 
Work email - jdike at linux dot intel dot com

-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

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

* Re: [uml-devel] [PATCH] uml compile fixes
  2008-03-17 15:38 [uml-devel] [PATCH] uml compile fixes Alexander van Heukelum
  2008-03-18 15:33 ` Jeff Dike
@ 2008-03-31 14:03 ` Jeff Dike
  2008-03-31 15:56   ` Alexander van Heukelum
  1 sibling, 1 reply; 4+ messages in thread
From: Jeff Dike @ 2008-03-31 14:03 UTC (permalink / raw)
  To: Alexander van Heukelum; +Cc: heukelum, user-mode-linux-devel

On Mon, Mar 17, 2008 at 04:38:00PM +0100, Alexander van Heukelum wrote:
> CONFIG_SLOB=y

> Please review/comment (or create a better patch for this yourself!).

Try the one below - it's a bit larger, but perhaps cleaner and more
future-proof.

				Jeff

-- 
Work email - jdike at linux dot intel dot com

Index: linux-2.6.22/arch/um/drivers/chan_user.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/chan_user.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/chan_user.c	2008-03-31 10:01:19.000000000 -0400
@@ -11,6 +11,7 @@
 #include <termios.h>
 #include <sys/ioctl.h>
 #include "chan_user.h"
+#include "kern_constants.h"
 #include "os.h"
 #include "um_malloc.h"
 #include "user.h"
Index: linux-2.6.22/arch/um/drivers/cow_sys.h
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/cow_sys.h	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/cow_sys.h	2008-03-31 10:01:19.000000000 -0400
@@ -8,7 +8,7 @@
 
 static inline void *cow_malloc(int size)
 {
-	return kmalloc(size, UM_GFP_KERNEL);
+	return uml_kmalloc(size, UM_GFP_KERNEL);
 }
 
 static inline void cow_free(void *ptr)
Index: linux-2.6.22/arch/um/drivers/daemon_user.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/daemon_user.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/daemon_user.c	2008-03-31 10:01:19.000000000 -0400
@@ -35,7 +35,7 @@ static struct sockaddr_un *new_addr(void
 {
 	struct sockaddr_un *sun;
 
-	sun = kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
+	sun = uml_kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
 	if (sun == NULL) {
 		printk(UM_KERN_ERR "new_addr: allocation of sockaddr_un "
 		       "failed\n");
@@ -84,7 +84,7 @@ static int connect_to_switch(struct daem
 		goto out_close;
 	}
 
-	sun = kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
+	sun = uml_kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
 	if (sun == NULL) {
 		printk(UM_KERN_ERR "new_addr: allocation of sockaddr_un "
 		       "failed\n");
Index: linux-2.6.22/arch/um/drivers/fd.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/fd.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/fd.c	2008-03-31 10:01:19.000000000 -0400
@@ -40,7 +40,7 @@ static void *fd_init(char *str, int devi
 		return NULL;
 	}
 
-	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
+	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
 	if (data == NULL)
 		return NULL;
 
Index: linux-2.6.22/arch/um/drivers/mcast_user.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/mcast_user.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/mcast_user.c	2008-03-31 10:01:19.000000000 -0400
@@ -15,6 +15,7 @@
 #include <unistd.h>
 #include <errno.h>
 #include <netinet/in.h>
+#include "kern_constants.h"
 #include "mcast.h"
 #include "net_user.h"
 #include "um_malloc.h"
@@ -24,7 +25,7 @@ static struct sockaddr_in *new_addr(char
 {
 	struct sockaddr_in *sin;
 
-	sin = kmalloc(sizeof(struct sockaddr_in), UM_GFP_KERNEL);
+	sin = uml_kmalloc(sizeof(struct sockaddr_in), UM_GFP_KERNEL);
 	if (sin == NULL) {
 		printk(UM_KERN_ERR "new_addr: allocation of sockaddr_in "
 		       "failed\n");
Index: linux-2.6.22/arch/um/drivers/net_user.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/net_user.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/net_user.c	2008-03-31 10:01:19.000000000 -0400
@@ -222,7 +222,7 @@ static void change(char *dev, char *what
 		netmask[2], netmask[3]);
 
 	output_len = UM_KERN_PAGE_SIZE;
-	output = kmalloc(output_len, UM_GFP_KERNEL);
+	output = uml_kmalloc(output_len, UM_GFP_KERNEL);
 	if (output == NULL)
 		printk(UM_KERN_ERR "change : failed to allocate output "
 		       "buffer\n");
Index: linux-2.6.22/arch/um/drivers/port_user.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/port_user.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/port_user.c	2008-03-31 10:01:19.000000000 -0400
@@ -47,7 +47,7 @@ static void *port_init(char *str, int de
 	if (kern_data == NULL)
 		return NULL;
 
-	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
+	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
 	if (data == NULL)
 		goto err;
 
Index: linux-2.6.22/arch/um/drivers/pty.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/pty.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/pty.c	2008-03-31 10:01:19.000000000 -0400
@@ -29,7 +29,7 @@ static void *pty_chan_init(char *str, in
 {
 	struct pty_chan *data;
 
-	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
+	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
 	if (data == NULL)
 		return NULL;
 
Index: linux-2.6.22/arch/um/drivers/slip_user.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/slip_user.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/slip_user.c	2008-03-31 10:01:19.000000000 -0400
@@ -96,7 +96,7 @@ static int slip_tramp(char **argv, int f
 	pid = err;
 
 	output_len = UM_KERN_PAGE_SIZE;
-	output = kmalloc(output_len, UM_GFP_KERNEL);
+	output = uml_kmalloc(output_len, UM_GFP_KERNEL);
 	if (output == NULL) {
 		printk(UM_KERN_ERR "slip_tramp : failed to allocate output "
 		       "buffer\n");
Index: linux-2.6.22/arch/um/drivers/tty.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/tty.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/tty.c	2008-03-31 10:01:19.000000000 -0400
@@ -29,7 +29,7 @@ static void *tty_chan_init(char *str, in
 	}
 	str++;
 
-	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
+	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
 	if (data == NULL)
 		return NULL;
 	*data = ((struct tty_chan) { .dev 	= str,
Index: linux-2.6.22/arch/um/drivers/xterm.c
===================================================================
--- linux-2.6.22.orig/arch/um/drivers/xterm.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/drivers/xterm.c	2008-03-31 10:01:19.000000000 -0400
@@ -30,7 +30,7 @@ static void *xterm_init(char *str, int d
 {
 	struct xterm_chan *data;
 
-	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
+	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
 	if (data == NULL)
 		return NULL;
 	*data = ((struct xterm_chan) { .pid 		= -1,
Index: linux-2.6.22/arch/um/include/um_malloc.h
===================================================================
--- linux-2.6.22.orig/arch/um/include/um_malloc.h	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/include/um_malloc.h	2008-03-31 10:01:19.000000000 -0400
@@ -8,15 +8,12 @@
 
 #include "kern_constants.h"
 
-extern void *__kmalloc(int size, int flags);
-static inline void *kmalloc(int size, int flags)
-{
-	return __kmalloc(size, flags);
-}
-
+extern void *uml_kmalloc(int size, int flags);
 extern void kfree(const void *ptr);
 
 extern void *vmalloc(unsigned long size);
 extern void vfree(void *ptr);
 
 #endif /* __UM_MALLOC_H__ */
+
+
Index: linux-2.6.22/arch/um/kernel/mem.c
===================================================================
--- linux-2.6.22.orig/arch/um/kernel/mem.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/kernel/mem.c	2008-03-31 10:01:19.000000000 -0400
@@ -375,3 +375,8 @@ pmd_t *pmd_alloc_one(struct mm_struct *m
 	return pmd;
 }
 #endif
+
+void *uml_kmalloc(int size, int flags)
+{
+	return kmalloc(size, flags);
+}
Index: linux-2.6.22/arch/um/os-Linux/drivers/ethertap_user.c
===================================================================
--- linux-2.6.22.orig/arch/um/os-Linux/drivers/ethertap_user.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/os-Linux/drivers/ethertap_user.c	2008-03-31 10:01:19.000000000 -0400
@@ -52,7 +52,7 @@ static void etap_change(int op, unsigned
 		return;
 	}
 
-	output = kmalloc(UM_KERN_PAGE_SIZE, UM_GFP_KERNEL);
+	output = uml_kmalloc(UM_KERN_PAGE_SIZE, UM_GFP_KERNEL);
 	if (output == NULL)
 		printk(UM_KERN_ERR "etap_change : Failed to allocate output "
 		       "buffer\n");
@@ -165,7 +165,7 @@ static int etap_open(void *data)
 	err = etap_tramp(pri->dev_name, pri->gate_addr, control_fds[0],
 			 control_fds[1], data_fds[0], data_fds[1]);
 	output_len = UM_KERN_PAGE_SIZE;
-	output = kmalloc(output_len, UM_GFP_KERNEL);
+	output = uml_kmalloc(output_len, UM_GFP_KERNEL);
 	read_output(control_fds[0], output, output_len);
 
 	if (output == NULL)
Index: linux-2.6.22/arch/um/os-Linux/helper.c
===================================================================
--- linux-2.6.22.orig/arch/um/os-Linux/helper.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/os-Linux/helper.c	2008-03-31 10:01:19.000000000 -0400
@@ -70,8 +70,8 @@ int run_helper(void (*pre_exec)(void *),
 	data.pre_data = pre_data;
 	data.argv = argv;
 	data.fd = fds[1];
-	data.buf = __cant_sleep() ? kmalloc(PATH_MAX, UM_GFP_ATOMIC) :
-					kmalloc(PATH_MAX, UM_GFP_KERNEL);
+	data.buf = __cant_sleep() ? uml_kmalloc(PATH_MAX, UM_GFP_ATOMIC) :
+					uml_kmalloc(PATH_MAX, UM_GFP_KERNEL);
 	pid = clone(helper_child, (void *) sp, CLONE_VM, &data);
 	if (pid < 0) {
 		ret = -errno;
Index: linux-2.6.22/arch/um/os-Linux/main.c
===================================================================
--- linux-2.6.22.orig/arch/um/os-Linux/main.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/os-Linux/main.c	2008-03-31 10:01:19.000000000 -0400
@@ -199,7 +199,7 @@ void *__wrap_malloc(int size)
 		return __real_malloc(size);
 	else if (size <= UM_KERN_PAGE_SIZE)
 		/* finding contiguous pages can be hard*/
-		ret = kmalloc(size, UM_GFP_KERNEL);
+		ret = uml_kmalloc(size, UM_GFP_KERNEL);
 	else ret = vmalloc(size);
 
 	/*
Index: linux-2.6.22/arch/um/os-Linux/sigio.c
===================================================================
--- linux-2.6.22.orig/arch/um/os-Linux/sigio.c	2008-03-31 10:01:02.000000000 -0400
+++ linux-2.6.22/arch/um/os-Linux/sigio.c	2008-03-31 10:02:05.000000000 -0400
@@ -109,7 +109,7 @@ static int need_poll(struct pollfds *pol
 	if (n <= polls->size)
 		return 0;
 
-	new = kmalloc(n * sizeof(struct pollfd), UM_GFP_ATOMIC);
+	new = uml_kmalloc(n * sizeof(struct pollfd), UM_GFP_ATOMIC);
 	if (new == NULL) {
 		printk(UM_KERN_ERR "need_poll : failed to allocate new "
 		       "pollfds\n");
@@ -243,7 +243,7 @@ static struct pollfd *setup_initial_poll
 {
 	struct pollfd *p;
 
-	p = kmalloc(sizeof(struct pollfd), UM_GFP_KERNEL);
+	p = uml_kmalloc(sizeof(struct pollfd), UM_GFP_KERNEL);
 	if (p == NULL) {
 		printk(UM_KERN_ERR "setup_initial_poll : failed to allocate "
 		       "poll\n");

-------------------------------------------------------------------------
Check out the new SourceForge.net Marketplace.
It's the best place to buy or sell services for
just about anything Open Source.
http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

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

* Re: [uml-devel] [PATCH] uml compile fixes
  2008-03-31 14:03 ` Jeff Dike
@ 2008-03-31 15:56   ` Alexander van Heukelum
  0 siblings, 0 replies; 4+ messages in thread
From: Alexander van Heukelum @ 2008-03-31 15:56 UTC (permalink / raw)
  To: Jeff Dike, Alexander van Heukelum; +Cc: user-mode-linux-devel

On Mon, 31 Mar 2008 10:03:44 -0400, "Jeff Dike" <jdike@addtoit.com>
said:
> On Mon, Mar 17, 2008 at 04:38:00PM +0100, Alexander van Heukelum wrote:
> > CONFIG_SLOB=y
> 
> > Please review/comment (or create a better patch for this yourself!).
> 
> Try the one below - it's a bit larger, but perhaps cleaner and more
> future-proof.

Hi,

This approach is indeed a lot cleaner.

I need the following on top of this patch to get it to
compile for my configs. I have compiled for x86_64 for
SLOB/SLUB/SLAB. I have verified that the kernels run
fine for i386 for SLOB/SLUB/SLAB.

--- a/include/asm-um/tlb.h
+++ b/include/asm-um/tlb.h
@@ -2,6 +2,7 @@
 #define __UM_TLB_H
 
 #include <linux/swap.h>
+#include <linux/pagemap.h>
 #include <asm/percpu.h>
 #include <asm/pgalloc.h>
 #include <asm/tlbflush.h>

The only comment I have on the patch is that it introduces
spurious whitespace at the end of arch/um/include/um_malloc.h

Greetings,
    Alexander

> 				Jeff
> 
> -- 
> Work email - jdike at linux dot intel dot com
> 
> Index: linux-2.6.22/arch/um/drivers/chan_user.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/chan_user.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/chan_user.c	2008-03-31
> 10:01:19.000000000 -0400
> @@ -11,6 +11,7 @@
>  #include <termios.h>
>  #include <sys/ioctl.h>
>  #include "chan_user.h"
> +#include "kern_constants.h"
>  #include "os.h"
>  #include "um_malloc.h"
>  #include "user.h"
> Index: linux-2.6.22/arch/um/drivers/cow_sys.h
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/cow_sys.h	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/cow_sys.h	2008-03-31 10:01:19.000000000
> -0400
> @@ -8,7 +8,7 @@
>  
>  static inline void *cow_malloc(int size)
>  {
> -	return kmalloc(size, UM_GFP_KERNEL);
> +	return uml_kmalloc(size, UM_GFP_KERNEL);
>  }
>  
>  static inline void cow_free(void *ptr)
> Index: linux-2.6.22/arch/um/drivers/daemon_user.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/daemon_user.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/daemon_user.c	2008-03-31
> 10:01:19.000000000 -0400
> @@ -35,7 +35,7 @@ static struct sockaddr_un *new_addr(void
>  {
>  	struct sockaddr_un *sun;
>  
> -	sun = kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
> +	sun = uml_kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
>  	if (sun == NULL) {
>  		printk(UM_KERN_ERR "new_addr: allocation of sockaddr_un "
>  		       "failed\n");
> @@ -84,7 +84,7 @@ static int connect_to_switch(struct daem
>  		goto out_close;
>  	}
>  
> -	sun = kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
> +	sun = uml_kmalloc(sizeof(struct sockaddr_un), UM_GFP_KERNEL);
>  	if (sun == NULL) {
>  		printk(UM_KERN_ERR "new_addr: allocation of sockaddr_un "
>  		       "failed\n");
> Index: linux-2.6.22/arch/um/drivers/fd.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/fd.c	2008-03-31 10:01:02.000000000
> -0400
> +++ linux-2.6.22/arch/um/drivers/fd.c	2008-03-31 10:01:19.000000000 -0400
> @@ -40,7 +40,7 @@ static void *fd_init(char *str, int devi
>  		return NULL;
>  	}
>  
> -	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
> +	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
>  	if (data == NULL)
>  		return NULL;
>  
> Index: linux-2.6.22/arch/um/drivers/mcast_user.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/mcast_user.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/mcast_user.c	2008-03-31
> 10:01:19.000000000 -0400
> @@ -15,6 +15,7 @@
>  #include <unistd.h>
>  #include <errno.h>
>  #include <netinet/in.h>
> +#include "kern_constants.h"
>  #include "mcast.h"
>  #include "net_user.h"
>  #include "um_malloc.h"
> @@ -24,7 +25,7 @@ static struct sockaddr_in *new_addr(char
>  {
>  	struct sockaddr_in *sin;
>  
> -	sin = kmalloc(sizeof(struct sockaddr_in), UM_GFP_KERNEL);
> +	sin = uml_kmalloc(sizeof(struct sockaddr_in), UM_GFP_KERNEL);
>  	if (sin == NULL) {
>  		printk(UM_KERN_ERR "new_addr: allocation of sockaddr_in "
>  		       "failed\n");
> Index: linux-2.6.22/arch/um/drivers/net_user.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/net_user.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/net_user.c	2008-03-31 10:01:19.000000000
> -0400
> @@ -222,7 +222,7 @@ static void change(char *dev, char *what
>  		netmask[2], netmask[3]);
>  
>  	output_len = UM_KERN_PAGE_SIZE;
> -	output = kmalloc(output_len, UM_GFP_KERNEL);
> +	output = uml_kmalloc(output_len, UM_GFP_KERNEL);
>  	if (output == NULL)
>  		printk(UM_KERN_ERR "change : failed to allocate output "
>  		       "buffer\n");
> Index: linux-2.6.22/arch/um/drivers/port_user.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/port_user.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/port_user.c	2008-03-31
> 10:01:19.000000000 -0400
> @@ -47,7 +47,7 @@ static void *port_init(char *str, int de
>  	if (kern_data == NULL)
>  		return NULL;
>  
> -	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
> +	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
>  	if (data == NULL)
>  		goto err;
>  
> Index: linux-2.6.22/arch/um/drivers/pty.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/pty.c	2008-03-31 10:01:02.000000000
> -0400
> +++ linux-2.6.22/arch/um/drivers/pty.c	2008-03-31 10:01:19.000000000
> -0400
> @@ -29,7 +29,7 @@ static void *pty_chan_init(char *str, in
>  {
>  	struct pty_chan *data;
>  
> -	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
> +	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
>  	if (data == NULL)
>  		return NULL;
>  
> Index: linux-2.6.22/arch/um/drivers/slip_user.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/slip_user.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/slip_user.c	2008-03-31
> 10:01:19.000000000 -0400
> @@ -96,7 +96,7 @@ static int slip_tramp(char **argv, int f
>  	pid = err;
>  
>  	output_len = UM_KERN_PAGE_SIZE;
> -	output = kmalloc(output_len, UM_GFP_KERNEL);
> +	output = uml_kmalloc(output_len, UM_GFP_KERNEL);
>  	if (output == NULL) {
>  		printk(UM_KERN_ERR "slip_tramp : failed to allocate output "
>  		       "buffer\n");
> Index: linux-2.6.22/arch/um/drivers/tty.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/tty.c	2008-03-31 10:01:02.000000000
> -0400
> +++ linux-2.6.22/arch/um/drivers/tty.c	2008-03-31 10:01:19.000000000
> -0400
> @@ -29,7 +29,7 @@ static void *tty_chan_init(char *str, in
>  	}
>  	str++;
>  
> -	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
> +	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
>  	if (data == NULL)
>  		return NULL;
>  	*data = ((struct tty_chan) { .dev 	= str,
> Index: linux-2.6.22/arch/um/drivers/xterm.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/drivers/xterm.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/drivers/xterm.c	2008-03-31 10:01:19.000000000
> -0400
> @@ -30,7 +30,7 @@ static void *xterm_init(char *str, int d
>  {
>  	struct xterm_chan *data;
>  
> -	data = kmalloc(sizeof(*data), UM_GFP_KERNEL);
> +	data = uml_kmalloc(sizeof(*data), UM_GFP_KERNEL);
>  	if (data == NULL)
>  		return NULL;
>  	*data = ((struct xterm_chan) { .pid 		= -1,
> Index: linux-2.6.22/arch/um/include/um_malloc.h
> ===================================================================
> --- linux-2.6.22.orig/arch/um/include/um_malloc.h	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/include/um_malloc.h	2008-03-31
> 10:01:19.000000000 -0400
> @@ -8,15 +8,12 @@
>  
>  #include "kern_constants.h"
>  
> -extern void *__kmalloc(int size, int flags);
> -static inline void *kmalloc(int size, int flags)
> -{
> -	return __kmalloc(size, flags);
> -}
> -
> +extern void *uml_kmalloc(int size, int flags);
>  extern void kfree(const void *ptr);
>  
>  extern void *vmalloc(unsigned long size);
>  extern void vfree(void *ptr);
>  
>  #endif /* __UM_MALLOC_H__ */
> +
> +
> Index: linux-2.6.22/arch/um/kernel/mem.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/kernel/mem.c	2008-03-31 10:01:02.000000000
> -0400
> +++ linux-2.6.22/arch/um/kernel/mem.c	2008-03-31 10:01:19.000000000 -0400
> @@ -375,3 +375,8 @@ pmd_t *pmd_alloc_one(struct mm_struct *m
>  	return pmd;
>  }
>  #endif
> +
> +void *uml_kmalloc(int size, int flags)
> +{
> +	return kmalloc(size, flags);
> +}
> Index: linux-2.6.22/arch/um/os-Linux/drivers/ethertap_user.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/os-Linux/drivers/ethertap_user.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/os-Linux/drivers/ethertap_user.c	2008-03-31
> 10:01:19.000000000 -0400
> @@ -52,7 +52,7 @@ static void etap_change(int op, unsigned
>  		return;
>  	}
>  
> -	output = kmalloc(UM_KERN_PAGE_SIZE, UM_GFP_KERNEL);
> +	output = uml_kmalloc(UM_KERN_PAGE_SIZE, UM_GFP_KERNEL);
>  	if (output == NULL)
>  		printk(UM_KERN_ERR "etap_change : Failed to allocate output "
>  		       "buffer\n");
> @@ -165,7 +165,7 @@ static int etap_open(void *data)
>  	err = etap_tramp(pri->dev_name, pri->gate_addr, control_fds[0],
>  			 control_fds[1], data_fds[0], data_fds[1]);
>  	output_len = UM_KERN_PAGE_SIZE;
> -	output = kmalloc(output_len, UM_GFP_KERNEL);
> +	output = uml_kmalloc(output_len, UM_GFP_KERNEL);
>  	read_output(control_fds[0], output, output_len);
>  
>  	if (output == NULL)
> Index: linux-2.6.22/arch/um/os-Linux/helper.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/os-Linux/helper.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/os-Linux/helper.c	2008-03-31 10:01:19.000000000
> -0400
> @@ -70,8 +70,8 @@ int run_helper(void (*pre_exec)(void *),
>  	data.pre_data = pre_data;
>  	data.argv = argv;
>  	data.fd = fds[1];
> -	data.buf = __cant_sleep() ? kmalloc(PATH_MAX, UM_GFP_ATOMIC) :
> -					kmalloc(PATH_MAX, UM_GFP_KERNEL);
> +	data.buf = __cant_sleep() ? uml_kmalloc(PATH_MAX, UM_GFP_ATOMIC) :
> +					uml_kmalloc(PATH_MAX, UM_GFP_KERNEL);
>  	pid = clone(helper_child, (void *) sp, CLONE_VM, &data);
>  	if (pid < 0) {
>  		ret = -errno;
> Index: linux-2.6.22/arch/um/os-Linux/main.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/os-Linux/main.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/os-Linux/main.c	2008-03-31 10:01:19.000000000
> -0400
> @@ -199,7 +199,7 @@ void *__wrap_malloc(int size)
>  		return __real_malloc(size);
>  	else if (size <= UM_KERN_PAGE_SIZE)
>  		/* finding contiguous pages can be hard*/
> -		ret = kmalloc(size, UM_GFP_KERNEL);
> +		ret = uml_kmalloc(size, UM_GFP_KERNEL);
>  	else ret = vmalloc(size);
>  
>  	/*
> Index: linux-2.6.22/arch/um/os-Linux/sigio.c
> ===================================================================
> --- linux-2.6.22.orig/arch/um/os-Linux/sigio.c	2008-03-31
> 10:01:02.000000000 -0400
> +++ linux-2.6.22/arch/um/os-Linux/sigio.c	2008-03-31 10:02:05.000000000
> -0400
> @@ -109,7 +109,7 @@ static int need_poll(struct pollfds *pol
>  	if (n <= polls->size)
>  		return 0;
>  
> -	new = kmalloc(n * sizeof(struct pollfd), UM_GFP_ATOMIC);
> +	new = uml_kmalloc(n * sizeof(struct pollfd), UM_GFP_ATOMIC);
>  	if (new == NULL) {
>  		printk(UM_KERN_ERR "need_poll : failed to allocate new "
>  		       "pollfds\n");
> @@ -243,7 +243,7 @@ static struct pollfd *setup_initial_poll
>  {
>  	struct pollfd *p;
>  
> -	p = kmalloc(sizeof(struct pollfd), UM_GFP_KERNEL);
> +	p = uml_kmalloc(sizeof(struct pollfd), UM_GFP_KERNEL);
>  	if (p == NULL) {
>  		printk(UM_KERN_ERR "setup_initial_poll : failed to allocate "
>  		       "poll\n");
-- 
  Alexander van Heukelum
  heukelum@fastmail.fm

-- 
http://www.fastmail.fm - Send your email first class


-------------------------------------------------------------------------
Check out the new SourceForge.net Marketplace.
It's the best place to buy or sell services for
just about anything Open Source.
http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

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

end of thread, other threads:[~2008-03-31 15:56 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-03-17 15:38 [uml-devel] [PATCH] uml compile fixes Alexander van Heukelum
2008-03-18 15:33 ` Jeff Dike
2008-03-31 14:03 ` Jeff Dike
2008-03-31 15:56   ` Alexander van Heukelum

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.