mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-11-03 20:53:13 +03:00 
			
		
		
		
	* sysdeps/mach/hurd/Makefile ($(common-objpfx)errnos.d): Depend on libc-modules.h * sysdeps/mach/hurd/i386/trampoline.c (_hurd_setup_sighandler): Remove unused declaration of _hurd_intr_rpc_msg_in_trap. * mach/mach_init.c (__mach_init): Test whether HAVE_HOST_PAGE_SIZE is defined instead of whether it is non-zero. * sysdeps/mach/hurd/i386/intr-msg.h (INTR_MSG_TRAP): Use "+m" input constraint instead of both input and output constraint. Use ecx clobber instead of %ecx. * sysdeps/mach/hurd/malloc-machine.h (mutex_init, mutex_lock, mutex_unlock): Use a statement expression instead of an expression list. * sysdeps/mach/hurd/setitimer.c (_hurd_itimer_thread_stack_size): Set type to vm_size_t instead of vm_address_t. * sysdeps/mach/hurd/fork.c (__fork): Test whether STACK_GROWTH_UP is defined instead of whether it is non-zero. * hurd/hurd/ioctl.h (_hurd_locked_install_cttyid): New declaration. * sysdeps/mach/hurd/setsid.c: Include <hurd/ioctl.h>. * sysdeps/mach/hurd/mmap.c (__mmap): Use 0 instead of NULL for comparisons with mapaddr. * nscd/nscd-client.h: Include <time.h>. * sysdeps/mach/hurd/dl-sysdep.c (fmh): Pass vm_offset_t dummy 9th parameter to __vm_region instead of int.
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Copyright (C) 1993-2015 Free Software Foundation, Inc.
 | 
						|
   This file is part of the GNU C Library.
 | 
						|
 | 
						|
   The GNU C Library is free software; you can redistribute it and/or
 | 
						|
   modify it under the terms of the GNU Lesser General Public
 | 
						|
   License as published by the Free Software Foundation; either
 | 
						|
   version 2.1 of the License, or (at your option) any later version.
 | 
						|
 | 
						|
   The GNU C Library is distributed in the hope that it will be useful,
 | 
						|
   but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
						|
   Lesser General Public License for more details.
 | 
						|
 | 
						|
   You should have received a copy of the GNU Lesser General Public
 | 
						|
   License along with the GNU C Library; if not, see
 | 
						|
   <http://www.gnu.org/licenses/>.  */
 | 
						|
 | 
						|
#include <errno.h>
 | 
						|
#include <unistd.h>
 | 
						|
#include <hurd.h>
 | 
						|
#include <hurd/port.h>
 | 
						|
#include <hurd/fd.h>
 | 
						|
#include <hurd/ioctl.h>
 | 
						|
 | 
						|
/* Create a new session with the calling process as its leader.
 | 
						|
   The process group IDs of the session and the calling process
 | 
						|
   are set to the process ID of the calling process, which is returned.  */
 | 
						|
pid_t
 | 
						|
__setsid (void)
 | 
						|
{
 | 
						|
  error_t err;
 | 
						|
  unsigned int stamp;
 | 
						|
 | 
						|
  HURD_CRITICAL_BEGIN;
 | 
						|
  __mutex_lock (&_hurd_dtable_lock);
 | 
						|
 | 
						|
  stamp = _hurd_pids_changed_stamp; /* Atomic fetch.  */
 | 
						|
 | 
						|
  /* Tell the proc server we want to start a new session.  */
 | 
						|
  err = __USEPORT (PROC, __proc_setsid (port));
 | 
						|
  if (err)
 | 
						|
    __mutex_unlock (&_hurd_dtable_lock);
 | 
						|
  else
 | 
						|
    {
 | 
						|
      /* Punt our current ctty, and update the dtable accordingly.  We hold
 | 
						|
	 the dtable lock from before the proc_setsid call through clearing
 | 
						|
	 the cttyid port and processing the dtable, so that we can be sure
 | 
						|
	 that it's all done by the time the signal thread processes the
 | 
						|
	 pgrp change notification.  */
 | 
						|
      _hurd_locked_install_cttyid (MACH_PORT_NULL);
 | 
						|
 | 
						|
      /* Synchronize with the signal thread to make sure we have received
 | 
						|
	 and processed proc_newids before returning to the user.
 | 
						|
	 This is necessary to ensure that _hurd_pgrp (and thus the value
 | 
						|
	 returned by `getpgrp ()' in other threads) has been updated before
 | 
						|
	 we return.  */
 | 
						|
      while (_hurd_pids_changed_stamp == stamp)
 | 
						|
	{
 | 
						|
#ifdef noteven
 | 
						|
	  /* XXX we have no need for a mutex, but cthreads demands one.  */
 | 
						|
	  __condition_wait (&_hurd_pids_changed_sync, NULL);
 | 
						|
#else
 | 
						|
	  __swtch_pri (0);
 | 
						|
#endif
 | 
						|
	}
 | 
						|
    }
 | 
						|
 | 
						|
  HURD_CRITICAL_END;
 | 
						|
 | 
						|
  return err ? __hurd_fail (err) : _hurd_pgrp;
 | 
						|
}
 | 
						|
 | 
						|
weak_alias (__setsid, setsid)
 |