abbde48704
* autoload.cc (WSACloseEvent): Remove. (WSACreateEvent): Remove. * cygheap.cc (cygheap_init): Drop initializing shared_prefix. * cygheap.h (struct init_cygheap): Drop shared_prefix and shared_prefix_buf members. * fhandler_socket.cc (sock_shared_name): New static function. (search_wsa_event_slot): Convert name buffers to WCHAR. Call NtCreateMutant/NtOpenMutant to create mutexes in session local namespace. (fhandler_socket::init_events): Ditto. Fix debug output. (fhandler_socket::release_events): Close mutexes using NtClose. (fhandler_socket::dup): Ditto. * kernel32.cc: New file, implementing Win32 calls in a Cygwin-specific way. * mmap.cc (MapView): Make static. * ntdll.h: Fix status code sorting. (STATUS_OBJECT_NAME_EXISTS): Define. (SEMAPHORE_QUERY_STATE): Define. (CYG_SHARED_DIR_ACCESS): Define. (CYG_MUTANT_ACCESS): Define. (CYG_EVENT_ACCESS): Define. (CYG_SEMAPHORE_ACCESS): Define. (enum _PROCESSINFOCLASS): Define ProcessSessionInformation. (struct _PROCESS_SESSION_INFORMATION): Define. (NtCreateSemaphore): Declare. (NtOpenSemaphore): Declare. * flock.cc: Use CYG_xxx_ACCESS access masks where appropriate. * posix_ipc.cc (ipc_mutex_init): Use native functions to create mutex. Create in cygwin-shared subdir. (ipc_cond_init): Ditto for event. (ipc_mutex_close): Use NtClose. (ipc_cond_close): Ditto. (mq_open): Drop "cyg" prefix from mqh_uname. * shared.cc (CYG_SHARED_DIR_ACCESS): Drop definition here. (_cygwin_testing): Declare extern on file level. (get_shared_parent_dir): Change name of shared directory. Add name to api_fatal output. (get_session_parent_dir): New function. (shared_name): Simplify. (shared_info::initialize): Call get_session_parent_dir. * shared_info.h (get_session_parent_dir): Declare. * smallprint.cc (__small_vswprintf): Fix bug in multibyte string conversion. * thread.cc (semaphore::semaphore): Align semaphore name to object names in posix IPC functions. * include/cygwin/version.h (CYGWIN_VERSION_SHARED_DATA): Bump.
188 lines
5.2 KiB
C++
188 lines
5.2 KiB
C++
/* shared_info.h: shared info for cygwin
|
|
|
|
Copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2008 Red Hat, Inc.
|
|
|
|
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. */
|
|
|
|
#include "tty.h"
|
|
#include "security.h"
|
|
#include "mtinfo.h"
|
|
|
|
/* Mount table entry */
|
|
|
|
class mount_item
|
|
{
|
|
public:
|
|
/* FIXME: Nasty static allocation. Need to have a heap in the shared
|
|
area [with the user being able to configure at runtime the max size]. */
|
|
/* Win32-style mounted partition source ("C:\foo\bar").
|
|
native_path[0] == 0 for unused entries. */
|
|
char native_path[CYG_MAX_PATH];
|
|
int native_pathlen;
|
|
|
|
/* POSIX-style mount point ("/foo/bar") */
|
|
char posix_path[CYG_MAX_PATH];
|
|
int posix_pathlen;
|
|
|
|
unsigned flags;
|
|
|
|
void init (const char *dev, const char *path, unsigned flags);
|
|
|
|
struct mntent *getmntent ();
|
|
int fnmunge (char *, const char *, int&);
|
|
int build_win32 (char *, const char *, unsigned *, unsigned);
|
|
};
|
|
|
|
/* Warning: Decreasing this value will cause cygwin.dll to ignore existing
|
|
higher numbered registry entries. Don't change this number willy-nilly.
|
|
What we need is to have a more dynamic allocation scheme, but the current
|
|
scheme should be satisfactory for a long while yet. */
|
|
#define MAX_MOUNTS 30
|
|
|
|
#define USER_VERSION 1 // increment when mount table changes and
|
|
#define USER_VERSION_MAGIC CYGWIN_VERSION_MAGIC (USER_MAGIC, USER_VERSION)
|
|
#define CURR_USER_MAGIC 0xb2232e71U
|
|
|
|
class reg_key;
|
|
struct device;
|
|
|
|
/* NOTE: Do not make gratuitous changes to the names or organization of the
|
|
below class. The layout is checksummed to determine compatibility between
|
|
different cygwin versions. */
|
|
class mount_info
|
|
{
|
|
public:
|
|
DWORD sys_mount_table_counter;
|
|
int nmounts;
|
|
mount_item mount[MAX_MOUNTS];
|
|
|
|
/* cygdrive_prefix is used as the root of the path automatically
|
|
prepended to a path when the path has no associated mount.
|
|
cygdrive_flags are the default flags for the cygdrives. */
|
|
char cygdrive[CYG_MAX_PATH];
|
|
size_t cygdrive_len;
|
|
unsigned cygdrive_flags;
|
|
private:
|
|
int posix_sorted[MAX_MOUNTS];
|
|
int native_sorted[MAX_MOUNTS];
|
|
|
|
public:
|
|
void init ();
|
|
int add_item (const char *dev, const char *path, unsigned flags);
|
|
int del_item (const char *path, unsigned flags);
|
|
|
|
bool from_fstab_line (char *line, bool user);
|
|
bool from_fstab (bool user);
|
|
void from_registry ();
|
|
|
|
unsigned set_flags_from_win32_path (const char *path);
|
|
int conv_to_win32_path (const char *src_path, char *dst, device&,
|
|
unsigned *flags = NULL);
|
|
int conv_to_posix_path (PWCHAR src_path, char *posix_path,
|
|
int keep_rel_p);
|
|
int conv_to_posix_path (const char *src_path, char *posix_path,
|
|
int keep_rel_p);
|
|
struct mntent *getmntent (int x);
|
|
|
|
int write_cygdrive_info (const char *cygdrive_prefix, unsigned flags);
|
|
int get_cygdrive_info (char *user, char *system, char* user_flags,
|
|
char* system_flags);
|
|
void cygdrive_posix_path (const char *src, char *dst, int trailing_slash_p);
|
|
int get_mounts_here (const char *parent_dir, int,
|
|
PUNICODE_STRING mount_points,
|
|
PUNICODE_STRING cygd);
|
|
|
|
private:
|
|
|
|
void sort ();
|
|
void read_mounts (reg_key& r);
|
|
void mount_slash ();
|
|
void to_registry ();
|
|
|
|
int cygdrive_win32_path (const char *src, char *dst, int& unit);
|
|
void read_cygdrive_info_from_registry ();
|
|
};
|
|
|
|
class user_info
|
|
{
|
|
public:
|
|
DWORD version;
|
|
DWORD cb;
|
|
bool warned_msdos;
|
|
mount_info mountinfo;
|
|
};
|
|
/******** Shared Info ********/
|
|
/* Data accessible to all tasks */
|
|
|
|
#define SHARED_VERSION (unsigned)(cygwin_version.api_major << 8 | \
|
|
cygwin_version.api_minor)
|
|
#define SHARED_VERSION_MAGIC CYGWIN_VERSION_MAGIC (SHARED_MAGIC, SHARED_VERSION)
|
|
|
|
#define SHARED_INFO_CB 31144
|
|
|
|
#define CURR_SHARED_MAGIC 0xbc77afb0U
|
|
|
|
/* NOTE: Do not make gratuitous changes to the names or organization of the
|
|
below class. The layout is checksummed to determine compatibility between
|
|
different cygwin versions. */
|
|
class shared_info
|
|
{
|
|
DWORD version;
|
|
DWORD cb;
|
|
public:
|
|
unsigned heap_chunk;
|
|
bool heap_slop_inited;
|
|
unsigned heap_slop;
|
|
DWORD sys_mount_table_counter;
|
|
tty_list tty;
|
|
LONG last_used_bindresvport;
|
|
mtinfo mt;
|
|
|
|
void initialize ();
|
|
unsigned heap_chunk_size ();
|
|
unsigned heap_slop_size ();
|
|
};
|
|
|
|
extern shared_info *cygwin_shared;
|
|
extern user_info *user_shared;
|
|
#define mount_table (&(user_shared->mountinfo))
|
|
extern HANDLE cygwin_user_h;
|
|
|
|
enum shared_locations
|
|
{
|
|
SH_CYGWIN_SHARED,
|
|
SH_USER_SHARED,
|
|
SH_SHARED_CONSOLE,
|
|
SH_MYSELF,
|
|
SH_TOTAL_SIZE,
|
|
SH_JUSTCREATE,
|
|
SH_JUSTOPEN
|
|
|
|
};
|
|
void __stdcall memory_init ();
|
|
|
|
#define shared_align_past(p) \
|
|
((char *) (system_info.dwAllocationGranularity * \
|
|
(((DWORD) ((p) + 1) + system_info.dwAllocationGranularity - 1) / \
|
|
system_info.dwAllocationGranularity)))
|
|
|
|
#ifdef _FHANDLER_H_
|
|
struct console_state
|
|
{
|
|
tty_min tty_min_state;
|
|
dev_console dev_state;
|
|
};
|
|
#endif
|
|
|
|
HANDLE get_shared_parent_dir ();
|
|
HANDLE get_session_parent_dir ();
|
|
char *__stdcall shared_name (char *, const char *, int);
|
|
void *__stdcall open_shared (const char *name, int n, HANDLE &shared_h, DWORD size,
|
|
shared_locations&, PSECURITY_ATTRIBUTES psa = &sec_all,
|
|
DWORD access = FILE_MAP_READ | FILE_MAP_WRITE);
|
|
extern void user_shared_initialize (bool reinit);
|