2000-09-03 12:16:35 +08:00
|
|
|
/* cygheap.h: Cygwin heap manager.
|
|
|
|
|
* child_info.h, cygheap.h, fhandler_clipboard.cc, fhandler_dsp.cc,
fhandler_floppy.cc, fhandler_mem.cc, fhandler_random.cc,
fhandler_tape.cc, fhandler_zero.cc, grp.cc, mmap.cc, passwd.cc,
pinfo.cc, pinfo.h, pipe.cc, sec_acl.cc, sec_helper.cc, security.cc,
security.h, thread.h, uinfo.cc, include/cygwin/acl.h: Fix copyright.
2002-02-10 21:50:13 +08:00
|
|
|
Copyright 2000, 2001, 2002 Red Hat, Inc.
|
2000-09-03 12:16:35 +08:00
|
|
|
|
|
|
|
This file is part of Cygwin.
|
|
|
|
|
|
|
|
This software is a copyrighted work licensed under the terms of the
|
|
|
|
Cygwin license. Please consult the file "CYGWIN_LICENSE" for
|
|
|
|
details. */
|
|
|
|
|
|
|
|
#undef cfree
|
|
|
|
|
|
|
|
enum cygheap_types
|
|
|
|
{
|
|
|
|
HEAP_FHANDLER,
|
|
|
|
HEAP_STR,
|
|
|
|
HEAP_ARGV,
|
2000-09-27 13:12:09 +08:00
|
|
|
HEAP_BUF,
|
2001-06-03 10:31:16 +08:00
|
|
|
HEAP_MOUNT,
|
2000-09-27 13:12:09 +08:00
|
|
|
HEAP_1_START,
|
|
|
|
HEAP_1_STR,
|
|
|
|
HEAP_1_ARGV,
|
|
|
|
HEAP_1_BUF,
|
2000-09-30 12:54:11 +08:00
|
|
|
HEAP_1_EXEC,
|
|
|
|
HEAP_1_MAX = 100
|
2000-09-03 12:16:35 +08:00
|
|
|
};
|
|
|
|
|
2000-10-02 10:26:04 +08:00
|
|
|
#define incygheap(s) (cygheap && ((char *) (s) >= (char *) cygheap) && ((char *) (s) <= ((char *) cygheap_max)))
|
2000-09-03 12:16:35 +08:00
|
|
|
|
2000-11-14 13:53:32 +08:00
|
|
|
struct _cmalloc_entry
|
|
|
|
{
|
|
|
|
union
|
|
|
|
{
|
|
|
|
DWORD b;
|
|
|
|
char *ptr;
|
|
|
|
};
|
|
|
|
struct _cmalloc_entry *prev;
|
|
|
|
char data[0];
|
|
|
|
};
|
|
|
|
|
2001-06-03 10:31:16 +08:00
|
|
|
struct cygheap_root_mount_info
|
|
|
|
{
|
|
|
|
char posix_path[MAX_PATH];
|
|
|
|
unsigned posix_pathlen;
|
|
|
|
char native_path[MAX_PATH];
|
|
|
|
unsigned native_pathlen;
|
|
|
|
};
|
|
|
|
|
2001-06-04 09:28:09 +08:00
|
|
|
/* CGF: FIXME This doesn't belong here */
|
|
|
|
|
2000-11-15 08:13:09 +08:00
|
|
|
class cygheap_root
|
|
|
|
{
|
|
|
|
/* Root directory information.
|
|
|
|
This is used after a chroot is called. */
|
2001-06-03 10:31:16 +08:00
|
|
|
struct cygheap_root_mount_info *m;
|
|
|
|
|
2000-11-15 08:13:09 +08:00
|
|
|
public:
|
2001-06-03 10:31:16 +08:00
|
|
|
bool posix_ok (const char *path)
|
|
|
|
{
|
|
|
|
if (!m)
|
|
|
|
return 1;
|
|
|
|
return path_prefix_p (m->posix_path, path, m->posix_pathlen);
|
|
|
|
}
|
|
|
|
bool ischroot_native (const char *path)
|
|
|
|
{
|
|
|
|
if (!m)
|
|
|
|
return 1;
|
|
|
|
return strncasematch (m->native_path, path, m->native_pathlen)
|
2001-09-08 05:32:07 +08:00
|
|
|
&& (path[m->native_pathlen] == '\\' || !path[m->native_pathlen]);
|
2001-06-03 10:31:16 +08:00
|
|
|
}
|
|
|
|
const char *unchroot (const char *path)
|
|
|
|
{
|
|
|
|
if (!m)
|
|
|
|
return path;
|
|
|
|
const char *p = path + m->posix_pathlen;
|
|
|
|
if (!*p)
|
|
|
|
p = "/";
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
bool exists () {return !!m;}
|
|
|
|
void set (const char *posix, const char *native);
|
|
|
|
size_t posix_length () const { return m->posix_pathlen; }
|
|
|
|
const char *posix_path () const { return m->posix_path; }
|
|
|
|
size_t native_length () const { return m->native_pathlen; }
|
|
|
|
const char *native_path () const { return m->native_path; }
|
2000-11-15 08:13:09 +08:00
|
|
|
};
|
|
|
|
|
2001-01-17 22:57:09 +08:00
|
|
|
class cygheap_user
|
|
|
|
{
|
2000-11-15 08:13:09 +08:00
|
|
|
/* Extendend user information.
|
|
|
|
The information is derived from the internal_getlogin call
|
|
|
|
when on a NT system. */
|
2000-11-16 05:04:02 +08:00
|
|
|
char *pname; /* user's name */
|
|
|
|
char *plogsrv; /* Logon server, may be FQDN */
|
|
|
|
char *pdomain; /* Logon domain of the user */
|
|
|
|
PSID psid; /* buffer for user's SID */
|
2002-05-08 22:21:08 +08:00
|
|
|
PSID orig_psid; /* Remains intact even after impersonation */
|
2000-11-15 08:13:09 +08:00
|
|
|
public:
|
* (child_info.h, cygheap.h, dcrt0.cc, dir.cc, fhandler.cc, fhandler.h,
fhandler_clipboard.cc, fhandler_disk_file.cc, fhandler_dsp.cc,
fhandler_floppy.cc, fhandler_mem.cc, fhandler_random.cc,
fhandler_tape.cc, fhandler_zero.cc, grp.cc, mmap.cc, passwd.cc,
pinfo.cc, pinfo.h, pipe.cc, sec_acl.cc, sec_helper.cc, security.cc,
security.h, spawn.cc, syscalls.cc, thread.h, uinfo.cc, winsup.h):
Change usage of uid_t to __uid16_t, gid_t to __gid16_t and
off_t to __off32_t throughout. Use INVALID_UID, INVALID_GID and
INVALID_SEEK instead casting -1 to the appropriate type.
* winsup.h: Define INVALID_UID, INVALID_GID and INVALID_SEEK.
* include/cygwin/acl.h: Define internal __aclent16_t and __aclent32_t
types. Don't declare acl functions when compiling Cygwin.
* include/cygwin/grp.h: Declare getgrgid() and getgrnam() with
correct types for internal usage.
2002-02-10 21:38:51 +08:00
|
|
|
__uid16_t orig_uid; /* Remains intact even after impersonation */
|
|
|
|
__uid16_t orig_gid; /* Ditto */
|
|
|
|
__uid16_t real_uid; /* Remains intact on seteuid, replaced by setuid */
|
|
|
|
__gid16_t real_gid; /* Ditto */
|
2000-11-15 08:13:09 +08:00
|
|
|
|
2000-11-16 05:04:02 +08:00
|
|
|
/* token is needed if set(e)uid should be called. It can be set by a call
|
|
|
|
to `set_impersonation_token()'. */
|
|
|
|
HANDLE token;
|
|
|
|
BOOL impersonated;
|
|
|
|
|
2001-06-04 22:29:54 +08:00
|
|
|
cygheap_user () : pname (NULL), plogsrv (NULL), pdomain (NULL),
|
|
|
|
psid (NULL), token (INVALID_HANDLE_VALUE) {}
|
2000-11-15 08:13:09 +08:00
|
|
|
~cygheap_user ();
|
|
|
|
|
|
|
|
void set_name (const char *new_name);
|
|
|
|
const char *name () const { return pname; }
|
|
|
|
|
|
|
|
void set_logsrv (const char *new_logsrv);
|
|
|
|
const char *logsrv () const { return plogsrv; }
|
|
|
|
|
|
|
|
void set_domain (const char *new_domain);
|
|
|
|
const char *domain () const { return pdomain; }
|
|
|
|
|
|
|
|
BOOL set_sid (PSID new_sid);
|
|
|
|
PSID sid () const { return psid; }
|
2002-05-08 22:21:08 +08:00
|
|
|
PSID orig_sid () const { return orig_psid; }
|
2000-11-15 08:13:09 +08:00
|
|
|
|
|
|
|
void operator =(cygheap_user &user)
|
2001-01-17 22:57:09 +08:00
|
|
|
{
|
|
|
|
set_name (user.name ());
|
|
|
|
set_logsrv (user.logsrv ());
|
|
|
|
set_domain (user.domain ());
|
|
|
|
set_sid (user.sid ());
|
|
|
|
}
|
2000-11-15 08:13:09 +08:00
|
|
|
};
|
2000-11-14 13:53:32 +08:00
|
|
|
|
2001-04-17 11:52:08 +08:00
|
|
|
/* cwd cache stuff. */
|
|
|
|
|
|
|
|
class muto;
|
|
|
|
|
|
|
|
struct cwdstuff
|
|
|
|
{
|
|
|
|
char *posix;
|
|
|
|
char *win32;
|
|
|
|
DWORD hash;
|
2002-02-23 03:33:41 +08:00
|
|
|
muto *cwd_lock;
|
2001-04-17 11:52:08 +08:00
|
|
|
char *get (char *buf, int need_posix = 1, int with_chroot = 0, unsigned ulen = MAX_PATH);
|
|
|
|
DWORD get_hash ();
|
|
|
|
void init ();
|
|
|
|
void fixup_after_exec (char *win32, char *posix, DWORD hash);
|
|
|
|
bool get_initial ();
|
|
|
|
void set (const char *win32_cwd, const char *posix_cwd = NULL);
|
|
|
|
};
|
|
|
|
|
2000-11-14 13:53:32 +08:00
|
|
|
struct init_cygheap
|
|
|
|
{
|
|
|
|
_cmalloc_entry *chain;
|
2001-09-06 11:39:18 +08:00
|
|
|
char *buckets[32];
|
2001-09-10 03:06:50 +08:00
|
|
|
struct /* User heap stuff. */
|
|
|
|
{
|
|
|
|
void *heapbase;
|
|
|
|
void *heapptr;
|
|
|
|
void *heaptop;
|
|
|
|
};
|
2000-11-15 08:13:09 +08:00
|
|
|
cygheap_root root;
|
|
|
|
cygheap_user user;
|
2000-11-14 13:53:32 +08:00
|
|
|
mode_t umask;
|
2001-01-28 13:51:15 +08:00
|
|
|
HANDLE shared_h;
|
|
|
|
HANDLE console_h;
|
2001-09-10 00:52:37 +08:00
|
|
|
HANDLE etc_changed_h;
|
2001-10-25 05:56:54 +08:00
|
|
|
char *cygwin_regname;
|
2001-04-17 11:52:08 +08:00
|
|
|
cwdstuff cwd;
|
2001-04-19 05:10:15 +08:00
|
|
|
dtable fdtab;
|
2001-09-10 00:52:37 +08:00
|
|
|
|
|
|
|
bool etc_changed ();
|
2000-11-14 13:53:32 +08:00
|
|
|
};
|
|
|
|
|
2001-04-19 05:10:15 +08:00
|
|
|
#define CYGHEAPSIZE (sizeof (init_cygheap) + (4000 * sizeof (fhandler_union)) + (2 * 65536))
|
|
|
|
|
2000-11-14 13:53:32 +08:00
|
|
|
extern init_cygheap *cygheap;
|
|
|
|
extern void *cygheap_max;
|
|
|
|
|
2001-10-16 07:39:33 +08:00
|
|
|
class cygheap_fdmanip
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
int fd;
|
|
|
|
fhandler_base **fh;
|
|
|
|
bool locked;
|
|
|
|
public:
|
2001-10-31 08:55:32 +08:00
|
|
|
cygheap_fdmanip (): fh (NULL) {}
|
2001-10-16 07:39:33 +08:00
|
|
|
virtual ~cygheap_fdmanip ()
|
|
|
|
{
|
|
|
|
if (locked)
|
|
|
|
ReleaseResourceLock (LOCK_FD_LIST, WRITE_LOCK | READ_LOCK, "cygheap_fdmanip");
|
|
|
|
}
|
|
|
|
void release ()
|
|
|
|
{
|
|
|
|
cygheap->fdtab.release (fd);
|
|
|
|
}
|
|
|
|
operator int &() {return fd;}
|
|
|
|
operator fhandler_base* &() {return *fh;}
|
|
|
|
void operator = (fhandler_base *fh) {*this->fh = fh;}
|
|
|
|
fhandler_base *operator -> () const {return *fh;}
|
2001-11-02 07:48:34 +08:00
|
|
|
bool isopen () const
|
|
|
|
{
|
|
|
|
if (*fh)
|
|
|
|
return true;
|
|
|
|
set_errno (EBADF);
|
|
|
|
return false;
|
|
|
|
}
|
2001-10-16 07:39:33 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class cygheap_fdnew : public cygheap_fdmanip
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
cygheap_fdnew (int seed_fd = -1, bool lockit = true)
|
|
|
|
{
|
|
|
|
if (lockit)
|
|
|
|
SetResourceLock (LOCK_FD_LIST, WRITE_LOCK | READ_LOCK, "cygheap_fdnew");
|
|
|
|
if (seed_fd < 0)
|
|
|
|
fd = cygheap->fdtab.find_unused_handle ();
|
|
|
|
else
|
|
|
|
fd = cygheap->fdtab.find_unused_handle (seed_fd + 1);
|
|
|
|
if (fd >= 0)
|
|
|
|
{
|
|
|
|
locked = lockit;
|
|
|
|
fh = cygheap->fdtab + fd;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
set_errno (EMFILE);
|
|
|
|
if (lockit)
|
|
|
|
ReleaseResourceLock (LOCK_FD_LIST, WRITE_LOCK | READ_LOCK, "cygheap_fdnew");
|
|
|
|
locked = false;
|
|
|
|
}
|
|
|
|
}
|
2001-11-21 14:47:57 +08:00
|
|
|
void operator = (fhandler_base *fh) {*this->fh = fh;}
|
2001-10-16 07:39:33 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class cygheap_fdget : public cygheap_fdmanip
|
|
|
|
{
|
|
|
|
public:
|
2001-10-16 11:31:50 +08:00
|
|
|
cygheap_fdget (int fd, bool lockit = false, bool do_set_errno = true)
|
2001-10-16 07:39:33 +08:00
|
|
|
{
|
|
|
|
if (lockit)
|
|
|
|
SetResourceLock (LOCK_FD_LIST, READ_LOCK, "cygheap_fdget");
|
|
|
|
if (fd >= 0 && fd < (int) cygheap->fdtab.size
|
|
|
|
&& *(fh = cygheap->fdtab + fd) != NULL)
|
|
|
|
{
|
|
|
|
this->fd = fd;
|
|
|
|
locked = lockit;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this->fd = -1;
|
2001-10-16 11:31:50 +08:00
|
|
|
if (do_set_errno)
|
2001-10-16 22:43:36 +08:00
|
|
|
set_errno (EBADF);
|
2001-10-16 07:39:33 +08:00
|
|
|
if (lockit)
|
|
|
|
ReleaseResourceLock (LOCK_FD_LIST, READ_LOCK, "cygheap_fdget");
|
|
|
|
locked = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2001-07-17 11:41:52 +08:00
|
|
|
class child_info;
|
2001-09-14 08:49:00 +08:00
|
|
|
void *__stdcall cygheap_setup_for_child (child_info *ci, bool dup_later) __attribute__ ((regparm(2)));
|
|
|
|
void __stdcall cygheap_setup_for_child_cleanup (void *, child_info *, bool) __attribute__ ((regparm(3)));
|
2001-07-17 11:41:52 +08:00
|
|
|
void __stdcall cygheap_fixup_in_child (child_info *, bool);
|
2000-09-03 12:16:35 +08:00
|
|
|
extern "C" {
|
2000-10-17 07:55:58 +08:00
|
|
|
void __stdcall cfree (void *) __attribute__ ((regparm(1)));
|
|
|
|
void *__stdcall cmalloc (cygheap_types, DWORD) __attribute__ ((regparm(2)));
|
|
|
|
void *__stdcall crealloc (void *, DWORD) __attribute__ ((regparm(2)));
|
|
|
|
void *__stdcall ccalloc (cygheap_types, DWORD, DWORD) __attribute__ ((regparm(3)));
|
|
|
|
char *__stdcall cstrdup (const char *) __attribute__ ((regparm(1)));
|
|
|
|
char *__stdcall cstrdup1 (const char *) __attribute__ ((regparm(1)));
|
2000-10-02 10:26:04 +08:00
|
|
|
void __stdcall cygheap_init ();
|
2000-09-03 12:16:35 +08:00
|
|
|
}
|