Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit dc1561ac authored by Paolo 'Blaisorblade' Giarrusso's avatar Paolo 'Blaisorblade' Giarrusso Committed by Linus Torvalds
Browse files

[PATCH] uml: os_connect_socket error path fixup



Fix an fd leak and a return of -1 instead of -errno in the error path - this
showed up in intensive testing of HPPFS, the os_connect_socket user.

Signed-off-by: default avatarPaolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
Acked-by: default avatarJeff Dike <jdike@addtoit.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 635dd50b
Loading
Loading
Loading
Loading
+14 −5
Original line number Diff line number Diff line
@@ -272,14 +272,23 @@ int os_connect_socket(char *name)
	snprintf(sock.sun_path, sizeof(sock.sun_path), "%s", name);

	fd = socket(AF_UNIX, SOCK_STREAM, 0);
	if(fd < 0)
		return(fd);
	if(fd < 0) {
		err = -errno;
		goto out;
	}

	err = connect(fd, (struct sockaddr *) &sock, sizeof(sock));
	if(err)
		return(-errno);
	if(err) {
		err = -errno;
		goto out_close;
	}

	return(fd);
	return fd;

out_close:
	close(fd);
out:
	return err;
}

void os_close_file(int fd)