mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-18 12:29:32 +08:00
* exceptions.cc (ctrl_c_handler): Send SIGHUP when events occur only if there
is a tty associated with the process. Send SIGHUP on CTRL_LOGOFF_EVENT. * fhandler_tty.cc (fhandler_tty_slave::open): Adjust console open handle counter regardless of whether this is a pty or tty. (fhandler_tty_slave::open): Ditto. (fhandler_tty_slave::dup): Ditto. (fhandler_tty_common::set_close_on_exec): Ditto. (fhandler_tty_master::init_console): Decrement console open handle counter after init since it will now be handled by all tty open. * syscalls.cc (setsid): Rework debugging output slightly.
This commit is contained in:
parent
ddb6762155
commit
df04ae29b2
@ -1,3 +1,18 @@
|
||||
2003-07-26 Christopher Faylor <cgf@redhat.com>
|
||||
|
||||
* exceptions.cc (ctrl_c_handler): Send SIGHUP when events occur only if
|
||||
there is a tty associated with the process. Send SIGHUP on
|
||||
CTRL_LOGOFF_EVENT.
|
||||
|
||||
* fhandler_tty.cc (fhandler_tty_slave::open): Adjust console open
|
||||
handle counter regardless of whether this is a pty or tty.
|
||||
(fhandler_tty_slave::open): Ditto.
|
||||
(fhandler_tty_slave::dup): Ditto.
|
||||
(fhandler_tty_common::set_close_on_exec): Ditto.
|
||||
(fhandler_tty_master::init_console): Decrement console open handle
|
||||
counter after init since it will now be handled by all tty open.
|
||||
* syscalls.cc (setsid): Rework debugging output slightly.
|
||||
|
||||
2003-07-25 Christopher Faylor <cgf@redhat.com>
|
||||
|
||||
* configure.in: Use 'install-sh -c'.
|
||||
@ -42,7 +57,7 @@
|
||||
|
||||
* security.cc (verify_token): Fix white space and style.
|
||||
Use type bool instead of BOOL and char. Use alloca
|
||||
instead of malloc and free for my_grps.
|
||||
instead of malloc and free for my_grps.
|
||||
|
||||
2003-07-17 Corinna Vinschen <corinna@vinschen.de>
|
||||
|
||||
|
@ -923,25 +923,29 @@ setup_handler (int sig, void *handler, struct sigaction& siga)
|
||||
static BOOL WINAPI
|
||||
ctrl_c_handler (DWORD type)
|
||||
{
|
||||
if (type == CTRL_LOGOFF_EVENT)
|
||||
return TRUE;
|
||||
static bool saw_close;
|
||||
|
||||
/* Return FALSE to prevent an "End task" dialog box from appearing
|
||||
for each Cygwin process window that's open when the computer
|
||||
is shut down or console window is closed. */
|
||||
|
||||
if (type == CTRL_SHUTDOWN_EVENT)
|
||||
{
|
||||
#if 0
|
||||
/* Don't send a signal. Only NT service applications and their child
|
||||
processes will receive this event and the services typically already
|
||||
processes will receive this event and the services typically already
|
||||
handle the shutdown action when getting the SERVICE_CONTROL_SHUTDOWN
|
||||
control message. */
|
||||
sig_send (NULL, SIGTERM);
|
||||
#endif
|
||||
return FALSE;
|
||||
}
|
||||
if (type == CTRL_CLOSE_EVENT)
|
||||
|
||||
if (myself->ctty != -1
|
||||
&& (type == CTRL_CLOSE_EVENT || (!saw_close && type == CTRL_LOGOFF_EVENT)))
|
||||
{
|
||||
if (type == CTRL_CLOSE_EVENT)
|
||||
saw_close = true;
|
||||
sig_send (NULL, SIGHUP);
|
||||
return FALSE;
|
||||
}
|
||||
|
@ -122,7 +122,7 @@ fhandler_disk_file::fstat_by_name (struct __stat64 *buf, path_conv *pc)
|
||||
FILETIME ft = {};
|
||||
res = fstat_helper (buf, pc, ft, ft, ft, 0, 0);
|
||||
}
|
||||
else
|
||||
else
|
||||
{
|
||||
debug_printf ("FindFirstFile failed for '%s', %E", (char *) *pc);
|
||||
__seterrno ();
|
||||
@ -226,7 +226,7 @@ fhandler_disk_file::fstat_helper (struct __stat64 *buf, path_conv *pc,
|
||||
/* Although the documentation indicates otherwise, it seems like
|
||||
"inodes" on these devices are persistent, at least across reboots. */
|
||||
buf->st_ino = (((__ino64_t) nFileIndexHigh) << 32)
|
||||
| (__ino64_t) nFileIndexLow;
|
||||
| (__ino64_t) nFileIndexLow;
|
||||
break;
|
||||
default:
|
||||
/* Either the nFileIndex* fields are unreliable or unavailable. Use the
|
||||
|
@ -639,30 +639,30 @@ format_proc_cpuinfo (char *destbuf, size_t maxsize)
|
||||
bufptr += __small_sprintf (bufptr, "vendor_id : %s\n", szBuffer);
|
||||
read_value ("Identifier", REG_SZ);
|
||||
bufptr += __small_sprintf (bufptr, "identifier : %s\n", szBuffer);
|
||||
if (wincap.is_winnt ())
|
||||
{
|
||||
if (wincap.is_winnt ())
|
||||
{
|
||||
read_value ("~Mhz", REG_DWORD);
|
||||
bufptr += __small_sprintf (bufptr, "cpu MHz : %u\n", *(DWORD *) szBuffer);
|
||||
|
||||
print ("flags :");
|
||||
if (IsProcessorFeaturePresent (PF_3DNOW_INSTRUCTIONS_AVAILABLE))
|
||||
print (" 3dnow");
|
||||
print (" 3dnow");
|
||||
if (IsProcessorFeaturePresent (PF_COMPARE_EXCHANGE_DOUBLE))
|
||||
print (" cx8");
|
||||
print (" cx8");
|
||||
if (!IsProcessorFeaturePresent (PF_FLOATING_POINT_EMULATED))
|
||||
print (" fpu");
|
||||
print (" fpu");
|
||||
if (IsProcessorFeaturePresent (PF_MMX_INSTRUCTIONS_AVAILABLE))
|
||||
print (" mmx");
|
||||
print (" mmx");
|
||||
if (IsProcessorFeaturePresent (PF_PAE_ENABLED))
|
||||
print (" pae");
|
||||
print (" pae");
|
||||
if (IsProcessorFeaturePresent (PF_RDTSC_INSTRUCTION_AVAILABLE))
|
||||
print (" tsc");
|
||||
print (" tsc");
|
||||
if (IsProcessorFeaturePresent (PF_XMMI_INSTRUCTIONS_AVAILABLE))
|
||||
print (" sse");
|
||||
print (" sse");
|
||||
if (IsProcessorFeaturePresent (PF_XMMI64_INSTRUCTIONS_AVAILABLE))
|
||||
print (" sse2");
|
||||
print (" sse2");
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
bufptr += __small_sprintf (bufptr, "processor : %d\n", cpu_number);
|
||||
@ -671,12 +671,12 @@ format_proc_cpuinfo (char *destbuf, size_t maxsize)
|
||||
maxf &= 0xffff;
|
||||
vendor_id[3] = 0;
|
||||
bufptr += __small_sprintf (bufptr, "vendor_id : %s\n", (char *)vendor_id);
|
||||
unsigned cpu_mhz = 0;
|
||||
if (wincap.is_winnt ())
|
||||
{
|
||||
unsigned cpu_mhz = 0;
|
||||
if (wincap.is_winnt ())
|
||||
{
|
||||
read_value ("~Mhz", REG_DWORD);
|
||||
cpu_mhz = *(DWORD *)szBuffer;
|
||||
}
|
||||
}
|
||||
if (maxf >= 1)
|
||||
{
|
||||
unsigned features2, features1, extra_info, cpuid_sig;
|
||||
@ -722,10 +722,10 @@ format_proc_cpuinfo (char *destbuf, size_t maxsize)
|
||||
// could implement a lookup table here if someone needs it
|
||||
strcpy (szBuffer, "unknown");
|
||||
}
|
||||
if (wincap.is_winnt ())
|
||||
{
|
||||
bufptr += __small_sprintf (bufptr, "type : %s\n"
|
||||
"cpu family : %d\n"
|
||||
if (wincap.is_winnt ())
|
||||
{
|
||||
bufptr += __small_sprintf (bufptr, "type : %s\n"
|
||||
"cpu family : %d\n"
|
||||
"model : %d\n"
|
||||
"model name : %s\n"
|
||||
"stepping : %d\n"
|
||||
@ -744,28 +744,28 @@ format_proc_cpuinfo (char *destbuf, size_t maxsize)
|
||||
apic_id,
|
||||
cpu_mhz,
|
||||
(features1 & (1 << 0)) ? "yes" : "no");
|
||||
}
|
||||
else
|
||||
{
|
||||
bufptr += __small_sprintf (bufptr, "type : %s\n"
|
||||
"cpu family : %d\n"
|
||||
"model : %d\n"
|
||||
"model name : %s\n"
|
||||
"stepping : %d\n"
|
||||
"brand id : %d\n"
|
||||
"cpu count : %d\n"
|
||||
"apic id : %d\n"
|
||||
"fpu : %s\n",
|
||||
type_str,
|
||||
family,
|
||||
model,
|
||||
szBuffer,
|
||||
stepping,
|
||||
brand_id,
|
||||
cpu_count,
|
||||
apic_id,
|
||||
(features1 & (1 << 0)) ? "yes" : "no");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
bufptr += __small_sprintf (bufptr, "type : %s\n"
|
||||
"cpu family : %d\n"
|
||||
"model : %d\n"
|
||||
"model name : %s\n"
|
||||
"stepping : %d\n"
|
||||
"brand id : %d\n"
|
||||
"cpu count : %d\n"
|
||||
"apic id : %d\n"
|
||||
"fpu : %s\n",
|
||||
type_str,
|
||||
family,
|
||||
model,
|
||||
szBuffer,
|
||||
stepping,
|
||||
brand_id,
|
||||
cpu_count,
|
||||
apic_id,
|
||||
(features1 & (1 << 0)) ? "yes" : "no");
|
||||
}
|
||||
print ("flags :");
|
||||
if (features1 & (1 << 0))
|
||||
print (" fpu");
|
||||
|
@ -49,7 +49,7 @@ secret_event_name (char *buf, short port, int *secret_ptr)
|
||||
{
|
||||
__small_sprintf (buf, "%scygwin.local_socket.secret.%d.%08x-%08x-%08x-%08x",
|
||||
wincap.has_terminal_services () ? "Global\\" : "",
|
||||
port,
|
||||
port,
|
||||
secret_ptr [0], secret_ptr [1],
|
||||
secret_ptr [2], secret_ptr [3]);
|
||||
}
|
||||
@ -224,7 +224,7 @@ fhandler_socket::check_peer_secret_event (struct sockaddr_in* peer, int* secret)
|
||||
{
|
||||
|
||||
char event_name[MAX_PATH];
|
||||
|
||||
|
||||
secret_event_name (event_name, peer->sin_port, secret ?: connect_secret);
|
||||
HANDLE ev = CreateEvent (&sec_all_nih, FALSE, FALSE, event_name);
|
||||
if (!ev && GetLastError () == ERROR_ALREADY_EXISTS)
|
||||
@ -956,7 +956,7 @@ fhandler_socket::sendto (const void *ptr, size_t len, int flags,
|
||||
res = ret;
|
||||
|
||||
/* Special handling for EPIPE and SIGPIPE.
|
||||
|
||||
|
||||
EPIPE is generated if the local end has been shut down on a connection
|
||||
oriented socket. In this case the process will also receive a SIGPIPE
|
||||
unless MSG_NOSIGNAL is set. */
|
||||
|
@ -555,25 +555,22 @@ fhandler_tty_slave::open (path_conv *, int flags, mode_t)
|
||||
set_output_handle (to_master_local);
|
||||
|
||||
set_open_status ();
|
||||
if (!output_done_event)
|
||||
if (fhandler_console::open_fhs++ == 0 && !output_done_event
|
||||
&& wincap.pty_needs_alloc_console ())
|
||||
{
|
||||
if (fhandler_console::open_fhs++ == 0
|
||||
&& wincap.pty_needs_alloc_console ())
|
||||
BOOL b;
|
||||
HWINSTA h = CreateWindowStation (NULL, 0, GENERIC_READ | GENERIC_WRITE, &sec_none_nih);
|
||||
termios_printf ("CreateWindowStation %p, %E", h);
|
||||
if (h)
|
||||
{
|
||||
BOOL b;
|
||||
HWINSTA h = CreateWindowStation (NULL, 0, GENERIC_READ | GENERIC_WRITE, &sec_none_nih);
|
||||
termios_printf ("CreateWindowStation %p, %E", h);
|
||||
if (h)
|
||||
{
|
||||
b = SetProcessWindowStation (h);
|
||||
termios_printf ("SetProcessWindowStation %d, %E", b);
|
||||
}
|
||||
b = AllocConsole (); // will cause flashing if workstation
|
||||
// stuff fails
|
||||
termios_printf ("%d = AllocConsole ()", b);
|
||||
b = SetProcessWindowStation (h);
|
||||
termios_printf ("SetProcessWindowStation %d, %E", b);
|
||||
}
|
||||
termios_printf ("incremented open_fhs %d", fhandler_console::open_fhs);
|
||||
b = AllocConsole (); // will cause flashing if workstation
|
||||
// stuff fails
|
||||
termios_printf ("%d = AllocConsole ()", b);
|
||||
}
|
||||
termios_printf ("incremented open_fhs %d", fhandler_console::open_fhs);
|
||||
termios_printf ("tty%d opened", ttynum);
|
||||
|
||||
return 1;
|
||||
@ -582,12 +579,9 @@ fhandler_tty_slave::open (path_conv *, int flags, mode_t)
|
||||
int
|
||||
fhandler_tty_slave::close ()
|
||||
{
|
||||
if (!output_done_event)
|
||||
{
|
||||
if (!--fhandler_console::open_fhs && myself->ctty == -1)
|
||||
FreeConsole ();
|
||||
termios_printf ("decremented open_fhs %d", fhandler_console::open_fhs);
|
||||
}
|
||||
if (!--fhandler_console::open_fhs && myself->ctty == -1)
|
||||
FreeConsole ();
|
||||
termios_printf ("decremented open_fhs %d", fhandler_console::open_fhs);
|
||||
return fhandler_tty_common::close ();
|
||||
}
|
||||
|
||||
@ -855,11 +849,8 @@ fhandler_tty_slave::read (void *ptr, size_t& len)
|
||||
int
|
||||
fhandler_tty_slave::dup (fhandler_base *child)
|
||||
{
|
||||
if (!output_done_event)
|
||||
{
|
||||
fhandler_console::open_fhs++;
|
||||
termios_printf ("incremented open_fhs %d", fhandler_console::open_fhs);
|
||||
}
|
||||
fhandler_console::open_fhs++;
|
||||
termios_printf ("incremented open_fhs %d", fhandler_console::open_fhs);
|
||||
return fhandler_tty_common::dup (child);
|
||||
}
|
||||
|
||||
@ -1253,11 +1244,8 @@ fhandler_tty_common::set_close_on_exec (int val)
|
||||
void
|
||||
fhandler_tty_slave::fixup_after_fork (HANDLE parent)
|
||||
{
|
||||
if (!output_done_event)
|
||||
{
|
||||
fhandler_console::open_fhs++;
|
||||
termios_printf ("incremented open_fhs %d", fhandler_console::open_fhs);
|
||||
}
|
||||
fhandler_console::open_fhs++;
|
||||
termios_printf ("incremented open_fhs %d", fhandler_console::open_fhs);
|
||||
fhandler_tty_common::fixup_after_fork (parent);
|
||||
}
|
||||
|
||||
@ -1317,6 +1305,7 @@ fhandler_tty_master::init_console ()
|
||||
return -1;
|
||||
|
||||
console->init (INVALID_HANDLE_VALUE, GENERIC_READ | GENERIC_WRITE, O_BINARY);
|
||||
fhandler_console::open_fhs--; /* handled when individual fds are opened */
|
||||
console->set_r_no_interrupt (1);
|
||||
return 0;
|
||||
}
|
||||
|
@ -35,45 +35,45 @@ ftok (const char *path, int id)
|
||||
We will have to alias; leaving open the possibility that the same
|
||||
key will be returned for multiple files. This possibility exists
|
||||
also on Linux; the question is, how to minimize this possibility.
|
||||
|
||||
|
||||
How to solve? Well, based on C. Vinschen's research, the nFileIndex*
|
||||
words vary as follows, on a partition with > 110,000 files
|
||||
nFileIndexHigh: 564 values between 0x00010000 -- 0xffff0000
|
||||
nFileIndexLow : 103812 values between 0x00000000 -- 0x0003ffff
|
||||
R. Collins suggests that these may represent a tree path,
|
||||
R. Collins suggests that these may represent a tree path,
|
||||
and that it would require ~2.9M files to force the tree depth
|
||||
to increase and reveal more bit usage.
|
||||
|
||||
|
||||
Implementation details: dev_t is 32bits, but is formed by
|
||||
device(32bits) << 16 | unit(32bits)
|
||||
device(32bits) << 16 | unit(32bits)
|
||||
But device is ACTUALLY == status & FH_DEVMASK, where FH_DEVMASK
|
||||
is 0x00000fff --> 12 bits
|
||||
|
||||
As it happens, the maximum number of devices is actually
|
||||
|
||||
As it happens, the maximum number of devices is actually
|
||||
FH_NDEV, not FH_DEVMASK, where FH_NDEV is currently 0x0000001d.
|
||||
However, FH_NDEV grows as new device types are added. So
|
||||
currently the device number needs 5 bits, but later? Let's
|
||||
take a cue from Linux, and use the lower 8 bits (instead of the
|
||||
lower 12 or 16) for the device (major?) number.
|
||||
|
||||
|
||||
Similarly, while 'units' is an int (32bits), it is unclear
|
||||
how many of these are significant. For most devices, it seems that
|
||||
'units' is equivalent to 'minor'. For FH_TAPE, it's obvious that
|
||||
only 8 bits are important. However, for FH_SOCKET...it might be
|
||||
as high as 16 significant bits.
|
||||
|
||||
|
||||
Let's assume that we only need 8 bits from device (major) and
|
||||
only 8 bits from unit (minor). (On linux, only 8 bits of minor
|
||||
are used, and none from major).
|
||||
---> so, we only need 0x00ff00ff (16 bits) of dev_t
|
||||
|
||||
|
||||
---> we MUST have all 8 bits of id.
|
||||
|
||||
|
||||
---> So, we only have 64 - 8 - 16 = 40 bits for ino_t. But, we
|
||||
need 0xffff0000 for nFileIndexHigh and 0x0003ffff for nFileIndexLow
|
||||
minimum, or 16 + 18 = 34 bits. Lucky us - we have 6 more bits
|
||||
to distribute.
|
||||
|
||||
|
||||
For lack of a better idea, we'll allocate 2 of the extra bits to
|
||||
nFileIndexHigh and 4 to nFileIndexLow. */
|
||||
|
||||
|
@ -332,7 +332,7 @@ list::match (caddr_t addr, DWORD len, caddr_t &m_addr, DWORD &m_len,
|
||||
for (int i = start + 1; i < nrecs; ++i)
|
||||
{
|
||||
low = (addr >= recs[i].get_address ()) ? addr : recs[i].get_address ();
|
||||
high = recs[i].get_address ()
|
||||
high = recs[i].get_address ()
|
||||
+ (PAGE_CNT (recs[i].get_size ()) * getpagesize ());
|
||||
high = (addr + len < high) ? addr + len : high;
|
||||
if (low < high)
|
||||
@ -565,7 +565,7 @@ mmap64 (caddr_t addr, size_t len, int prot, int flags, int fd, _off64_t off)
|
||||
The offset is re-added when evaluating the return value. */
|
||||
if (base)
|
||||
base -= off - gran_off;
|
||||
|
||||
|
||||
HANDLE h = fh->mmap (&base, gran_len, access, flags, gran_off);
|
||||
|
||||
if (h == INVALID_HANDLE_VALUE)
|
||||
@ -843,7 +843,7 @@ fhandler_disk_file::mmap (caddr_t *addr, size_t len, DWORD access,
|
||||
if (!base && !(flags & MAP_FIXED))
|
||||
base = MapViewOfFileEx (h, access, high, low, len, NULL);
|
||||
debug_printf ("%x = MapViewOfFileEx (h:%x, access:%x, 0, off:%D, "
|
||||
"len:%u, addr:%x)", base, h, access, off, len, *addr);
|
||||
"len:%u, addr:%x)", base, h, access, off, len, *addr);
|
||||
if (!base || ((flags & MAP_FIXED) && base != *addr))
|
||||
{
|
||||
if (!base)
|
||||
|
@ -522,7 +522,7 @@ fdsock (int &fd, const char *name, SOCKET soc)
|
||||
debug_printf ("not setting socket inheritance since winsock2_active %d",
|
||||
winsock2_active);
|
||||
fhandler_socket *fh = (fhandler_socket *)
|
||||
cygheap->fdtab.build_fhandler (fd, FH_SOCKET, name, NULL,
|
||||
cygheap->fdtab.build_fhandler (fd, FH_SOCKET, name, NULL,
|
||||
tolower (name[5]) - 'a');
|
||||
if (!fh)
|
||||
return NULL;
|
||||
@ -775,14 +775,14 @@ cygwin_connect (int fd, const struct sockaddr *name, int namelen)
|
||||
{
|
||||
bool was_blocking = false;
|
||||
if (!fh->is_nonblocking ())
|
||||
{
|
||||
{
|
||||
int nonblocking = 1;
|
||||
fh->ioctl (FIONBIO, &nonblocking);
|
||||
was_blocking = true;
|
||||
}
|
||||
res = fh->connect (name, namelen);
|
||||
if (was_blocking)
|
||||
{
|
||||
{
|
||||
if (res == -1 && get_errno () == EINPROGRESS)
|
||||
{
|
||||
size_t fds_size = howmany (fd + 1, NFDBITS) * sizeof (fd_mask);
|
||||
@ -794,7 +794,7 @@ cygwin_connect (int fd, const struct sockaddr *name, int namelen)
|
||||
FD_SET (fd, except_fds);
|
||||
res = cygwin_select (fd + 1, NULL, write_fds, except_fds, NULL);
|
||||
if (res > 0 && FD_ISSET (fd, except_fds))
|
||||
{
|
||||
{
|
||||
res = -1;
|
||||
for (;;)
|
||||
{
|
||||
@ -803,7 +803,7 @@ cygwin_connect (int fd, const struct sockaddr *name, int namelen)
|
||||
cygwin_getsockopt (fd, SOL_SOCKET, SO_ERROR,
|
||||
(void *) &err, &len);
|
||||
if (err)
|
||||
{
|
||||
{
|
||||
set_errno (err);
|
||||
break;
|
||||
}
|
||||
@ -811,9 +811,9 @@ cygwin_connect (int fd, const struct sockaddr *name, int namelen)
|
||||
}
|
||||
}
|
||||
else if (res > 0)
|
||||
res = 0;
|
||||
res = 0;
|
||||
else
|
||||
{
|
||||
{
|
||||
WSASetLastError (WSAEINPROGRESS);
|
||||
set_winsock_errno ();
|
||||
}
|
||||
@ -1304,7 +1304,7 @@ getdomainname (char *domain, size_t len)
|
||||
|
||||
/* This is only used by Win95 and NT <= 4.0.
|
||||
The registry names are language independent.
|
||||
FIXME: Handle DHCP on Win95. The DhcpDomain(s) may be available
|
||||
FIXME: Handle DHCP on Win95. The DhcpDomain(s) may be available
|
||||
in ..VxD\DHCP\DhcpInfoXX\OptionInfo, RFC 1533 format */
|
||||
|
||||
reg_key r (HKEY_LOCAL_MACHINE, KEY_READ,
|
||||
@ -2014,7 +2014,7 @@ cygwin_rcmd (char **ahost, unsigned short inport, char *locuser,
|
||||
fh = NULL;
|
||||
if (newfd >= 0)
|
||||
fh = fdsock (newfd, "/dev/tcp", fd2s);
|
||||
if (fh)
|
||||
if (fh)
|
||||
{
|
||||
*fd2p = newfd;
|
||||
fh->set_connect_state (CONNECTED);
|
||||
|
@ -1391,7 +1391,7 @@ static char special_chars[] =
|
||||
"I" "J" "K" "L" "M" "N" "O" "P"
|
||||
"Q" "R" "S" "T" "U" "V" "W" "X"
|
||||
"Y" "Z";
|
||||
static char special_introducers[] =
|
||||
static char special_introducers[] =
|
||||
"anpcl";
|
||||
|
||||
static char
|
||||
@ -1434,7 +1434,7 @@ special_name (const char *s, int inc = 1)
|
||||
}
|
||||
|
||||
bool
|
||||
fnunmunge (char *dst, const char *src)
|
||||
fnunmunge (char *dst, const char *src)
|
||||
{
|
||||
bool converted = false;
|
||||
char c;
|
||||
|
@ -757,7 +757,7 @@ verify_token (HANDLE token, cygsid &usersid, user_groups &groups, BOOL *pintern)
|
||||
debug_printf ("GetTokenInformation(my_token, TokenGroups): %E");
|
||||
else if (!groups.issetgroups ()) /* setgroups was never called */
|
||||
ret = sid_in_token_groups (my_grps, groups.pgsid)
|
||||
|| groups.pgsid == usersid;
|
||||
|| groups.pgsid == usersid;
|
||||
else /* setgroups was called */
|
||||
{
|
||||
struct __group32 *gr;
|
||||
@ -1430,15 +1430,15 @@ get_nt_object_attribute (HANDLE handle, SE_OBJECT_TYPE object_type,
|
||||
psd = (PSECURITY_DESCRIPTOR) & sd_buf[0];
|
||||
DWORD len = sizeof (sd_buf);
|
||||
if (ERROR_SUCCESS != RegGetKeySecurity ((HKEY) handle,
|
||||
DACL_SECURITY_INFORMATION |
|
||||
GROUP_SECURITY_INFORMATION |
|
||||
OWNER_SECURITY_INFORMATION,
|
||||
psd, &len))
|
||||
{
|
||||
__seterrno ();
|
||||
debug_printf ("RegGetKeySecurity %E");
|
||||
psd = NULL;
|
||||
}
|
||||
DACL_SECURITY_INFORMATION |
|
||||
GROUP_SECURITY_INFORMATION |
|
||||
OWNER_SECURITY_INFORMATION,
|
||||
psd, &len))
|
||||
{
|
||||
__seterrno ();
|
||||
debug_printf ("RegGetKeySecurity %E");
|
||||
psd = NULL;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -1447,7 +1447,7 @@ get_nt_object_attribute (HANDLE handle, SE_OBJECT_TYPE object_type,
|
||||
GROUP_SECURITY_INFORMATION |
|
||||
OWNER_SECURITY_INFORMATION,
|
||||
NULL, NULL, NULL, NULL, &psd))
|
||||
{
|
||||
{
|
||||
__seterrno ();
|
||||
debug_printf ("GetSecurityInfo %E");
|
||||
psd = NULL;
|
||||
|
@ -284,14 +284,14 @@ setsid (void)
|
||||
{
|
||||
if (myself->ctty >= 0 && fhandler_console::open_fhs <= 0)
|
||||
{
|
||||
syscall_printf ("open_fhs %d, freeing console",
|
||||
fhandler_console::open_fhs);
|
||||
syscall_printf ("freeing console");
|
||||
FreeConsole ();
|
||||
}
|
||||
myself->ctty = -1;
|
||||
myself->sid = getpid ();
|
||||
myself->pgid = getpid ();
|
||||
syscall_printf ("sid %d, pgid %d, ctty %d", myself->sid, myself->pgid, myself->ctty);
|
||||
syscall_printf ("sid %d, pgid %d, ctty %d, open_fhs %d", myself->sid,
|
||||
myself->pgid, myself->ctty, fhandler_console::open_fhs);
|
||||
return myself->sid;
|
||||
}
|
||||
|
||||
@ -2105,7 +2105,7 @@ seteuid32 (__uid32_t uid)
|
||||
if (usersid != (origpsid = cygheap->user.orig_sid ()))
|
||||
psid2 = usersid;
|
||||
if (sec_acl ((PACL) dacl_buf, FALSE, origpsid, psid2))
|
||||
{
|
||||
{
|
||||
TOKEN_DEFAULT_DACL tdacl;
|
||||
tdacl.DefaultDacl = (PACL) dacl_buf;
|
||||
if (!SetTokenInformation (ptok, TokenDefaultDacl,
|
||||
@ -2562,7 +2562,7 @@ logout (char *line)
|
||||
/* Writing to wtmp must be atomic to prevent mixed up data. */
|
||||
char mutex_name[MAX_PATH];
|
||||
HANDLE mutex = CreateMutex (NULL, FALSE,
|
||||
shared_name (mutex_name, "wtmp_mutex", 0));
|
||||
shared_name (mutex_name, "wtmp_mutex", 0));
|
||||
if (mutex)
|
||||
while (WaitForSingleObject (mutex, INFINITE) == WAIT_ABANDONED)
|
||||
;
|
||||
@ -2603,11 +2603,11 @@ internal_setutent (bool force_readwrite)
|
||||
case we try again for reading only unless the process calls
|
||||
pututline() (==force_readwrite) in which case opening just fails. */
|
||||
if (utmp_fd < 0 && !force_readwrite)
|
||||
{
|
||||
{
|
||||
utmp_fd = open (utmp_file, O_RDONLY | O_BINARY);
|
||||
if (utmp_fd >= 0)
|
||||
utmp_readonly = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
lseek (utmp_fd, 0, SEEK_SET);
|
||||
@ -2653,7 +2653,7 @@ getutent ()
|
||||
{
|
||||
internal_setutent (false);
|
||||
if (utmp_fd < 0)
|
||||
return NULL;
|
||||
return NULL;
|
||||
}
|
||||
if (read (utmp_fd, &utmp_data, sizeof utmp_data) != sizeof utmp_data)
|
||||
return NULL;
|
||||
@ -2670,7 +2670,7 @@ getutid (struct utmp *id)
|
||||
{
|
||||
internal_setutent (false);
|
||||
if (utmp_fd < 0)
|
||||
return NULL;
|
||||
return NULL;
|
||||
}
|
||||
while (read (utmp_fd, &utmp_data, sizeof utmp_data) == sizeof utmp_data)
|
||||
{
|
||||
@ -2707,7 +2707,7 @@ getutline (struct utmp *line)
|
||||
{
|
||||
internal_setutent (false);
|
||||
if (utmp_fd < 0)
|
||||
return NULL;
|
||||
return NULL;
|
||||
}
|
||||
while (read (utmp_fd, &utmp_data, sizeof utmp_data) == sizeof utmp_data)
|
||||
{
|
||||
@ -2754,18 +2754,18 @@ extern "C"
|
||||
long gethostid(void)
|
||||
{
|
||||
unsigned data[13] = {0x92895012,
|
||||
0x10293412,
|
||||
0x29602018,
|
||||
0x81928167,
|
||||
0x34601329,
|
||||
0x75630198,
|
||||
0x89860395,
|
||||
0x62897564,
|
||||
0x00194362,
|
||||
0x20548593,
|
||||
0x96839102,
|
||||
0x12219854,
|
||||
0x00290012};
|
||||
0x10293412,
|
||||
0x29602018,
|
||||
0x81928167,
|
||||
0x34601329,
|
||||
0x75630198,
|
||||
0x89860395,
|
||||
0x62897564,
|
||||
0x00194362,
|
||||
0x20548593,
|
||||
0x96839102,
|
||||
0x12219854,
|
||||
0x00290012};
|
||||
|
||||
bool has_cpuid = false;
|
||||
sigframe thisframe (mainthread);
|
||||
@ -2780,12 +2780,12 @@ long gethostid(void)
|
||||
{
|
||||
debug_printf ("486 processor");
|
||||
if (can_set_flag (0x00200000))
|
||||
{
|
||||
debug_printf ("processor supports CPUID instruction");
|
||||
has_cpuid = true;
|
||||
}
|
||||
{
|
||||
debug_printf ("processor supports CPUID instruction");
|
||||
has_cpuid = true;
|
||||
}
|
||||
else
|
||||
debug_printf ("processor does not support CPUID instruction");
|
||||
debug_printf ("processor does not support CPUID instruction");
|
||||
}
|
||||
if (has_cpuid)
|
||||
{
|
||||
@ -2793,22 +2793,22 @@ long gethostid(void)
|
||||
cpuid (&maxf, &unused[0], &unused[1], &unused[2], 0);
|
||||
maxf &= 0xffff;
|
||||
if (maxf >= 1)
|
||||
{
|
||||
unsigned features;
|
||||
cpuid (&data[0], &unused[0], &unused[1], &features, 1);
|
||||
if (features & (1 << 18))
|
||||
{
|
||||
debug_printf ("processor has psn");
|
||||
if (maxf >= 3)
|
||||
{
|
||||
cpuid (&unused[0], &unused[1], &data[1], &data[2], 3);
|
||||
debug_printf ("Processor PSN: %04x-%04x-%04x-%04x-%04x-%04x",
|
||||
data[0] >> 16, data[0] & 0xffff, data[2] >> 16, data[2] & 0xffff, data[1] >> 16, data[1] & 0xffff);
|
||||
}
|
||||
}
|
||||
else
|
||||
debug_printf ("processor does not have psn");
|
||||
}
|
||||
{
|
||||
unsigned features;
|
||||
cpuid (&data[0], &unused[0], &unused[1], &features, 1);
|
||||
if (features & (1 << 18))
|
||||
{
|
||||
debug_printf ("processor has psn");
|
||||
if (maxf >= 3)
|
||||
{
|
||||
cpuid (&unused[0], &unused[1], &data[1], &data[2], 3);
|
||||
debug_printf ("Processor PSN: %04x-%04x-%04x-%04x-%04x-%04x",
|
||||
data[0] >> 16, data[0] & 0xffff, data[2] >> 16, data[2] & 0xffff, data[1] >> 16, data[1] & 0xffff);
|
||||
}
|
||||
}
|
||||
else
|
||||
debug_printf ("processor does not have psn");
|
||||
}
|
||||
}
|
||||
|
||||
UUID Uuid;
|
||||
@ -2822,8 +2822,8 @@ long gethostid(void)
|
||||
// Unfortunately Windows will sometimes pick a virtual Ethernet card
|
||||
// e.g. VMWare Virtual Ethernet Adaptor
|
||||
debug_printf ("MAC address of first Ethernet card: %02x:%02x:%02x:%02x:%02x:%02x",
|
||||
Uuid.Data4[2], Uuid.Data4[3], Uuid.Data4[4],
|
||||
Uuid.Data4[5], Uuid.Data4[6], Uuid.Data4[7]);
|
||||
Uuid.Data4[2], Uuid.Data4[3], Uuid.Data4[4],
|
||||
Uuid.Data4[5], Uuid.Data4[6], Uuid.Data4[7]);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -2839,16 +2839,16 @@ long gethostid(void)
|
||||
GetDiskFreeSpace ("C:\\", NULL, NULL, NULL, (DWORD *)&data[11]);
|
||||
|
||||
debug_printf ("hostid entropy: %08x %08x %08x %08x "
|
||||
"%08x %08x %08x %08x "
|
||||
"%08x %08x %08x %08x "
|
||||
"%08x",
|
||||
data[0], data[1],
|
||||
data[2], data[3],
|
||||
data[4], data[5],
|
||||
data[6], data[7],
|
||||
data[8], data[9],
|
||||
data[10], data[11],
|
||||
data[12]);
|
||||
"%08x %08x %08x %08x "
|
||||
"%08x %08x %08x %08x "
|
||||
"%08x",
|
||||
data[0], data[1],
|
||||
data[2], data[3],
|
||||
data[4], data[5],
|
||||
data[6], data[7],
|
||||
data[8], data[9],
|
||||
data[10], data[11],
|
||||
data[12]);
|
||||
|
||||
long hostid = 0x40291372;
|
||||
// a random hashing algorithm
|
||||
|
@ -288,7 +288,7 @@ List<pthread> pthread::threads;
|
||||
|
||||
/* member methods */
|
||||
pthread::pthread ():verifyable_object (PTHREAD_MAGIC), win32_obj_id (0),
|
||||
running (false), suspended (false),
|
||||
running (false), suspended (false),
|
||||
cancelstate (0), canceltype (0), cancel_event (0),
|
||||
joiner (NULL), next (NULL), cleanup_stack (NULL)
|
||||
{
|
||||
@ -856,8 +856,8 @@ pthread_cond::pthread_cond (pthread_condattr *attr) :
|
||||
if (attr)
|
||||
if (attr->shared != PTHREAD_PROCESS_PRIVATE)
|
||||
{
|
||||
magic = 0;
|
||||
return;
|
||||
magic = 0;
|
||||
return;
|
||||
}
|
||||
|
||||
verifyable_mutex_obj = &mtx_in;
|
||||
@ -907,7 +907,7 @@ pthread_cond::unblock (const bool all)
|
||||
{
|
||||
unsigned long releaseable;
|
||||
|
||||
/*
|
||||
/*
|
||||
* Block outgoing threads (and avoid simultanous unblocks)
|
||||
*/
|
||||
mtx_out.lock ();
|
||||
@ -918,19 +918,19 @@ pthread_cond::unblock (const bool all)
|
||||
unsigned long released;
|
||||
|
||||
if (!pending)
|
||||
{
|
||||
/*
|
||||
* Block incoming threads until all waiting threads are released.
|
||||
*/
|
||||
mtx_in.lock ();
|
||||
{
|
||||
/*
|
||||
* Block incoming threads until all waiting threads are released.
|
||||
*/
|
||||
mtx_in.lock ();
|
||||
|
||||
/*
|
||||
* Calculate releaseable again because threads can enter until
|
||||
* the semaphore has been taken, but they can not leave, therefore pending
|
||||
* is unchanged and releaseable can only get higher
|
||||
*/
|
||||
releaseable = waiting - pending;
|
||||
}
|
||||
/*
|
||||
* Calculate releaseable again because threads can enter until
|
||||
* the semaphore has been taken, but they can not leave, therefore pending
|
||||
* is unchanged and releaseable can only get higher
|
||||
*/
|
||||
releaseable = waiting - pending;
|
||||
}
|
||||
|
||||
released = all ? releaseable : 1;
|
||||
pending += released;
|
||||
@ -971,20 +971,20 @@ pthread_cond::wait (pthread_mutex_t mutex, DWORD dwMilliseconds)
|
||||
rv = pthread::cancelable_wait (sem_wait, dwMilliseconds, false);
|
||||
|
||||
mtx_out.lock ();
|
||||
|
||||
|
||||
if (rv != WAIT_OBJECT_0)
|
||||
{
|
||||
/*
|
||||
* It might happen that a signal is sent while the thread got canceled
|
||||
* or timed out. Try to take one.
|
||||
* If the thread gets one than a signal|broadcast is in progress.
|
||||
*/
|
||||
*/
|
||||
if (WaitForSingleObject (sem_wait, 0) == WAIT_OBJECT_0)
|
||||
/*
|
||||
* thread got cancelled ot timed out while a signalling is in progress.
|
||||
* Set wait result back to signaled
|
||||
*/
|
||||
rv = WAIT_OBJECT_0;
|
||||
/*
|
||||
* thread got cancelled ot timed out while a signalling is in progress.
|
||||
* Set wait result back to signaled
|
||||
*/
|
||||
rv = WAIT_OBJECT_0;
|
||||
}
|
||||
|
||||
InterlockedDecrement ((long *)&waiting);
|
||||
@ -997,7 +997,7 @@ pthread_cond::wait (pthread_mutex_t mutex, DWORD dwMilliseconds)
|
||||
mtx_in.unlock ();
|
||||
|
||||
mtx_out.unlock ();
|
||||
|
||||
|
||||
mutex->lock ();
|
||||
--mutex->condwaits;
|
||||
|
||||
@ -1068,8 +1068,8 @@ pthread_rwlock::pthread_rwlock (pthread_rwlockattr *attr) :
|
||||
if (attr)
|
||||
if (attr->shared != PTHREAD_PROCESS_PRIVATE)
|
||||
{
|
||||
magic = 0;
|
||||
return;
|
||||
magic = 0;
|
||||
return;
|
||||
}
|
||||
|
||||
if (!pthread_mutex::is_good_object (&verifyable_mutex_obj))
|
||||
@ -1129,7 +1129,7 @@ pthread_rwlock::rdlock ()
|
||||
}
|
||||
|
||||
while (writer || waiting_writers)
|
||||
{
|
||||
{
|
||||
pthread_cleanup_push (pthread_rwlock::rdlock_cleanup, this);
|
||||
|
||||
++waiting_readers;
|
||||
@ -1162,14 +1162,14 @@ pthread_rwlock::tryrdlock ()
|
||||
{
|
||||
struct RWLOCK_READER *reader = new struct RWLOCK_READER;
|
||||
if (reader)
|
||||
{
|
||||
reader->thread = self;
|
||||
add_reader (reader);
|
||||
}
|
||||
{
|
||||
reader->thread = self;
|
||||
add_reader (reader);
|
||||
}
|
||||
else
|
||||
result = EAGAIN;
|
||||
result = EAGAIN;
|
||||
}
|
||||
|
||||
|
||||
mtx.unlock ();
|
||||
|
||||
return result;
|
||||
@ -1190,7 +1190,7 @@ pthread_rwlock::wrlock ()
|
||||
}
|
||||
|
||||
while (writer || readers)
|
||||
{
|
||||
{
|
||||
pthread_cleanup_push (pthread_rwlock::wrlock_cleanup, this);
|
||||
|
||||
++waiting_writers;
|
||||
@ -1220,7 +1220,7 @@ pthread_rwlock::trywrlock ()
|
||||
result = EBUSY;
|
||||
else
|
||||
writer = self;
|
||||
|
||||
|
||||
mtx.unlock ();
|
||||
|
||||
return result;
|
||||
@ -1237,10 +1237,10 @@ pthread_rwlock::unlock ()
|
||||
if (writer)
|
||||
{
|
||||
if (writer != self)
|
||||
{
|
||||
result = EPERM;
|
||||
goto DONE;
|
||||
}
|
||||
{
|
||||
result = EPERM;
|
||||
goto DONE;
|
||||
}
|
||||
|
||||
writer = NULL;
|
||||
}
|
||||
@ -1249,10 +1249,10 @@ pthread_rwlock::unlock ()
|
||||
struct RWLOCK_READER *reader = lookup_reader (self);
|
||||
|
||||
if (!reader)
|
||||
{
|
||||
result = EPERM;
|
||||
goto DONE;
|
||||
}
|
||||
{
|
||||
result = EPERM;
|
||||
goto DONE;
|
||||
}
|
||||
|
||||
remove_reader (reader);
|
||||
delete reader;
|
||||
@ -1336,13 +1336,13 @@ pthread_rwlock::_fixup_after_fork ()
|
||||
while (*temp)
|
||||
{
|
||||
if ((*temp)->thread == self)
|
||||
temp = &((*temp)->next);
|
||||
temp = &((*temp)->next);
|
||||
else
|
||||
{
|
||||
struct RWLOCK_READER *cur = *temp;
|
||||
*temp = (*temp)->next;
|
||||
delete cur;
|
||||
}
|
||||
{
|
||||
struct RWLOCK_READER *cur = *temp;
|
||||
*temp = (*temp)->next;
|
||||
delete cur;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -540,7 +540,7 @@ wincapc::init ()
|
||||
case 0:
|
||||
caps = &wincap_2000;
|
||||
break;
|
||||
|
||||
|
||||
case 1:
|
||||
caps = &wincap_xp;
|
||||
break;
|
||||
|
Loading…
x
Reference in New Issue
Block a user