blob: 0f46a96f604862677c9cd58ff93492ff6b058e4b [file] [log] [blame]
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
#pragma once
#include <cstdlib>
#include <mutex>
#include "arrow/util/macros.h"
#include "gandiva/lru_cache.h"
#include "gandiva/visibility.h"
namespace gandiva {
namespace internal {
// Only called once by GetCacheCapacity().
// Do the actual work of getting the cache capacity from env var.
// Also makes the testing easier.
GANDIVA_EXPORT
int GetCacheCapacityFromEnvVar();
} // namespace internal
GANDIVA_EXPORT
int GetCacheCapacity();
GANDIVA_EXPORT
void LogCacheSize(size_t capacity);
template <class KeyType, typename ValueType>
class Cache {
public:
explicit Cache(size_t capacity) : cache_(capacity) { LogCacheSize(capacity); }
Cache() : Cache(GetCacheCapacity()) {}
ValueType GetObjectCode(const KeyType& cache_key) {
std::optional<ValueType> result;
std::lock_guard<std::mutex> lock(mtx_);
result = cache_.get(cache_key);
return result != std::nullopt ? *result : nullptr;
}
void PutObjectCode(const KeyType& cache_key, const ValueType& module) {
std::lock_guard<std::mutex> lock(mtx_);
cache_.insert(cache_key, module);
}
private:
LruCache<KeyType, ValueType> cache_;
std::mutex mtx_;
};
} // namespace gandiva