Coverage Report

Created: 2026-01-25 07:18

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/LibRaw/libraw/libraw_alloc.h
Line
Count
Source
1
/* -*- C++ -*-
2
 * File: libraw_alloc.h
3
 * Copyright 2008-2025 LibRaw LLC (info@libraw.org)
4
 * Created: Sat Mar  22, 2008
5
 *
6
 * LibRaw C++ interface
7
 *
8
LibRaw is free software; you can redistribute it and/or modify
9
it under the terms of the one of two licenses as you choose:
10
11
1. GNU LESSER GENERAL PUBLIC LICENSE version 2.1
12
   (See file LICENSE.LGPL provided in LibRaw distribution archive for details).
13
14
2. COMMON DEVELOPMENT AND DISTRIBUTION LICENSE (CDDL) Version 1.0
15
   (See file LICENSE.CDDL provided in LibRaw distribution archive for details).
16
17
 */
18
19
#ifndef __LIBRAW_ALLOC_H
20
#define __LIBRAW_ALLOC_H
21
22
#include <stdlib.h>
23
#include <string.h>
24
#include "libraw_const.h"
25
26
#ifdef __cplusplus
27
28
0
#define LIBRAW_MSIZE 512
29
30
class DllDef libraw_memmgr
31
{
32
public:
33
0
  libraw_memmgr(unsigned ee) : extra_bytes(ee)
34
0
  {
35
0
    size_t alloc_sz = LIBRAW_MSIZE * sizeof(void *);
36
0
    mems = (void **)::malloc(alloc_sz);
37
0
    memset(mems, 0, alloc_sz);
38
0
  }
39
  ~libraw_memmgr()
40
0
  {
41
0
    cleanup();
42
0
    ::free(mems);
43
0
  }
44
  void *malloc(size_t sz)
45
0
  {
46
#ifdef LIBRAW_USE_CALLOC_INSTEAD_OF_MALLOC
47
    void *ptr = ::calloc(sz + extra_bytes, 1);
48
#else
49
0
    void *ptr = ::malloc(sz + extra_bytes);
50
0
#endif
51
0
    mem_ptr(ptr);
52
0
    return ptr;
53
0
  }
54
  void *calloc(size_t n, size_t sz)
55
0
  {
56
0
    void *ptr = ::calloc(n + (extra_bytes + sz - 1) / (sz ? sz : 1), sz);
57
0
    mem_ptr(ptr);
58
0
    return ptr;
59
0
  }
60
  void *realloc(void *ptr, size_t newsz)
61
0
  {
62
0
    void *ret = ::realloc(ptr, newsz + extra_bytes);
63
0
    forget_ptr(ptr);
64
0
    mem_ptr(ret);
65
0
    return ret;
66
0
  }
67
  void free(void *ptr)
68
0
  {
69
0
    forget_ptr(ptr);
70
0
    ::free(ptr);
71
0
  }
72
  void cleanup(void)
73
0
  {
74
0
    for (int i = 0; i < LIBRAW_MSIZE; i++)
75
0
      if (mems[i])
76
0
      {
77
0
        ::free(mems[i]);
78
0
        mems[i] = NULL;
79
0
      }
80
0
  }
81
82
private:
83
  void **mems;
84
  unsigned extra_bytes;
85
  void mem_ptr(void *ptr)
86
0
  {
87
#if defined(LIBRAW_USE_OPENMP)
88
      bool ok = false; /* do not return from critical section */
89
#endif
90
91
#if defined(LIBRAW_USE_OPENMP)
92
#pragma omp critical
93
      {
94
#endif
95
0
          if (ptr)
96
0
          {
97
0
              for (int i = 0; i < LIBRAW_MSIZE - 1; i++)
98
0
                  if (!mems[i])
99
0
                  {
100
0
                      mems[i] = ptr;
101
#if defined(LIBRAW_USE_OPENMP)
102
          ok = true;
103
          break;
104
#else
105
0
                      return;
106
0
#endif
107
0
                  }
108
0
#ifdef LIBRAW_MEMPOOL_CHECK
109
0
#if !defined(LIBRAW_USE_OPENMP)
110
              /* remember ptr in last mems item to be free'ed at cleanup */
111
0
              if (!mems[LIBRAW_MSIZE - 1])
112
0
                  mems[LIBRAW_MSIZE - 1] = ptr;
113
0
              throw LIBRAW_EXCEPTION_MEMPOOL;
114
0
#endif
115
0
#endif
116
0
          }
117
#if defined(LIBRAW_USE_OPENMP)
118
      }
119
      if(!ok)
120
      {
121
          if (!mems[LIBRAW_MSIZE - 1])
122
              mems[LIBRAW_MSIZE - 1] = ptr;
123
          throw LIBRAW_EXCEPTION_MEMPOOL;
124
      }
125
#endif
126
0
  }
127
  void forget_ptr(void *ptr)
128
0
  {
129
#if defined(LIBRAW_USE_OPENMP)
130
#pragma omp critical
131
    {
132
#endif
133
0
     if (ptr)
134
0
      for (int i = 0; i < LIBRAW_MSIZE; i++)
135
0
        if (mems[i] == ptr)
136
0
        {
137
0
          mems[i] = NULL;
138
0
          break;
139
0
        }
140
#if defined(LIBRAW_USE_OPENMP)
141
    }
142
#endif
143
0
  }
144
};
145
146
#endif /* C++ */
147
148
#endif