machine.h 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /*
  2. * Copyright (C) 2016 Imagination Technologies
  3. * Author: Paul Burton <paul.burton@mips.com>
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License as published by the
  7. * Free Software Foundation; either version 2 of the License, or (at your
  8. * option) any later version.
  9. */
  10. #ifndef __MIPS_ASM_MACHINE_H__
  11. #define __MIPS_ASM_MACHINE_H__
  12. #include <linux/libfdt.h>
  13. #include <linux/of.h>
  14. struct mips_machine {
  15. const struct of_device_id *matches;
  16. const void *fdt;
  17. bool (*detect)(void);
  18. const void *(*fixup_fdt)(const void *fdt, const void *match_data);
  19. unsigned int (*measure_hpt_freq)(void);
  20. };
  21. extern long __mips_machines_start;
  22. extern long __mips_machines_end;
  23. #define MIPS_MACHINE(name) \
  24. static const struct mips_machine __mips_mach_##name \
  25. __used __section(.mips.machines.init)
  26. #define for_each_mips_machine(mach) \
  27. for ((mach) = (struct mips_machine *)&__mips_machines_start; \
  28. (mach) < (struct mips_machine *)&__mips_machines_end; \
  29. (mach)++)
  30. /**
  31. * mips_machine_is_compatible() - check if a machine is compatible with an FDT
  32. * @mach: the machine struct to check
  33. * @fdt: the FDT to check for compatibility with
  34. *
  35. * Check whether the given machine @mach is compatible with the given flattened
  36. * device tree @fdt, based upon the compatibility property of the root node.
  37. *
  38. * Return: the device id matched if any, else NULL
  39. */
  40. static inline const struct of_device_id *
  41. mips_machine_is_compatible(const struct mips_machine *mach, const void *fdt)
  42. {
  43. const struct of_device_id *match;
  44. if (!mach->matches)
  45. return NULL;
  46. for (match = mach->matches; match->compatible[0]; match++) {
  47. if (fdt_node_check_compatible(fdt, 0, match->compatible) == 0)
  48. return match;
  49. }
  50. return NULL;
  51. }
  52. /**
  53. * struct mips_fdt_fixup - Describe a fixup to apply to an FDT
  54. * @apply: applies the fixup to @fdt, returns zero on success else -errno
  55. * @description: a short description of the fixup
  56. *
  57. * Describes a fixup applied to an FDT blob by the @apply function. The
  58. * @description field provides a short description of the fixup intended for
  59. * use in error messages if the @apply function returns non-zero.
  60. */
  61. struct mips_fdt_fixup {
  62. int (*apply)(void *fdt);
  63. const char *description;
  64. };
  65. /**
  66. * apply_mips_fdt_fixups() - apply fixups to an FDT blob
  67. * @fdt_out: buffer in which to place the fixed-up FDT
  68. * @fdt_out_size: the size of the @fdt_out buffer
  69. * @fdt_in: the FDT blob
  70. * @fixups: pointer to an array of fixups to be applied
  71. *
  72. * Loop through the array of fixups pointed to by @fixups, calling the apply
  73. * function on each until either one returns an error or we reach the end of
  74. * the list as indicated by an entry with a NULL apply field.
  75. *
  76. * Return: zero on success, else -errno
  77. */
  78. extern int __init apply_mips_fdt_fixups(void *fdt_out, size_t fdt_out_size,
  79. const void *fdt_in,
  80. const struct mips_fdt_fixup *fixups);
  81. #endif /* __MIPS_ASM_MACHINE_H__ */