summaryrefslogtreecommitdiff
path: root/ext/sysvshm
diff options
context:
space:
mode:
authorThies C. Arntzen <thies@php.net>1999-08-09 15:03:09 +0000
committerThies C. Arntzen <thies@php.net>1999-08-09 15:03:09 +0000
commit5d2206d3af9e2ef8acf8712bc296f5e0c65609d2 (patch)
tree8cfe09231a400e4ce81155d5e3c9ae569ad3a698 /ext/sysvshm
parent3d8bd038d25211301ccc0b9daa12d4b4bbd6ecdf (diff)
downloadphp-git-5d2206d3af9e2ef8acf8712bc296f5e0c65609d2.tar.gz
fixed sysv_shm*
Diffstat (limited to 'ext/sysvshm')
-rw-r--r--ext/sysvshm/sysvshm.c39
1 files changed, 10 insertions, 29 deletions
diff --git a/ext/sysvshm/sysvshm.c b/ext/sysvshm/sysvshm.c
index 44d8b3128a..0b9b2b3276 100644
--- a/ext/sysvshm/sysvshm.c
+++ b/ext/sysvshm/sysvshm.c
@@ -29,7 +29,7 @@
#include <errno.h>
#include "php3_sysvshm.h"
-
+#include "../standard/php3_var.h"
function_entry sysvshm_functions[] = {
{"shm_attach", php3_sysvshm_attach, NULL},
@@ -53,15 +53,13 @@ php3_module_entry *get_module() { return &sysvshm_module_entry; }
THREAD_LS sysvshm_module php3_sysvshm_module;
-
-
-static void php3i_release_sysvshm(sysvshm_shm *shm_ptr) {
-
+static void php3i_release_sysvshm(sysvshm_shm *shm_ptr)
+{
shmdt((void*)shm_ptr->ptr);
+ efree(shm_ptr);
}
-
int php3_minit_sysvshm(INIT_FUNC_ARGS)
{
php3_sysvshm_module.le_shm = register_list_destructors(php3i_release_sysvshm, NULL);
@@ -171,9 +169,6 @@ PHP_FUNCTION(sysvshm_detach)
{
pval *arg_id;
long id;
- sysvshm_shm *shm_list_ptr;
- int type;
-
switch (ARG_COUNT(ht)) {
case 1:
@@ -188,23 +183,9 @@ PHP_FUNCTION(sysvshm_detach)
break;
}
- shm_list_ptr = (sysvshm_shm *) php3_list_find(id, &type);
- if (type!=php3_sysvshm_module.le_shm) {
- php_error(E_WARNING, "%d is not a SysV shared memory index", id);
- RETURN_FALSE;
- }
-
- if(shmdt((void*)shm_list_ptr->ptr)<0) {
- php_error(E_WARNING, "shm_detach() failed for id 0x%x: %s", id, strerror(errno));
- RETURN_FALSE;
- }
+ php3_list_delete(id);
}
/* }}} */
-
-
-
-
-
/* {{{ proto int shm_remove(int key)
removes the shared memory with the given key. */
PHP_FUNCTION(sysvshm_remove)
@@ -227,7 +208,6 @@ PHP_FUNCTION(sysvshm_remove)
break;
}
-
if((id=shmget(key,0,0))<0) {
php_error(E_WARNING, "%d is not a existing SysV shared memory key", key);
RETURN_FALSE;
@@ -236,6 +216,7 @@ PHP_FUNCTION(sysvshm_remove)
php_error(E_WARNING, "shm_remove() failed for key 0x%x: %s", key, strerror(errno));
RETURN_FALSE;
}
+
RETURN_TRUE;
}
/* }}} */
@@ -275,11 +256,11 @@ PHP_FUNCTION(sysvshm_put_var)
}
/* setup string-variable and serialize */
+
shm_var.type=IS_STRING;
shm_var.value.str.len=0;
- shm_var.value.str.val=emalloc(1);
- shm_var.value.str.val[0]=0;
- php3api_var_serialize(&shm_var,arg_var);
+ shm_var.value.str.val=0;
+ php3api_var_serialize(&shm_var,&arg_var);
/* insert serialized variable into shared memory */
ret=php3int_put_shmdata(shm_list_ptr->ptr,key,shm_var.value.str.val,shm_var.value.str.len);
@@ -341,7 +322,7 @@ PHP_FUNCTION(sysvshm_get_var)
shm_var=(sysvshm_chunk*)((char*)shm_list_ptr->ptr+shm_varpos);
shm_data=&shm_var->mem;
- if(php3api_var_unserialize(return_value, &shm_data, shm_data+shm_var->length)!=1) {
+ if(php3api_var_unserialize(&return_value, (const char **) &shm_data, shm_data+shm_var->length)!=1) {
php_error(E_WARNING, "variable data in shared memory is corruped");
RETURN_FALSE;
}