00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #include "mmprivate.h"
00029
00030
00031
00032
00033
00034 extern void abort PARAMS ((void));
00035
00036
00037
00038 #define MAGICWORD (unsigned int) 0xfedabeeb
00039 #define MAGICWORDFREE (unsigned int) 0xdeadbeef
00040 #define MAGICBYTE ((char) 0xd7)
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051 struct hdr
00052 {
00053 size_t size;
00054 unsigned long int magic;
00055 };
00056
00057 typedef void (*mmfree_fun_t) PARAMS ((PTR, PTR));
00058 typedef PTR (*mmalloc_fun_t) PARAMS ((PTR, size_t));
00059 typedef PTR (*mmrealloc_fun_t) PARAMS ((PTR, PTR, size_t));
00060
00061
00062
00063
00064 static void
00065 checkhdr (mdp, hdr)
00066 struct mdesc *mdp;
00067 const struct hdr *hdr;
00068 {
00069 if (hdr -> magic != MAGICWORD ||
00070 ((char *) &hdr[1])[hdr -> size] != MAGICBYTE)
00071 {
00072 (*mdp -> abortfunc)();
00073 }
00074 }
00075
00076 static void
00077 mfree_check (md, ptr)
00078 PTR md;
00079 PTR ptr;
00080 {
00081 struct hdr *hdr = ((struct hdr *) ptr) - 1;
00082 struct mdesc *mdp;
00083
00084 mdp = MD_TO_MDP (md);
00085 checkhdr (mdp, hdr);
00086 hdr -> magic = MAGICWORDFREE;
00087 mdp -> mfree_hook = NULL;
00088 mfree (md, (PTR)hdr);
00089 mdp -> mfree_hook = (mmfree_fun_t) mfree_check;
00090 }
00091
00092 static PTR
00093 mmalloc_check (md, size)
00094 PTR md;
00095 size_t size;
00096 {
00097 struct hdr *hdr;
00098 struct mdesc *mdp;
00099 size_t nbytes;
00100
00101 mdp = MD_TO_MDP (md);
00102 mdp -> mmalloc_hook = NULL;
00103 nbytes = sizeof (struct hdr) + size + 1;
00104 hdr = (struct hdr *) mmalloc (md, nbytes);
00105 mdp -> mmalloc_hook = (mmalloc_fun_t) mmalloc_check;
00106 if (hdr != NULL)
00107 {
00108 hdr -> size = size;
00109 hdr -> magic = MAGICWORD;
00110 hdr++;
00111 *((char *) hdr + size) = MAGICBYTE;
00112 }
00113 return ((PTR) hdr);
00114 }
00115
00116 static PTR
00117 mrealloc_check (md, ptr, size)
00118 PTR md;
00119 PTR ptr;
00120 size_t size;
00121 {
00122 struct hdr *hdr = ((struct hdr *) ptr) - 1;
00123 struct mdesc *mdp;
00124 size_t nbytes;
00125
00126 mdp = MD_TO_MDP (md);
00127 checkhdr (mdp, hdr);
00128 mdp -> mfree_hook = NULL;
00129 mdp -> mmalloc_hook = NULL;
00130 mdp -> mrealloc_hook = NULL;
00131 nbytes = sizeof (struct hdr) + size + 1;
00132 hdr = (struct hdr *) mrealloc (md, (PTR) hdr, nbytes);
00133 mdp -> mfree_hook = (mmfree_fun_t) mfree_check;
00134 mdp -> mmalloc_hook = (mmalloc_fun_t) mmalloc_check;
00135 mdp -> mrealloc_hook = (mmrealloc_fun_t) mrealloc_check;
00136 if (hdr != NULL)
00137 {
00138 hdr -> size = size;
00139 hdr++;
00140 *((char *) hdr + size) = MAGICBYTE;
00141 }
00142 return ((PTR) hdr);
00143 }
00144
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164
00165
00166
00167
00168 int
00169 mmcheck (md, func)
00170 PTR md;
00171 void (*func) PARAMS ((void));
00172 {
00173 struct mdesc *mdp;
00174 int rtnval;
00175
00176 mdp = MD_TO_MDP (md);
00177
00178
00179
00180
00181 mdp -> abortfunc = (func != NULL ? func : abort);
00182
00183
00184
00185
00186
00187 if (1 ||
00188 !(mdp -> flags & MMALLOC_INITIALIZED) ||
00189 (mdp -> mfree_hook != NULL))
00190 {
00191 mdp -> mfree_hook = (mmfree_fun_t) mfree_check;
00192 mdp -> mmalloc_hook = (mmalloc_fun_t) mmalloc_check;
00193 mdp -> mrealloc_hook = (mmrealloc_fun_t) mrealloc_check;
00194 mdp -> flags |= MMALLOC_MMCHECK_USED;
00195 rtnval = 1;
00196 }
00197 else
00198 {
00199 rtnval = 0;
00200 }
00201
00202 return (rtnval);
00203 }