File: port_malloc.c

package info (click to toggle)
libosip 0.9.7-1
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 2,852 kB
  • ctags: 1,812
  • sloc: ansic: 20,266; sh: 9,218; makefile: 215
file content (88 lines) | stat: -rw-r--r-- 2,089 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*
  The oSIP library implements the Session Initiation Protocol (SIP -rfc3261-)
  Copyright (C) 2001,2002,2003  Aymeric MOIZARD jack@atosc.org
  
  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either
  version 2.1 of the License, or (at your option) any later version.
  
  This library 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
  Lesser General Public License for more details.
  
  You should have received a copy of the GNU Lesser General Public
  License along with this library; if not, write to the Free Software
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

#include <stdlib.h>
#include <stdio.h>

#include <osip/port.h>

/* to enable memory leak detection: */
/* #define ENABLE_LEAKD */

#ifdef ENABLE_LEAKD
static int malloccomptr = 0;
#endif


void *
smalloc (size_t size)
{
#ifdef ENABLE_LEAKD
  static int comptr = 0;
#endif
  void *value;

  value = malloc (size);
#ifdef ENABLE_LEAKD
  comptr++;
  malloccomptr++;

  fprintf (stdout,
	   "INITMALLOC (%i) (%x) =(size,value)| (%i,%i)=(el_freed,difference)\n",
	   size, (char *) value, comptr, malloccomptr);
  fflush (stdout);
#endif
  if (value == 0)
    {
      fprintf (stdout, "<port_malloc.c> virtual memory exhausted\n");
      /* How can I handle that case properly? */
      exit (0);
    }

  return value;
}

void
sfree (void *ptr)
{
#ifdef ENABLE_LEAKD
  static int comptr = 0;

  if (ptr != NULL)
    comptr++;
  if (ptr != NULL)
    malloccomptr--;
  fprintf (stdout, "FREEMALLOC (%x) comptr: %i existing element %i\n",
	   (char *) ptr, comptr, malloccomptr);
  fflush (stdout);
#endif

/* SPD added NULL check just for grins :-) */

  if (ptr != NULL)
    free (ptr);
/* 
   Robin Nayathodan <roooot@softhome.net> 
   N.K Electronics INDIA

   Most People Check This Condition 
 */
  ptr = NULL;

}