PIT.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*
  2. * Copyright (c) 2020, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/NonnullRefPtr.h>
  8. #include <AK/Types.h>
  9. #include <Kernel/Time/HardwareTimer.h>
  10. namespace Kernel {
  11. /* Timer related ports */
  12. #define TIMER0_CTL 0x40
  13. #define TIMER1_CTL 0x41
  14. #define TIMER2_CTL 0x42
  15. #define PIT_CTL 0x43
  16. /* Building blocks for PIT_CTL */
  17. #define TIMER0_SELECT 0x00
  18. #define TIMER1_SELECT 0x40
  19. #define TIMER2_SELECT 0x80
  20. #define MODE_COUNTDOWN 0x00
  21. #define MODE_ONESHOT 0x02
  22. #define MODE_RATE 0x04
  23. #define MODE_SQUARE_WAVE 0x06
  24. #define WRITE_WORD 0x30
  25. #define BASE_FREQUENCY 1193182
  26. class PIT final : public HardwareTimer<IRQHandler> {
  27. public:
  28. static NonnullRefPtr<PIT> initialize(Function<void(const RegisterState&)>);
  29. virtual HardwareTimerType timer_type() const override { return HardwareTimerType::i8253; }
  30. virtual StringView model() const override { return "i8254"sv; }
  31. virtual size_t ticks_per_second() const override;
  32. virtual bool is_periodic() const override { return m_periodic; }
  33. virtual bool is_periodic_capable() const override { return true; }
  34. virtual void set_periodic() override;
  35. virtual void set_non_periodic() override;
  36. virtual void disable() override { }
  37. virtual void reset_to_default_ticks_per_second() override;
  38. virtual bool try_to_set_frequency(size_t frequency) override;
  39. virtual bool is_capable_of_frequency(size_t frequency) const override;
  40. virtual size_t calculate_nearest_possible_frequency(size_t frequency) const override;
  41. private:
  42. explicit PIT(Function<void(const RegisterState&)>);
  43. bool m_periodic { true };
  44. };
  45. }