2003-08-13 01:53:07 +00:00
/*
Unix SMB / CIFS implementation .
process model manager - main loop
Copyright ( C ) Andrew Tridgell 1992 - 2003
Copyright ( C ) James J Myers 2003 < myersjj @ samba . org >
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2003-08-13 01:53:07 +00:00
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2003-08-13 01:53:07 +00:00
*/
# include "includes.h"
2006-03-26 01:23:40 +00:00
# include "smbd/process_model.h"
2007-09-08 12:42:09 +00:00
# include "param/param.h"
2011-09-09 21:24:49 +10:00
# include "lib/util/samba_modules.h"
2003-08-13 01:53:07 +00:00
2010-10-30 11:24:15 +11:00
/* the list of currently registered process models */
static struct process_model {
2010-11-03 20:57:38 +11:00
const struct model_ops * ops ;
2010-10-30 11:24:15 +11:00
bool initialised ;
} * models = NULL ;
static int num_models ;
/*
return the operations structure for a named backend of the specified type
*/
static struct process_model * process_model_byname ( const char * name )
{
int i ;
for ( i = 0 ; i < num_models ; i + + ) {
if ( strcmp ( models [ i ] . ops - > name , name ) = = 0 ) {
return & models [ i ] ;
}
}
return NULL ;
}
2008-09-22 18:15:24 +02:00
2004-06-23 23:44:50 +00:00
/*
setup the events for the chosen process model
*/
2010-10-30 11:24:15 +11:00
_PUBLIC_ const struct model_ops * process_model_startup ( const char * model )
2004-06-23 23:44:50 +00:00
{
2010-10-30 11:24:15 +11:00
struct process_model * m ;
2004-06-23 23:44:50 +00:00
2010-10-30 11:24:15 +11:00
m = process_model_byname ( model ) ;
if ( m = = NULL ) {
2004-06-23 23:44:50 +00:00
DEBUG ( 0 , ( " Unknown process model '%s' \n " , model ) ) ;
exit ( - 1 ) ;
}
2010-10-30 11:24:15 +11:00
if ( ! m - > initialised ) {
m - > initialised = true ;
m - > ops - > model_init ( ) ;
}
2004-06-23 23:44:50 +00:00
2010-10-30 11:24:15 +11:00
return m - > ops ;
2004-06-23 23:44:50 +00:00
}
2003-08-13 01:53:07 +00:00
/*
register a process model .
The ' name ' can be later used by other backends to find the operations
structure for this backend .
*/
2010-11-03 20:57:38 +11:00
_PUBLIC_ NTSTATUS register_process_model ( const struct model_ops * ops )
2003-08-13 01:53:07 +00:00
{
2004-02-02 13:43:03 +00:00
if ( process_model_byname ( ops - > name ) ! = NULL ) {
2003-08-13 01:53:07 +00:00
/* its already registered! */
2004-02-02 13:43:03 +00:00
DEBUG ( 0 , ( " PROCESS_MODEL '%s' already registered \n " ,
ops - > name ) ) ;
return NT_STATUS_OBJECT_NAME_COLLISION ;
2003-08-13 01:53:07 +00:00
}
2010-11-03 20:57:38 +11:00
models = talloc_realloc ( NULL , models , struct process_model , num_models + 1 ) ;
2003-08-13 01:53:07 +00:00
if ( ! models ) {
smb_panic ( " out of memory in register_process_model " ) ;
}
2010-11-03 20:57:38 +11:00
models [ num_models ] . ops = ops ;
2010-11-02 20:55:18 +11:00
models [ num_models ] . initialised = false ;
2003-08-13 01:53:07 +00:00
num_models + + ;
2010-11-03 20:57:38 +11:00
DEBUG ( 3 , ( " PROCESS_MODEL '%s' registered \n " , ops - > name ) ) ;
2004-02-02 13:43:03 +00:00
return NT_STATUS_OK ;
2003-08-13 01:53:07 +00:00
}
2008-04-02 04:53:27 +02:00
_PUBLIC_ NTSTATUS process_model_init ( struct loadparm_context * lp_ctx )
2005-12-26 16:46:55 +00:00
{
2010-11-01 14:58:32 +11:00
# define _MODULE_PROTO(init) extern NTSTATUS init(void);
STATIC_process_model_MODULES_PROTO ;
init_module_fn static_init [ ] = { STATIC_process_model_MODULES } ;
init_module_fn * shared_init ;
2010-10-30 23:42:27 +11:00
static bool initialised ;
2005-12-26 16:46:55 +00:00
2010-11-01 14:58:32 +11:00
if ( initialised ) {
return NT_STATUS_OK ;
2010-10-30 23:42:27 +11:00
}
2010-11-01 14:58:32 +11:00
initialised = true ;
2011-06-06 14:58:28 +10:00
shared_init = load_samba_modules ( NULL , " process_model " ) ;
2005-12-26 16:46:55 +00:00
2010-11-01 14:58:32 +11:00
run_init_functions ( static_init ) ;
run_init_functions ( shared_init ) ;
talloc_free ( shared_init ) ;
2005-12-26 16:46:55 +00:00
return NT_STATUS_OK ;
}
2004-02-02 13:43:03 +00:00
/*
return the PROCESS_MODEL module version , and the size of some critical types
This can be used by process model modules to either detect compilation errors , or provide
multiple implementations for different smbd compilation options in one module
*/
const struct process_model_critical_sizes * process_model_version ( void )
{
static const struct process_model_critical_sizes critical_sizes = {
PROCESS_MODEL_VERSION ,
2005-02-03 02:35:52 +00:00
sizeof ( struct model_ops )
2004-02-02 13:43:03 +00:00
} ;
return & critical_sizes ;
}