2001-04-11 13:04:03 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2000
|
|
|
|
* SWsoft company
|
|
|
|
*
|
|
|
|
* This material is provided "as is", with absolutely no warranty expressed
|
|
|
|
* or implied. Any use is at your own risk.
|
|
|
|
*
|
|
|
|
* Permission to use or copy this software for any purpose is hereby granted
|
|
|
|
* without fee, provided the above notices are retained on all copies.
|
|
|
|
* Permission to modify the code and to distribute modified code is granted,
|
|
|
|
* provided the above notices are retained, and a notice that the code was
|
|
|
|
* modified is included with the above copyright notice.
|
|
|
|
*
|
2002-07-23 17:31:22 +02:00
|
|
|
|
|
|
|
This code was modified by the MySQL team
|
|
|
|
*/
|
2001-04-11 13:04:03 +02:00
|
|
|
|
2001-09-30 04:47:34 +02:00
|
|
|
/*
|
|
|
|
The following is needed to not cause conflicts when we include mysqld.cc
|
|
|
|
*/
|
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
#define main main1
|
|
|
|
#define mysql_unix_port mysql_inix_port1
|
|
|
|
#define mysql_port mysql_port1
|
|
|
|
|
2002-01-09 08:38:48 +01:00
|
|
|
#if defined (__WIN__)
|
|
|
|
#include "../sql/mysqld.cpp"
|
|
|
|
#else
|
2001-06-05 00:34:04 +02:00
|
|
|
#include "../sql/mysqld.cc"
|
2002-01-09 08:38:48 +01:00
|
|
|
#endif
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
#define SCRAMBLE_LENGTH 8
|
2001-10-02 04:53:00 +02:00
|
|
|
C_MODE_START
|
2002-07-23 17:31:22 +02:00
|
|
|
#include "lib_vio.c"
|
2001-10-02 04:53:00 +02:00
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
static int check_connections1(THD * thd);
|
|
|
|
static int check_connections2(THD * thd);
|
|
|
|
static bool check_user(THD *thd, enum_server_command command,
|
|
|
|
const char *user, const char *passwd, const char *db,
|
|
|
|
bool check_count);
|
2001-09-30 04:47:34 +02:00
|
|
|
char * get_mysql_home(){ return mysql_home;};
|
|
|
|
char * get_mysql_real_data_home(){ return mysql_real_data_home;};
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
bool lib_dispatch_command(enum enum_server_command command, NET *net,
|
|
|
|
const char *arg, ulong length)
|
|
|
|
{
|
2001-06-15 21:55:15 +02:00
|
|
|
THD *thd=(THD *) net->vio->dest_thd;
|
|
|
|
thd->store_globals(); // Fix if more than one connect
|
2001-06-24 21:11:00 +02:00
|
|
|
thd->net.last_error[0]=0; // Clear error message
|
|
|
|
thd->net.last_errno=0;
|
2001-12-06 13:10:51 +01:00
|
|
|
|
2001-06-15 21:55:15 +02:00
|
|
|
net_new_transaction(&thd->net);
|
|
|
|
return dispatch_command(command, thd, (char *) arg, length + 1);
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2001-09-30 04:47:34 +02:00
|
|
|
void lib_connection_phase(NET * net, int phase)
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
2001-06-24 21:11:00 +02:00
|
|
|
THD * thd;
|
|
|
|
thd = (THD *)(net->vio->dest_thd);
|
|
|
|
if (thd)
|
|
|
|
{
|
|
|
|
switch (phase)
|
|
|
|
{
|
|
|
|
case 2:
|
|
|
|
check_connections2(thd);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
2001-10-02 04:53:00 +02:00
|
|
|
C_MODE_END
|
2001-09-30 04:47:34 +02:00
|
|
|
|
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
void start_embedded_conn1(NET * net)
|
|
|
|
{
|
|
|
|
THD * thd = new THD;
|
|
|
|
my_net_init(&thd->net,NULL);
|
|
|
|
/* if (protocol_version>9) */
|
|
|
|
thd->net.return_errno=1;
|
|
|
|
thd->thread_id = thread_id++;
|
|
|
|
|
|
|
|
Vio * v = net->vio;
|
|
|
|
if (!v)
|
|
|
|
{
|
|
|
|
v = vio_new(0,VIO_CLOSED,0);
|
|
|
|
net->vio = v;
|
|
|
|
}
|
|
|
|
if (v)
|
|
|
|
{
|
|
|
|
v -> dest_thd = thd;
|
|
|
|
}
|
|
|
|
thd->net.vio = v;
|
|
|
|
if (thd->store_globals())
|
|
|
|
{
|
2001-06-15 21:55:15 +02:00
|
|
|
fprintf(stderr,"store_globals failed.\n");
|
2001-04-11 13:04:03 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
thd->mysys_var=my_thread_var;
|
|
|
|
thd->dbug_thread_id=my_thread_id();
|
|
|
|
thd->thread_stack= (char*) &thd;
|
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
if (thd->variables.max_join_size == (ulong) HA_POS_ERROR)
|
2001-04-11 13:04:03 +02:00
|
|
|
thd->options |= OPTION_BIG_SELECTS;
|
|
|
|
|
|
|
|
thd->proc_info=0; // Remove 'login'
|
|
|
|
thd->command=COM_SLEEP;
|
|
|
|
thd->version=refresh_version;
|
|
|
|
thd->set_time();
|
2002-10-21 06:56:30 +02:00
|
|
|
bzero(thd->scramble, sizeof(thd->scramble));
|
2001-04-11 13:04:03 +02:00
|
|
|
init_sql_alloc(&thd->mem_root,8192,8192);
|
|
|
|
|
|
|
|
check_connections1(thd);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
check_connections1(THD *thd)
|
|
|
|
{
|
|
|
|
uint connect_errors=0;
|
|
|
|
NET *net= &thd->net;
|
|
|
|
/*
|
|
|
|
** store the connection details
|
|
|
|
*/
|
|
|
|
DBUG_PRINT("info", (("check_connections called by thread %d"),
|
|
|
|
thd->thread_id));
|
|
|
|
DBUG_PRINT("general",("New connection received on %s",
|
|
|
|
vio_description(net->vio)));
|
|
|
|
if (!thd->host) // If TCP/IP connection
|
|
|
|
{
|
|
|
|
thd->host=(char*) localhost;
|
|
|
|
}
|
|
|
|
else /* Hostname given means that the connection was on a socket */
|
|
|
|
{
|
|
|
|
DBUG_PRINT("general",("Host: %s",thd->host));
|
|
|
|
thd->ip=0;
|
|
|
|
bzero((char*) &thd->remote,sizeof(struct sockaddr));
|
|
|
|
}
|
|
|
|
//vio_keepalive(net->vio, TRUE);
|
|
|
|
|
|
|
|
/* nasty, but any other way? */
|
|
|
|
uint pkt_len = 0;
|
2001-12-06 13:10:51 +01:00
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
char buff[80],*end;
|
|
|
|
int client_flags = CLIENT_LONG_FLAG | CLIENT_CONNECT_WITH_DB |
|
|
|
|
CLIENT_TRANSACTIONS;
|
|
|
|
LINT_INIT(pkt_len);
|
|
|
|
|
|
|
|
end=strmov(buff,server_version)+1;
|
|
|
|
int4store((uchar*) end,thd->thread_id);
|
|
|
|
end+=4;
|
|
|
|
memcpy(end,thd->scramble,SCRAMBLE_LENGTH+1);
|
|
|
|
end+=SCRAMBLE_LENGTH +1;
|
|
|
|
int2store(end,client_flags);
|
|
|
|
end[2]=MY_CHARSET_CURRENT;
|
|
|
|
|
|
|
|
#define MIN_HANDSHAKE_SIZE 6
|
|
|
|
|
|
|
|
int2store(end+3,thd->server_status);
|
|
|
|
bzero(end+5,13);
|
|
|
|
end+=18;
|
|
|
|
if (net_write_command(net,protocol_version, buff,
|
|
|
|
(uint) (end-buff)))
|
|
|
|
{
|
|
|
|
inc_host_errors(&thd->remote.sin_addr);
|
|
|
|
return(ER_HANDSHAKE_ERROR);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
check_connections2(THD * thd)
|
|
|
|
{
|
2001-09-17 14:40:03 +02:00
|
|
|
uint connect_errors=0;
|
|
|
|
uint pkt_len = 0;
|
|
|
|
NET * net = &thd -> net;
|
|
|
|
if (protocol_version>9) net -> return_errno=1;
|
2001-04-11 13:04:03 +02:00
|
|
|
|
2001-09-17 14:40:03 +02:00
|
|
|
if ( (pkt_len=my_net_read(net)) == packet_error ||
|
|
|
|
pkt_len < MIN_HANDSHAKE_SIZE)
|
|
|
|
{
|
|
|
|
inc_host_errors(&thd->remote.sin_addr);
|
|
|
|
return(ER_HANDSHAKE_ERROR);
|
|
|
|
}
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
#ifdef _CUSTOMCONFIG_
|
|
|
|
#include "_cust_sql_parse.h"
|
|
|
|
#endif
|
|
|
|
if (connect_errors)
|
|
|
|
reset_host_errors(&thd->remote.sin_addr);
|
2002-07-23 17:31:22 +02:00
|
|
|
if (thd->packet.alloc(thd->variables.net_buffer_length))
|
2001-04-11 13:04:03 +02:00
|
|
|
return(ER_OUT_OF_RESOURCES);
|
|
|
|
|
|
|
|
thd->client_capabilities=uint2korr(net->read_pos);
|
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
thd->max_client_packet_length=uint3korr(net->read_pos+2);
|
2001-04-11 13:04:03 +02:00
|
|
|
char *user= (char*) net->read_pos+5;
|
|
|
|
char *passwd= strend(user)+1;
|
|
|
|
char *db=0;
|
|
|
|
if (passwd[0] && strlen(passwd) != SCRAMBLE_LENGTH)
|
|
|
|
return ER_HANDSHAKE_ERROR;
|
|
|
|
if (thd->client_capabilities & CLIENT_CONNECT_WITH_DB)
|
|
|
|
db=strend(passwd)+1;
|
|
|
|
if (thd->client_capabilities & CLIENT_TRANSACTIONS)
|
|
|
|
thd->net.return_status= &thd->server_status;
|
2002-07-23 17:31:22 +02:00
|
|
|
net->read_timeout=thd->variables.net_read_timeout;
|
2001-04-11 13:04:03 +02:00
|
|
|
if (check_user(thd,COM_CONNECT, user, passwd, db, 1))
|
|
|
|
return (-1);
|
|
|
|
thd->password=test(passwd[0]);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool check_user(THD *thd,enum_server_command command, const char *user,
|
|
|
|
const char *passwd, const char *db, bool check_count)
|
|
|
|
{
|
|
|
|
NET *net= &thd->net;
|
2002-05-15 17:41:36 +02:00
|
|
|
USER_RESOURCES ur;
|
2001-04-11 13:04:03 +02:00
|
|
|
thd->db=0;
|
|
|
|
|
|
|
|
if (!(thd->user = my_strdup(user, MYF(0))))
|
|
|
|
{
|
|
|
|
send_error(net,ER_OUT_OF_RESOURCES);
|
|
|
|
return 1;
|
|
|
|
}
|
2003-12-12 15:27:25 +01:00
|
|
|
strmake(thd->priv_host, LOCAL_HOST, sizeof(thd->priv_host)-1);
|
2001-09-30 04:46:20 +02:00
|
|
|
thd->master_access=acl_getroot(thd, thd->host, thd->ip, thd->user,
|
2003-04-29 15:11:45 +02:00
|
|
|
passwd, thd->scramble,
|
2003-04-30 09:15:09 +02:00
|
|
|
&thd->priv_user, thd->priv_host,
|
2001-04-11 13:04:03 +02:00
|
|
|
protocol_version == 9 ||
|
|
|
|
!(thd->client_capabilities &
|
2002-05-15 17:41:36 +02:00
|
|
|
CLIENT_LONG_PASSWORD),&ur);
|
|
|
|
DBUG_PRINT("info",
|
2001-04-11 13:04:03 +02:00
|
|
|
("Capabilities: %d packet_length: %d Host: '%s' User: '%s' Using password: %s Access: %u db: '%s'",
|
2002-07-23 17:31:22 +02:00
|
|
|
thd->client_capabilities, thd->max_client_packet_length,
|
2002-05-15 17:41:36 +02:00
|
|
|
thd->host_or_ip, thd->priv_user,
|
2001-04-11 13:04:03 +02:00
|
|
|
passwd[0] ? "yes": "no",
|
|
|
|
thd->master_access, thd->db ? thd->db : "*none*"));
|
|
|
|
if (thd->master_access & NO_ACCESS)
|
|
|
|
{
|
|
|
|
net_printf(net, ER_ACCESS_DENIED_ERROR,
|
|
|
|
thd->user,
|
2002-05-15 17:41:36 +02:00
|
|
|
thd->host_or_ip,
|
2001-04-11 13:04:03 +02:00
|
|
|
passwd[0] ? ER(ER_YES) : ER(ER_NO));
|
|
|
|
mysql_log.write(thd,COM_CONNECT,ER(ER_ACCESS_DENIED_ERROR),
|
|
|
|
thd->user,
|
2002-05-15 17:41:36 +02:00
|
|
|
thd->host_or_ip,
|
2001-04-11 13:04:03 +02:00
|
|
|
passwd[0] ? ER(ER_YES) : ER(ER_NO));
|
|
|
|
return(1); // Error already given
|
|
|
|
}
|
|
|
|
if (check_count)
|
|
|
|
{
|
|
|
|
VOID(pthread_mutex_lock(&LOCK_thread_count));
|
|
|
|
bool tmp=(thread_count - delayed_insert_threads >= max_connections &&
|
|
|
|
!(thd->master_access & PROCESS_ACL));
|
|
|
|
VOID(pthread_mutex_unlock(&LOCK_thread_count));
|
|
|
|
if (tmp)
|
|
|
|
{ // Too many connections
|
|
|
|
send_error(net, ER_CON_COUNT_ERROR);
|
|
|
|
return(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
mysql_log.write(thd,command,
|
|
|
|
(thd->priv_user == thd->user ?
|
|
|
|
(char*) "%s@%s on %s" :
|
|
|
|
(char*) "%s@%s as anonymous on %s"),
|
|
|
|
user,
|
2002-05-15 17:41:36 +02:00
|
|
|
thd->host_or_ip,
|
2001-04-11 13:04:03 +02:00
|
|
|
db ? db : (char*) "");
|
|
|
|
thd->db_access=0;
|
|
|
|
if (db && db[0])
|
|
|
|
return test(mysql_change_db(thd,db));
|
|
|
|
else
|
|
|
|
send_ok(net); // Ready to handle questions
|
|
|
|
return 0; // ok
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-12-16 13:40:57 +01:00
|
|
|
void THD::clear_error()
|
|
|
|
{
|
|
|
|
net.last_error[0]= 0;
|
|
|
|
net.last_errno= 0;
|
|
|
|
}
|
|
|
|
|
2002-12-05 15:38:49 +01:00
|
|
|
/*
|
|
|
|
Make a copy of array and the strings array points to
|
|
|
|
*/
|
|
|
|
|
|
|
|
char **copy_arguments(int argc, char **argv)
|
|
|
|
{
|
|
|
|
uint length= 0;
|
|
|
|
char **from, **res, **end= argv+argc;
|
|
|
|
|
|
|
|
for (from=argv ; from != end ; from++)
|
|
|
|
length+= strlen(*from);
|
|
|
|
|
|
|
|
if ((res= (char**) my_malloc(sizeof(argv)*(argc+1)+length+argc,
|
|
|
|
MYF(MY_WME))))
|
|
|
|
{
|
|
|
|
char **to= res, *to_str= (char*) (res+argc+1);
|
|
|
|
for (from=argv ; from != end ;)
|
|
|
|
{
|
|
|
|
*to++= to_str;
|
|
|
|
to_str= strmov(to_str, *from++)+1;
|
|
|
|
}
|
|
|
|
*to= 0; // Last ptr should be null
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2001-10-02 04:53:00 +02:00
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
|
2003-09-08 10:02:19 +02:00
|
|
|
static my_bool org_my_init_done;
|
|
|
|
my_bool server_inited;
|
2002-07-23 17:31:22 +02:00
|
|
|
ulong max_allowed_packet, net_buffer_length;
|
2002-12-05 15:38:49 +01:00
|
|
|
char ** copy_arguments_ptr= 0;
|
2001-10-02 04:53:00 +02:00
|
|
|
|
2001-11-03 20:33:11 +01:00
|
|
|
int STDCALL mysql_server_init(int argc, char **argv, char **groups)
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
2001-10-02 04:53:00 +02:00
|
|
|
char glob_hostname[FN_REFLEN];
|
2001-04-11 13:04:03 +02:00
|
|
|
|
2001-08-10 18:37:36 +02:00
|
|
|
/* This mess is to allow people to call the init function without
|
|
|
|
* having to mess with a fake argv */
|
|
|
|
int *argcp;
|
|
|
|
char ***argvp;
|
|
|
|
int fake_argc = 1;
|
|
|
|
char *fake_argv[] = { (char *)"", 0 };
|
2001-10-08 03:58:07 +02:00
|
|
|
const char *fake_groups[] = { "server", "embedded", 0 };
|
2001-08-10 18:37:36 +02:00
|
|
|
if (argc)
|
|
|
|
{
|
|
|
|
argcp = &argc;
|
2001-09-17 14:40:03 +02:00
|
|
|
argvp = (char***) &argv;
|
2001-08-10 18:37:36 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
argcp = &fake_argc;
|
2001-09-17 14:40:03 +02:00
|
|
|
argvp = (char ***) &fake_argv;
|
2001-08-10 18:37:36 +02:00
|
|
|
}
|
|
|
|
if (!groups)
|
2002-12-05 15:38:49 +01:00
|
|
|
groups = (char**) fake_groups;
|
2001-08-10 18:37:36 +02:00
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
my_umask=0660; // Default umask for new files
|
|
|
|
my_umask_dir=0700; // Default umask for new directories
|
2001-10-02 04:53:00 +02:00
|
|
|
|
|
|
|
/* Only call MY_INIT() if it hasn't been called before */
|
2003-09-08 10:02:19 +02:00
|
|
|
if (!server_inited)
|
2001-10-02 04:53:00 +02:00
|
|
|
{
|
2003-09-08 10:02:19 +02:00
|
|
|
server_inited=1;
|
2001-10-02 04:53:00 +02:00
|
|
|
org_my_init_done=my_init_done;
|
|
|
|
}
|
|
|
|
if (!org_my_init_done)
|
2001-10-08 03:58:07 +02:00
|
|
|
{
|
2001-10-02 04:53:00 +02:00
|
|
|
MY_INIT((char *)"mysql_embedded"); // init my_sys library & pthreads
|
2001-10-08 03:58:07 +02:00
|
|
|
}
|
2001-10-02 04:53:00 +02:00
|
|
|
|
2002-12-05 15:38:49 +01:00
|
|
|
/*
|
|
|
|
Make a copy of the arguments to guard against applications that
|
|
|
|
may change or move the initial arguments.
|
|
|
|
*/
|
|
|
|
if (argvp == &argv)
|
|
|
|
if (!(copy_arguments_ptr= argv= copy_arguments(argc, argv)))
|
|
|
|
return 1;
|
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
tzset(); // Set tzname
|
|
|
|
|
|
|
|
start_time=time((time_t*) 0);
|
|
|
|
#ifdef HAVE_TZNAME
|
|
|
|
#if defined(HAVE_LOCALTIME_R) && defined(_REENTRANT)
|
|
|
|
{
|
|
|
|
struct tm tm_tmp;
|
|
|
|
localtime_r(&start_time,&tm_tmp);
|
2001-10-02 04:53:00 +02:00
|
|
|
strmov(time_zone,tzname[tm_tmp.tm_isdst != 0 ? 1 : 0]);
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
|
|
|
#else
|
|
|
|
{
|
|
|
|
struct tm *start_tm;
|
|
|
|
start_tm=localtime(&start_time);
|
2001-10-02 04:53:00 +02:00
|
|
|
strmov(time_zone,tzname[start_tm->tm_isdst != 0 ? 1 : 0]);
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2001-10-02 04:53:00 +02:00
|
|
|
if (gethostname(glob_hostname,sizeof(glob_hostname)-4) < 0)
|
|
|
|
strmov(glob_hostname,"mysql");
|
2001-10-08 03:58:07 +02:00
|
|
|
load_defaults("my", (const char **) groups, argcp, argvp);
|
2001-08-10 18:37:36 +02:00
|
|
|
defaults_argv=*argvp;
|
2002-07-23 17:31:22 +02:00
|
|
|
|
|
|
|
/* Get default temporary directory */
|
|
|
|
opt_mysql_tmpdir=getenv("TMPDIR"); /* Use this if possible */
|
2001-10-02 04:53:00 +02:00
|
|
|
#if defined( __WIN__) || defined(OS2)
|
2002-07-23 17:31:22 +02:00
|
|
|
if (!opt_mysql_tmpdir)
|
|
|
|
opt_mysql_tmpdir=getenv("TEMP");
|
|
|
|
if (!opt_mysql_tmpdir)
|
|
|
|
opt_mysql_tmpdir=getenv("TMP");
|
2001-04-11 13:04:03 +02:00
|
|
|
#endif
|
2002-07-23 17:31:22 +02:00
|
|
|
if (!opt_mysql_tmpdir || !opt_mysql_tmpdir[0])
|
|
|
|
opt_mysql_tmpdir=(char*) P_tmpdir; /* purecov: inspected */
|
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
set_options();
|
2001-08-10 18:37:36 +02:00
|
|
|
get_options(*argcp, *argvp);
|
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
Ensured that all projects compile
Removed compiler warnings
Better setting of server_version variable.
Fix that make_win_src_distribution creates the privilege tables.
VC++Files/bdb/bdb.dsp:
Small, automatic changes
VC++Files/client/mysql.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/client/mysqladmin.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/client/mysqlclient.dsp:
Removed files that should only be used with mysql command line client
VC++Files/client/mysqldump.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/client/mysqlimport.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/client/mysqlshow.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/comp_err/comp_err.dsp:
Automatic changes
VC++Files/dbug/dbug.dsp:
Automatic changes
VC++Files/heap/heap.dsp:
automatic changes
VC++Files/innobase/innobase.dsp:
Automatic changes
VC++Files/isam/isam.dsp:
Automatic changes
VC++Files/isamchk/isamchk.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/libmysql/libmysql.dsp:
Automatic changes
VC++Files/libmysqld/examples/test_libmysqld.dsp:
Add missing files
VC++Files/libmysqld/libmysqld.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/libmysqltest/myTest.dsp:
Automatic changes
VC++Files/merge/merge.dsp:
Automatic changes
VC++Files/my_print_defaults/my_print_defaults.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/myisam/myisam.dsp:
automatic changes
VC++Files/myisam_ftdump/myisam_ftdump.dsp:
automatic changes
VC++Files/myisamchk/myisamchk.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/myisamlog/myisamlog.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/myisammrg/myisammrg.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/myisampack/myisampack.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/mysql.dsw:
Automatic changes
VC++Files/mysqlbinlog/mysqlbinlog.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/mysqlcheck/mysqlcheck.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/mysqldemb/mysqldemb.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/mysqlserver/mysqlserver.dsp:
Automatic changes
VC++Files/mysqlshutdown/mysqlshutdown.dsp:
Automatic changes
VC++Files/mysqlwatch/mysqlwatch.dsp:
Automatic changes
VC++Files/mysys/mysys.dsp:
Automatic changes
VC++Files/pack_isam/pack_isam.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/perror/perror.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/regex/regex.dsp:
Automatic changes
VC++Files/replace/replace.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/sql/mysqld.dsp:
Added support for projects 'classic', 'classic nt', 'pro' and 'pro nt'
VC++Files/strings/strings.dsp:
Removed duplicate code for strnlen
VC++Files/test1/test1.dsp:
Automatic changes
VC++Files/thr_test/thr_test.dsp:
Automatic changes
VC++Files/vio/vio.dsp:
Automatic changes
VC++Files/zlib/contrib/asm386/zlibvc.dsp:
Automatic changes
VC++Files/zlib/zlib.dsp:
Automatic changes
extra/my_print_defaults.c:
Fixed bug in --verbose
include/m_string.h:
Portability fix
include/mysql_embed.h:
Better setting of server_version variable
include/mysql_version.h.in:
Better license text handling
innobase/pars/pars0lex.l:
Remove compiler warnings
innobase/trx/trx0sys.c:
Remove compiler warnings
libmysqld/lib_sql.cc:
Better setting of server_version variable
libmysqld/libmysqld.def:
Add functions needed for mysql command line client
myisam/myisam_ftdump.c:
Remove compiler warnings
mysys/sha1.c:
Remove compiler warnings
scripts/make_win_src_distribution.sh:
Safety fix
scripts/mysql_install_db.sh:
Backport from 4.1 to allow make_win_src_distribution create the privilege tables
sql/Makefile.am:
Add new file mysqld_suffix.h
Remove not used file sql_olap.h
sql/ha_innodb.cc:
Remove not used variable
sql/mysqld.cc:
Better setting of server_version variable
sql/set_var.cc:
Fixed bug when showing lower_case_file_system
strings/ctype-tis620.c:
Remove compiler warnings
2004-05-19 15:38:12 +02:00
|
|
|
set_server_version();
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
DBUG_PRINT("info",("%s Ver %s for %s on %s\n",my_progname,
|
|
|
|
server_version, SYSTEM_TYPE,MACHINE_TYPE));
|
|
|
|
|
2003-03-10 11:06:21 +01:00
|
|
|
if (opt_error_log)
|
|
|
|
{
|
|
|
|
if (!log_error_file_ptr[0])
|
|
|
|
fn_format(log_error_file, glob_hostname, mysql_data_home, ".err", 0);
|
|
|
|
else
|
|
|
|
fn_format(log_error_file, log_error_file_ptr, mysql_data_home, ".err",
|
|
|
|
MY_UNPACK_FILENAME | MY_SAFE_PATH);
|
|
|
|
if (!log_error_file[0])
|
|
|
|
opt_error_log= 1; // Too long file name
|
|
|
|
else
|
|
|
|
{
|
|
|
|
freopen(log_error_file, "a+", stderr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
/* These must be set early */
|
|
|
|
|
2001-04-25 00:11:29 +02:00
|
|
|
(void) pthread_mutex_init(&LOCK_mysql_create_db,MY_MUTEX_INIT_SLOW);
|
|
|
|
(void) pthread_mutex_init(&LOCK_Acl,MY_MUTEX_INIT_SLOW);
|
|
|
|
(void) pthread_mutex_init(&LOCK_grant,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_open,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_thread_count,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_mapped_file,MY_MUTEX_INIT_SLOW);
|
|
|
|
(void) pthread_mutex_init(&LOCK_status,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_error_log,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_delayed_insert,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_delayed_status,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_delayed_create,MY_MUTEX_INIT_SLOW);
|
|
|
|
(void) pthread_mutex_init(&LOCK_manager,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_crypt,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_bytes_sent,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_bytes_received,MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_user_conn, MY_MUTEX_INIT_FAST);
|
2002-07-23 17:31:22 +02:00
|
|
|
(void) pthread_mutex_init(&LOCK_rpl_status, MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_active_mi, MY_MUTEX_INIT_FAST);
|
|
|
|
(void) pthread_mutex_init(&LOCK_global_system_variables, MY_MUTEX_INIT_FAST);
|
2001-04-11 13:04:03 +02:00
|
|
|
(void) pthread_cond_init(&COND_thread_count,NULL);
|
|
|
|
(void) pthread_cond_init(&COND_refresh,NULL);
|
|
|
|
(void) pthread_cond_init(&COND_thread_cache,NULL);
|
|
|
|
(void) pthread_cond_init(&COND_flush_thread_cache,NULL);
|
|
|
|
(void) pthread_cond_init(&COND_manager,NULL);
|
2002-07-23 17:31:22 +02:00
|
|
|
(void) pthread_cond_init(&COND_rpl_status, NULL);
|
2001-04-11 13:04:03 +02:00
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
if (set_default_charset_by_name(sys_charset.value, MYF(MY_WME)))
|
2001-10-02 04:53:00 +02:00
|
|
|
{
|
|
|
|
mysql_server_end();
|
|
|
|
return 1;
|
|
|
|
}
|
2001-04-11 13:04:03 +02:00
|
|
|
charsets_list = list_charsets(MYF(MY_COMPILED_SETS|MY_CONFIG_SETS));
|
|
|
|
|
|
|
|
/* Parameter for threads created for connections */
|
|
|
|
(void) pthread_attr_init(&connection_attrib);
|
|
|
|
(void) pthread_attr_setdetachstate(&connection_attrib,
|
|
|
|
PTHREAD_CREATE_DETACHED);
|
|
|
|
pthread_attr_setstacksize(&connection_attrib,thread_stack);
|
|
|
|
pthread_attr_setscope(&connection_attrib, PTHREAD_SCOPE_SYSTEM);
|
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
#if defined( SET_RLIMIT_NOFILE) || defined( OS2)
|
|
|
|
/* connections and databases needs lots of files */
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
|
|
|
uint wanted_files=10+(uint) max(max_connections*5,
|
|
|
|
max_connections+table_cache_size*2);
|
2002-07-23 17:31:22 +02:00
|
|
|
set_if_bigger(wanted_files, open_files_limit);
|
|
|
|
// Note that some system returns 0 if we succeed here:
|
2001-04-11 13:04:03 +02:00
|
|
|
uint files=set_maximum_open_files(wanted_files);
|
2002-07-23 17:31:22 +02:00
|
|
|
if (files && files < wanted_files && ! open_files_limit)
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
|
|
|
max_connections= (ulong) min((files-10),max_connections);
|
|
|
|
table_cache_size= (ulong) max((files-10-max_connections)/2,64);
|
|
|
|
DBUG_PRINT("warning",
|
|
|
|
("Changed limits: max_connections: %ld table_cache: %ld",
|
|
|
|
max_connections,table_cache_size));
|
|
|
|
sql_print_error("Warning: Changed limits: max_connections: %ld table_cache: %ld",max_connections,table_cache_size);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
unireg_init(opt_specialflag); /* Set up extern variabels */
|
|
|
|
init_errmessage(); /* Read error messages from file */
|
|
|
|
lex_init();
|
|
|
|
item_init();
|
2002-07-23 17:31:22 +02:00
|
|
|
set_var_init();
|
2001-04-11 13:04:03 +02:00
|
|
|
mysys_uses_curses=0;
|
|
|
|
#ifdef USE_REGEX
|
|
|
|
regex_init();
|
|
|
|
#endif
|
2001-12-15 05:00:01 +01:00
|
|
|
if (use_temp_pool && bitmap_init(&temp_pool,1024,1))
|
2001-10-02 04:53:00 +02:00
|
|
|
{
|
|
|
|
mysql_server_end();
|
|
|
|
return 1;
|
|
|
|
}
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
/*
|
2002-07-23 17:31:22 +02:00
|
|
|
We have enough space for fiddling with the argv, continue
|
2001-04-11 13:04:03 +02:00
|
|
|
*/
|
|
|
|
umask(((~my_umask) & 0666));
|
|
|
|
table_cache_init();
|
|
|
|
hostname_cache_init();
|
2002-07-23 17:31:22 +02:00
|
|
|
query_cache_result_size_limit(query_cache_limit);
|
|
|
|
query_cache_resize(query_cache_size);
|
2001-04-11 13:04:03 +02:00
|
|
|
randominit(&sql_rand,(ulong) start_time,(ulong) start_time/2);
|
|
|
|
reset_floating_point_exceptions();
|
|
|
|
init_thr_lock();
|
2001-10-02 04:53:00 +02:00
|
|
|
init_slave_list();
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
/* Setup log files */
|
|
|
|
if (opt_log)
|
2002-08-08 02:12:02 +02:00
|
|
|
open_log(&mysql_log, glob_hostname, opt_logname, ".log", NullS,
|
2003-07-06 17:59:54 +02:00
|
|
|
LOG_NORMAL, 0, 0, 0);
|
2001-04-11 13:04:03 +02:00
|
|
|
if (opt_update_log)
|
2001-10-02 04:53:00 +02:00
|
|
|
{
|
|
|
|
open_log(&mysql_update_log, glob_hostname, opt_update_logname, "",
|
2003-07-06 17:59:54 +02:00
|
|
|
NullS, LOG_NEW, 0, 0, 0);
|
2001-10-02 04:53:00 +02:00
|
|
|
using_update_log=1;
|
|
|
|
}
|
2001-12-06 13:10:51 +01:00
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
if (opt_slow_log)
|
2001-10-02 04:53:00 +02:00
|
|
|
open_log(&mysql_slow_log, glob_hostname, opt_slow_logname, "-slow.log",
|
2003-07-06 17:59:54 +02:00
|
|
|
NullS, LOG_NORMAL, 0, 0, 0);
|
2001-04-11 13:04:03 +02:00
|
|
|
if (ha_init())
|
|
|
|
{
|
|
|
|
sql_print_error("Can't init databases");
|
|
|
|
exit(1);
|
|
|
|
}
|
2001-10-02 04:53:00 +02:00
|
|
|
ha_key_cache();
|
2002-07-23 17:31:22 +02:00
|
|
|
#if defined(HAVE_MLOCKALL) && defined(MCL_CURRENT)
|
2001-04-11 13:04:03 +02:00
|
|
|
if (locked_in_memory && !geteuid())
|
|
|
|
{
|
|
|
|
if (mlockall(MCL_CURRENT))
|
|
|
|
{
|
|
|
|
sql_print_error("Warning: Failed to lock memory. Errno: %d\n",errno);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
locked_in_memory=1;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
locked_in_memory=0;
|
2003-01-27 00:14:12 +01:00
|
|
|
#endif
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
if (opt_myisam_log)
|
|
|
|
(void) mi_log( 1 );
|
2003-01-27 00:14:12 +01:00
|
|
|
ft_init_stopwords();
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
init signals & alarm
|
|
|
|
After this we can't quit by a simple unireg_abort
|
|
|
|
*/
|
|
|
|
error_handler_hook = my_message_sql;
|
|
|
|
if (pthread_key_create(&THR_THD,NULL) || pthread_key_create(&THR_NET,NULL) ||
|
|
|
|
pthread_key_create(&THR_MALLOC,NULL))
|
|
|
|
{
|
|
|
|
sql_print_error("Can't create thread-keys");
|
|
|
|
exit(1);
|
|
|
|
}
|
2001-10-02 04:53:00 +02:00
|
|
|
opt_noacl = 1; // No permissions
|
2002-10-29 20:59:03 +01:00
|
|
|
if (acl_init((THD*) 0,opt_noacl))
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
2001-10-02 04:53:00 +02:00
|
|
|
mysql_server_end();
|
|
|
|
return 1;
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
2002-07-23 17:31:22 +02:00
|
|
|
if (!opt_noacl)
|
2002-10-29 20:59:03 +01:00
|
|
|
(void) grant_init((THD*) 0);
|
2002-07-23 17:31:22 +02:00
|
|
|
init_max_user_conn();
|
2002-09-16 14:55:19 +02:00
|
|
|
init_update_queries();
|
2001-04-11 13:04:03 +02:00
|
|
|
|
|
|
|
#ifdef HAVE_DLOPEN
|
|
|
|
if (!opt_noacl)
|
|
|
|
udf_init();
|
|
|
|
#endif
|
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
if (opt_bin_log)
|
|
|
|
{
|
|
|
|
if (!opt_bin_logname)
|
|
|
|
{
|
|
|
|
char tmp[FN_REFLEN];
|
|
|
|
/* TODO: The following should be using fn_format(); We just need to
|
|
|
|
first change fn_format() to cut the file name if it's too long.
|
|
|
|
*/
|
|
|
|
strmake(tmp,glob_hostname,FN_REFLEN-5);
|
|
|
|
strmov(strcend(tmp,'.'),"-bin");
|
|
|
|
opt_bin_logname=my_strdup(tmp,MYF(MY_WME));
|
|
|
|
}
|
|
|
|
open_log(&mysql_bin_log, glob_hostname, opt_bin_logname, "-bin",
|
2003-07-06 17:59:54 +02:00
|
|
|
opt_binlog_index_name, LOG_BIN, 0, 0, max_binlog_size);
|
2002-07-23 17:31:22 +02:00
|
|
|
using_update_log=1;
|
|
|
|
}
|
|
|
|
|
2001-04-11 13:04:03 +02:00
|
|
|
(void) thr_setconcurrency(concurrency); // 10 by default
|
|
|
|
|
2001-10-02 04:53:00 +02:00
|
|
|
if (
|
|
|
|
#ifdef HAVE_BERKELEY_DB
|
|
|
|
!berkeley_skip ||
|
|
|
|
#endif
|
|
|
|
(flush_time && flush_time != ~(ulong) 0L))
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
|
|
|
pthread_t hThread;
|
|
|
|
if (pthread_create(&hThread,&connection_attrib,handle_manager,0))
|
|
|
|
sql_print_error("Warning: Can't create thread to manage maintenance");
|
|
|
|
}
|
2002-07-23 17:31:22 +02:00
|
|
|
|
2002-08-16 23:35:51 +02:00
|
|
|
/*
|
|
|
|
Update mysqld variables from client variables if set
|
|
|
|
The client variables are set also by get_one_option() in mysqld.cc
|
|
|
|
*/
|
|
|
|
if (max_allowed_packet)
|
|
|
|
global_system_variables.max_allowed_packet= max_allowed_packet;
|
|
|
|
if (net_buffer_length)
|
|
|
|
global_system_variables.net_buffer_length= net_buffer_length;
|
2001-10-02 04:53:00 +02:00
|
|
|
return 0;
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
|
|
|
|
2001-10-02 04:53:00 +02:00
|
|
|
|
2001-11-03 20:33:11 +01:00
|
|
|
void STDCALL mysql_server_end()
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
2002-12-05 15:38:49 +01:00
|
|
|
my_free((char*) copy_arguments_ptr, MYF(MY_ALLOW_ZERO_PTR));
|
|
|
|
copy_arguments_ptr=0;
|
2001-10-02 04:53:00 +02:00
|
|
|
clean_up(0);
|
2002-05-15 15:36:41 +02:00
|
|
|
/* If library called my_init(), free memory allocated by it */
|
|
|
|
if (!org_my_init_done)
|
|
|
|
my_end(0);
|
2001-08-10 18:37:36 +02:00
|
|
|
}
|
|
|
|
|
2001-11-03 20:33:11 +01:00
|
|
|
my_bool STDCALL mysql_thread_init()
|
2001-08-10 18:37:36 +02:00
|
|
|
{
|
|
|
|
#ifdef THREAD
|
2001-10-02 04:53:00 +02:00
|
|
|
return my_thread_init();
|
2001-08-10 18:37:36 +02:00
|
|
|
#else
|
2001-10-02 04:53:00 +02:00
|
|
|
return 0;
|
2001-08-10 18:37:36 +02:00
|
|
|
#endif
|
|
|
|
}
|
2001-04-11 13:04:03 +02:00
|
|
|
|
2001-11-03 20:33:11 +01:00
|
|
|
void STDCALL mysql_thread_end()
|
2001-08-10 18:37:36 +02:00
|
|
|
{
|
|
|
|
#ifdef THREAD
|
2001-10-02 04:53:00 +02:00
|
|
|
my_thread_end();
|
2001-08-10 18:37:36 +02:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void start_embedded_connection(NET * net)
|
|
|
|
{
|
2001-09-30 04:47:34 +02:00
|
|
|
start_embedded_conn1(net);
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
2001-09-30 04:47:34 +02:00
|
|
|
|
2001-10-02 04:53:00 +02:00
|
|
|
void end_embedded_connection(NET * net)
|
2001-04-11 13:04:03 +02:00
|
|
|
{
|
2001-10-02 04:53:00 +02:00
|
|
|
THD *thd = (THD *) net->vio->dest_thd;
|
|
|
|
delete thd;
|
2001-04-11 13:04:03 +02:00
|
|
|
}
|
2001-10-02 04:53:00 +02:00
|
|
|
|
|
|
|
} /* extern "C" */
|