2023-08-04 10:22:20 +03:00
|
|
|
#pragma once
|
|
|
|
|
2024-03-06 00:46:20 +02:00
|
|
|
#include <kernel/Interruptable.h>
|
2024-07-21 18:56:41 +03:00
|
|
|
#include <kernel/Lock/SpinLock.h>
|
2023-08-04 10:22:20 +03:00
|
|
|
#include <kernel/Timer/Timer.h>
|
|
|
|
|
|
|
|
namespace Kernel
|
|
|
|
{
|
|
|
|
|
2023-10-05 18:53:45 +03:00
|
|
|
class PIT final : public Timer, public Interruptable
|
2023-08-04 10:22:20 +03:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
static BAN::ErrorOr<BAN::UniqPtr<PIT>> create();
|
|
|
|
|
|
|
|
virtual uint64_t ms_since_boot() const override;
|
2023-10-12 21:16:39 +03:00
|
|
|
virtual uint64_t ns_since_boot() const override;
|
2023-08-04 15:44:32 +03:00
|
|
|
virtual timespec time_since_boot() const override;
|
2023-08-04 10:22:20 +03:00
|
|
|
|
2024-09-19 14:41:59 +03:00
|
|
|
virtual bool pre_scheduler_sleep_needs_lock() const override { return true; }
|
2024-07-23 02:28:52 +03:00
|
|
|
virtual void pre_scheduler_sleep_ns(uint64_t) override;
|
|
|
|
|
2023-10-05 18:53:45 +03:00
|
|
|
virtual void handle_irq() override;
|
|
|
|
|
2023-08-04 10:22:20 +03:00
|
|
|
private:
|
|
|
|
void initialize();
|
2024-07-23 02:28:52 +03:00
|
|
|
|
|
|
|
uint64_t read_counter_ns() const;
|
2023-10-05 18:53:45 +03:00
|
|
|
|
|
|
|
private:
|
2024-07-21 18:56:41 +03:00
|
|
|
mutable SpinLock m_lock;
|
2024-07-23 02:28:52 +03:00
|
|
|
uint64_t m_system_time_ms { 0 };
|
2023-08-04 10:22:20 +03:00
|
|
|
};
|
|
|
|
|
2024-01-24 14:43:46 +02:00
|
|
|
}
|