Date: Sun, 6 May 2001 13:54:05 +0300 (IDT)
From: Eli Zaretskii <eliz AT is DOT elta DOT co DOT il>
X-Sender: eliz AT is
To: Rafal Maj <maj_rafal AT poczta DOT onet DOT pl>
cc: djgpp AT delorie DOT com
Subject: Re: Counting allocated memory
In-Reply-To: <9d33ak$gbv$1@info.cyf-kr.edu.pl>
Message-ID: <Pine.SUN.3.91.1010506134501.6726A-100000@is>
MIME-Version: 1.0
Content-Type: TEXT/PLAIN; charset=US-ASCII
Reply-To: djgpp AT delorie DOT com
Errors-To: nobody AT delorie DOT com
X-Mailing-List: djgpp AT delorie DOT com
X-Unsubscribes-To: listserv AT delorie DOT com
Precedence: bulk


On Sun, 6 May 2001, Rafal Maj wrote:

> I have question about allocating memory. In DJGPP, is there somewhere
> information about all blocks of memory that have been allocated and still
> wheren't freed ?

It's kept internally by malloc and sbrk.  For the former, see the source 
file malloc.c in the library source distribution djlsr203.zip.  For the 
latter, you can use the docs of the function __djgpp_memory_handle and 
the source file memhandl.c.

> If not, then can I get exacly number of allocated bytes ?

Please tell the details--what does ``exactly number of allocated bytes'' 
mean?  Memory allocation happens in at least two stages: first, `sbrk' 
requests memory from the DPMO host in large chunks, then it subdivides 
those chunk into smaller pieces and hands them to `malloc'.  `malloc' 
then maintains its own list of allocated and free memory in its internal 
data structures.

Which part of this is ``exactly number of allocated bytes''?

> It can be very useful for debugging purpose...

What debugging purposes did you have in mind?  If you are looking for a 
way to find memory leaks, there are packages that will let you do that 
without messing with the internals of `malloc'.  See section 22.4 of the 
DJGPP FAQ list for some pointers.