php-src/ext/standard/dl.c

208 lines
5.6 KiB
C
Raw Normal View History

/*
+----------------------------------------------------------------------+
1999-07-16 21:13:16 +08:00
| PHP version 4.0 |
+----------------------------------------------------------------------+
| Copyright (c) 1997, 1998, 1999, 2000 The PHP Group |
+----------------------------------------------------------------------+
2000-02-20 07:41:32 +08:00
| This source file is subject to version 2.01 of the PHP license, |
1999-07-16 21:13:16 +08:00
| that is bundled with this package in the file LICENSE, and is |
| available at through the world-wide-web at |
2000-02-20 07:41:32 +08:00
| http://www.php.net/license/2_01.txt. |
1999-07-16 21:13:16 +08:00
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@php.net so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
| Authors: Brian Schaffner <brian@tool.net> |
| Shane Caraveo <shane@caraveo.com> |
| Zeev Suraski <zeev@zend.com> |
+----------------------------------------------------------------------+
*/
#include "php.h"
#include "dl.h"
#include "php_globals.h"
#ifdef HAVE_LIBDL
#include <stdlib.h>
#include <stdio.h>
2000-03-19 00:16:15 +08:00
#if HAVE_STRING_H
#include <string.h>
#else
#include <strings.h>
#endif
2000-02-11 23:59:30 +08:00
#ifdef PHP_WIN32
#include "win32/param.h"
#include "win32/winutil.h"
#else
#include <sys/param.h>
#endif
#endif
/* {{{ proto int dl(string extension_filename)
Load a PHP extension at runtime */
PHP_FUNCTION(dl)
{
pval **file;
PLS_FETCH();
/* obtain arguments */
1999-12-19 06:40:35 +08:00
if (ARG_COUNT(ht) != 1 || zend_get_parameters_ex(1, &file) == FAILURE) {
WRONG_PARAM_COUNT;
}
convert_to_string_ex(file);
if (!PG(enable_dl)) {
php_error(E_ERROR, "Dynamically loaded extentions aren't enabled.");
} else if (PG(safe_mode)) {
php_error(E_ERROR, "Dynamically loaded extensions aren't allowed when running in SAFE MODE.");
} else {
php_dl(*file,MODULE_TEMPORARY,return_value);
}
}
/* }}} */
#ifdef HAVE_LIBDL
#ifdef ZTS
#define USING_ZTS 1
#else
#define USING_ZTS 0
#endif
void php_dl(pval *file,int type,pval *return_value)
{
void *handle;
char *libpath;
zend_module_entry *module_entry,*tmp;
zend_module_entry *(*get_module)(void);
PLS_FETCH();
2000-02-05 23:16:12 +08:00
ELS_FETCH();
if (cfg_get_string("extension_dir",&PG(extension_dir))==SUCCESS
&& PG(extension_dir)
&& PG(extension_dir)[0]){
int extension_dir_len = strlen(PG(extension_dir));
libpath = emalloc(extension_dir_len+file->value.str.len+2);
sprintf(libpath,"%s/%s",PG(extension_dir),file->value.str.val);
} else {
2000-03-07 23:50:51 +08:00
libpath = estrndup(file->value.str.val, file->value.str.len);
}
/* load dynamic symbol */
handle = DL_LOAD(libpath);
if (!handle) {
1999-09-07 06:40:27 +08:00
int error_type;
if (type==MODULE_TEMPORARY) {
error_type = E_ERROR;
} else {
error_type = E_CORE_ERROR;
}
2000-02-11 23:59:30 +08:00
#ifdef PHP_WIN32
1999-12-18 06:34:04 +08:00
php_error(error_type,"Unable to load dynamic library '%s'<br>\n%s",libpath,php_win_err());
#else
1999-09-07 06:40:27 +08:00
php_error(error_type,"Unable to load dynamic library '%s' - %s",libpath,dlerror());
#endif
efree(libpath);
RETURN_FALSE;
}
efree(libpath);
get_module = (zend_module_entry *(*)(void)) DL_FETCH_SYMBOL(handle, "get_module");
/*
* some OS prepend _ to symbol names while their dynamic linker
* does not do that automatically. Thus we check manually for
* _get_module.
*/
if (!get_module)
get_module = (zend_module_entry *(*)(void)) DL_FETCH_SYMBOL(handle, "_get_module");
if (!get_module) {
DL_UNLOAD(handle);
1999-10-30 01:33:19 +08:00
php_error(E_CORE_WARNING,"Invalid library (maybe not a PHP library) '%s' ",file->value.str.val);
RETURN_FALSE;
}
module_entry = get_module();
2000-03-13 14:00:36 +08:00
if ((module_entry->zend_debug != ZEND_DEBUG) || (module_entry->zts != USING_ZTS)
|| (module_entry->zend_api != ZEND_MODULE_API_NO)) {
php_error(E_CORE_WARNING,
"%s: Unable to initialize module\n"
2000-03-13 14:00:36 +08:00
"Module compiled with debug=%d, thread-safety=%d module API=%d\n"
"PHP compiled with debug=%d, thread-safety=%d module API=%d\n"
"These options need to match\n",
2000-03-13 14:00:36 +08:00
module_entry->name, module_entry->zend_debug, module_entry->zts, module_entry->zend_api,
ZEND_DEBUG, USING_ZTS, ZEND_MODULE_API_NO);
DL_UNLOAD(handle);
RETURN_FALSE;
}
module_entry->type = type;
module_entry->module_number = zend_next_free_module();
if (module_entry->module_startup_func) {
2000-02-05 23:16:12 +08:00
if (module_entry->module_startup_func(type, module_entry->module_number ELS_CC)==FAILURE) {
php_error(E_CORE_WARNING,"%s: Unable to initialize module",module_entry->name);
DL_UNLOAD(handle);
RETURN_FALSE;
}
}
zend_register_module(module_entry);
if (module_entry->request_startup_func) {
2000-02-05 23:16:12 +08:00
if (module_entry->request_startup_func(type, module_entry->module_number ELS_CC)) {
php_error(E_CORE_WARNING,"%s: Unable to initialize module",module_entry->name);
DL_UNLOAD(handle);
RETURN_FALSE;
}
}
/* update the .request_started property... */
if (zend_hash_find(&module_registry,module_entry->name,strlen(module_entry->name)+1,(void **) &tmp)==FAILURE) {
php_error(E_ERROR,"%s: Loaded module got lost",module_entry->name);
RETURN_FALSE;
}
tmp->handle = handle;
RETURN_TRUE;
}
PHP_MINFO_FUNCTION(dl)
{
PUTS("Dynamic Library support enabled<br>.\n");
}
#else
void php_dl(pval *file,int type,pval *return_value)
{
php_error(E_WARNING,"Cannot dynamically load %s - dynamic modules are not supported",file->value.str.val);
RETURN_FALSE;
}
PHP_MINFO_FUNCTION(dl)
{
PUTS("Dynamic Library support not available<br>.\n");
}
#endif
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* End:
*/