file descriptor allocation order is identical to the kernels.
struct bitmap *bitmap_allocate(int n);
BOOL bitmap_set(struct bitmap *bm, unsigned i);
BOOL bitmap_clear(struct bitmap *bm, unsigned i);
+BOOL bitmap_query(struct bitmap *bm, unsigned i);
int bitmap_find(struct bitmap *bm, unsigned ofs);
/*The following definitions come from lib/charcnv.c */
/****************************************************************************
query a bit in a bitmap
****************************************************************************/
-static BOOL bitmap_query(struct bitmap *bm, unsigned i)
+BOOL bitmap_query(struct bitmap *bm, unsigned i)
{
if (i >= bm->n) return False;
if (bm->b[i/32] & (1<<(i%32))) {
int smbw_fd(int fd)
{
if (smbw_busy) return 0;
- return (fd >= SMBW_FD_OFFSET);
+ return smbw_file_bmap && bitmap_query(smbw_file_bmap, fd);
}
/*****************************************************
goto failed;
}
file->srv = srv;
- file->fd = bitmap_find(smbw_file_bmap, 0);
-
+ file->fd = open("/dev/null", O_WRONLY);
if (file->fd == -1) {
errno = EMFILE;
goto failed;
}
- bitmap_set(smbw_file_bmap, file->fd);
+ if (bitmap_query(smbw_file_bmap, file->fd)) {
+ DEBUG(0,("ERROR: fd used in smbw_open\n"));
+ errno = EIO;
+ goto failed;
+ }
- file->fd += SMBW_FD_OFFSET;
+ bitmap_set(smbw_file_bmap, file->fd);
DLIST_ADD(smbw_files, file);
}
- bitmap_clear(smbw_file_bmap, file->fd - SMBW_FD_OFFSET);
+ bitmap_clear(smbw_file_bmap, file->fd);
+ close(file->fd);
DLIST_REMOVE(smbw_files, file);
#define SMBW_PREFIX "/smb/"
-#define SMBW_FD_OFFSET 700
#define SMBW_CLI_FD 512
-#define SMBW_MAX_OPEN 2048
+#define SMBW_MAX_OPEN 8192
#define SMBW_FILE_MODE (S_IFREG | 0644)
#define SMBW_DIR_MODE (S_IFDIR | 0755)
cur_dir = NULL;
- fd = bitmap_find(smbw_file_bmap, 0);
+ fd = open("/dev/null", O_WRONLY);
if (fd == -1) {
errno = EMFILE;
goto failed;
}
+ if (bitmap_query(smbw_file_bmap, fd)) {
+ DEBUG(0,("ERROR: fd used in smbw_dir_open\n"));
+ errno = EIO;
+ goto failed;
+ }
+
DLIST_ADD(smbw_dirs, dir);
bitmap_set(smbw_file_bmap, fd);
- dir->fd = fd + SMBW_FD_OFFSET;
+ dir->fd = fd;
dir->srv = srv;
dir->path = strdup(s);
return -1;
}
- bitmap_clear(smbw_file_bmap, dir->fd - SMBW_FD_OFFSET);
+ bitmap_clear(smbw_file_bmap, dir->fd);
+ close(dir->fd);
DLIST_REMOVE(smbw_dirs, dir);