2
0

0115-RISC-V-Factor-out-common-code-of-__cpu_resume_enter.patch 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. From f0e2b8f9bb240d7391d3eeca55534160fd385ea8 Mon Sep 17 00:00:00 2001
  2. From: Sia Jee Heng <[email protected]>
  3. Date: Thu, 30 Mar 2023 14:43:19 +0800
  4. Subject: [PATCH 115/122] RISC-V: Factor out common code of
  5. __cpu_resume_enter()
  6. The cpu_resume() function is very similar for the suspend to disk and
  7. suspend to ram cases. Factor out the common code into suspend_restore_csrs
  8. macro and suspend_restore_regs macro.
  9. Signed-off-by: Sia Jee Heng <[email protected]>
  10. Reviewed-by: Andrew Jones <[email protected]>
  11. Reviewed-by: Conor Dooley <[email protected]>
  12. ---
  13. arch/riscv/include/asm/assembler.h | 62 ++++++++++++++++++++++++++++++
  14. arch/riscv/kernel/suspend_entry.S | 34 ++--------------
  15. 2 files changed, 65 insertions(+), 31 deletions(-)
  16. create mode 100644 arch/riscv/include/asm/assembler.h
  17. --- /dev/null
  18. +++ b/arch/riscv/include/asm/assembler.h
  19. @@ -0,0 +1,62 @@
  20. +/* SPDX-License-Identifier: GPL-2.0-only */
  21. +/*
  22. + * Copyright (C) 2023 StarFive Technology Co., Ltd.
  23. + *
  24. + * Author: Jee Heng Sia <[email protected]>
  25. + */
  26. +
  27. +#ifndef __ASSEMBLY__
  28. +#error "Only include this from assembly code"
  29. +#endif
  30. +
  31. +#ifndef __ASM_ASSEMBLER_H
  32. +#define __ASM_ASSEMBLER_H
  33. +
  34. +#include <asm/asm.h>
  35. +#include <asm/asm-offsets.h>
  36. +#include <asm/csr.h>
  37. +
  38. +/*
  39. + * suspend_restore_csrs - restore CSRs
  40. + */
  41. + .macro suspend_restore_csrs
  42. + REG_L t0, (SUSPEND_CONTEXT_REGS + PT_EPC)(a0)
  43. + csrw CSR_EPC, t0
  44. + REG_L t0, (SUSPEND_CONTEXT_REGS + PT_STATUS)(a0)
  45. + csrw CSR_STATUS, t0
  46. + REG_L t0, (SUSPEND_CONTEXT_REGS + PT_BADADDR)(a0)
  47. + csrw CSR_TVAL, t0
  48. + REG_L t0, (SUSPEND_CONTEXT_REGS + PT_CAUSE)(a0)
  49. + csrw CSR_CAUSE, t0
  50. + .endm
  51. +
  52. +/*
  53. + * suspend_restore_regs - Restore registers (except A0 and T0-T6)
  54. + */
  55. + .macro suspend_restore_regs
  56. + REG_L ra, (SUSPEND_CONTEXT_REGS + PT_RA)(a0)
  57. + REG_L sp, (SUSPEND_CONTEXT_REGS + PT_SP)(a0)
  58. + REG_L gp, (SUSPEND_CONTEXT_REGS + PT_GP)(a0)
  59. + REG_L tp, (SUSPEND_CONTEXT_REGS + PT_TP)(a0)
  60. + REG_L s0, (SUSPEND_CONTEXT_REGS + PT_S0)(a0)
  61. + REG_L s1, (SUSPEND_CONTEXT_REGS + PT_S1)(a0)
  62. + REG_L a1, (SUSPEND_CONTEXT_REGS + PT_A1)(a0)
  63. + REG_L a2, (SUSPEND_CONTEXT_REGS + PT_A2)(a0)
  64. + REG_L a3, (SUSPEND_CONTEXT_REGS + PT_A3)(a0)
  65. + REG_L a4, (SUSPEND_CONTEXT_REGS + PT_A4)(a0)
  66. + REG_L a5, (SUSPEND_CONTEXT_REGS + PT_A5)(a0)
  67. + REG_L a6, (SUSPEND_CONTEXT_REGS + PT_A6)(a0)
  68. + REG_L a7, (SUSPEND_CONTEXT_REGS + PT_A7)(a0)
  69. + REG_L s2, (SUSPEND_CONTEXT_REGS + PT_S2)(a0)
  70. + REG_L s3, (SUSPEND_CONTEXT_REGS + PT_S3)(a0)
  71. + REG_L s4, (SUSPEND_CONTEXT_REGS + PT_S4)(a0)
  72. + REG_L s5, (SUSPEND_CONTEXT_REGS + PT_S5)(a0)
  73. + REG_L s6, (SUSPEND_CONTEXT_REGS + PT_S6)(a0)
  74. + REG_L s7, (SUSPEND_CONTEXT_REGS + PT_S7)(a0)
  75. + REG_L s8, (SUSPEND_CONTEXT_REGS + PT_S8)(a0)
  76. + REG_L s9, (SUSPEND_CONTEXT_REGS + PT_S9)(a0)
  77. + REG_L s10, (SUSPEND_CONTEXT_REGS + PT_S10)(a0)
  78. + REG_L s11, (SUSPEND_CONTEXT_REGS + PT_S11)(a0)
  79. + .endm
  80. +
  81. +#endif /* __ASM_ASSEMBLER_H */
  82. --- a/arch/riscv/kernel/suspend_entry.S
  83. +++ b/arch/riscv/kernel/suspend_entry.S
  84. @@ -7,6 +7,7 @@
  85. #include <linux/linkage.h>
  86. #include <asm/asm.h>
  87. #include <asm/asm-offsets.h>
  88. +#include <asm/assembler.h>
  89. #include <asm/csr.h>
  90. #include <asm/xip_fixup.h>
  91. @@ -83,39 +84,10 @@ ENTRY(__cpu_resume_enter)
  92. add a0, a1, zero
  93. /* Restore CSRs */
  94. - REG_L t0, (SUSPEND_CONTEXT_REGS + PT_EPC)(a0)
  95. - csrw CSR_EPC, t0
  96. - REG_L t0, (SUSPEND_CONTEXT_REGS + PT_STATUS)(a0)
  97. - csrw CSR_STATUS, t0
  98. - REG_L t0, (SUSPEND_CONTEXT_REGS + PT_BADADDR)(a0)
  99. - csrw CSR_TVAL, t0
  100. - REG_L t0, (SUSPEND_CONTEXT_REGS + PT_CAUSE)(a0)
  101. - csrw CSR_CAUSE, t0
  102. + suspend_restore_csrs
  103. /* Restore registers (except A0 and T0-T6) */
  104. - REG_L ra, (SUSPEND_CONTEXT_REGS + PT_RA)(a0)
  105. - REG_L sp, (SUSPEND_CONTEXT_REGS + PT_SP)(a0)
  106. - REG_L gp, (SUSPEND_CONTEXT_REGS + PT_GP)(a0)
  107. - REG_L tp, (SUSPEND_CONTEXT_REGS + PT_TP)(a0)
  108. - REG_L s0, (SUSPEND_CONTEXT_REGS + PT_S0)(a0)
  109. - REG_L s1, (SUSPEND_CONTEXT_REGS + PT_S1)(a0)
  110. - REG_L a1, (SUSPEND_CONTEXT_REGS + PT_A1)(a0)
  111. - REG_L a2, (SUSPEND_CONTEXT_REGS + PT_A2)(a0)
  112. - REG_L a3, (SUSPEND_CONTEXT_REGS + PT_A3)(a0)
  113. - REG_L a4, (SUSPEND_CONTEXT_REGS + PT_A4)(a0)
  114. - REG_L a5, (SUSPEND_CONTEXT_REGS + PT_A5)(a0)
  115. - REG_L a6, (SUSPEND_CONTEXT_REGS + PT_A6)(a0)
  116. - REG_L a7, (SUSPEND_CONTEXT_REGS + PT_A7)(a0)
  117. - REG_L s2, (SUSPEND_CONTEXT_REGS + PT_S2)(a0)
  118. - REG_L s3, (SUSPEND_CONTEXT_REGS + PT_S3)(a0)
  119. - REG_L s4, (SUSPEND_CONTEXT_REGS + PT_S4)(a0)
  120. - REG_L s5, (SUSPEND_CONTEXT_REGS + PT_S5)(a0)
  121. - REG_L s6, (SUSPEND_CONTEXT_REGS + PT_S6)(a0)
  122. - REG_L s7, (SUSPEND_CONTEXT_REGS + PT_S7)(a0)
  123. - REG_L s8, (SUSPEND_CONTEXT_REGS + PT_S8)(a0)
  124. - REG_L s9, (SUSPEND_CONTEXT_REGS + PT_S9)(a0)
  125. - REG_L s10, (SUSPEND_CONTEXT_REGS + PT_S10)(a0)
  126. - REG_L s11, (SUSPEND_CONTEXT_REGS + PT_S11)(a0)
  127. + suspend_restore_regs
  128. /* Return zero value */
  129. add a0, zero, zero