aot_llvm_extra2.cpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * Copyright (c)2023 YAMAMOTO Takashi. All rights reserved.
  3. * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. */
  5. #include <llvm-c/TargetMachine.h>
  6. #include <llvm/MC/TargetRegistry.h>
  7. #include <llvm/Target/TargetMachine.h>
  8. #include "bh_assert.h"
  9. #include "aot_llvm_extra2.h"
  10. static llvm::Optional<llvm::Reloc::Model>
  11. convert(LLVMRelocMode reloc_mode)
  12. {
  13. switch (reloc_mode) {
  14. case LLVMRelocDefault:
  15. return llvm::None;
  16. case LLVMRelocStatic:
  17. return llvm::Reloc::Static;
  18. case LLVMRelocPIC:
  19. return llvm::Reloc::PIC_;
  20. case LLVMRelocDynamicNoPic:
  21. return llvm::Reloc::DynamicNoPIC;
  22. case LLVMRelocROPI:
  23. return llvm::Reloc::ROPI;
  24. case LLVMRelocRWPI:
  25. return llvm::Reloc::RWPI;
  26. case LLVMRelocROPI_RWPI:
  27. return llvm::Reloc::ROPI_RWPI;
  28. }
  29. bh_assert(0);
  30. return llvm::None;
  31. }
  32. static llvm::CodeGenOpt::Level
  33. convert(LLVMCodeGenOptLevel opt_level)
  34. {
  35. switch (opt_level) {
  36. case LLVMCodeGenLevelNone:
  37. return llvm::CodeGenOpt::None;
  38. case LLVMCodeGenLevelLess:
  39. return llvm::CodeGenOpt::Less;
  40. case LLVMCodeGenLevelDefault:
  41. return llvm::CodeGenOpt::Default;
  42. case LLVMCodeGenLevelAggressive:
  43. return llvm::CodeGenOpt::Aggressive;
  44. }
  45. bh_assert(0);
  46. return llvm::CodeGenOpt::None;
  47. }
  48. static llvm::Optional<llvm::CodeModel::Model>
  49. convert(LLVMCodeModel code_model, bool *jit)
  50. {
  51. *jit = false;
  52. switch (code_model) {
  53. case LLVMCodeModelDefault:
  54. return llvm::None;
  55. case LLVMCodeModelJITDefault:
  56. *jit = true;
  57. return llvm::None;
  58. case LLVMCodeModelTiny:
  59. return llvm::CodeModel::Tiny;
  60. case LLVMCodeModelSmall:
  61. return llvm::CodeModel::Small;
  62. case LLVMCodeModelKernel:
  63. return llvm::CodeModel::Kernel;
  64. case LLVMCodeModelMedium:
  65. return llvm::CodeModel::Medium;
  66. case LLVMCodeModelLarge:
  67. return llvm::CodeModel::Large;
  68. }
  69. bh_assert(0);
  70. return llvm::None;
  71. }
  72. LLVMTargetMachineRef
  73. LLVMCreateTargetMachineWithOpts(LLVMTargetRef ctarget, const char *triple,
  74. const char *cpu, const char *features,
  75. LLVMCodeGenOptLevel opt_level,
  76. LLVMRelocMode reloc_mode,
  77. LLVMCodeModel code_model,
  78. bool EmitStackSizeSection,
  79. const char *StackUsageOutput)
  80. {
  81. llvm::TargetOptions opts;
  82. // -fstack-size-section equiv
  83. // emit it to ".stack_sizes" section in case of ELF
  84. // you can read it with "llvm-readobj --stack-sizes"
  85. opts.EmitStackSizeSection = EmitStackSizeSection;
  86. // -fstack-usage equiv
  87. if (StackUsageOutput != NULL) {
  88. opts.StackUsageOutput = StackUsageOutput;
  89. }
  90. auto target = reinterpret_cast<llvm::Target *>(ctarget);
  91. auto rm = convert(reloc_mode);
  92. auto ol = convert(opt_level);
  93. bool jit;
  94. auto cm = convert(code_model, &jit);
  95. auto targetmachine = target->createTargetMachine(triple, cpu, features,
  96. opts, rm, cm, ol, jit);
  97. return reinterpret_cast<LLVMTargetMachineRef>(targetmachine);
  98. }