newlib/winsup/cygserver
Corinna Vinschen dafef5e249 * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak.
* bsd_mutex.cc: Include stdlib.h, sys/msg.h and sys/sem.h.
	(mtx_init): Initialize lock counter to 0.
	(_mtx_lock): Increment and log mutex lock counter.
	(mtx_owned): Add winpid argument. Return true only if mutex is
	actually owned by process winpid.
	(_mtx_assert): Add winpid argument accordingly.
	(_mtx_unlock): Log owner and lock count.
	(MSLEEP_MUTEX): Remove.
	(MSLEEP_SEM): Ditto.
	(MSLEEP_EVENT): Ditto.
	(msleep_event_name): Ditto.
	(msleep_cs): New global critical section.
	(msleep_cnt): New global variable indicating msleep record usage.
	(msleep_max_cnt): New global variable indicating msleep record size.
	(msleep_arr): New global pointer to msleep records.
	(msleep_init): Initialize msleep_cs. Allocate msleep_arr array.
	(_msleep): Rewrite using new msleep_cs/msleep_arr based thread
	synchronization. Don't be shy with debug output.
	(wakeup): Rewrite using new msleep_cs/msleep_arr based thread
	synchronization.
	* bsd_mutex.h (struct mtx): Add lock counter for better debugging.
	(mtx_owned): Declare with winpid argument.
	(_mtx_assert): Ditto.
	(mtx_assert): Define with winpid argument.
	* cygserver.cc (version): Remove.
	(SERVER_VERSION): New define, decoupling server version information
	from source code control system.
	(print_version): Simplify printing server version.
	* process.cc (process::process): Fix wrong bracketing (and handle leak).
	(process::~process): Only try to close _signal_arrived if valid.
	* sysv_sem.cc: Include sys/smallprint.h.
	(semundo_clear): Define with additional struct thread pointer argument.
	Accomodate throughout.
	(SEMUNDO_LOCKASSERT): Define with winpid argument. Accomodate
	throughout.
	(struct sem_undo): Define un_proc as pid_t on Cygwin. Accomodate
	throughout.
	(seminit): Improve debugging by adding the semid to the mutex name.
	(semget): Correctly print key value as 64 bit hex value in debug
	output.
	(semexit_myhook): Remove Cygwin specific unlocking of mutexes owned
	by exiting process.  Keep semaphore global lock throughout whole
	function to avoid races.
	* sysv_shm.cc (GIANT_REQUIRED): Define empty on Cygwin. We know that
	Giant is locked.
2005-04-06 11:11:07 +00:00
..
bsd_helper.cc * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
bsd_helper.h
bsd_log.cc Fix copyright throughout. 2004-09-15 10:17:53 +00:00
bsd_log.h
bsd_mutex.cc * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
bsd_mutex.h * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
ChangeLog * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
client.cc Fix copyright throughout. 2004-09-15 10:17:53 +00:00
configure
configure.in
cygserver-config
cygserver.cc * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
cygserver.conf * cygserver.conf: Describe relation between shmmaxpgs and SHMMAX. 2004-07-26 09:31:07 +00:00
Makefile.in * Makefile.in (CFLAGS, CXXFLAGS): Remove unneeded include. 2003-12-26 05:37:54 +00:00
msg.cc * bsd_mutex.cc (_msleep): Simplify event creation. Revert change from 2004-10-04 19:44:05 +00:00
process.cc * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
process.h * bsd_mutex.cc (_msleep): Simplify event creation. Revert change from 2004-10-04 19:44:05 +00:00
README * Makefile.in (install): Explicitely create directories. Install 2003-11-21 18:10:49 +00:00
sem.cc * bsd_mutex.cc (_msleep): Simplify event creation. Revert change from 2004-10-04 19:44:05 +00:00
shm.cc * bsd_mutex.cc (_msleep): Simplify event creation. Revert change from 2004-10-04 19:44:05 +00:00
sysv_msg.cc * bsd_helper.cc (tunable_params): Add entries for kern.ipc.msgmnb and 2003-12-16 10:13:34 +00:00
sysv_sem.cc * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
sysv_shm.cc * bsd_helper.cc (ipcexit_hookthread): Fix whitespace and handle leak. 2005-04-06 11:11:07 +00:00
threaded_queue.cc
threaded_queue.h Fix copyright throughout. 2004-09-15 10:17:53 +00:00
transport_pipes.cc Fix copyright throughout. 2004-09-15 10:17:53 +00:00
transport_pipes.h
transport_sockets.cc Fix copyright throughout. 2004-09-15 10:17:53 +00:00
transport_sockets.h Fix copyright throughout. 2004-09-15 10:17:53 +00:00
transport.cc Fix copyright throughout. 2004-09-15 10:17:53 +00:00
transport.h Fix copyright throughout. 2004-09-15 10:17:53 +00:00
woutsup.h

What is Cygserver?

  Cygserver is a program which is designed to run as a background service.
  It provides Cygwin applications with services which require security
  arbitration or which need to persist while no other cygwin application
  is running.

  The implemented services so far are:

  - Control slave tty/pty handle dispersal from tty owner to other
    processes without compromising the owner processes' security.
  - XSI IPC Message Queues.
  - XSI IPC Semaphores.
  - XSI IPC Shared Memory.


Cygserver command line options:

  Options to Cygserver take the normal UNIX-style `-X' or `--longoption' form.
  Nearly all options have a counterpart in the configuration file (see below)
  so setting them on the command line isn't really necessary.  Command line
  options override settings from the Cygserver configuration file.

  The one-character options are prepended by a single dash, the long variants
  are prepended with two dashes.  Arguments to options are marked in angle
  brackets below.  These are not part of the actual syntax but are used only to
  denote the arguments.  Note that all arguments are required.  Cygserver
  has no options with optional arguments.
  
  The options recognized are:

  -f, --config-file <file>
  
    Use <file> as configuration file instead of the default configuration
    line.  The default configuration file is /etc/cygserver.conf, typically. 
    The --help and --version options will print the default configuration
    pathname.

    This option has no counterpart in the configuration file, for obvious
   reasons.

  -c, --cleanup-threads <num>  
  
    Number of threads started to perform cleanup tasks.  Default is 2.
    Configuration file option:  kern.srv.cleanup_threads

  -r, --request-threads <num>  
  
    Number of threads started to serve application requests.  Default is 10.
    The -c and -r options can be used to play with Cygserver's performance
    under heavy load conditions or on slow machines.
    Configuration file option:  kern.srv.request_threads

  -d, --debug
  
    Log debug messages to stderr.  These will clutter your stderr output with
    a lot of information, typically only useful to developers.

  -e, --stderr
  
    Force logging to stderr.  This is the default if stderr is connected to
    a tty.  Otherwise, the default is logging to the system log.  By using
    the -e, -E, -y, -Y options (or the appropriate settings in the
    configuration file), you can explicitely set the logging output as you
    like, even to both, stderr and syslog.
    Configuration file option:  kern.log.stderr

  -E, --no-stderr
  
    Don't log to stderr.  Configuration file option:  kern.log.stderr

  -y, --syslog
  
    Force logging to the system log.  This is the default, if stderr is not
    connected to a tty, e. g. redirected to a file.  Note, that on 9x/Me
    systems the syslog is faked by a file C:\CYGWIN_SYSLOG.TXT.
    Configuration file option:  kern.log.syslog

  -Y, --no-syslog
  
    Don't log to syslog.  Configuration file option:  kern.log.syslog

  -l, --log-level <level>
  
    Set the verbosity level of the logging output.  Valid values are between
    1 and 7.  The default level is 6, which is relatively chatty.  If you set
    it to 1, you will get only messages which are printed under severe conditions,
    which will result in stopping Cygserver itself.
    Configuration file option:  kern.log.level

  -m, --no-sharedmem
  
    Don't start XSI IPC Shared Memory support.  If you don't need XSI IPC
    Shared Memory support, you can switch it off here.
    Configuration file option:  kern.srv.sharedmem

  -q, --no-msgqueues
  
    Don't start XSI IPC Message Queues. 
    Configuration file option:  kern.srv.msgqueues

  -s, --no-semaphores
  
    Don't start XSI IPC Semaphores.
    Configuration file option:  kern.srv.semaphores

  -S, --shutdown
  
    Shutdown a running daemon and exit.  Other methods are sending a SIGHUP
    to the Cygserver PID or, if running as service under NT, calling
    `net stop cygserver' or `cygrunsrv -E cygserver'.

  -h, --help
  
    Output usage information and exit.

  -v, --version
  
    Output version information and exit.


How to start Cygserver:

  Before you run Cygserver for the first time, you should run the
  /usr/bin/cygserver-config script once.  It creates the default
  configuration file and, upon request, installs Cygserver as service
  when running under NT.  The script only performs a default install,
  with no further options given to Cygserver when running as service.
  Due to the wide configurability by changing the configuration file,
  that's typically not necessary.

  On Windows 9x/Me, just start Cygserver in any console window.  It's
  advisable to redirect stderr to a file of choice (e. g.
  /var/log/cygserver.log) and to use the -e and -Y options or the
  set the appropriate settings in the configuration file (see below).

  On Windows NT/2000/XP or 2003, you should always run Cygserver as a
  service under LocalSystem account.  This is the way it is installed
  for you by the /usr/bin/cygserver-config script.


How to use the Cygserver services:

  The Cygserver services are used by Cygwin applications only if you
  set the environment variable CYGWIN to contain the string "server".
  You must do this before starting the application.

  Typically, you don't need any other option, so it's ok to set CYGWIN
  just to "server".  It is not necessary to set the CYGWIN environment
  variable prior to starting the Cygserver process itself, but it won't
  hurt to do so.

  The easiest way is to set the environment variable CYGWIN to the values
  you want in the Windows system environment and to reboot the machine.
  This is advisable, since it allows you to set the variable once and
  then forget about it.  It also ensures that services as well as desktop
  applications have the same setting.

  If you don't want that for whatever reason, you can set the
  variable in the /cygwin.bat file which is used in the net distribution,
  to start a Cygwin bash from the desktop.  In that file, you can set
  the CYGWIN variable using Windows command line interpreter syntax, e. g.:

    set CYGWIN=server

  If you don't set CYGWIN in the system environment, but you're running
  other Cygwin services, these services need to get that CYGWIN value by
  setting the environment using the appropriate cygrunsrv option '-e' when
  installing the service.  Example installing a service 'foo':

    cygrunsrv -I foo -p /usr/sbin/foo -e "CYGWIN=server"


The Cygserver configuration file:

  Cygserver has many options, which allow to customize the server
  to your needs.  Customization is accomplished by editing the configuration
  file, which is by default /etc/cygserver.conf.  This file is read only
  once on startup of Cygserver.  There's no option to re-read the file on
  runtime by, say, sending a signal to Cygserver.

  The configuration file determines how Cygserver operates.  There are
  options which set the number of threads running in parallel, options
  for setting how and what to log and options to set various maximum
  values for the IPC services.

  The default configuration file delivered with Cygserver is installed
  to /etc/defaults/etc.  The /usr/bin/cygserver-config script copies it to
  /etc, giving you the option to overwrite an already existing file or to
  leave it alone.  Therefore, the /etc file is safe to be changed by you,
  since it will not be overwritten by a later update installation.

  The default configuration file contains many comments which describe
  everything needed to understand the settings.  A comment at the start of the
  file describes the syntax rules for the file.  The default options are shown
  in the file but are commented out.

  It is generally a good idea to uncomment only options which you intend to
  change from the default values.  Since reading the options file on Cygserver
  startup doesn't take much time, it's also considered good practice to keep
  all other comments in the file.  This keeps you from searching for clues
  in other sources.


If you have problems with Cygserver, or you have found a bug, or you
think you have found a bug, or you don't understand configuration file
options, the mailing list <cygwin@cygwin.com> is the right place to ask
questions.

Have fun!