summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--doio.c13
-rw-r--r--embed.h13
-rwxr-xr-xembed.pl5
-rw-r--r--makedef.pl5
-rw-r--r--perl.h10
-rw-r--r--pp_sys.c3
-rw-r--r--proto.h5
-rwxr-xr-xt/lib/io_sock.t2
8 files changed, 45 insertions, 11 deletions
diff --git a/doio.c b/doio.c
index bd4d353f00..3c0bcf1119 100644
--- a/doio.c
+++ b/doio.c
@@ -60,9 +60,6 @@ typedef struct __s64_iobuffer {
int *buffer; /* the buffer */
} S64_IOB;
-static S64_IOB *_s64_get_buffer( PerlIO *f);
-static S64_IOB *_s64_create_buffer( PerlIO *f);
-static int _s64_malloc( S64_IOB *ptr);
#endif
bool
@@ -2094,6 +2091,12 @@ Perl_do_shmio(pTHX_ I32 optype, SV **mark, SV **sp)
static S64_IOB *s64_buffer = (S64_IOB *) NULL;
+/* initialize the buffer area */
+/* required after a fork(2) call in order to remove side effects */
+void Perl_do_s64_init_buffer() {
+ s64_buffer = (S64_IOB *) NULL;
+}
+
/* get a buffered stream pointer */
static S64_IOB *S_s64_get_buffer( PerlIO *fp) {
S64_IOB *ptr = s64_buffer;
@@ -2103,7 +2106,7 @@ static S64_IOB *S_s64_get_buffer( PerlIO *fp) {
}
/* create a buffered stream pointer */
-static S64_IOB *_s64_create_buffer( PerlIO *f) {
+static S64_IOB *S_s64_create_buffer( PerlIO *f) {
S64_IOB *ptr = malloc( sizeof( S64_IOB));
if( ptr) {
ptr->fp = f;
@@ -2135,7 +2138,7 @@ void Perl_do_s64_delete_buffer( PerlIO *f) {
/* internal buffer management */
#define _S64_BUFFER_SIZE 32
-static int _s64_malloc( S64_IOB *ptr) {
+static int S_s64_malloc( S64_IOB *ptr) {
if( ptr) {
if( !ptr->buffer) {
ptr->buffer = (int *) calloc( _S64_BUFFER_SIZE, sizeof( int));
diff --git a/embed.h b/embed.h
index b7db7c0869..80d6537fab 100644
--- a/embed.h
+++ b/embed.h
@@ -195,6 +195,8 @@
#define do_vop Perl_do_vop
#if defined(SOCKS_64BIT_BUG)
#define s64_get_buffer S_s64_get_buffer
+#define s64_create_buffer S_s64_create_buffer
+#define s64_malloc S_s64_malloc
#endif
#define dofile Perl_dofile
#define dowantarray Perl_dowantarray
@@ -1666,6 +1668,8 @@
#define do_vop(a,b,c,d) Perl_do_vop(aTHX_ a,b,c,d)
#if defined(SOCKS_64BIT_BUG)
#define s64_get_buffer(a) S_s64_get_buffer(aTHX_ a)
+#define s64_create_buffer(a) S_s64_create_buffer(aTHX_ a)
+#define s64_malloc(a) S_s64_malloc(aTHX_ a)
#endif
#define dofile(a) Perl_dofile(aTHX_ a)
#define dowantarray() Perl_dowantarray(aTHX)
@@ -3262,14 +3266,19 @@
#define Perl_do_vop CPerlObj::Perl_do_vop
#define do_vop Perl_do_vop
#if defined(SOCKS_64BIT_BUG)
-#define S_s64_get_buffer CPerlObj::S_s64_get_buffer
-#define s64_get_buffer S_s64_get_buffer
#define do_s64_tell Perl_do_s64_tell
#define do_s64_fread Perl_do_s64_fread
#define do_s64_getc Perl_do_s64_getc
#define do_s64_seek Perl_do_s64_seek
#define do_s64_ungetc Perl_do_s64_ungetc
#define do_s64_delete_buffer Perl_do_s64_delete_buffer
+#define do_s64_init_buffer Perl_do_s64_init_buffer
+#define S_s64_get_buffer CPerlObj::S_s64_get_buffer
+#define s64_get_buffer S_s64_get_buffer
+#define S_s64_create_buffer CPerlObj::S_s64_create_buffer
+#define s64_create_buffer S_s64_create_buffer
+#define S_s64_malloc CPerlObj::S_s64_malloc
+#define s64_malloc S_s64_malloc
#endif
#define Perl_dofile CPerlObj::Perl_dofile
#define dofile Perl_dofile
diff --git a/embed.pl b/embed.pl
index 498ab5c35b..7e06389e90 100755
--- a/embed.pl
+++ b/embed.pl
@@ -1506,13 +1506,16 @@ p |UV |do_vecget |SV* sv|I32 offset|I32 size
p |void |do_vecset |SV* sv
p |void |do_vop |I32 optype|SV* sv|SV* left|SV* right
#if defined(SOCKS_64BIT_BUG)
-s |S64_IOB*|s64_get_buffer|PerlIO* fp
Ajnop |Off_t |do_s64_tell |PerlIO* fp
Ajnop |SSize_t|do_s64_fread |void *buf|SSize_t count|PerlIO* fp
Ajnop |int |do_s64_getc |PerlIO* fp
Ajnop |int |do_s64_seek |PerlIO* fp|Off_t pos|int whence
Ajnop |int |do_s64_ungetc |int ch|PerlIO* fp
Ajnop |void |do_s64_delete_buffer|PerlIO* fp
+Ajnop |void |do_s64_init_buffer
+s |S64_IOB * |s64_get_buffer |PerlIO *f
+s |S64_IOB * |s64_create_buffer |PerlIO *f
+s |int |s64_malloc |S64_IOB *ptr
#endif
p |OP* |dofile |OP* term
Ap |I32 |dowantarray
diff --git a/makedef.pl b/makedef.pl
index bf43e665b2..2cc9a09279 100644
--- a/makedef.pl
+++ b/makedef.pl
@@ -480,12 +480,13 @@ unless ($define{'FAKE_THREADS'}) {
# All quad int platforms are assumed to have broken SOCKS
unless ($define{USE_SOCKS} && $define{USE_64_BIT_ALL}) {
skip_symbols [qw(
+ Perl_do_s64_delete_buffer
Perl_do_s64_fread
Perl_do_s64_getc
- Perl_do_s64_delete_buffer
+ Perl_do_s64_init_buffer
Perl_do_s64_seek
Perl_do_s64_tell
- Perl_do_s64_tell
+ Perl_do_s64_ungetc
)];
}
diff --git a/perl.h b/perl.h
index de6185b401..f17f3a9136 100644
--- a/perl.h
+++ b/perl.h
@@ -3443,6 +3443,16 @@ typedef struct am_table_short AMTS;
# include <libutil.h> /* setproctitle() in some FreeBSDs */
#endif
+#ifdef SOCKS_64BIT_BUG
+typedef struct __s64_iobuffer {
+ struct __s64_iobuffer *next, *last; /* Queue pointer */
+ PerlIO *fp; /* Assigned file pointer */
+ int cnt; /* Buffer counter */
+ int size; /* Buffer size */
+ int *buffer; /* The buffer */
+} S64_IOB;
+#endif
+
/* and finally... */
#define PERL_PATCHLEVEL_H_IMPLICIT
#include "patchlevel.h"
diff --git a/pp_sys.c b/pp_sys.c
index 12c368dea3..2194653a1f 100644
--- a/pp_sys.c
+++ b/pp_sys.c
@@ -3724,6 +3724,9 @@ PP(pp_fork)
if (childpid < 0)
RETSETUNDEF;
if (!childpid) {
+#ifdef SOCKS_64BIT_BUG
+ Perl_do_s64_init_buffer();
+#endif
/*SUPPRESS 560*/
if ((tmpgv = gv_fetchpv("$", TRUE, SVt_PV)))
sv_setiv(GvSV(tmpgv), (IV)PerlProc_getpid());
diff --git a/proto.h b/proto.h
index 664336b6e7..bec0bf530d 100644
--- a/proto.h
+++ b/proto.h
@@ -248,13 +248,16 @@ PERL_CALLCONV UV Perl_do_vecget(pTHX_ SV* sv, I32 offset, I32 size);
PERL_CALLCONV void Perl_do_vecset(pTHX_ SV* sv);
PERL_CALLCONV void Perl_do_vop(pTHX_ I32 optype, SV* sv, SV* left, SV* right);
#if defined(SOCKS_64BIT_BUG)
-STATIC S64_IOB* S_s64_get_buffer(pTHX_ PerlIO* fp);
PERL_CALLCONV Off_t Perl_do_s64_tell(PerlIO* fp);
PERL_CALLCONV SSize_t Perl_do_s64_fread(void *buf, SSize_t count, PerlIO* fp);
PERL_CALLCONV int Perl_do_s64_getc(PerlIO* fp);
PERL_CALLCONV int Perl_do_s64_seek(PerlIO* fp, Off_t pos, int whence);
PERL_CALLCONV int Perl_do_s64_ungetc(int ch, PerlIO* fp);
PERL_CALLCONV void Perl_do_s64_delete_buffer(PerlIO* fp);
+PERL_CALLCONV void Perl_do_s64_init_buffer(void);
+STATIC S64_IOB * S_s64_get_buffer(pTHX_ PerlIO *f);
+STATIC S64_IOB * S_s64_create_buffer(pTHX_ PerlIO *f);
+STATIC int S_s64_malloc(pTHX_ S64_IOB *ptr);
#endif
PERL_CALLCONV OP* Perl_dofile(pTHX_ OP* term);
PERL_CALLCONV I32 Perl_dowantarray(pTHX);
diff --git a/t/lib/io_sock.t b/t/lib/io_sock.t
index 45c16c2a23..4ac4e352ce 100755
--- a/t/lib/io_sock.t
+++ b/t/lib/io_sock.t
@@ -156,6 +156,8 @@ if($pid = fork()) {
if ($sock) {
$sock->print("ok 11\n");
$sock->print("quit\n");
+ } else {
+ print "not ok 11\n";
}
$sock = undef;
sleep(1);