summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPankaj Gupta2014-03-12 17:54:27 +0100
committerStefan Hajnoczi2014-04-25 13:40:03 +0200
commit13a12f869bf2211c7039f9a601ac9e1076535663 (patch)
tree89601331da8c02629e46283952a43c7e6cde2bf6
parentMerge remote-tracking branch 'remotes/kraxel/tags/pull-usb-5' into staging (diff)
downloadqemu-13a12f869bf2211c7039f9a601ac9e1076535663.tar.gz
qemu-13a12f869bf2211c7039f9a601ac9e1076535663.tar.xz
qemu-13a12f869bf2211c7039f9a601ac9e1076535663.zip
tap: Avoid extra iterations while closing file fd
Avoid iterations for fd 0, 1 & 2 when we are closing file fds in child process. Signed-off-by: Pankaj Gupta <pagupta@redhat.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
-rw-r--r--net/tap.c14
1 files changed, 4 insertions, 10 deletions
diff --git a/net/tap.c b/net/tap.c
index 8847ce100a..fc1b865e08 100644
--- a/net/tap.c
+++ b/net/tap.c
@@ -367,11 +367,8 @@ static int launch_script(const char *setup_script, const char *ifname, int fd)
if (pid == 0) {
int open_max = sysconf(_SC_OPEN_MAX), i;
- for (i = 0; i < open_max; i++) {
- if (i != STDIN_FILENO &&
- i != STDOUT_FILENO &&
- i != STDERR_FILENO &&
- i != fd) {
+ for (i = 3; i < open_max; i++) {
+ if (i != fd) {
close(i);
}
}
@@ -452,11 +449,8 @@ static int net_bridge_run_helper(const char *helper, const char *bridge)
char br_buf[6+IFNAMSIZ] = {0};
char helper_cmd[PATH_MAX + sizeof(fd_buf) + sizeof(br_buf) + 15];
- for (i = 0; i < open_max; i++) {
- if (i != STDIN_FILENO &&
- i != STDOUT_FILENO &&
- i != STDERR_FILENO &&
- i != sv[1]) {
+ for (i = 3; i < open_max; i++) {
+ if (i != sv[1]) {
close(i);
}
}