2020-12-28 19:15:37 +04:00
|
|
|
// Copyright 2020 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <mutex>
|
|
|
|
#include <unordered_map>
|
|
|
|
|
|
|
|
#include "core/hle/kernel/object.h"
|
|
|
|
|
|
|
|
namespace Core {
|
|
|
|
class System;
|
|
|
|
} // namespace Core
|
|
|
|
|
|
|
|
namespace Core::Timing {
|
|
|
|
struct EventType;
|
|
|
|
} // namespace Core::Timing
|
|
|
|
|
|
|
|
namespace Kernel {
|
|
|
|
|
2021-01-21 10:23:23 +04:00
|
|
|
class Thread;
|
2020-12-28 19:15:37 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The `TimeManager` takes care of scheduling time events on threads and executes their TimeUp
|
|
|
|
* method when the event is triggered.
|
|
|
|
*/
|
|
|
|
class TimeManager {
|
|
|
|
public:
|
|
|
|
explicit TimeManager(Core::System& system);
|
|
|
|
|
|
|
|
/// Schedule a time event on `timetask` thread that will expire in 'nanoseconds'
|
2021-01-21 10:23:23 +04:00
|
|
|
/// returns a non-invalid handle in `event_handle` if correctly scheduled
|
|
|
|
void ScheduleTimeEvent(Handle& event_handle, Thread* timetask, s64 nanoseconds);
|
2020-12-28 19:15:37 +04:00
|
|
|
|
|
|
|
/// Unschedule an existing time event
|
2021-01-21 10:23:23 +04:00
|
|
|
void UnscheduleTimeEvent(Handle event_handle);
|
|
|
|
|
|
|
|
void CancelTimeEvent(Thread* time_task);
|
2020-12-28 19:15:37 +04:00
|
|
|
|
|
|
|
private:
|
|
|
|
Core::System& system;
|
|
|
|
std::shared_ptr<Core::Timing::EventType> time_manager_event_type;
|
2021-01-21 10:23:23 +04:00
|
|
|
std::unordered_map<Handle, bool> cancelled_events;
|
2020-12-28 19:15:37 +04:00
|
|
|
std::mutex mutex;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Kernel
|