summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Ing-Simmons <nik@tiuk.ti.com>2000-12-11 19:09:51 +0000
committerNick Ing-Simmons <nik@tiuk.ti.com>2000-12-11 19:09:51 +0000
commita5262162c2c854ee96768d32ed06a8df25b95505 (patch)
tree13952ba5d1d4b7fef3c0d7da3f272519e8a6f376
parent33af2bc731cf870df7b094c6b3d116322b4b493f (diff)
downloadperl-a5262162c2c854ee96768d32ed06a8df25b95505.tar.gz
Restore mmap function (broken by tweaks to shared buffer
layer for encode(xxxx)). p4raw-id: //depot/perlio@8082
-rw-r--r--perlio.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/perlio.c b/perlio.c
index f4a86d8967..bd421c6780 100644
--- a/perlio.c
+++ b/perlio.c
@@ -1873,7 +1873,7 @@ PerlIOBuf_flush(PerlIO *f)
if (PerlIOBase(f)->flags & PERLIO_F_WRBUF)
{
/* write() the buffer */
- STDCHAR *buf = PerlIO_get_base(f);
+ STDCHAR *buf = b->buf;
STDCHAR *p = buf;
int count;
PerlIO *n = PerlIONext(f);
@@ -1920,7 +1920,6 @@ PerlIOBuf_fill(PerlIO *f)
{
PerlIOBuf *b = PerlIOSelf(f,PerlIOBuf);
PerlIO *n = PerlIONext(f);
- STDCHAR *buf;
SSize_t avail;
/* FIXME: doing the down-stream flush is a bad idea if it causes
pre-read data in stdio buffer to be discarded
@@ -1933,7 +1932,10 @@ PerlIOBuf_fill(PerlIO *f)
if (PerlIO_flush(f) != 0)
return -1;
- b->ptr = b->end = buf = PerlIO_get_base(f);
+ if (!b->buf)
+ PerlIO_get_base(f); /* allocate via vtable */
+
+ b->ptr = b->end = b->buf;
if (PerlIO_fast_gets(n))
{
/* Layer below is also buffered
@@ -1975,7 +1977,7 @@ PerlIOBuf_fill(PerlIO *f)
PerlIOBase(f)->flags |= PERLIO_F_ERROR;
return -1;
}
- b->end = buf+avail;
+ b->end = b->buf+avail;
PerlIOBase(f)->flags |= PERLIO_F_RDBUF;
return 0;
}
@@ -2752,12 +2754,15 @@ PerlIOMmap_map(PerlIO *f)
}
posn = (b->posn / page_size) * page_size;
len = st.st_size - posn;
- m->mptr = mmap(NULL, len, PROT_READ, MAP_PRIVATE, fd, posn);
+ m->mptr = mmap(NULL, len, PROT_READ, MAP_SHARED, fd, posn);
if (m->mptr && m->mptr != (Mmap_t) -1)
{
-#if defined(HAS_MADVISE) && defined(MADV_SEQUENTIAL)
+#if 0 && defined(HAS_MADVISE) && defined(MADV_SEQUENTIAL)
madvise(m->mptr, len, MADV_SEQUENTIAL);
#endif
+#if 0 && defined(HAS_MADVISE) && defined(MADV_WILLNEED)
+ madvise(m->mptr, len, MADV_WILLNEED);
+#endif
PerlIOBase(f)->flags = (flags & ~PERLIO_F_EOF) | PERLIO_F_RDBUF;
b->end = ((STDCHAR *)m->mptr) + len;
b->buf = ((STDCHAR *)m->mptr) + (b->posn - posn);