- djm@cvs.openbsd.org 2008/01/21 17:24:30

[sftp-server.c]
     Remove the fixed 100 handle limit in sftp-server and allocate as many
     as we have available file descriptors. Patch from miklos AT szeredi.hu;
     ok dtucker@ markus@
This commit is contained in:
Damien Miller 2008-02-10 22:26:51 +11:00
parent aec5cf8a30
commit 3397d0e0c5
2 changed files with 37 additions and 27 deletions

View File

@ -49,6 +49,11 @@
When uploading, correctly handle the case of an unquoted filename with When uploading, correctly handle the case of an unquoted filename with
glob metacharacters that match a file exactly but not as a glob, e.g. a glob metacharacters that match a file exactly but not as a glob, e.g. a
file called "[abcd]". report and test cases from duncan2nd AT gmx.de file called "[abcd]". report and test cases from duncan2nd AT gmx.de
- djm@cvs.openbsd.org 2008/01/21 17:24:30
[sftp-server.c]
Remove the fixed 100 handle limit in sftp-server and allocate as many
as we have available file descriptors. Patch from miklos AT szeredi.hu;
ok dtucker@ markus@
20080119 20080119
- (djm) Silence noice from expr in ssh-copy-id; patch from - (djm) Silence noice from expr in ssh-copy-id; patch from
@ -3577,4 +3582,4 @@
OpenServer 6 and add osr5bigcrypt support so when someone migrates OpenServer 6 and add osr5bigcrypt support so when someone migrates
passwords between UnixWare and OpenServer they will still work. OK dtucker@ passwords between UnixWare and OpenServer they will still work. OK dtucker@
$Id: ChangeLog,v 1.4829 2008/02/10 11:26:24 djm Exp $ $Id: ChangeLog,v 1.4830 2008/02/10 11:26:51 djm Exp $

View File

@ -1,4 +1,4 @@
/* $OpenBSD: sftp-server.c,v 1.74 2007/09/13 04:39:04 djm Exp $ */ /* $OpenBSD: sftp-server.c,v 1.75 2008/01/21 17:24:30 djm Exp $ */
/* /*
* Copyright (c) 2000-2004 Markus Friedl. All rights reserved. * Copyright (c) 2000-2004 Markus Friedl. All rights reserved.
* *
@ -169,6 +169,7 @@ struct Handle {
int fd; int fd;
char *name; char *name;
u_int64_t bytes_read, bytes_write; u_int64_t bytes_read, bytes_write;
int next_unused;
}; };
enum { enum {
@ -177,40 +178,46 @@ enum {
HANDLE_FILE HANDLE_FILE
}; };
Handle handles[100]; Handle *handles = NULL;
u_int num_handles = 0;
int first_unused_handle = -1;
static void static void handle_unused(int i)
handle_init(void)
{ {
u_int i;
for (i = 0; i < sizeof(handles)/sizeof(Handle); i++)
handles[i].use = HANDLE_UNUSED; handles[i].use = HANDLE_UNUSED;
handles[i].next_unused = first_unused_handle;
first_unused_handle = i;
} }
static int static int
handle_new(int use, const char *name, int fd, DIR *dirp) handle_new(int use, const char *name, int fd, DIR *dirp)
{ {
u_int i; int i;
if (first_unused_handle == -1) {
if (num_handles + 1 <= num_handles)
return -1;
num_handles++;
handles = xrealloc(handles, num_handles, sizeof(Handle));
handle_unused(num_handles - 1);
}
i = first_unused_handle;
first_unused_handle = handles[i].next_unused;
for (i = 0; i < sizeof(handles)/sizeof(Handle); i++) {
if (handles[i].use == HANDLE_UNUSED) {
handles[i].use = use; handles[i].use = use;
handles[i].dirp = dirp; handles[i].dirp = dirp;
handles[i].fd = fd; handles[i].fd = fd;
handles[i].name = xstrdup(name); handles[i].name = xstrdup(name);
handles[i].bytes_read = handles[i].bytes_write = 0; handles[i].bytes_read = handles[i].bytes_write = 0;
return i; return i;
}
}
return -1;
} }
static int static int
handle_is_ok(int i, int type) handle_is_ok(int i, int type)
{ {
return i >= 0 && (u_int)i < sizeof(handles)/sizeof(Handle) && return i >= 0 && (u_int)i < num_handles && handles[i].use == type;
handles[i].use == type;
} }
static int static int
@ -300,12 +307,12 @@ handle_close(int handle)
if (handle_is_ok(handle, HANDLE_FILE)) { if (handle_is_ok(handle, HANDLE_FILE)) {
ret = close(handles[handle].fd); ret = close(handles[handle].fd);
handles[handle].use = HANDLE_UNUSED;
xfree(handles[handle].name); xfree(handles[handle].name);
handle_unused(handle);
} else if (handle_is_ok(handle, HANDLE_DIR)) { } else if (handle_is_ok(handle, HANDLE_DIR)) {
ret = closedir(handles[handle].dirp); ret = closedir(handles[handle].dirp);
handles[handle].use = HANDLE_UNUSED;
xfree(handles[handle].name); xfree(handles[handle].name);
handle_unused(handle);
} else { } else {
errno = ENOENT; errno = ENOENT;
} }
@ -333,7 +340,7 @@ handle_log_exit(void)
{ {
u_int i; u_int i;
for (i = 0; i < sizeof(handles)/sizeof(Handle); i++) for (i = 0; i < num_handles; i++)
if (handles[i].use != HANDLE_UNUSED) if (handles[i].use != HANDLE_UNUSED)
handle_log_close(i, "forced"); handle_log_close(i, "forced");
} }
@ -1271,8 +1278,6 @@ main(int argc, char **argv)
logit("session opened for local user %s from [%s]", logit("session opened for local user %s from [%s]",
pw->pw_name, client_addr); pw->pw_name, client_addr);
handle_init();
in = dup(STDIN_FILENO); in = dup(STDIN_FILENO);
out = dup(STDOUT_FILENO); out = dup(STDOUT_FILENO);