~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/sql_connect.cc

Merging Eric's refactoring and cleanup of Listen and Protocol

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 *  Copyright (C) 2008 Sun Microsystems
5
 
 *
6
 
 *  This program is free software; you can redistribute it and/or modify
7
 
 *  it under the terms of the GNU General Public License as published by
8
 
 *  the Free Software Foundation; version 2 of the License.
9
 
 *
10
 
 *  This program 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
13
 
 *  GNU General Public License for more details.
14
 
 *
15
 
 *  You should have received a copy of the GNU General Public License
16
 
 *  along with this program; if not, write to the Free Software
17
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
 
 */
19
 
 
20
 
 
21
 
/*
22
 
  Functions to autenticate and handle reqests for a connection
23
 
*/
24
 
#include <drizzled/server_includes.h>
25
 
 
26
 
#include <drizzled/error.h>
27
 
#include <drizzled/sql_parse.h>
28
 
#include <drizzled/scheduling.h>
29
 
#include <drizzled/session.h>
30
 
#include <drizzled/connect.h>
31
 
 
32
 
 
33
 
/*
34
 
  Thread handler for a connection
35
 
 
36
 
  SYNOPSIS
37
 
    handle_one_connection()
38
 
    arg         Connection object (Session)
39
 
 
40
 
  IMPLEMENTATION
41
 
    This function (normally) does the following:
42
 
    - Initialize thread
43
 
    - Initialize Session to be used with this thread
44
 
    - Authenticate user
45
 
    - Execute all queries sent on the connection
46
 
    - Take connection down
47
 
    - End thread  / Handle next connection using thread from thread cache
48
 
*/
49
 
pthread_handler_t handle_one_connection(void *arg)
50
 
{
51
 
  Session *session= static_cast<Session*>(arg);
52
 
 
53
 
  Scheduler &thread_scheduler= get_thread_scheduler();
54
 
  if (thread_scheduler.init_new_connection_thread())
55
 
  {
56
 
    session->disconnect(ER_OUT_OF_RESOURCES, true);
57
 
    statistic_increment(aborted_connects,&LOCK_status);
58
 
    thread_scheduler.end_thread(session,0);
59
 
    return 0;
60
 
  }
61
 
 
62
 
  /*
63
 
    handle_one_connection() is normally the only way a thread would
64
 
    start and would always be on the very high end of the stack ,
65
 
    therefore, the thread stack always starts at the address of the
66
 
    first local variable of handle_one_connection, which is session. We
67
 
    need to know the start of the stack so that we could check for
68
 
    stack overruns.
69
 
  */
70
 
  session->thread_stack= (char*) &session;
71
 
  if (! session->initGlobals())
72
 
    return 0;
73
 
 
74
 
  for (;;)
75
 
  {
76
 
    if (! session->authenticate())
77
 
      goto end_thread;
78
 
 
79
 
    session->prepareForQueries();
80
 
 
81
 
    while (!session->protocol->haveError() &&
82
 
           !(session->killed == Session::KILL_CONNECTION))
83
 
    {
84
 
      if (! session->executeStatement())
85
 
              break;
86
 
    }
87
 
 
88
 
end_thread:
89
 
    session->disconnect(0, true);
90
 
    if (thread_scheduler.end_thread(session, 1))
91
 
      return 0;                                 // Probably no-threads
92
 
 
93
 
    /*
94
 
      If end_thread() returns, we are either running with
95
 
      thread-handler=no-threads or this thread has been schedule to
96
 
      handle the next connection.
97
 
    */
98
 
    session= current_session;
99
 
    session->thread_stack= (char*) &session;
100
 
  }
101
 
}