GCC Code Coverage Report


Directory: cvmfs/
File: cvmfs/ingestion/item_mem.cc
Date: 2025-11-16 02:35:16
Exec Total Coverage
Lines: 45 46 97.8%
Branches: 34 50 68.0%

Line Branch Exec Source
1 /**
2 * This file is part of the CernVM File System.
3 */
4
5 #include "item_mem.h"
6
7 #include <cassert>
8 #include <cstdlib>
9
10 #include "util/concurrency.h"
11 #include "util/exception.h"
12
13 atomic_int64 ItemAllocator::total_allocated_ = 0;
14
15
16 31710672 void ItemAllocator::Free(void *ptr) {
17 31710672 const MutexLockGuard guard(lock_);
18
19 31805103 MallocArena *M = MallocArena::GetMallocArena(ptr, kArenaSize);
20
1/2
✓ Branch 1 taken 31805103 times.
✗ Branch 2 not taken.
31805103 M->Free(ptr);
21 31805103 const unsigned N = malloc_arenas_.size();
22
6/6
✓ Branch 0 taken 6291615 times.
✓ Branch 1 taken 25513488 times.
✓ Branch 3 taken 164 times.
✓ Branch 4 taken 6291451 times.
✓ Branch 5 taken 164 times.
✓ Branch 6 taken 31804939 times.
31805103 if ((N > 1) && M->IsEmpty()) {
23
1/2
✓ Branch 0 taken 242 times.
✗ Branch 1 not taken.
242 for (unsigned i = 0; i < N; ++i) {
24
2/2
✓ Branch 1 taken 164 times.
✓ Branch 2 taken 78 times.
242 if (malloc_arenas_[i] == M) {
25
1/2
✓ Branch 1 taken 164 times.
✗ Branch 2 not taken.
164 delete malloc_arenas_[i];
26 164 atomic_xadd64(&total_allocated_, -static_cast<int>(kArenaSize));
27
1/2
✓ Branch 4 taken 164 times.
✗ Branch 5 not taken.
164 malloc_arenas_.erase(malloc_arenas_.begin() + i);
28 164 idx_last_arena_ = 0;
29 164 return;
30 }
31 }
32 PANIC(NULL);
33 }
34
2/2
✓ Branch 1 taken 31784003 times.
✓ Branch 2 taken 1022 times.
31805103 }
35
36
37 2351 ItemAllocator::ItemAllocator() : idx_last_arena_(0) {
38 2351 const int retval = pthread_mutex_init(&lock_, NULL);
39
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 2351 times.
2351 assert(retval == 0);
40
41
3/6
✓ Branch 1 taken 2351 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2351 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2351 times.
✗ Branch 8 not taken.
2351 malloc_arenas_.push_back(new MallocArena(kArenaSize));
42 2351 atomic_xadd64(&total_allocated_, kArenaSize);
43 2351 }
44
45
46 2350 ItemAllocator::~ItemAllocator() {
47
2/2
✓ Branch 1 taken 2350 times.
✓ Branch 2 taken 2350 times.
4700 for (unsigned i = 0; i < malloc_arenas_.size(); ++i) {
48 2350 atomic_xadd64(&total_allocated_, -static_cast<int>(kArenaSize));
49
1/2
✓ Branch 1 taken 2350 times.
✗ Branch 2 not taken.
2350 delete malloc_arenas_[i];
50 }
51 2350 pthread_mutex_destroy(&lock_);
52 2350 }
53
54
55 31652898 void *ItemAllocator::Malloc(unsigned size) {
56 31652898 const MutexLockGuard guard(lock_);
57
58
1/2
✓ Branch 2 taken 31805103 times.
✗ Branch 3 not taken.
31805103 void *p = malloc_arenas_[idx_last_arena_]->Malloc(size);
59
2/2
✓ Branch 0 taken 31804822 times.
✓ Branch 1 taken 281 times.
31805103 if (p != NULL)
60 31804822 return p;
61 281 const unsigned N = malloc_arenas_.size();
62
2/2
✓ Branch 0 taken 359 times.
✓ Branch 1 taken 164 times.
523 for (unsigned i = 0; i < N; ++i) {
63
1/2
✓ Branch 2 taken 359 times.
✗ Branch 3 not taken.
359 p = malloc_arenas_[i]->Malloc(size);
64
2/2
✓ Branch 0 taken 117 times.
✓ Branch 1 taken 242 times.
359 if (p != NULL) {
65 117 idx_last_arena_ = i;
66 117 return p;
67 }
68 }
69 164 idx_last_arena_ = N;
70
2/4
✓ Branch 1 taken 164 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 164 times.
✗ Branch 5 not taken.
164 MallocArena *M = new MallocArena(kArenaSize);
71 164 atomic_xadd64(&total_allocated_, kArenaSize);
72
1/2
✓ Branch 1 taken 164 times.
✗ Branch 2 not taken.
164 malloc_arenas_.push_back(M);
73
1/2
✓ Branch 1 taken 164 times.
✗ Branch 2 not taken.
164 p = M->Malloc(size);
74
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 164 times.
164 assert(p != NULL);
75 164 return p;
76 31805103 }
77