Mercurial > hg > orthanc
view OrthancFramework/Sources/DataSource/DataSourceMemoryBudget.cpp @ 6939:ae404101b2ae streaming tip
renamed DicomDataSource threads to differentiate them from the current DICOM network threads
| author | Alain Mazy <am@orthanc.team> |
|---|---|
| date | Tue, 09 Jun 2026 09:53:51 +0200 |
| parents | 7c9ecd5a793c |
| children |
line wrap: on
line source
/** * Orthanc - A Lightweight, RESTful DICOM Store * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017-2023 Osimis S.A., Belgium * Copyright (C) 2024-2026 Orthanc Team SRL, Belgium * Copyright (C) 2021-2026 Sebastien Jodogne, ICTEAM UCLouvain, Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this program. If not, see * <http://www.gnu.org/licenses/>. **/ #include "../PrecompiledHeaders.h" #include "DataSourceMemoryBudget.h" namespace Orthanc { namespace Internals { DataSourceMemoryBudget::DataSourceMemoryBudget(uint64_t maximumMemory) : maximumMemory_(maximumMemory), currentMemory_(0), reservations_(0) { } void DataSourceMemoryBudget::Acquire(size_t memory) ORTHANC_NOEXCEPT { boost::mutex::scoped_lock lock(mutex_); while (reservations_ != 0 && // Make sure that 1 thread can always proceed currentMemory_ + memory > maximumMemory_) { cond_.wait(lock); } currentMemory_ += memory; reservations_++; } void DataSourceMemoryBudget::Release(size_t memory) ORTHANC_NOEXCEPT { boost::mutex::scoped_lock lock(mutex_); assert(currentMemory_ >= memory); currentMemory_ -= memory; assert(reservations_ > 0); reservations_--; cond_.notify_all(); } uint64_t DataSourceMemoryBudget::GetCurrentMemory() ORTHANC_NOEXCEPT { boost::mutex::scoped_lock lock(mutex_); return currentMemory_; } void DataSourceMemoryBudget::GetStatistics(uint64_t& maximumMemory, uint64_t& currentMemory, unsigned int& countReservations) { boost::mutex::scoped_lock lock(mutex_); maximumMemory = maximumMemory_; currentMemory = currentMemory_; countReservations = reservations_; } } }
