home *** CD-ROM | disk | FTP | other *** search
/ DP Tool Club 8 / CDASC08.ISO / NEWS / RADIANCE / SRC / COMMON / BMALLOC.C < prev    next >
C/C++ Source or Header  |  1993-10-07  |  2KB  |  74 lines

  1. /* Copyright (c) 1991 Regents of the University of California */
  2.  
  3. #ifndef lint
  4. static char SCCSid[] = "@(#)bmalloc.c 2.2 3/10/92 LBL";
  5. #endif
  6.  
  7. /*
  8.  * Bmalloc provides basic memory allocation without overhead (no free lists).
  9.  * Use only to take the load off of malloc for all those
  10.  * piddling little requests that you never expect to free.
  11.  * Bmalloc defers to malloc for big requests.
  12.  * Bfree should hand memory to bmalloc, but it usually fails here.
  13.  */
  14.  
  15. #define  NULL        0
  16.  
  17. #ifndef  MBLKSIZ
  18. #define  MBLKSIZ    16376        /* size of memory allocation block */
  19. #endif
  20. #define  WASTEFRAC    12        /* don't waste more than a fraction */
  21. #ifndef  ALIGN
  22. #define  ALIGN        int        /* type for alignment */
  23. #endif
  24. #define  BYTES_WORD    sizeof(ALIGN)
  25.  
  26. extern char  *malloc();
  27.  
  28. static char  *bposition = NULL;
  29. static unsigned  nremain = 0;
  30.  
  31.  
  32. char *
  33. bmalloc(n)        /* allocate a block of n bytes */
  34. register unsigned  n;
  35. {
  36.     if (n > nremain && (n > MBLKSIZ || nremain > MBLKSIZ/WASTEFRAC))
  37.         return(malloc(n));            /* too big */
  38.  
  39.     n = (n+(BYTES_WORD-1))&~(BYTES_WORD-1);        /* word align */
  40.  
  41.     if (n > nremain && (bposition = malloc(nremain = MBLKSIZ)) == NULL) {
  42.         nremain = 0;
  43.         return(NULL);
  44.     }
  45.     bposition += n;
  46.     nremain -= n;
  47.     return(bposition - n);
  48. }
  49.  
  50.  
  51. bfree(p, n)            /* free random memory */
  52. register char    *p;
  53. register unsigned    n;
  54. {
  55.     register unsigned    bsiz;
  56.                     /* check alignment */
  57.     bsiz = BYTES_WORD - ((unsigned)p&(BYTES_WORD-1));
  58.     if (bsiz < BYTES_WORD) {
  59.         p += bsiz;
  60.         n -= bsiz;
  61.     }
  62.     if (p + n == bposition) {    /* just allocated? */
  63.         bposition = p;
  64.         nremain += n;
  65.         return;
  66.     }
  67.     if (n > nremain) {        /* better than what we've got? */
  68.         bposition = p;
  69.         nremain = n;
  70.         return;
  71.     }
  72.                 /* just throw it away, then */
  73. }
  74.