FlattenedDeviceTree.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /*
  2. * Copyright (c) 2021, Andrew Kaster <akaster@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Endian.h>
  8. #include <AK/Types.h>
  9. namespace DeviceTree {
  10. // https://devicetree-specification.readthedocs.io/en/v0.3/flattened-format.html
  11. struct FlattenedDeviceTreeHeader {
  12. BigEndian<u32> magic; // 0xDOODFEED (BE)
  13. BigEndian<u32> totalsize; // Total size of entire blob including padding b/w and after fields
  14. BigEndian<u32> off_dt_struct; // Offset of StructureBlock from beginning of header
  15. // https://devicetree-specification.readthedocs.io/en/v0.3/flattened-format.html#sect-fdt-structure-block
  16. BigEndian<u32> off_dt_strings; // Offset of StringsBlock from beginning of header
  17. // https://devicetree-specification.readthedocs.io/en/v0.3/flattened-format.html#sect-fdt-strings-block
  18. BigEndian<u32> off_mem_rsvmap; // Offset of MemoryReservationBlock from beginning of header
  19. BigEndian<u32> version; // 0.3 spec defines version 17
  20. BigEndian<u32> last_comp_version; // 0.3 spec back-compatible with version 16, mandated to be 16
  21. BigEndian<u32> boot_cpuid_phys; // Physical ID given in `reg` property of CPU node of boot cpu
  22. BigEndian<u32> size_dt_strings; // Length in bytes of StringsBlock
  23. BigEndian<u32> size_dt_struct; // Length in bytes of StructureBlock
  24. };
  25. static_assert(sizeof(FlattenedDeviceTreeHeader) == 40, "FDT Header size must match specification");
  26. // https://devicetree-specification.readthedocs.io/en/v0.3/flattened-format.html#format
  27. struct FlattenedDeviceTreeReserveEntry {
  28. BigEndian<u64> address;
  29. BigEndian<u64> size;
  30. bool operator==(FlattenedDeviceTreeReserveEntry const& other) const { return other.address == address && other.size == size; }
  31. bool operator!=(FlattenedDeviceTreeReserveEntry const& other) const { return !(operator==(other)); }
  32. };
  33. static_assert(sizeof(FlattenedDeviceTreeReserveEntry) == 16, "FDT Memory Reservation entry size must match specification");
  34. } // namespace DeviceTree