bpf_jit64.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /*
  2. * bpf_jit64.h: BPF JIT compiler for PPC64
  3. *
  4. * Copyright 2016 Naveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
  5. * IBM Corporation
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License
  9. * as published by the Free Software Foundation; version 2
  10. * of the License.
  11. */
  12. #ifndef _BPF_JIT64_H
  13. #define _BPF_JIT64_H
  14. #include "bpf_jit.h"
  15. /*
  16. * Stack layout:
  17. * Ensure the top half (upto local_tmp_var) stays consistent
  18. * with our redzone usage.
  19. *
  20. * [ prev sp ] <-------------
  21. * [ nv gpr save area ] 6*8 |
  22. * [ tail_call_cnt ] 8 |
  23. * [ local_tmp_var ] 8 |
  24. * fp (r31) --> [ ebpf stack space ] upto 512 |
  25. * [ frame header ] 32/112 |
  26. * sp (r1) ---> [ stack pointer ] --------------
  27. */
  28. /* for gpr non volatile registers BPG_REG_6 to 10 */
  29. #define BPF_PPC_STACK_SAVE (6*8)
  30. /* for bpf JIT code internal usage */
  31. #define BPF_PPC_STACK_LOCALS 16
  32. /* stack frame excluding BPF stack, ensure this is quadword aligned */
  33. #define BPF_PPC_STACKFRAME (STACK_FRAME_MIN_SIZE + \
  34. BPF_PPC_STACK_LOCALS + BPF_PPC_STACK_SAVE)
  35. #ifndef __ASSEMBLY__
  36. /* BPF register usage */
  37. #define TMP_REG_1 (MAX_BPF_JIT_REG + 0)
  38. #define TMP_REG_2 (MAX_BPF_JIT_REG + 1)
  39. /* BPF to ppc register mappings */
  40. static const int b2p[] = {
  41. /* function return value */
  42. [BPF_REG_0] = 8,
  43. /* function arguments */
  44. [BPF_REG_1] = 3,
  45. [BPF_REG_2] = 4,
  46. [BPF_REG_3] = 5,
  47. [BPF_REG_4] = 6,
  48. [BPF_REG_5] = 7,
  49. /* non volatile registers */
  50. [BPF_REG_6] = 27,
  51. [BPF_REG_7] = 28,
  52. [BPF_REG_8] = 29,
  53. [BPF_REG_9] = 30,
  54. /* frame pointer aka BPF_REG_10 */
  55. [BPF_REG_FP] = 31,
  56. /* eBPF jit internal registers */
  57. [BPF_REG_AX] = 2,
  58. [TMP_REG_1] = 9,
  59. [TMP_REG_2] = 10
  60. };
  61. /* PPC NVR range -- update this if we ever use NVRs below r27 */
  62. #define BPF_PPC_NVR_MIN 27
  63. /*
  64. * WARNING: These can use TMP_REG_2 if the offset is not at word boundary,
  65. * so ensure that it isn't in use already.
  66. */
  67. #define PPC_BPF_LL(r, base, i) do { \
  68. if ((i) % 4) { \
  69. PPC_LI(b2p[TMP_REG_2], (i)); \
  70. PPC_LDX(r, base, b2p[TMP_REG_2]); \
  71. } else \
  72. PPC_LD(r, base, i); \
  73. } while(0)
  74. #define PPC_BPF_STL(r, base, i) do { \
  75. if ((i) % 4) { \
  76. PPC_LI(b2p[TMP_REG_2], (i)); \
  77. PPC_STDX(r, base, b2p[TMP_REG_2]); \
  78. } else \
  79. PPC_STD(r, base, i); \
  80. } while(0)
  81. #define PPC_BPF_STLU(r, base, i) do { PPC_STDU(r, base, i); } while(0)
  82. #define SEEN_FUNC 0x1000 /* might call external helpers */
  83. #define SEEN_STACK 0x2000 /* uses BPF stack */
  84. #define SEEN_TAILCALL 0x4000 /* uses tail calls */
  85. struct codegen_context {
  86. /*
  87. * This is used to track register usage as well
  88. * as calls to external helpers.
  89. * - register usage is tracked with corresponding
  90. * bits (r3-r10 and r27-r31)
  91. * - rest of the bits can be used to track other
  92. * things -- for now, we use bits 16 to 23
  93. * encoded in SEEN_* macros above
  94. */
  95. unsigned int seen;
  96. unsigned int idx;
  97. unsigned int stack_size;
  98. };
  99. #endif /* !__ASSEMBLY__ */
  100. #endif