From: "Øyvind Harboe" <oyvind.harboe@zylin.com>
To: Andrew Lunn <andrew@lunn.ch>
Cc: ecos-discuss@sources.redhat.com
Subject: Re: [ECOS] New memory allocation debug feature
Date: Fri, 18 Jun 2004 15:06:00 -0000 [thread overview]
Message-ID: <1087571213.40d3050d5a703@mail.broadpark.no> (raw)
In-Reply-To: <20040618115847.GA2031@lunn.ch>
[-- Attachment #1: Type: text/plain, Size: 849 bytes --]
Quoting Andrew Lunn <andrew@lunn.ch>:
> > > You also need to provide an implementation in libtarget.a for when the
> > > application does not have such a function. eg all the test programs
> > > will not provide this function, so will fail to link when your new
> > > option is enabled. So please add a week function which does nothing,
> > > or maybe throws an CYG_FAIL().
> >
> > Hmmm... Can this be done without adding a new source file?
>
> Can you declare a function using C calling convention in a C++ file? I
> don't know, im a C programmer. If you can, i suggest you add it to the
> end of malloc.cxx
I found it easiest to just add a new debug.cxx file.
New patch attached.
> > You should try emacs.
I use emacs all the time, but from different computers, so I find that I don't
want to spend the time configuring it.
Ãyvind
[-- Attachment #2: memdebug.txt --]
[-- Type: text/plain, Size: 10303 bytes --]
Index: common/current/ChangeLog
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/ChangeLog,v
retrieving revision 1.30
diff -w -u -r1.30 ChangeLog
--- common/current/ChangeLog 15 Mar 2004 15:42:04 -0000 1.30
+++ common/current/ChangeLog 18 Jun 2004 15:01:06 -0000
@@ -1,3 +1,8 @@
+2004-06-17 Oyvind Harboe <oyvind.harboe@zylin.com>
+
+ * Added cyg_memalloc_alloc_fail() fn which is invoked before return NULL
+ from failed allocations. Useful breakpoint site.
+
2004-02-15 Jonathan Larmour <jifl@eCosCentric.com>
* include/kapi.h: Add throw specifications throughout.
Index: common/current/cdl/memalloc.cdl
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/cdl/memalloc.cdl,v
retrieving revision 1.12
diff -w -u -r1.12 memalloc.cdl
--- common/current/cdl/memalloc.cdl 6 Oct 2003 16:41:07 -0000 1.12
+++ common/current/cdl/memalloc.cdl 18 Jun 2004 15:01:06 -0000
@@ -56,7 +56,7 @@
interface. It also contains some sample implementations."
include_dir cyg/memalloc
compile dlmalloc.cxx memfixed.cxx memvar.cxx \
- sepmeta.cxx
+ sepmeta.cxx debug.cxx
# ====================================================================
@@ -239,6 +239,14 @@
forces a NULL pointer to be returned."
}
+ cdl_option CYGSEM_MEMALLOC_INVOKE_OUTOFMEMORY {
+ display "invoke user supplied cyg_memalloc_alloc_fail() function when running out of memory"
+ default_value 0
+ description "
+ Whenever the system runs out of memory, it invokes this function before either
+ going to sleep(waiting for memory to become available) or returning failure."
+ }
+
cdl_component CYGPKG_MEMALLOC_MALLOC_ALLOCATORS {
display "malloc() and supporting allocators"
flavor bool
Index: common/current/include/common.hxx
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/include/common.hxx,v
retrieving revision 1.3
diff -w -u -r1.3 common.hxx
--- common/current/include/common.hxx 23 May 2002 23:08:43 -0000 1.3
+++ common/current/include/common.hxx 18 Jun 2004 15:01:14 -0000
@@ -131,5 +131,14 @@
typedef cyg_uint16 cyg_mempool_status_flag_t;
+#if CYGSEM_MEMALLOC_INVOKE_OUTOFMEMORY
+// breakpoint site for out of memory conditions
+__externC void cyg_memalloc_alloc_fail();
+#else
+// this will compile away to nothing with optimisations turned on.
+inline void cyg_memalloc_alloc_fail() {
+}
+#endif
+
#endif /* ifndef CYGONCE_MEMALLOC_COMMON_HXX */
/* EOF common.hxx */
Index: common/current/include/memjoin.inl
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/include/memjoin.inl,v
retrieving revision 1.6
diff -w -u -r1.6 memjoin.inl
--- common/current/include/memjoin.inl 5 Feb 2003 01:10:12 -0000 1.6
+++ common/current/include/memjoin.inl 18 Jun 2004 15:01:15 -0000
@@ -178,6 +178,10 @@
}
CYG_REPORT_RETVAL( ptr );
+
+ if (ptr==NULL) {
+ cyg_memalloc_alloc_fail();
+ }
return ptr;
} // Cyg_Mempool_Joined<T>::try_alloc()
@@ -214,6 +218,7 @@
ret = pool->resize_alloc( alloc_ptr, newsize, oldsize );
CYG_REPORT_RETVAL( ret );
+
return ret;
} // Cyg_Mempool_Joined<T>::resize_alloc()
Index: common/current/include/mempolt2.inl
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/include/mempolt2.inl,v
retrieving revision 1.3
diff -w -u -r1.3 mempolt2.inl
--- common/current/include/mempolt2.inl 23 May 2002 23:08:43 -0000 1.3
+++ common/current/include/mempolt2.inl 18 Jun 2004 15:01:15 -0000
@@ -116,6 +116,8 @@
Mempolt2WaitInfo waitinfo( size );
+ cyg_memalloc_alloc_fail();
+
self->set_wait_info( (CYG_ADDRWORD)&waitinfo );
self->set_sleep_reason( Cyg_Thread::WAIT );
self->sleep();
@@ -187,6 +189,9 @@
// straight to unlock.
if( Cyg_Thread::NONE == self->get_wake_reason() ) {
+
+ cyg_memalloc_alloc_fail();
+
self->set_wait_info( (CYG_ADDRWORD)&waitinfo );
self->sleep();
queue.enqueue( self );
@@ -251,6 +256,11 @@
// Unlock the scheduler and maybe switch threads
Cyg_Scheduler::unlock();
+
+ if (ret==NULL) {
+ cyg_memalloc_alloc_fail();
+ }
+
return ret;
}
@@ -283,6 +293,11 @@
// Unlock the scheduler and maybe switch threads
Cyg_Scheduler::unlock();
+
+ if (ret==NULL) {
+ cyg_memalloc_alloc_fail();
+ }
+
return ret;
}
Index: common/current/include/mempoolt.inl
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/include/mempoolt.inl,v
retrieving revision 1.3
diff -w -u -r1.3 mempoolt.inl
--- common/current/include/mempoolt.inl 23 May 2002 23:08:43 -0000 1.3
+++ common/current/include/mempoolt.inl 18 Jun 2004 15:01:16 -0000
@@ -111,6 +111,9 @@
cyg_uint8 *ret;
cyg_bool result = true;
while( result && (NULL == (ret = pool.alloc( size ))) ) {
+
+ cyg_memalloc_alloc_fail();
+
self->set_sleep_reason( Cyg_Thread::WAIT );
self->sleep();
queue.enqueue( self );
@@ -182,6 +185,8 @@
result = false;
while( result && (NULL == (ret = pool.alloc( size ))) ) {
+ cyg_memalloc_alloc_fail();
+
self->set_sleep_reason( Cyg_Thread::TIMEOUT );
self->sleep();
queue.enqueue( self );
@@ -248,6 +253,10 @@
// Unlock the scheduler and maybe switch threads
Cyg_Scheduler::unlock();
CYG_REPORT_RETVAL( ret );
+
+ if (ret==NULL) {
+ cyg_memalloc_alloc_fail();
+ }
return ret;
}
Index: common/current/include/mfiximpl.inl
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/include/mfiximpl.inl,v
retrieving revision 1.3
diff -w -u -r1.3 mfiximpl.inl
--- common/current/include/mfiximpl.inl 23 May 2002 23:08:44 -0000 1.3
+++ common/current/include/mfiximpl.inl 18 Jun 2004 15:01:16 -0000
@@ -122,8 +122,10 @@
{
// size parameter is not used
CYG_UNUSED_PARAM( cyg_int32, size );
- if ( 0 >= freeblocks )
+ if ( 0 >= freeblocks ) {
+ cyg_memalloc_alloc_fail();
return NULL;
+ }
cyg_int32 i = firstfree;
cyg_uint8 *p = NULL;
do {
@@ -172,8 +174,10 @@
if (newsize == blocksize)
return alloc_ptr;
- else
+ else {
+ cyg_memalloc_alloc_fail();
return NULL;
+ }
} // resize_alloc()
Index: common/current/include/mvarimpl.inl
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/include/mvarimpl.inl,v
retrieving revision 1.5
diff -w -u -r1.5 mvarimpl.inl
--- common/current/include/mvarimpl.inl 23 May 2002 23:08:44 -0000 1.5
+++ common/current/include/mvarimpl.inl 18 Jun 2004 15:01:16 -0000
@@ -275,6 +275,9 @@
cyg_uint8 *ptr = memdq2alloc( dq );
CYG_ASSERT( ((CYG_ADDRESS)ptr & (alignment-1)) == 0,
"returned memory not aligned" );
+ if (ptr==NULL) {
+ cyg_memalloc_alloc_fail();
+ }
return ptr;
}
@@ -358,6 +361,9 @@
ret = alloc_ptr;
}
+ if (ret==NULL) {
+ cyg_memalloc_alloc_fail();
+ }
return ret;
} // resize_alloc()
Index: common/current/include/sepmetaimpl.inl
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/include/sepmetaimpl.inl,v
retrieving revision 1.4
diff -w -u -r1.4 sepmetaimpl.inl
--- common/current/include/sepmetaimpl.inl 23 May 2002 23:08:44 -0000 1.4
+++ common/current/include/sepmetaimpl.inl 18 Jun 2004 15:01:17 -0000
@@ -374,8 +374,10 @@
size = (size + alignment - 1) & -alignment;
struct memdq *dq = find_free_dq( size );
- if (NULL == dq)
+ if (NULL == dq) {
+ cyg_memalloc_alloc_fail();
return NULL;
+ }
cyg_int32 dqsize = dq->memnext->mem - dq->mem;
@@ -399,8 +401,11 @@
// first get a memdq
- if ( NULL == freemetahead ) // out of metadata.
+ if ( NULL == freemetahead ) {
+ // out of metadata.
+ cyg_memalloc_alloc_fail();
return NULL;
+ }
// FIXME: since we don't search all the way for an exact fit
// first we may be able to find an exact fit later and therefore
@@ -496,7 +501,10 @@
prevmemsize = dq->mem - dq->memprev->mem;
}
if (nextmemsize + prevmemsize + currsize < newsize)
+ {
+ cyg_memalloc_alloc_fail();
return NULL; // can't fit it
+ }
// expand forwards
if ( nextmemsize != 0 ) {
@@ -560,8 +568,10 @@
} else {
// if its already allocated we need to create a new free list
// entry
- if (NULL == freemetahead)
+ if (NULL == freemetahead) {
+ cyg_memalloc_alloc_fail();
return NULL; // can't do it
+ }
struct memdq *fdq = freemetahead;
freemetahead = fdq->next;
Index: common/current/src/dlmalloc.cxx
===================================================================
RCS file: /cvs/ecos/ecos/packages/services/memalloc/common/current/src/dlmalloc.cxx,v
retrieving revision 1.8
diff -w -u -r1.8 dlmalloc.cxx
--- common/current/src/dlmalloc.cxx 6 Oct 2003 18:25:57 -0000 1.8
+++ common/current/src/dlmalloc.cxx 18 Jun 2004 15:01:18 -0000
@@ -217,6 +217,8 @@
#include <cyg/memalloc/dlmalloc.hxx>
//#include <cyg/infra/diag.h>
+
+
/*
Debugging:
@@ -1273,6 +1275,7 @@
//diag_printf("chunksize(top)=%ld, nb=%d, remainder=%ld\n", chunksize(top),
// nb, remainder_size);
MALLOC_UNLOCK;
+ cyg_memalloc_alloc_fail();
return NULL; /* propagate failure */
}
@@ -1558,6 +1561,7 @@
// couldn't resize the allocation any direction, so return failure
MALLOC_UNLOCK;
+ cyg_memalloc_alloc_fail();
return NULL;
}
[-- Attachment #3: debug.cxx --]
[-- Type: text/plain, Size: 2842 bytes --]
//========================================================================
//
// debug.cxx
//
// default implementation of out of memory debug breakpoint site
//
//========================================================================
//####ECOSGPLCOPYRIGHTBEGIN####
// -------------------------------------------
// This file is part of eCos, the Embedded Configurable Operating System.
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
//
// eCos is free software; you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the Free
// Software Foundation; either version 2 or (at your option) any later version.
//
// eCos is distributed in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
// for more details.
//
// You should have received a copy of the GNU General Public License along
// with eCos; if not, write to the Free Software Foundation, Inc.,
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
//
// As a special exception, if other files instantiate templates or use macros
// or inline functions from this file, or you compile this file and link it
// with other works to produce a work based on this file, this file does not
// by itself cause the resulting work to be covered by the GNU General Public
// License. However the source code for this file must still be made available
// in accordance with section (3) of the GNU General Public License.
//
// This exception does not invalidate any other reasons why a work based on
// this file might be covered by the GNU General Public License.
//
// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
// at http://sources.redhat.com/ecos/ecos-license/
// -------------------------------------------
//####ECOSGPLCOPYRIGHTEND####
//========================================================================
//#####DESCRIPTIONBEGIN####
//
// Author(s): oyvind
// Contributors:
// Date: 2000-06-17
// Purpose:
// Description: Memory usage debugging
// Usage:
//
//####DESCRIPTIONEND####
//
//========================================================================
// CONFIGURATION
#include <pkgconf/memalloc.h> // Configuration header
#include <cyg/infra/cyg_type.h> // Common type definitions and support
#include <cyg/infra/cyg_trac.h> // Common tracing support
#include <cyg/infra/cyg_ass.h> // Common assertion support
#include <string.h> // For memset() and memmove()
#include <stdlib.h> // header for this file
#if CYGSEM_MEMALLOC_INVOKE_OUTOFMEMORY
__externC void cyg_memalloc_alloc_fail()
{
// handy breakpoint site.
}
#endif
// EOF debug.cxx
[-- Attachment #4: Type: text/plain, Size: 148 bytes --]
--
Before posting, please read the FAQ: http://ecos.sourceware.org/fom/ecos
and search the list archive: http://ecos.sourceware.org/ml/ecos-discuss
next prev parent reply other threads:[~2004-06-18 15:06 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-06-17 10:55 Øyvind Harboe
2004-06-17 12:10 ` Andrew Lunn
2004-06-17 13:01 ` Nick Garnett
2004-06-17 14:30 ` Øyvind Harboe
2004-06-18 11:58 ` Andrew Lunn
2004-06-18 15:06 ` Øyvind Harboe [this message]
2004-06-18 21:42 ` Andrew Lunn
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1087571213.40d3050d5a703@mail.broadpark.no \
--to=oyvind.harboe@zylin.com \
--cc=andrew@lunn.ch \
--cc=ecos-discuss@sources.redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).