2007-03-08 04:03:40 +08:00
|
|
|
/**********************************************************************
|
|
|
|
* File: memry.h (Formerly memory.h)
|
|
|
|
* Description: Header file for basic memory allocation/deallocation.
|
|
|
|
* Author: Ray Smith
|
|
|
|
* Created: Tue May 8 16:03:48 BST 1990
|
|
|
|
*
|
|
|
|
* (C) Copyright 1990, Hewlett-Packard Ltd.
|
|
|
|
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
** you may not use this file except in compliance with the License.
|
|
|
|
** You may obtain a copy of the License at
|
|
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
** Unless required by applicable law or agreed to in writing, software
|
|
|
|
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
** See the License for the specific language governing permissions and
|
|
|
|
** limitations under the License.
|
|
|
|
*
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#ifndef MEMRY_H
|
|
|
|
#define MEMRY_H
|
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
#include "host.h"
|
|
|
|
|
|
|
|
#define JUSTCHECKS 0 /*just check consistency */
|
|
|
|
#define MEMCHECKS 1 /*report totals */
|
|
|
|
#define FULLMEMCHECKS 2 /*report on all blocks */
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* ALLOC_2D_ARRAY
|
|
|
|
*
|
|
|
|
* Create a dynamic 2D array.
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#define ALLOC_2D_ARRAY(x,y,mem,ptrs,type) /*make 2d array*/\
|
|
|
|
{ \
|
2008-04-22 08:23:41 +08:00
|
|
|
inT32 TMP_i; \
|
2007-03-08 04:03:40 +08:00
|
|
|
mem=(type*)alloc_mem((x)*(y)*sizeof(type)); /*get memory*/\
|
|
|
|
ptrs=(type**)alloc_mem((x)*sizeof(type*)); /*get ptrs*/\
|
|
|
|
for (TMP_i=0;TMP_i<(x);TMP_i++)\
|
|
|
|
ptrs[TMP_i]=mem+(y)*TMP_i; /*set ptrs*/\
|
|
|
|
} \
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* FREE_2D_ARRAY
|
|
|
|
*
|
|
|
|
* Destroy a 2D array created by ALLOC_2D_ARRAY
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#define FREE_2D_ARRAY(mem,ptrs) /*free a 2D array*/\
|
|
|
|
{ \
|
|
|
|
free_mem(mem); /*free the memory*/\
|
|
|
|
free_mem(ptrs); /*and the ptrs*/\
|
|
|
|
} \
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* ALLOC_BIG_2D_ARRAY
|
|
|
|
*
|
|
|
|
* Create a dynamic 2D array. Use a memory allocator that allows
|
|
|
|
* allocation of bigger chunks.
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#define ALLOC_BIG_2D_ARRAY(x,y,mem,ptrs,type) /*make 2d array*/\
|
|
|
|
{ \
|
2008-04-22 08:23:41 +08:00
|
|
|
inT32 TMP_i; \
|
2007-03-08 04:03:40 +08:00
|
|
|
mem=(type*)alloc_big_mem((x)*(y)*sizeof(type)); /*get memory*/\
|
|
|
|
ptrs=(type**)alloc_big_mem((x)*sizeof(type*)); /*get ptrs*/\
|
|
|
|
for (TMP_i=0;TMP_i<(x);TMP_i++)\
|
|
|
|
ptrs[TMP_i]=mem+(y)*TMP_i; /*set ptrs*/\
|
|
|
|
} \
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* FREE_BIG_2D_ARRAY
|
|
|
|
*
|
|
|
|
* Destroy a 2D array created by ALLOC_BIG_2D_ARRAY
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#define FREE_BIG_2D_ARRAY(mem,ptrs) /*free a 2D array*/\
|
|
|
|
{ \
|
|
|
|
free_big_mem(mem); /*free the memory*/\
|
|
|
|
free_big_mem(ptrs); /*and the ptrs*/\
|
|
|
|
} \
|
|
|
|
|
|
|
|
extern DLLSYM void check_mem( //check consistency
|
|
|
|
const char *string, //context message
|
2008-04-22 08:23:41 +08:00
|
|
|
inT8 level //level of check
|
2007-03-08 04:03:40 +08:00
|
|
|
);
|
|
|
|
//allocate string
|
2008-04-22 08:23:41 +08:00
|
|
|
extern DLLSYM char *alloc_string(inT32 count //no of chars required
|
2007-03-08 04:03:40 +08:00
|
|
|
);
|
|
|
|
extern DLLSYM void free_string( //free a string
|
|
|
|
char *string //string to free
|
|
|
|
);
|
|
|
|
//allocate memory
|
|
|
|
extern DLLSYM void *alloc_struct (
|
2008-04-22 08:23:41 +08:00
|
|
|
inT32 count, //no of chars required
|
2007-03-08 04:03:40 +08:00
|
|
|
const char *name = NULL //class name
|
|
|
|
);
|
|
|
|
extern DLLSYM void free_struct ( //free a structure
|
|
|
|
void *deadstruct, //structure to free
|
2008-04-22 08:23:41 +08:00
|
|
|
inT32 count, //no of bytes
|
2007-03-08 04:03:40 +08:00
|
|
|
const char *name = NULL //class name
|
|
|
|
);
|
|
|
|
extern DLLSYM void *alloc_mem_p( //allocate permanent space
|
2008-04-22 08:23:41 +08:00
|
|
|
inT32 count //block size to allocate
|
2007-03-08 04:03:40 +08:00
|
|
|
);
|
|
|
|
extern DLLSYM void *alloc_mem( //get some memory
|
2008-04-22 08:23:41 +08:00
|
|
|
inT32 count //no of bytes to get
|
2007-03-08 04:03:40 +08:00
|
|
|
);
|
|
|
|
//get some memory
|
2008-04-22 08:23:41 +08:00
|
|
|
extern DLLSYM void *alloc_big_mem(inT32 count //no of bytes to get
|
2007-03-08 04:03:40 +08:00
|
|
|
);
|
|
|
|
//get some memory
|
2008-04-22 08:23:41 +08:00
|
|
|
extern DLLSYM void *alloc_big_zeros(inT32 count //no of bytes to get
|
2007-03-08 04:03:40 +08:00
|
|
|
);
|
|
|
|
extern DLLSYM void free_mem( //free mem from alloc_mem
|
|
|
|
void *oldchunk //chunk to free
|
|
|
|
);
|
|
|
|
extern DLLSYM void free_big_mem( //free mem from alloc_mem
|
|
|
|
void *oldchunk //chunk to free
|
|
|
|
);
|
|
|
|
#endif
|