e3cef0d21d601c3a5939cbc3e8cafcc0efdfda4c
[kopensolaris-gnu/glibc.git] / sysdeps / unix / sysv / solaris2 / kopensolaris-gnu / bits / utmpx.h
1 /* Structures and definitions for the user accounting database.  GNU version.
2    Copyright (C) 1997, 1998, 2000, 2001, 2002 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
9
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
14
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
19
20 #ifndef _UTMPX_H
21 # error "Never include <bits/utmpx.h> directly; use <utmpx.h> instead."
22 #endif
23
24 #include <bits/types.h>
25 #include <sys/time.h>
26 #include <bits/wordsize.h>
27
28
29 #define _UTMPX_FILE     "/var/adm/utmpx"
30 #define _WTMPX_FILE     "/var/adm/wtmpx"
31 #ifdef __USE_MISC
32 # include <paths.h>
33 # define _PATH_UTMPX    _PATH_UTMP
34 # define _PATH_WTMPX    _PATH_WTMP
35 # define UTMPX_FILE     _UTMPX_FILE
36 # define WTMPX_FILE     _WTMPX_FILE
37 #endif
38
39
40 #define __UT_LINESIZE   32
41 #define __UT_NAMESIZE   32
42 #define __UT_HOSTSIZE   256
43
44
45 /* The structure describing the status of a terminated process.  This
46    type is used in `struct utmpx' below.  */
47 struct __exit_status
48   {
49 #ifdef __USE_MISC
50     short int e_termination;    /* Process termination status.  */
51     short int e_exit;           /* Process exit status.  */
52 #else
53     short int __e_termination;  /* Process termination status.  */
54     short int __e_exit;         /* Process exit status.  */
55 #endif
56   };
57
58
59 /* The structure describing an entry in the user accounting database.  */
60 struct utmpx
61 {
62   short int ut_type;            /* Type of login.  */
63   __pid_t ut_pid;               /* Process ID of login process.  */
64   char ut_line[__UT_LINESIZE];  /* Devicename.  */
65   char ut_id[4];                /* Inittab ID. */
66   char ut_user[__UT_NAMESIZE];  /* Username.  */
67   char ut_host[__UT_HOSTSIZE];  /* Hostname for remote login.  */
68   struct __exit_status ut_exit; /* Exit status of a process marked
69                                    as DEAD_PROCESS.  */
70
71 /* The fields ut_session and ut_tv must be the same size when compiled
72    32- and 64-bit.  This allows files and shared memory to be shared
73    between 32- and 64-bit applications.  */
74 #if __WORDSIZE == 64 && defined __WORDSIZE_COMPAT32
75   __int32_t ut_session;         /* Session ID, used for windowing.  */
76   struct
77   {
78     __int32_t tv_sec;           /* Seconds.  */
79     __int32_t tv_usec;          /* Microseconds.  */
80   } ut_tv;                      /* Time entry was made.  */
81 #else
82   long int ut_session;          /* Session ID, used for windowing.  */
83   struct timeval ut_tv;         /* Time entry was made.  */
84 #endif
85   __int32_t ut_addr_v6[4];      /* Internet address of remote host.  */
86   char __unused[20];            /* Reserved for future use.  */
87 };
88
89 /* Backwards compatibility hacks.  */
90 #define ut_name         ut_user
91 #ifndef _NO_UT_TIME
92 /* We have a problem here: `ut_time' is also used otherwise.  Define
93    _NO_UT_TIME if the compiler complains.  */
94 # define ut_time        ut_tv.tv_sec
95 #endif
96 #define ut_xtime        ut_tv.tv_sec
97 #define ut_addr         ut_addr_v6[0]
98
99
100 /* Values for the `ut_type' field of a `struct utmpx'.  */
101 #define EMPTY           0       /* No valid user accounting information.  */
102
103 #ifdef __USE_MISC
104 # define RUN_LVL        1       /* The system's runlevel.  */
105 #endif
106 #define BOOT_TIME       2       /* Time of system boot.  */
107 #define NEW_TIME        3       /* Time after system clock changed.  */
108 #define OLD_TIME        4       /* Time when system clock changed.  */
109
110 #define INIT_PROCESS    5       /* Process spawned by the init process.  */
111 #define LOGIN_PROCESS   6       /* Session leader of a logged in user.  */
112 #define USER_PROCESS    7       /* Normal process.  */
113 #define DEAD_PROCESS    8       /* Terminated process.  */
114
115 #ifdef __USE_MISC
116 # define ACCOUNTING     9       /* System accounting.  */
117 # define DOWN_TIME      10
118 # define UTMAXTYPE      DOWN_TIME
119 #endif
120
121 #ifdef __USE_MISC
122 # define RUNLVL_MSG     "run-level %c"
123 # define BOOT_MSG       "system boot"
124 # define OTIME_MSG      "old time"
125 # define NTIME_MSG      "new time"
126 # define PSRADM_MSG     "%03d  %s"
127 # define DOWN_MSG       "system down"
128 #endif