diff options
author | Christopher Faylor <me@cgf.cx> | 2010-03-16 00:29:15 +0300 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2010-03-16 00:29:15 +0300 |
commit | cef5dfd75aca85d5fd3996d387cfee5a28b467c7 (patch) | |
tree | 118617d399410aeb76a778c48c7de8dbaed5df66 /winsup/cygwin/mount.cc | |
parent | 654e623ce009fc0d430eed044519539e624938cc (diff) |
* shared_info.h (user_info): Add dll_crt0_1 as a friend.
(user_info::version): Make LONG to accommodate spinlock use.
(user_info::create): New static function renamed from user_info_create.
(user_info::initialize): New private function renamed from
user_info_initialize.
(SHARED_VERSION): Delete.
(SHARED_VERSION_MAGIC): Ditto.
(USER_VERSION_MAGIC): Ditto.
(SHARED_INFO_CB): Ditto.
(USER_VERSION): Ditto.
(USER_VERSION_MAGIC): Ditto.
(CURR_SHARED_MAGIC): Update.
(CURR_USER_MAGIC): Ditto.
(shared_info::version): Make LONG to accommodate spinlock use.
(shared_info::create): New static function mirroring user_info::create.
(dll_crt0_1): Accommodate change to user_info::initialize.
* spinlock.h (spinlock::setto): New variable member.
(spinlock::done): New function.
(spinlock::spinlock): Generalize to allow arbitrary values and timeouts. Call
done() when lock is not needed.
* ntdll.h: Make multiple-inclusion safe.
(NtQuerySystemTime): Declare.
* shared.cc (installation_root_inited): Rename from shared_mem_inited.
(init_installation_root): Make inline. Use a spinlock to ensure that this is
initialized only once per session.
(user_info::initialize): Rename from user_shared_initialize. Protect with
spinlock on sversion and remove other spinlock-like things. Remove reference
to user_shared since it is now implicit. Refer to spinlock version of
multiple_cygwin_problem to ensure that any spinlock is released.
(user_info::create): Rename from user_shared_create. Accommodate change from
user_shared_initialize to user_info::initialize.
(shared_info::create): New inline function.
(shared_info::initialize): Protect with spinlock on sversion. Move heap_init
back under specific control of shared_info spinlock. Remove reference to
SHARED_INFO_CB and just use sizeof(*this).
(memory_init): Move all locking into respective functions where it is needed.
Accommodate name changes. Remove call to heap_init().
* syscalls.cc (seteuid32): Accommodate name change to user_info::create().
* mount.cc (mount_info::create_root_entry): Report on errors from add_item
since they should be nonexistent.
(mount_info::init): Don't initialize nmounts. It should already be zero. Give
more verbose error when root_idx < 0. Implicitly use this pointer rather than
explicitly referencing mount_table->.
(mount_info::add_item): Minor whitespace fix.
Diffstat (limited to 'winsup/cygwin/mount.cc')
-rw-r--r-- | winsup/cygwin/mount.cc | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/winsup/cygwin/mount.cc b/winsup/cygwin/mount.cc index e8d181125..d8dbb7662 100644 --- a/winsup/cygwin/mount.cc +++ b/winsup/cygwin/mount.cc @@ -338,8 +338,11 @@ mount_info::create_root_entry (const PWCHAR root) The entry is immutable, unless the "override" option is given in /etc/fstab. */ char native_root[PATH_MAX]; sys_wcstombs (native_root, PATH_MAX, root); - mount_table->add_item (native_root, "/", - MOUNT_SYSTEM | MOUNT_BINARY | MOUNT_IMMUTABLE | MOUNT_AUTOMATIC); + assert (*native_root != '\0'); + if (add_item (native_root, "/", + MOUNT_SYSTEM | MOUNT_BINARY | MOUNT_IMMUTABLE | MOUNT_AUTOMATIC) + < 0) + api_fatal ("add_item (\"%W\", \"/\", ...) failed, errno %d", native_root, errno); /* Create a default cygdrive entry. Note that this is a user entry. This allows to override it with mount, unless the sysadmin created a cygdrive entry in /etc/fstab. */ @@ -353,7 +356,6 @@ mount_info::create_root_entry (const PWCHAR root) void mount_info::init () { - nmounts = 0; PWCHAR pathend; WCHAR path[PATH_MAX]; @@ -367,19 +369,20 @@ mount_info::init () if (!got_usr_bin || !got_usr_lib) { char native[PATH_MAX]; - assert (root_idx != -1); + if (root_idx < 0) + api_fatal ("root_idx %d, user_shared magic %p, nmounts %d", root_idx, user_shared->version, nmounts); char *p = stpcpy (native, mount[root_idx].native_path); if (!got_usr_bin) { stpcpy (p, "\\bin"); - mount_table->add_item (native, "/usr/bin", - MOUNT_SYSTEM | MOUNT_BINARY | MOUNT_AUTOMATIC); + add_item (native, "/usr/bin", + MOUNT_SYSTEM | MOUNT_BINARY | MOUNT_AUTOMATIC); } if (!got_usr_lib) { stpcpy (p, "\\lib"); - mount_table->add_item (native, "/usr/lib", - MOUNT_SYSTEM | MOUNT_BINARY | MOUNT_AUTOMATIC); + add_item (native, "/usr/lib", + MOUNT_SYSTEM | MOUNT_BINARY | MOUNT_AUTOMATIC); } } } @@ -1285,7 +1288,7 @@ mount_info::add_item (const char *native, const char *posix, if (nativeerr || posixerr) { - set_errno (nativeerr?:posixerr); + set_errno (nativeerr ?: posixerr); return -1; } |