~drizzle-trunk/drizzle/development

1 by brian
clean slate
1
/* Copyright (C) 2000-2003 MySQL AB
2
3
   This program is free software; you can redistribute it and/or modify
4
   it under the terms of the GNU General Public License as published by
5
   the Free Software Foundation; version 2 of the License.
6
7
   This program is distributed in the hope that it will be useful,
8
   but WITHOUT ANY WARRANTY; without even the implied warranty of
9
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10
   GNU General Public License for more details.
11
12
   You should have received a copy of the GNU General Public License
13
   along with this program; if not, write to the Free Software
14
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
15
16
#include "mysys_priv.h"
17
#include "my_static.h"
18
#include "mysys_err.h"
19
#include <m_string.h>
20
#include <m_ctype.h>
21
#include <signal.h>
22
23
my_bool my_init_done= 0;
24
uint	mysys_usage_id= 0;              /* Incremented for each my_init() */
25
ulong   my_thread_stack_size= 65536;
26
27
static ulong atoi_octal(const char *str)
28
{
29
  long int tmp;
30
  while (*str && my_isspace(&my_charset_latin1, *str))
31
    str++;
32
  str2int(str,
33
	  (*str == '0' ? 8 : 10),       /* Octalt or decimalt */
34
	  0, INT_MAX, &tmp);
35
  return (ulong) tmp;
36
}
37
38
39
/*
40
  Init my_sys functions and my_sys variabels
41
42
  SYNOPSIS
43
    my_init()
44
45
  RETURN
46
    0  ok
47
    1  Couldn't initialize environment
48
*/
49
50
my_bool my_init(void)
51
{
52
  char * str;
53
  if (my_init_done)
54
    return 0;
55
  my_init_done=1;
56
  mysys_usage_id++;
57
  my_umask= 0660;                       /* Default umask for new files */
58
  my_umask_dir= 0700;                   /* Default umask for new directories */
59
  init_glob_errs();
28.1.35 by Monty Taylor
Removed all references to THREAD.
60
#if defined(SAFE_MUTEX)
1 by brian
clean slate
61
  safe_mutex_global_init();		/* Must be called early */
62
#endif
28.1.35 by Monty Taylor
Removed all references to THREAD.
63
#if defined(MY_PTHREAD_FASTMUTEX) && !defined(SAFE_MUTEX)
1 by brian
clean slate
64
  fastmutex_global_init();              /* Must be called early */
65
#endif
66
#if defined(HAVE_PTHREAD_INIT)
67
  pthread_init();			/* Must be called before DBUG_ENTER */
68
#endif
69
  if (my_thread_global_init())
70
    return 1;
71
  sigfillset(&my_signals);		/* signals blocked by mf_brkhant */
72
  {
73
    DBUG_ENTER("my_init");
74
    DBUG_PROCESS((char*) (my_progname ? my_progname : "unknown"));
75
    if (!home_dir)
76
    {					/* Don't initialize twice */
77
      if ((home_dir=getenv("HOME")) != 0)
78
	home_dir=intern_filename(home_dir_buff,home_dir);
79
      /* Default creation of new files */
80
      if ((str=getenv("UMASK")) != 0)
81
	my_umask=(int) (atoi_octal(str) | 0600);
82
	/* Default creation of new dir's */
83
      if ((str=getenv("UMASK_DIR")) != 0)
84
	my_umask_dir=(int) (atoi_octal(str) | 0700);
85
      DBUG_PRINT("exit",("home: '%s'",home_dir));
86
    }
87
    DBUG_RETURN(0);
88
  }
89
} /* my_init */
90
91
92
	/* End my_sys */
93
94
void my_end(int infoflag)
95
{
96
  /*
97
    this code is suboptimal to workaround a bug in
98
    Sun CC: Sun C++ 5.6 2004/06/02 for x86, and should not be
99
    optimized until this compiler is not in use anymore
100
  */
101
  FILE *info_file= DBUG_FILE;
102
  my_bool print_info= (info_file != stderr);
103
  /*
104
    We do not use DBUG_ENTER here, as after cleanup DBUG is no longer
105
    operational, so we cannot use DBUG_RETURN.
106
  */
107
  DBUG_PRINT("info",("Shutting down: infoflag: %d  print_info: %d",
108
                     infoflag, print_info));
109
  if (!info_file)
110
  {
111
    info_file= stderr;
112
    print_info= 0;
113
  }
114
115
  if ((infoflag & MY_CHECK_ERROR) || print_info)
116
117
  {					/* Test if some file is left open */
118
    if (my_file_opened | my_stream_opened)
119
    {
120
      sprintf(errbuff[0],EE(EE_OPEN_WARNING),my_file_opened,my_stream_opened);
121
      (void) my_message_no_curses(EE_OPEN_WARNING,errbuff[0],ME_BELL);
122
      DBUG_PRINT("error",("%s",errbuff[0]));
123
      my_print_open_files();
124
    }
125
  }
126
  free_charsets();
127
  my_error_unregister_all();
128
  my_once_free();
129
130
  if ((infoflag & MY_GIVE_INFO) || print_info)
131
  {
132
#ifdef HAVE_GETRUSAGE
133
    struct rusage rus;
134
#ifdef HAVE_purify
135
    /* Purify assumes that rus is uninitialized after getrusage call */
136
    bzero((char*) &rus, sizeof(rus));
137
#endif
138
    if (!getrusage(RUSAGE_SELF, &rus))
139
      fprintf(info_file,"\n\
140
User time %.2f, System time %.2f\n\
141
Maximum resident set size %ld, Integral resident set size %ld\n\
142
Non-physical pagefaults %ld, Physical pagefaults %ld, Swaps %ld\n\
143
Blocks in %ld out %ld, Messages in %ld out %ld, Signals %ld\n\
144
Voluntary context switches %ld, Involuntary context switches %ld\n",
145
	      (rus.ru_utime.tv_sec * SCALE_SEC +
146
	       rus.ru_utime.tv_usec / SCALE_USEC) / 100.0,
147
	      (rus.ru_stime.tv_sec * SCALE_SEC +
148
	       rus.ru_stime.tv_usec / SCALE_USEC) / 100.0,
149
	      rus.ru_maxrss, rus.ru_idrss,
150
	      rus.ru_minflt, rus.ru_majflt,
151
	      rus.ru_nswap, rus.ru_inblock, rus.ru_oublock,
152
	      rus.ru_msgsnd, rus.ru_msgrcv, rus.ru_nsignals,
153
	      rus.ru_nvcsw, rus.ru_nivcsw);
154
#endif
155
  }
156
  else if (infoflag & MY_CHECK_ERROR)
157
  {
158
    TERMINATE(stderr, 0);		/* Print memory leaks on screen */
159
  }
160
161
  if (!(infoflag & MY_DONT_FREE_DBUG))
162
  {
163
    DBUG_END();                /* Must be done before my_thread_end */
164
  }
165
  my_thread_end();
166
  my_thread_global_end();
167
#if defined(SAFE_MUTEX)
168
  /*
169
    Check on destroying of mutexes. A few may be left that will get cleaned
170
    up by C++ destructors
171
  */
172
  safe_mutex_end((infoflag & (MY_GIVE_INFO | MY_CHECK_ERROR)) ? stderr :
173
                 (FILE *) 0);
174
#endif /* defined(SAFE_MUTEX) */
175
176
  my_init_done=0;
177
} /* my_end */