From: Yann Droneaud <ydrone...@opteya.com> Date: Mon, 2 Dec 2013 11:12:26 +0100
> socketpair() error paths can be simplified to not call > heavy-weight sys_close(). > > This patch makes socketpair() use of error paths which do not > rely on heavy-weight call to sys_lose(): it's better to try > to push the file descriptor to userspace before installing > the socket file to the file descriptor, so that errors are > catched earlier and being easier to handle. > > Three distinct error paths are needed since calling fput() > on file structure returned by sock_alloc_file() will > implicitly call sock_release() on the associated socket > structure. > > Cc: David S. Miller <da...@davemloft.net> > Cc: Al Viro <v...@zeniv.linux.org.uk> > Signed-off-by: Yann Droneaud <ydrone...@opteya.com> > Link: > http://marc.info/?i=1385977019-12282-1-git-send-email-ydrone...@opteya.com I know that sys_close() is expensive, _but_ erroring out on the put_user() is extremely rare and logically it makes a ton more sense to fully install a file descriptor before writing it's numeric value into userspace. Sorry, I think the current code is fine and I'm not going to apply this, thanks. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/