v2m.c 832 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <linux/of.h>
  3. #include <linux/of_address.h>
  4. #include <asm/mach/arch.h>
  5. #include "vexpress.h"
  6. #define SYS_FLAGSSET 0x030
  7. #define SYS_FLAGSCLR 0x034
  8. void vexpress_flags_set(u32 data)
  9. {
  10. static void __iomem *base;
  11. if (!base) {
  12. struct device_node *node = of_find_compatible_node(NULL, NULL,
  13. "arm,vexpress-sysreg");
  14. base = of_iomap(node, 0);
  15. }
  16. if (WARN_ON(!base))
  17. return;
  18. writel(~0, base + SYS_FLAGSCLR);
  19. writel(data, base + SYS_FLAGSSET);
  20. }
  21. static const char * const v2m_dt_match[] __initconst = {
  22. "arm,vexpress",
  23. NULL,
  24. };
  25. DT_MACHINE_START(VEXPRESS_DT, "ARM-Versatile Express")
  26. .dt_compat = v2m_dt_match,
  27. .l2c_aux_val = 0x00400000,
  28. .l2c_aux_mask = 0xfe0fffff,
  29. .smp = smp_ops(vexpress_smp_dt_ops),
  30. .smp_init = smp_init_ops(vexpress_smp_init_ops),
  31. MACHINE_END