[patch 7/8] fdmap v2 - implement sys_socket2

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: Linux Kernel Mailing List <linux-kernel@...>
Cc: Linus Torvalds <torvalds@...>, Andrew Morton <akpm@...>, Ulrich Drepper <drepper@...>, Ingo Molnar <mingo@...>, Eric Dumazet <dada1@...>
Date: Wednesday, June 6, 2007 - 6:30 pm

This patch implement a new syscall sys_socket2(), that accepts an
extra "flags" parameter:

int socket2(int domain, int type, int protocol, int flags);

The flags parameter is used to pass extra flags to the kernel, and is
at the moment used to select the file descriptor allocations inside
the non-sequential area (O_NONSEQFD). The remaining parameters are
exactly the same as the ones of sys_socket().
The sys_accept() system call has been modified to return a file
descriptor inside the non-sequential area, if the listening fd is.
The sys_socketcall() system call has been also changed to support
a new SYS_SOCKET2 indentifier.



Signed-off-by: Davide Libenzi <davidel@xmailserver.org>


- Davide



Index: linux-2.6.mod/fs/9p/trans_fd.c
===================================================================
--- linux-2.6.mod.orig/fs/9p/trans_fd.c	2007-06-06 12:38:27.000000000 -0700
+++ linux-2.6.mod/fs/9p/trans_fd.c	2007-06-06 12:48:41.000000000 -0700
@@ -181,7 +181,7 @@
 	int fd, ret;
 
 	csocket->sk->sk_allocation = GFP_NOIO;
-	if ((fd = sock_map_fd(csocket)) < 0) {
+	if ((fd = sock_map_fd(csocket, 0)) < 0) {
 		eprintk(KERN_ERR, "v9fs_socket_open: failed to map fd\n");
 		ret = fd;
 	      release_csocket:
Index: linux-2.6.mod/include/linux/net.h
===================================================================
--- linux-2.6.mod.orig/include/linux/net.h	2007-06-06 12:38:27.000000000 -0700
+++ linux-2.6.mod/include/linux/net.h	2007-06-06 13:09:20.000000000 -0700
@@ -43,6 +43,7 @@
 #define SYS_GETSOCKOPT	15		/* sys_getsockopt(2)		*/
 #define SYS_SENDMSG	16		/* sys_sendmsg(2)		*/
 #define SYS_RECVMSG	17		/* sys_recvmsg(2)		*/
+#define SYS_SOCKET2	18		/* sys_socket2(2)		*/
 
 typedef enum {
 	SS_FREE = 0,			/* not allocated		*/
@@ -190,7 +191,7 @@
 				  size_t len);
 extern int	     sock_recvmsg(struct socket *sock, struct msghdr *msg,
 				  size_t size, int flags);
-extern int 	     sock_map_fd(struct socket *sock);
+extern int 	     sock_map_fd(struct socket *sock, int flags);
 extern struct socket *sockfd_lookup(int fd, int *err);
 #define		     sockfd_put(sock) fput(sock->file)
 extern int	     net_ratelimit(void);
Index: linux-2.6.mod/net/sctp/socket.c
===================================================================
--- linux-2.6.mod.orig/net/sctp/socket.c	2007-06-06 12:38:27.000000000 -0700
+++ linux-2.6.mod/net/sctp/socket.c	2007-06-06 12:48:41.000000000 -0700
@@ -3605,7 +3605,7 @@
 		goto out;
 
 	/* Map the socket to an unused fd that can be returned to the user.  */
-	retval = sock_map_fd(newsock);
+	retval = sock_map_fd(newsock, 0);
 	if (retval < 0) {
 		sock_release(newsock);
 		goto out;
Index: linux-2.6.mod/net/socket.c
===================================================================
--- linux-2.6.mod.orig/net/socket.c	2007-06-06 12:38:27.000000000 -0700
+++ linux-2.6.mod/net/socket.c	2007-06-06 13:14:08.000000000 -0700
@@ -344,11 +344,11 @@
  *	but we take care of internal coherence yet.
  */
 
-static int sock_alloc_fd(struct file **filep)
+static int sock_alloc_fd(struct file **filep, int flags)
 {
 	int fd;
 
-	fd = get_unused_fd();
+	fd = allocate_fd(flags);
 	if (likely(fd >= 0)) {
 		struct file *file = get_empty_filp();
 
@@ -391,10 +391,10 @@
 	return 0;
 }
 
-int sock_map_fd(struct socket *sock)
+int sock_map_fd(struct socket *sock, int flags)
 {
 	struct file *newfile;
-	int fd = sock_alloc_fd(&newfile);
+	int fd = sock_alloc_fd(&newfile, flags);
 
 	if (likely(fd >= 0)) {
 		int err = sock_attach_fd(sock, newfile);
@@ -1198,7 +1198,7 @@
 	return __sock_create(family, type, protocol, res, 1);
 }
 
-asmlinkage long sys_socket(int family, int type, int protocol)
+asmlinkage long sys_socket2(int family, int type, int protocol, int flags)
 {
 	int retval;
 	struct socket *sock;
@@ -1207,7 +1207,7 @@
 	if (retval < 0)
 		goto out;
 
-	retval = sock_map_fd(sock);
+	retval = sock_map_fd(sock, flags);
 	if (retval < 0)
 		goto out_release;
 
@@ -1220,6 +1220,11 @@
 	return retval;
 }
 
+asmlinkage long sys_socket(int family, int type, int protocol)
+{
+	return sys_socket2(family, type, protocol, 0);
+}
+
 /*
  *	Create a pair of connected sockets.
  */
@@ -1248,11 +1253,11 @@
 	if (err < 0)
 		goto out_release_both;
 
-	fd1 = sock_alloc_fd(&newfile1);
+	fd1 = sock_alloc_fd(&newfile1, 0);
 	if (unlikely(fd1 < 0))
 		goto out_release_both;
 
-	fd2 = sock_alloc_fd(&newfile2);
+	fd2 = sock_alloc_fd(&newfile2, 0);
 	if (unlikely(fd2 < 0)) {
 		put_filp(newfile1);
 		put_unused_fd(fd1);
@@ -1407,7 +1412,8 @@
 	 */
 	__module_get(newsock->ops->owner);
 
-	newfd = sock_alloc_fd(&newfile);
+	newfd = sock_alloc_fd(&newfile,
+	      fd > current->signal->rlim[RLIMIT_NOFILE].rlim_cur ? O_NONSEQFD: 0);
 	if (unlikely(newfd < 0)) {
 		err = newfd;
 		sock_release(newsock);
@@ -1983,10 +1989,11 @@
 
 /* Argument list sizes for sys_socketcall */
 #define AL(x) ((x) * sizeof(unsigned long))
-static const unsigned char nargs[18]={
+static const unsigned char nargs[]={
 	AL(0),AL(3),AL(3),AL(3),AL(2),AL(3),
 	AL(3),AL(3),AL(4),AL(4),AL(4),AL(6),
-	AL(6),AL(2),AL(5),AL(5),AL(3),AL(3)
+	AL(6),AL(2),AL(5),AL(5),AL(3),AL(3),
+	AL(4)
 };
 
 #undef AL
@@ -2005,7 +2012,7 @@
 	unsigned long a0, a1;
 	int err;
 
-	if (call < 1 || call > SYS_RECVMSG)
+	if (call < 1 || call >= ARRAY_SIZE(nargs))
 		return -EINVAL;
 
 	/* copy_from_user should be SMP safe. */
@@ -2082,6 +2089,9 @@
 	case SYS_RECVMSG:
 		err = sys_recvmsg(a0, (struct msghdr __user *)a1, a[2]);
 		break;
+	case SYS_SOCKET2:
+		err = sys_socket2(a0, a1, a[2], a[3]);
+		break;
 	default:
 		err = -EINVAL;
 		break;

-
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Wed Jun 6, 6:30 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Arnd Bergmann, (Wed Jun 6, 8:29 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Wed Jun 6, 8:33 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Wed Jun 6, 6:59 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Thu Jun 7, 4:10 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Jeff Dike, (Fri Jun 8, 11:56 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Matt Mackall, (Thu Jun 7, 8:59 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Thu Jun 7, 10:25 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 6:22 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Thu Jun 7, 7:42 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 8:04 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 5:31 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Guillaume Chazarain, (Thu Jun 7, 4:59 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Guillaume Chazarain, (Thu Jun 7, 5:06 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Thu Jun 7, 4:47 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Thu Jun 7, 5:08 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 5:41 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Wed Jun 6, 7:04 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Wed Jun 6, 7:19 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Wed Jun 6, 7:29 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Thu Jun 7, 6:06 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 11:41 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Thu Jun 7, 6:45 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Thu Jun 7, 7:27 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Wed Jun 6, 7:22 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Thu Jun 7, 6:04 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 10:25 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Thu Jun 7, 1:56 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 2:26 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 2:39 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Andrew Morton, (Thu Jun 7, 4:03 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 10:55 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 1:16 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 2:56 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 3:12 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 2:03 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Thu Jun 7, 2:57 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Kyle Moffett, (Thu Jun 7, 7:59 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Thu Jun 7, 9:12 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 3:49 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Thu Jun 7, 4:05 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 5:57 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Fri Jun 8, 12:38 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 1:20 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 4:18 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 5:44 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 6:03 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 6:40 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Theodore Tso, (Fri Jun 8, 8:07 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Fri Jun 8, 2:35 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 2:07 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Fri Jun 8, 9:01 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 2:11 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Paul Mackerras, (Sat Jun 9, 1:41 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sat Jun 9, 1:00 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Paul Mackerras, (Sun Jun 10, 2:26 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sun Jun 10, 11:52 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, William Lee Irwin III, (Sun Jun 10, 3:10 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Kyle Moffett, (Sat Jun 9, 10:38 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Paul Mackerras, (Sun Jun 10, 2:48 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sun Jun 10, 3:16 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sun Jun 10, 11:56 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Fri Jun 8, 2:26 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 3:22 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Fri Jun 8, 2:43 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Fri Jun 8, 3:30 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Xavier Bestel, (Mon Jun 11, 4:24 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 3:37 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Fri Jun 8, 3:48 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 3:51 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Fri Jun 8, 5:24 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 5:59 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Fri Jun 8, 6:28 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 6:38 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Fri Jun 8, 2:56 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Fri Jun 8, 3:34 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Fri Jun 8, 3:07 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 3:21 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Fri Jun 8, 8:03 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Fri Jun 8, 9:19 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Fri Jun 8, 10:10 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Al Viro, (Sat Jun 9, 11:15 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Sat Jun 9, 12:26 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Al Viro, (Sat Jun 9, 12:54 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Sat Jun 9, 1:08 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Kyle Moffett, (Sat Jun 9, 3:27 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Al Viro, (Sat Jun 9, 10:40 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Sat Jun 9, 4:21 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Eric Dumazet, (Sun Jun 10, 5:14 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Sun Jun 10, 2:19 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Alan Cox, (Sun Jun 10, 11:16 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Al Viro, (Sat Jun 9, 11:19 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Sat Jun 9, 11:48 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, dean gaudet, (Sun Jun 10, 12:45 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Sun Jun 10, 1:06 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Al Viro, (Sun Jun 10, 1:46 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Sun Jun 10, 1:23 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Al Viro, (Sun Jun 10, 12:00 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Sun Jun 10, 12:03 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Al Viro, (Sun Jun 10, 12:06 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Linus Torvalds, (Sat Jun 9, 7:33 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sat Jun 9, 11:35 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sat Jun 9, 11:49 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Matt Mackall, (Sat Jun 9, 5:55 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sat Jun 9, 4:31 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Matt Mackall, (Sat Jun 9, 5:41 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sat Jun 9, 6:12 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sat Jun 9, 1:04 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Sat Jun 9, 1:08 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Fri Jun 8, 8:13 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Thu Jun 7, 4:02 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Thu Jun 7, 11:51 am)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, David Miller, (Wed Jun 6, 7:08 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Wed Jun 6, 6:58 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, David Miller, (Wed Jun 6, 6:44 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Ulrich Drepper, (Wed Jun 6, 6:57 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, David Miller, (Wed Jun 6, 7:02 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, Davide Libenzi, (Wed Jun 6, 6:52 pm)
Re: [patch 7/8] fdmap v2 - implement sys_socket2, David Miller, (Wed Jun 6, 6:57 pm)