- 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:
parent
aec5cf8a30
commit
3397d0e0c5
|
@ -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 $
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue