Definitions.h 986 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /*
  2. * Copyright (c) 2022, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Types.h>
  8. namespace Kernel::IntelGraphics {
  9. enum class GlobalGenerationRegister {
  10. PipeAConf = 0x70008,
  11. PipeBConf = 0x71008,
  12. };
  13. struct PLLSettings;
  14. struct PLLParameterLimit {
  15. size_t min, max;
  16. };
  17. struct PLLMaxSettings {
  18. PLLParameterLimit dot_clock, vco, n, m, m1, m2, p, p1, p2;
  19. };
  20. struct PLLSettings {
  21. bool is_valid() const { return (n != 0 && m1 != 0 && m2 != 0 && p1 != 0 && p2 != 0); }
  22. u64 compute_dot_clock(u64 refclock) const
  23. {
  24. return (refclock * (5 * m1 + m2) / n) / (p1 * p2);
  25. }
  26. u64 compute_vco(u64 refclock) const
  27. {
  28. return refclock * (5 * m1 + m2) / n;
  29. }
  30. u64 compute_m() const
  31. {
  32. return 5 * m1 + m2;
  33. }
  34. u64 compute_p() const
  35. {
  36. return p1 * p2;
  37. }
  38. u64 n { 0 };
  39. u64 m1 { 0 };
  40. u64 m2 { 0 };
  41. u64 p1 { 0 };
  42. u64 p2 { 0 };
  43. };
  44. }