Compare commits

..

5 Commits

Author SHA1 Message Date
Attila Uygun 068656ddc2 Bump version to 1.0.4 2023-06-06 00:26:29 +02:00
Attila Uygun 00f57bab05 Fix for Vulkan renderer
Terminate the bg thread before destroying resources
2023-06-06 00:26:29 +02:00
Attila Uygun 3bc8785469 Fix for benchmark 2023-06-05 23:41:27 +02:00
Attila Uygun 5c6e414a15 Consume input events when switching between renderers 2023-06-05 23:41:27 +02:00
Attila Uygun 1d1452d4aa Add support for canceling tasks in TaskRunner 2023-06-05 23:41:27 +02:00
9 changed files with 52 additions and 14 deletions

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:versionCode="19" android:versionCode="22"
android:versionName="1.0.3"> android:versionName="1.0.4">
<application <application
android:allowBackup="false" android:allowBackup="false"

View File

@ -35,7 +35,7 @@ TaskRunner* TaskRunner::GetThreadLocalTaskRunner() {
void TaskRunner::PostTask(const Location& from, Closure task) { void TaskRunner::PostTask(const Location& from, Closure task) {
DCHECK(task) << LOCATION(from); DCHECK(task) << LOCATION(from);
task_count_.fetch_add(1, std::memory_order_release); task_count_.fetch_add(1, std::memory_order_relaxed);
std::lock_guard<std::mutex> scoped_lock(lock_); std::lock_guard<std::mutex> scoped_lock(lock_);
queue_.emplace_back(from, std::move(task)); queue_.emplace_back(from, std::move(task));
} }
@ -71,6 +71,11 @@ void TaskRunner::MultiConsumerRun() {
task_cb(); task_cb();
task_count_.fetch_sub(1, std::memory_order_release); task_count_.fetch_sub(1, std::memory_order_release);
if (cancel_tasks_.load(std::memory_order_relaxed)) {
CancelTasksInternal();
break;
}
} }
} }
@ -93,12 +98,28 @@ void TaskRunner::SingleConsumerRun() {
task_cb(); task_cb();
task_count_.fetch_sub(1, std::memory_order_release); task_count_.fetch_sub(1, std::memory_order_release);
if (cancel_tasks_.load(std::memory_order_relaxed)) {
CancelTasksInternal();
break;
}
} }
} }
void TaskRunner::CancelTasks() {
cancel_tasks_.store(true, std::memory_order_relaxed);
}
void TaskRunner::WaitForCompletion() { void TaskRunner::WaitForCompletion() {
while (task_count_.load(std::memory_order_acquire) > 0) while (task_count_.load(std::memory_order_acquire) > 0)
std::this_thread::yield(); std::this_thread::yield();
} }
void TaskRunner::CancelTasksInternal() {
cancel_tasks_.store(false, std::memory_order_relaxed);
task_count_.store(0, std::memory_order_relaxed);
std::lock_guard<std::mutex> scoped_lock(lock_);
queue_.clear();
}
} // namespace base } // namespace base

View File

@ -60,9 +60,9 @@ class TaskRunner {
} }
void MultiConsumerRun(); void MultiConsumerRun();
void SingleConsumerRun(); void SingleConsumerRun();
void CancelTasks();
void WaitForCompletion(); void WaitForCompletion();
static void CreateThreadLocalTaskRunner(); static void CreateThreadLocalTaskRunner();
@ -74,9 +74,12 @@ class TaskRunner {
std::deque<Task> queue_; std::deque<Task> queue_;
mutable std::mutex lock_; mutable std::mutex lock_;
std::atomic<size_t> task_count_{0}; std::atomic<size_t> task_count_{0};
std::atomic<bool> cancel_tasks_{false};
static thread_local std::unique_ptr<TaskRunner> thread_local_task_runner; static thread_local std::unique_ptr<TaskRunner> thread_local_task_runner;
void CancelTasksInternal();
TaskRunner(TaskRunner const&) = delete; TaskRunner(TaskRunner const&) = delete;
TaskRunner& operator=(TaskRunner const&) = delete; TaskRunner& operator=(TaskRunner const&) = delete;
}; };

View File

@ -130,11 +130,11 @@ void Demo::Update(float delta_time) {
if (do_benchmark_) { if (do_benchmark_) {
benchmark_time_ += delta_time; benchmark_time_ += delta_time;
if (benchmark_time_ > 1) { if (benchmark_time_ > 3) {
avarage_fps_ += Engine::Get().fps(); avarage_fps_ += Engine::Get().fps();
++num_benchmark_samples_; ++num_benchmark_samples_;
} }
if (benchmark_time_ > 6) { if (benchmark_time_ > 5) {
avarage_fps_ /= num_benchmark_samples_; avarage_fps_ /= num_benchmark_samples_;
do_benchmark_ = false; do_benchmark_ = false;
BenchmarkResult(avarage_fps_); BenchmarkResult(avarage_fps_);
@ -166,14 +166,22 @@ void Demo::Update(float delta_time) {
UpdateGameState(delta_time); UpdateGameState(delta_time);
} }
void Demo::ContextLost() {
if (do_benchmark_) {
benchmark_time_ = 0;
num_benchmark_samples_ = 0;
avarage_fps_ = 0;
}
}
void Demo::LostFocus() {} void Demo::LostFocus() {}
void Demo::GainedFocus(bool from_interstitial_ad) { void Demo::GainedFocus(bool from_interstitial_ad) {
DLOG << __func__ << " from_interstitial_ad: " << from_interstitial_ad; DLOG << __func__ << " from_interstitial_ad: " << from_interstitial_ad;
if (!from_interstitial_ad) { if (!from_interstitial_ad) {
if (saved_data_.root().get(kLaunchCount, Json::Value(0)).asInt() > // if (saved_data_.root().get(kLaunchCount, Json::Value(0)).asInt() >
kLaunchCountBeforeAd) // kLaunchCountBeforeAd)
Engine::Get().ShowInterstitialAd(); // Engine::Get().ShowInterstitialAd();
if (state_ == kGame) if (state_ == kGame)
EnterMenuState(); EnterMenuState();
} }

View File

@ -27,7 +27,7 @@ class Demo final : public eng::Game {
void Update(float delta_time) final; void Update(float delta_time) final;
void ContextLost() final {} void ContextLost() final;
void LostFocus() final; void LostFocus() final;

View File

@ -23,7 +23,7 @@ using namespace eng;
namespace { namespace {
constexpr char kVersionStr[] = "Version 1.0.3"; constexpr char kVersionStr[] = "Version 1.0.4";
constexpr char kMenuOption[Menu::kOption_Max][10] = {"continue", "start", constexpr char kMenuOption[Menu::kOption_Max][10] = {"continue", "start",
"credits", "exit"}; "credits", "exit"};
@ -201,6 +201,7 @@ bool Menu::Initialize() {
: RendererType::kOpenGL); : RendererType::kOpenGL);
renderer_type_.SetEnabled( renderer_type_.SetEnabled(
(Engine::Get().GetRendererType() == RendererType::kVulkan)); (Engine::Get().GetRendererType() == RendererType::kVulkan));
Engine::Get().ConsumeInputEvents();
}, },
true, Engine::Get().GetRendererType() == RendererType::kVulkan, true, Engine::Get().GetRendererType() == RendererType::kVulkan,
kColorFadeOut, {Vector4f{1, 1, 1, 1}, Vector4f{1, 1, 1, 1}}); kColorFadeOut, {Vector4f{1, 1, 1, 1}, Vector4f{1, 1, 1, 1}});

View File

@ -396,6 +396,10 @@ std::unique_ptr<InputEvent> Engine::GetNextInputEvent() {
return event; return event;
} }
void Engine::ConsumeInputEvents() {
input_queue_.clear();
}
void Engine::StartRecording(const Json::Value& payload) { void Engine::StartRecording(const Json::Value& payload) {
if (!replaying_ && !recording_) { if (!replaying_ && !recording_) {
recording_ = true; recording_ = true;

View File

@ -84,6 +84,7 @@ class Engine : public PlatformObserver {
void RemoveCustomShader(const std::string& asset_name); void RemoveCustomShader(const std::string& asset_name);
std::unique_ptr<InputEvent> GetNextInputEvent(); std::unique_ptr<InputEvent> GetNextInputEvent();
void ConsumeInputEvents();
void StartRecording(const Json::Value& payload); void StartRecording(const Json::Value& payload);
void EndRecording(const std::string file_name); void EndRecording(const std::string file_name);

View File

@ -987,13 +987,13 @@ void RendererVulkan::Shutdown() {
return; return;
LOG << "Shutting down renderer."; LOG << "Shutting down renderer.";
DestroyAllResources();
context_lost_ = true;
quit_.store(true, std::memory_order_relaxed); quit_.store(true, std::memory_order_relaxed);
semaphore_.release(); semaphore_.release();
setup_thread_.join(); setup_thread_.join();
DestroyAllResources();
context_lost_ = true;
vkDeviceWaitIdle(device_); vkDeviceWaitIdle(device_);
for (size_t i = 0; i < frames_.size(); ++i) { for (size_t i = 0; i < frames_.size(); ++i) {