GCC Code Coverage Report


Directory: cvmfs/
File: cvmfs/fd_refcount_mgr.cc
Date: 2025-11-16 02:35:16
Exec Total Coverage
Lines: 80 80 100.0%
Branches: 45 76 59.2%

Line Branch Exec Source
1 /**
2 * This file is part of the CernVM File System.
3 */
4
5 #include "fd_refcount_mgr.h"
6
7 #include <fcntl.h>
8 #include <unistd.h>
9
10 #include <cassert>
11 #include <string>
12
13 #include "util/mutex.h"
14 #include "util/smalloc.h"
15
16
17 6585 int FdRefcountMgr::Open(const shash::Any id, const std::string &path) {
18 6585 int result = -1;
19 6585 const MutexLockGuard lock_guard(lock_cache_refcount_);
20
3/4
✓ Branch 1 taken 6585 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 6350 times.
✓ Branch 4 taken 235 times.
6585 if (!map_fd_.Lookup(id, &result)) {
21
1/2
✓ Branch 2 taken 6350 times.
✗ Branch 3 not taken.
6350 result = open(path.c_str(), O_RDONLY);
22
2/2
✓ Branch 0 taken 2384 times.
✓ Branch 1 taken 3966 times.
6350 if (result >= 0) {
23
1/2
✓ Branch 1 taken 2384 times.
✗ Branch 2 not taken.
2384 map_fd_.Insert(id, result);
24 }
25 }
26
2/2
✓ Branch 0 taken 2619 times.
✓ Branch 1 taken 3966 times.
6585 if (result >= 0) {
27
1/2
✓ Branch 1 taken 2619 times.
✗ Branch 2 not taken.
2619 FdRefcountInfo refc_info;
28
3/4
✓ Branch 1 taken 2619 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 235 times.
✓ Branch 4 taken 2384 times.
2619 if (map_refcount_.Lookup(result, &refc_info)) {
29 235 refc_info.refcount++;
30 } else {
31 2384 refc_info.refcount = 1;
32 2384 refc_info.id = id;
33 }
34
1/2
✓ Branch 1 taken 2619 times.
✗ Branch 2 not taken.
2619 map_refcount_.Insert(result, refc_info);
35 }
36 6585 return result;
37 6585 }
38
39 2418 int FdRefcountMgr::Close(int fd) {
40 2418 int retval = -1;
41 2418 const MutexLockGuard lock_guard(lock_cache_refcount_);
42
1/2
✓ Branch 1 taken 2418 times.
✗ Branch 2 not taken.
2418 FdRefcountInfo refc_info;
43
3/4
✓ Branch 1 taken 2418 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 2404 times.
✓ Branch 4 taken 14 times.
2418 if (map_refcount_.Lookup(fd, &refc_info)) {
44
2/2
✓ Branch 0 taken 176 times.
✓ Branch 1 taken 2228 times.
2404 if (refc_info.refcount > 1) {
45 176 refc_info.refcount -= 1;
46
1/2
✓ Branch 1 taken 176 times.
✗ Branch 2 not taken.
176 map_refcount_.Insert(fd, refc_info);
47 176 retval = 0;
48 } else {
49
1/2
✓ Branch 1 taken 2228 times.
✗ Branch 2 not taken.
2228 retval = close(fd);
50
1/2
✓ Branch 1 taken 2228 times.
✗ Branch 2 not taken.
2228 map_fd_.Erase(refc_info.id);
51
1/2
✓ Branch 1 taken 2228 times.
✗ Branch 2 not taken.
2228 map_refcount_.Erase(fd);
52 }
53 } else {
54 // fd not present in our table - this should only happen
55 // when reloading from the normal posix cache manager!
56
1/2
✓ Branch 1 taken 14 times.
✗ Branch 2 not taken.
14 LogCvmfs(kLogCache, kLogDebug,
57 "WARNING: trying to close fd that "
58 " is not in refcount tables");
59
1/2
✓ Branch 1 taken 14 times.
✗ Branch 2 not taken.
14 retval = close(fd);
60 }
61 2418 return retval;
62 2418 }
63
64 116 int FdRefcountMgr::Dup(int fd) {
65 116 int retval = -1;
66 116 const MutexLockGuard lock_guard(lock_cache_refcount_);
67
1/2
✓ Branch 1 taken 116 times.
✗ Branch 2 not taken.
116 FdRefcountInfo refc_info;
68
3/4
✓ Branch 1 taken 116 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 58 times.
✓ Branch 4 taken 58 times.
116 if (map_refcount_.Lookup(fd, &refc_info)) {
69 58 refc_info.refcount += 1;
70
1/2
✓ Branch 1 taken 58 times.
✗ Branch 2 not taken.
58 map_refcount_.Insert(fd, refc_info);
71 58 retval = fd;
72 } else {
73 // fd not present in our table - this should
74 // not happen in the current usage of Dup
75
1/2
✓ Branch 1 taken 58 times.
✗ Branch 2 not taken.
58 LogCvmfs(kLogCache, kLogDebug,
76 "WARNING: trying to dup fd that "
77 " is not in refcount tables");
78 58 retval = dup(fd);
79 }
80 116 return retval;
81 116 }
82
83 11 FdRefcountMgr *FdRefcountMgr::Clone() {
84
1/2
✓ Branch 2 taken 11 times.
✗ Branch 3 not taken.
11 FdRefcountMgr *clone = new FdRefcountMgr(map_refcount_, map_fd_);
85 11 return clone;
86 }
87
88 11 SmallHashDynamic<shash::Any, int> *FdRefcountMgr::GetFdMapPtr() {
89 11 return &map_fd_;
90 }
91
92 SmallHashDynamic<int, FdRefcountMgr::FdRefcountInfo> *
93 11 FdRefcountMgr::GetRefcountMapPtr() {
94 11 return &map_refcount_;
95 }
96
97 11 void FdRefcountMgr::AssignFrom(FdRefcountMgr *other) {
98 11 map_fd_ = *other->GetFdMapPtr();
99 11 map_refcount_ = *other->GetRefcountMapPtr();
100 11 }
101
102 5040 FdRefcountMgr::~FdRefcountMgr() {
103 5040 pthread_mutex_destroy(lock_cache_refcount_);
104 5040 free(lock_cache_refcount_);
105 5040 }
106
107
1/2
✓ Branch 2 taken 5038 times.
✗ Branch 3 not taken.
5038 FdRefcountMgr::FdRefcountMgr() {
108
1/2
✓ Branch 1 taken 5038 times.
✗ Branch 2 not taken.
5038 const shash::Any hash_null;
109
1/2
✓ Branch 1 taken 5038 times.
✗ Branch 2 not taken.
5038 map_fd_.Init(16, hash_null, hasher_any);
110
1/2
✓ Branch 1 taken 5038 times.
✗ Branch 2 not taken.
5038 map_refcount_.Init(16, -1, hasher_int);
111 5038 lock_cache_refcount_ = reinterpret_cast<pthread_mutex_t *>(
112 5038 smalloc(sizeof(pthread_mutex_t)));
113 5038 const int retval = pthread_mutex_init(lock_cache_refcount_, NULL);
114
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 5038 times.
5038 assert(retval == 0);
115 5038 }
116
117 11 FdRefcountMgr::FdRefcountMgr(
118 const SmallHashDynamic<int, FdRefcountMgr::FdRefcountInfo> &map_refcount,
119
1/2
✓ Branch 2 taken 11 times.
✗ Branch 3 not taken.
11 const SmallHashDynamic<shash::Any, int> &map_fd) {
120
1/2
✓ Branch 1 taken 11 times.
✗ Branch 2 not taken.
11 const shash::Any hash_null;
121
1/2
✓ Branch 1 taken 11 times.
✗ Branch 2 not taken.
11 map_fd_.Init(16, hash_null, hasher_any);
122
1/2
✓ Branch 1 taken 11 times.
✗ Branch 2 not taken.
11 map_refcount_.Init(16, -1, hasher_int);
123
1/2
✓ Branch 1 taken 11 times.
✗ Branch 2 not taken.
11 map_refcount_ = map_refcount;
124
1/2
✓ Branch 1 taken 11 times.
✗ Branch 2 not taken.
11 map_fd_ = map_fd;
125 11 lock_cache_refcount_ = reinterpret_cast<pthread_mutex_t *>(
126 11 smalloc(sizeof(pthread_mutex_t)));
127 11 const int retval = pthread_mutex_init(lock_cache_refcount_, NULL);
128
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 11 times.
11 assert(retval == 0);
129 11 }
130