diff options
author | 2025-03-08 22:04:20 +0800 | |
---|---|---|
committer | 2025-03-08 22:04:20 +0800 | |
commit | a07bb8fd1299070229f0e8f3dcb57ffd5ef9870a (patch) | |
tree | 84f21bd0bf7071bc5fc7dd989e77d7ceb5476682 /arch/mips/power | |
download | ohosKernel-a07bb8fd1299070229f0e8f3dcb57ffd5ef9870a.tar.gz ohosKernel-a07bb8fd1299070229f0e8f3dcb57ffd5ef9870a.zip |
Initial commit: OpenHarmony-v4.0-ReleaseOpenHarmony-v4.0-Release
Diffstat (limited to 'arch/mips/power')
-rw-r--r-- | arch/mips/power/Makefile | 2 | ||||
-rw-r--r-- | arch/mips/power/cpu.c | 42 | ||||
-rw-r--r-- | arch/mips/power/hibernate.c | 11 | ||||
-rw-r--r-- | arch/mips/power/hibernate_asm.S | 60 |
4 files changed, 115 insertions, 0 deletions
diff --git a/arch/mips/power/Makefile b/arch/mips/power/Makefile new file mode 100644 index 000000000..14b7d9ee6 --- /dev/null +++ b/arch/mips/power/Makefile | |||
@@ -0,0 +1,2 @@ | |||
1 | # SPDX-License-Identifier: GPL-2.0-only | ||
2 | obj-$(CONFIG_HIBERNATION) += cpu.o hibernate.o hibernate_asm.o | ||
diff --git a/arch/mips/power/cpu.c b/arch/mips/power/cpu.c new file mode 100644 index 000000000..a15e29dfc --- /dev/null +++ b/arch/mips/power/cpu.c | |||
@@ -0,0 +1,42 @@ | |||
1 | // SPDX-License-Identifier: GPL-2.0-only | ||
2 | /* | ||
3 | * Suspend support specific for mips. | ||
4 | * | ||
5 | * Copyright (C) 2009 Lemote Inc. | ||
6 | * Author: Hu Hongbing <huhb@lemote.com> | ||
7 | * Wu Zhangjin <wuzhangjin@gmail.com> | ||
8 | */ | ||
9 | #include <asm/sections.h> | ||
10 | #include <asm/fpu.h> | ||
11 | #include <asm/dsp.h> | ||
12 | |||
13 | static u32 saved_status; | ||
14 | struct pt_regs saved_regs; | ||
15 | |||
16 | void save_processor_state(void) | ||
17 | { | ||
18 | saved_status = read_c0_status(); | ||
19 | |||
20 | if (is_fpu_owner()) | ||
21 | save_fp(current); | ||
22 | |||
23 | save_dsp(current); | ||
24 | } | ||
25 | |||
26 | void restore_processor_state(void) | ||
27 | { | ||
28 | write_c0_status(saved_status); | ||
29 | |||
30 | if (is_fpu_owner()) | ||
31 | restore_fp(current); | ||
32 | |||
33 | restore_dsp(current); | ||
34 | } | ||
35 | |||
36 | int pfn_is_nosave(unsigned long pfn) | ||
37 | { | ||
38 | unsigned long nosave_begin_pfn = PFN_DOWN(__pa(&__nosave_begin)); | ||
39 | unsigned long nosave_end_pfn = PFN_UP(__pa(&__nosave_end)); | ||
40 | |||
41 | return (pfn >= nosave_begin_pfn) && (pfn < nosave_end_pfn); | ||
42 | } | ||
diff --git a/arch/mips/power/hibernate.c b/arch/mips/power/hibernate.c new file mode 100644 index 000000000..94ab17c3c --- /dev/null +++ b/arch/mips/power/hibernate.c | |||
@@ -0,0 +1,11 @@ | |||
1 | // SPDX-License-Identifier: GPL-2.0 | ||
2 | #include <asm/tlbflush.h> | ||
3 | |||
4 | extern int restore_image(void); | ||
5 | |||
6 | int swsusp_arch_resume(void) | ||
7 | { | ||
8 | /* Avoid TLB mismatch during and after kernel resume */ | ||
9 | local_flush_tlb_all(); | ||
10 | return restore_image(); | ||
11 | } | ||
diff --git a/arch/mips/power/hibernate_asm.S b/arch/mips/power/hibernate_asm.S new file mode 100644 index 000000000..e62538734 --- /dev/null +++ b/arch/mips/power/hibernate_asm.S | |||
@@ -0,0 +1,60 @@ | |||
1 | /* SPDX-License-Identifier: GPL-2.0-only */ | ||
2 | /* | ||
3 | * Hibernation support specific for mips - temporary page tables | ||
4 | * | ||
5 | * Copyright (C) 2009 Lemote Inc. | ||
6 | * Author: Hu Hongbing <huhb@lemote.com> | ||
7 | * Wu Zhangjin <wuzhangjin@gmail.com> | ||
8 | */ | ||
9 | #include <asm/asm-offsets.h> | ||
10 | #include <asm/regdef.h> | ||
11 | #include <asm/asm.h> | ||
12 | |||
13 | .text | ||
14 | LEAF(swsusp_arch_suspend) | ||
15 | PTR_LA t0, saved_regs | ||
16 | PTR_S ra, PT_R31(t0) | ||
17 | PTR_S sp, PT_R29(t0) | ||
18 | PTR_S fp, PT_R30(t0) | ||
19 | PTR_S gp, PT_R28(t0) | ||
20 | PTR_S s0, PT_R16(t0) | ||
21 | PTR_S s1, PT_R17(t0) | ||
22 | PTR_S s2, PT_R18(t0) | ||
23 | PTR_S s3, PT_R19(t0) | ||
24 | PTR_S s4, PT_R20(t0) | ||
25 | PTR_S s5, PT_R21(t0) | ||
26 | PTR_S s6, PT_R22(t0) | ||
27 | PTR_S s7, PT_R23(t0) | ||
28 | j swsusp_save | ||
29 | END(swsusp_arch_suspend) | ||
30 | |||
31 | LEAF(restore_image) | ||
32 | PTR_L t0, restore_pblist | ||
33 | 0: | ||
34 | PTR_L t1, PBE_ADDRESS(t0) /* source */ | ||
35 | PTR_L t2, PBE_ORIG_ADDRESS(t0) /* destination */ | ||
36 | PTR_ADDU t3, t1, _PAGE_SIZE | ||
37 | 1: | ||
38 | REG_L t8, (t1) | ||
39 | REG_S t8, (t2) | ||
40 | PTR_ADDIU t1, t1, SZREG | ||
41 | PTR_ADDIU t2, t2, SZREG | ||
42 | bne t1, t3, 1b | ||
43 | PTR_L t0, PBE_NEXT(t0) | ||
44 | bnez t0, 0b | ||
45 | PTR_LA t0, saved_regs | ||
46 | PTR_L ra, PT_R31(t0) | ||
47 | PTR_L sp, PT_R29(t0) | ||
48 | PTR_L fp, PT_R30(t0) | ||
49 | PTR_L gp, PT_R28(t0) | ||
50 | PTR_L s0, PT_R16(t0) | ||
51 | PTR_L s1, PT_R17(t0) | ||
52 | PTR_L s2, PT_R18(t0) | ||
53 | PTR_L s3, PT_R19(t0) | ||
54 | PTR_L s4, PT_R20(t0) | ||
55 | PTR_L s5, PT_R21(t0) | ||
56 | PTR_L s6, PT_R22(t0) | ||
57 | PTR_L s7, PT_R23(t0) | ||
58 | PTR_LI v0, 0x0 | ||
59 | jr ra | ||
60 | END(restore_image) | ||