1Mmap(3)               User Contributed Perl Documentation              Mmap(3)
2
3
4

NAME

6       Sys::Mmap - uses mmap to map in a file as a Perl variable
7

SYNOPSIS

9           use Sys::Mmap;
10
11           Sys::Mmap->new( my $str, 8192, 'structtest2.pl' ) or die $!;
12           Sys::Mmap->new( $var, 8192 ) or die $!;
13
14           mmap( $foo, 0, PROT_READ, MAP_SHARED, FILEHANDLE ) or die "mmap: $!";
15           @tags = $foo =~ /<(.*?)>/g;
16           munmap($foo) or die "munmap: $!";
17
18           mmap( $bar, 8192, PROT_READ | PROT_WRITE, MAP_SHARED, FILEHANDLE );
19           substr( $bar, 1024, 11 ) = "Hello world";
20
21           mmap( $baz, 8192, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANON, STDOUT );
22
23           $addr = mmap( $baz, 8192, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANON, STDOUT );
24           Sys::Mmap::hardwire( $qux, $addr, 8192 );
25

DESCRIPTION

27       The Sys::Mmap module uses the POSIX mmap
28       <https://en.wikipedia.org/wiki/Mmap> call to map in a file as a Perl
29       variable.  Memory access by mmap may be shared between threads or
30       forked processes, and may be a disc file that has been mapped into
31       memory.  Sys::Mmap depends on your operating system supporting UNIX or
32       POSIX.1b mmap, of course.
33
34       Note that PerlIO now defines a ":mmap" tag and presents mmap'd files as
35       regular files, if that is your cup of joe.
36
37       Several processes may share one copy of the file or string, saving
38       memory, and concurrently making changes to portions of the file or
39       string. When not used with a file, it is an alternative to SysV shared
40       memory. Unlike SysV shared memory, there are no arbitrary size limits
41       on the shared memory area, and sparse memory usage is handled optimally
42       on most modern UNIX implementations.
43
44       Using the new() method provides a tie()'d interface to mmap() that
45       allows you to use the variable as a normal variable. If a filename is
46       provided, the file is opened and mapped in. If the file is smaller than
47       the length provided, the file is grown to that length.  If no filename
48       is provided, anonymous shared inheritable memory is used. Assigning to
49       the variable will replace a section in the file corresponding to the
50       length of the variable, leaving the remainder of the file intact and
51       unmodified. Using substr() allows you to access the file at an offset,
52       and does not place any requirements on the length argument to substr()
53       or the length of the variable being inserted, provided it does not
54       exceed the length of the memory region. This protects you from the
55       pathological cases involved in using mmap() directly, documented below.
56
57       When calling mmap() or hardwire() directly, you need to be careful how
58       you use the variable. Some programming constructs may create copies of
59       a string which, while unimportant for smallish strings, are far less
60       welcome if you're mapping in a file which is a few gigabytes big. If
61       you use "PROT_WRITE" and attempt to write to the file via the variable
62       you need to be even more careful.  One of the few ways in which you can
63       safely write to the string in-place is by using substr() as an lvalue
64       and ensuring that the part of the string that you replace is exactly
65       the same length.  Other functions will allocate other storage for the
66       variable, and it will no longer overlay the mapped in file.
67
68       Sys::Mmap->new( "VARIABLE", "LENGTH", "OPTIONALFILENAME" )
69           Maps "LENGTH" bytes of (the contents of) "OPTIONALFILENAME" if
70           "OPTIONALFILENAME" is provided, otherwise uses anonymous, shared
71           inheritable memory. This memory region is inherited by any fork()ed
72           children.  "VARIABLE" will now refer to the contents of that file.
73           Any change to "VARIABLE" will make an identical change to the file.
74           If "LENGTH" is zero and a file is specified, the current length of
75           the file will be used.  If "LENGTH" is larger then the file, and
76           "OPTIONALFILENAME" is provided, the file is grown to that length
77           before being mapped.  This is the preferred interface, as it
78           requires much less caution in handling the variable.  "VARIABLE"
79           will be tied into the "Sys::Mmap" package, and mmap() will be
80           called for you.
81
82           Assigning to "VARIABLE" will overwrite the beginning of the file
83           for a length of the value being assigned in. The rest of the file
84           or memory region after that point will be left intact.  You may use
85           substr() to assign at a given position:
86
87               substr(VARIABLE, POSITION, LENGTH) = NEWVALUE
88
89       mmap(VARIABLE, LENGTH, PROTECTION, FLAGS, FILEHANDLE, OFFSET)
90           Maps "LENGTH" bytes of (the underlying contents of) "FILEHANDLE"
91           into your address space, starting at offset "OFFSET" and makes
92           "VARIABLE" refer to that memory. The "OFFSET" argument can be
93           omitted in which case it defaults to zero. The "LENGTH" argument
94           can be zero in which case a stat is done on "FILEHANDLE" and the
95           size of the underlying file is used instead.
96
97           The "PROTECTION" argument should be some ORed combination of the
98           constants "PROT_READ", "PROT_WRITE" and "PROT_EXEC", or else
99           "PROT_NONE". The constants "PROT_EXEC" and "PROT_NONE" are unlikely
100           to be useful here but are included for completeness.
101
102           The "FLAGS" argument must include either "MAP_SHARED" or
103           "MAP_PRIVATE" (the latter is unlikely to be useful here).  If your
104           platform supports it, you may also use "MAP_ANON" or
105           "MAP_ANONYMOUS".  If your platform supplies "MAP_FILE" as a non-
106           zero constant (necessarily non-POSIX) then you should also include
107           that in "FLAGS".  POSIX.1b does not specify "MAP_FILE" as a "FLAG"
108           argument and most if not all versions of Unix have "MAP_FILE" as
109           zero.
110
111           mmap returns "undef" on failure, and the address in memory where
112           the variable was mapped to on success.
113
114       munmap(VARIABLE)
115           Unmaps the part of your address space which was previously mapped
116           in with a call to "mmap(VARIABLE, ...)" and makes VARIABLE become
117           undefined.
118
119           munmap returns 1 on success and undef on failure.
120
121       hardwire(VARIABLE, ADDRESS, LENGTH)
122           Specifies the address in memory of a variable, possibly within a
123           region you've mmap()ed another variable to. You must use the same
124           precautions to keep the variable from being reallocated, and use
125           substr() with an exact length. If you munmap() a region that a
126           hardwire()ed variable lives in, the hardwire()ed variable will not
127           automatically be "undef"ed. You must do this manually.
128
129       Constants
130           The Sys::Mmap module exports the following constants into your
131           namespace:
132
133               MAP_SHARED MAP_PRIVATE MAP_ANON MAP_ANONYMOUS MAP_FILE
134               MAP_NORESERVE MAP_POPULATE
135               MAP_HUGETLB MAP_HUGE_2MB MAP_HUGE_1GB
136               PROT_EXEC PROT_NONE PROT_READ PROT_WRITE
137
138           Of the constants beginning with "MAP_", only "MAP_SHARED" and
139           "MAP_PRIVATE" are defined in POSIX.1b and only "MAP_SHARED" is
140           likely to be useful.
141

BUGS

143       Scott Walters doesn't know XS, and is just winging it. There must be a
144       better way to tell Perl not to reallocate a variable in memory...
145
146       The tie() interface makes writing to a substring of the variable much
147       less efficient.  One user cited his application running 10-20 times
148       slower when "Sys::Mmap->new()" is used than when mmap() is called
149       directly.
150
151       Malcolm Beattie has not reviewed Scott's work and is not responsible
152       for any bugs, errors, omissions, stylistic failings, importabilities,
153       or design flaws in this version of the code.
154
155       There should be a tied interface to hardwire() as well.
156
157       Scott Walter's spelling is awful.
158
159       hardwire() will segfault Perl if the mmap() area it was referring to is
160       munmap()'d out from under it.
161
162       munmap() will segfault Perl if the variable was not successfully
163       mmap()'d previously, or if it has since been reallocated by Perl.
164

AUTHOR

166       CowboyTim added support for MAP_NORESERVE, MAP_HUGETLB, MAP_HUGE_2MB,
167       and MAP_HUGE_1GB.  Thanks CowboyTim!
168
169       Todd Rinaldo cleaned up code, modernized again, and merged in many
170       fixes, 2010-2011.
171
172       Scott Walters updated for Perl 5.6.x, additions, 2002.
173
174       Malcolm Beattie, 21 June 1996.
175
176
177
178perl v5.36.0                      2023-01-20                           Mmap(3)
Impressum