mmap 2GB allocation limit on Win XP, 32-bits, Python 2.5.4

Diez B. Roggisch deets at nospam.web.de
Fri Jul 24 05:38:05 EDT 2009


Slaunger schrieb:
> OS: Win XP SP3, 32 bit
> Python 2.5.4
> 
> Hi I have run into some problems with allocating numpy.memmaps
> exceeding and accumulated size of about 2 GB. I have found out that
> the real problem relates to numpy.memmap using mmap.mmap
> 
> I've written a small test program to illustrate it:
> 
> import itertools
> import mmap
> import os
> 
> files = []
> mmaps = []
> file_names= []
> mmap_cap=0
> bytes_per_mmap = 100 * 1024 ** 2
> try:
>     for i in itertools.count(1):
>         file_name = "d:/%d.tst" % i
>         file_names.append(file_name)
>         f = open(file_name, "w+b")
>         files.append(f)
>         mm = mmap.mmap(f.fileno(), bytes_per_mmap)
>         mmaps.append(mm)
>         mmap_cap += bytes_per_mmap
>         print "Created %d writeable mmaps containing %d MB" % (i,
> mmap_cap/(1024**2))
> 
> #Clean up
> finally:
>     print "Removing mmaps..."
>     for mm, f, file_name in zip(mmaps, files, file_names):
>         mm.close()
>         f.close()
>         os.remove(file_name)
>     print "Done..."
> 
> 
> which creates this output
> 
> Created 1 writeable mmaps containing 100 MB
> Created 2 writeable mmaps containing 200 MB
> ....
> Created 17 writeable mmaps containing 1700 MB
> Created 18 writeable mmaps containing 1800 MB
> Removing mmaps...
> Done...
> Traceback (most recent call last):
>   File "C:\svn-sandbox\research\scipy\scipy\src\com\terma\kha
> \mmaptest.py", line 16, in <module>
>     mm = mmap.mmap(f.fileno(), bytes_per_mmap)
> WindowsError: [Error 8] Not enough storage is available to process
> this command
> 
> There is more than 25 GB of free space on drive d: at this stage.
> 
> Is it a bug or a "feature" of the 32 bit OS?

It's a limitation, yes. That's what 64-bit-OSes are for.

> I am surprised about it as I have not found any notes about these
> kinds of limitations in the documentation.
> 
> I am in dire need of these large memmaps for my task, and it is not an
> option to change OS due to other constraints in the system.
> 
> Is there anything I can do about it?

Only by partitioning data yourself, and accessing these partitions. Like 
in the good old days of DOS-programming.

Diez



More information about the Python-list mailing list