Coverage Report

Created: 2025-06-22 08:04

/src/LibRaw/libraw/libraw_alloc.h
Line
Count
Source (jump to first uncovered line)
1
/* -*- C++ -*-
2
 * File: libraw_alloc.h
3
 * Copyright 2008-2024 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
52.5M
#define LIBRAW_MSIZE 512
29
30
class DllDef libraw_memmgr
31
{
32
public:
33
25.6k
  libraw_memmgr(unsigned ee) : extra_bytes(ee)
34
25.6k
  {
35
25.6k
    size_t alloc_sz = LIBRAW_MSIZE * sizeof(void *);
36
25.6k
    mems = (void **)::malloc(alloc_sz);
37
25.6k
    memset(mems, 0, alloc_sz);
38
25.6k
  }
39
  ~libraw_memmgr()
40
25.6k
  {
41
25.6k
    cleanup();
42
25.6k
    ::free(mems);
43
25.6k
  }
44
  void *malloc(size_t sz)
45
7.49k
  {
46
#ifdef LIBRAW_USE_CALLOC_INSTEAD_OF_MALLOC
47
    void *ptr = ::calloc(sz + extra_bytes, 1);
48
#else
49
7.49k
    void *ptr = ::malloc(sz + extra_bytes);
50
7.49k
#endif
51
7.49k
    mem_ptr(ptr);
52
7.49k
    return ptr;
53
7.49k
  }
54
  void *calloc(size_t n, size_t sz)
55
282k
  {
56
282k
    void *ptr = ::calloc(n + (extra_bytes + sz - 1) / (sz ? sz : 1), sz);
57
282k
    mem_ptr(ptr);
58
282k
    return ptr;
59
282k
  }
60
  void *realloc(void *ptr, size_t newsz)
61
78
  {
62
78
    void *ret = ::realloc(ptr, newsz + extra_bytes);
63
78
    forget_ptr(ptr);
64
78
    mem_ptr(ret);
65
78
    return ret;
66
78
  }
67
  void free(void *ptr)
68
260k
  {
69
260k
    forget_ptr(ptr);
70
260k
    ::free(ptr);
71
260k
  }
72
  void cleanup(void)
73
89.4k
  {
74
45.9M
    for (int i = 0; i < LIBRAW_MSIZE; i++)
75
45.8M
      if (mems[i])
76
29.0k
      {
77
29.0k
        ::free(mems[i]);
78
29.0k
        mems[i] = NULL;
79
29.0k
      }
80
89.4k
  }
81
82
private:
83
  void **mems;
84
  unsigned extra_bytes;
85
  void mem_ptr(void *ptr)
86
289k
  {
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
289k
          if (ptr)
96
289k
          {
97
4.12M
              for (int i = 0; i < LIBRAW_MSIZE - 1; i++)
98
4.12M
                  if (!mems[i])
99
289k
                  {
100
289k
                      mems[i] = ptr;
101
#if defined(LIBRAW_USE_OPENMP)
102
          ok = true;
103
          break;
104
#else
105
289k
                      return;
106
289k
#endif
107
289k
                  }
108
2
#ifdef LIBRAW_MEMPOOL_CHECK
109
2
#if !defined(LIBRAW_USE_OPENMP)
110
              /* remember ptr in last mems item to be free'ed at cleanup */
111
2
              if (!mems[LIBRAW_MSIZE - 1])
112
2
                  mems[LIBRAW_MSIZE - 1] = ptr;
113
2
              throw LIBRAW_EXCEPTION_MEMPOOL;
114
289k
#endif
115
289k
#endif
116
289k
          }
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
289k
  }
127
  void forget_ptr(void *ptr)
128
260k
  {
129
#if defined(LIBRAW_USE_OPENMP)
130
#pragma omp critical
131
    {
132
#endif
133
260k
     if (ptr)
134
2.48M
      for (int i = 0; i < LIBRAW_MSIZE; i++)
135
2.48M
        if (mems[i] == ptr)
136
260k
        {
137
260k
          mems[i] = NULL;
138
260k
          break;
139
260k
        }
140
#if defined(LIBRAW_USE_OPENMP)
141
    }
142
#endif
143
260k
  }
144
};
145
146
#endif /* C++ */
147
148
#endif