cpu-features.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright (C) 2020-2022 Loongson Technology Corporation Limited
  4. *
  5. * Derived from MIPS:
  6. * Copyright (C) 2003, 2004 Ralf Baechle
  7. * Copyright (C) 2004 Maciej W. Rozycki
  8. */
  9. #ifndef __ASM_CPU_FEATURES_H
  10. #define __ASM_CPU_FEATURES_H
  11. #include <asm/cpu.h>
  12. #include <asm/cpu-info.h>
  13. #define cpu_opt(opt) (cpu_data[0].options & (opt))
  14. #define cpu_has(feat) (cpu_data[0].options & BIT_ULL(feat))
  15. #define cpu_has_loongarch (cpu_has_loongarch32 | cpu_has_loongarch64)
  16. #define cpu_has_loongarch32 (cpu_data[0].isa_level & LOONGARCH_CPU_ISA_32BIT)
  17. #define cpu_has_loongarch64 (cpu_data[0].isa_level & LOONGARCH_CPU_ISA_64BIT)
  18. #ifdef CONFIG_32BIT
  19. # define cpu_has_64bits (cpu_data[0].isa_level & LOONGARCH_CPU_ISA_64BIT)
  20. # define cpu_vabits 31
  21. # define cpu_pabits 31
  22. #endif
  23. #ifdef CONFIG_64BIT
  24. # define cpu_has_64bits 1
  25. # define cpu_vabits cpu_data[0].vabits
  26. # define cpu_pabits cpu_data[0].pabits
  27. # define __NEED_ADDRBITS_PROBE
  28. #endif
  29. /*
  30. * SMP assumption: Options of CPU 0 are a superset of all processors.
  31. * This is true for all known LoongArch systems.
  32. */
  33. #define cpu_has_cpucfg cpu_opt(LOONGARCH_CPU_CPUCFG)
  34. #define cpu_has_lam cpu_opt(LOONGARCH_CPU_LAM)
  35. #define cpu_has_ual cpu_opt(LOONGARCH_CPU_UAL)
  36. #define cpu_has_fpu cpu_opt(LOONGARCH_CPU_FPU)
  37. #define cpu_has_lsx cpu_opt(LOONGARCH_CPU_LSX)
  38. #define cpu_has_lasx cpu_opt(LOONGARCH_CPU_LASX)
  39. #define cpu_has_crc32 cpu_opt(LOONGARCH_CPU_CRC32)
  40. #define cpu_has_complex cpu_opt(LOONGARCH_CPU_COMPLEX)
  41. #define cpu_has_crypto cpu_opt(LOONGARCH_CPU_CRYPTO)
  42. #define cpu_has_lvz cpu_opt(LOONGARCH_CPU_LVZ)
  43. #define cpu_has_lbt_x86 cpu_opt(LOONGARCH_CPU_LBT_X86)
  44. #define cpu_has_lbt_arm cpu_opt(LOONGARCH_CPU_LBT_ARM)
  45. #define cpu_has_lbt_mips cpu_opt(LOONGARCH_CPU_LBT_MIPS)
  46. #define cpu_has_lbt (cpu_has_lbt_x86|cpu_has_lbt_arm|cpu_has_lbt_mips)
  47. #define cpu_has_csr cpu_opt(LOONGARCH_CPU_CSR)
  48. #define cpu_has_tlb cpu_opt(LOONGARCH_CPU_TLB)
  49. #define cpu_has_watch cpu_opt(LOONGARCH_CPU_WATCH)
  50. #define cpu_has_vint cpu_opt(LOONGARCH_CPU_VINT)
  51. #define cpu_has_csripi cpu_opt(LOONGARCH_CPU_CSRIPI)
  52. #define cpu_has_extioi cpu_opt(LOONGARCH_CPU_EXTIOI)
  53. #define cpu_has_prefetch cpu_opt(LOONGARCH_CPU_PREFETCH)
  54. #define cpu_has_pmp cpu_opt(LOONGARCH_CPU_PMP)
  55. #define cpu_has_perf cpu_opt(LOONGARCH_CPU_PMP)
  56. #define cpu_has_scalefreq cpu_opt(LOONGARCH_CPU_SCALEFREQ)
  57. #define cpu_has_flatmode cpu_opt(LOONGARCH_CPU_FLATMODE)
  58. #define cpu_has_eiodecode cpu_opt(LOONGARCH_CPU_EIODECODE)
  59. #define cpu_has_guestid cpu_opt(LOONGARCH_CPU_GUESTID)
  60. #define cpu_has_hypervisor cpu_opt(LOONGARCH_CPU_HYPERVISOR)
  61. #endif /* __ASM_CPU_FEATURES_H */