delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2006/08/13/15:12:17

X-Spam-Check-By: sourceware.org
Date: Sun, 13 Aug 2006 22:11:53 +0300
Message-Id: <ubqqofo1y.fsf@gnu.org>
From: Eli Zaretskii <eliz AT gnu DOT org>
To: cygwin AT cygwin DOT com, emacs-pretest-bug AT gnu DOT org, emacs_user AT hotmail DOT com
In-reply-to: <44DEEF84.803@x-ray.at> (message from Reini Urban on Sun, 13 Aug 2006 11:23:16 +0200)
Subject: Re: reproducible cygwin memory problems
Reply-to: Eli Zaretskii <eliz AT gnu DOT org>
References: <BAY107-F22549D794C527187392FB2F8480 AT phx DOT gbl> <uoduqc8g9 DOT fsf AT gnu DOT org> <20060812165300 DOT GB19272 AT calimero DOT vinschen DOT de> <44DEEF84 DOT 803 AT x-ray DOT at>
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com>
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com

> Date: Sun, 13 Aug 2006 11:23:16 +0200
> From: Reini Urban <rurban AT x-ray DOT at>
> 
> Corinna Vinschen schrieb:
> ...
> > Ok, back to mmap/munmap.  Private anonymous mappings are implemented in
> > Cygwin by calling VirtualAlloc/VirtualFree.  However, due to
> > restrictions in the Win32 API, VirtualFree is only called by munmap, as
> > soon as *all* pages within a single mmap'ed area are free'ed by this or
> > preceding calls to munmap.
> > 
> > In other words, the mmap'ed memory will not be returned to the OS, if
> > not the complete mmap'ed area is munmap'ed.  Therefore I assume that the
> > implementation in Lisp keeps bits of memory around which are not
> > munmap'ed for some internal reason.

As far as I could tell from the OP's report about Emacs configuration
results, available here:

    http://www.deas.harvard.edu/climate/eli/emacs-debug/

Emacs he built does not use mmap.  Here's the relevant excerpt:

    Should Emacs use the GNU version of malloc?             yes
    Should Emacs use a relocating allocator for buffers?    yes
    Should Emacs use mmap(2) for buffer allocation?         no

So it looks like the above hypothesis about mmap is not relevant, and
this portion of Corinna's message:

> Cygwin uses the Doug Lea version of malloc/free.  The latest Cygwin
> versions uses the DEFAULT_MMAP_THRESHOLD of 256K, so mmap/munmap are
> used for mappings > 256K.  I assume that's the case here, since we're
> talking about images.  Otherwise, for mallocs < 256K, Cygwin is using
> sbrk and sbrk'ed memory is never returned to the OS.

seems to say that the fact that memory is not returned to the OS is a
known issue with Cygwin's malloc when sbrk is used.  Am I missing
something?

If I don't miss anything, it remains to be explained why the OP didn't
see problems with normal buffers.  Could the OP please try visiting
several large text files, then kill their buffers, invoke the
`garbage-collect' function ("M-x garbage-collect RET"), and see if the
memory footprint returns to its original value?

A few more tests come to mind:

  . Put a breakpoint in sbrk and in mmap, and find out which one is
    being called when normal text files and image files (both small
    and large) are visited.

  . Visit many small image files (smaller than 256K) and see whether
    the memory is being returned to the OS.

I'd like to ask the OP to try these and report the results.

--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Problem reports:       http://cygwin.com/problems.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019