aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips/power
diff options
context:
space:
mode:
authorWe-unite <3205135446@qq.com>2025-03-08 22:04:20 +0800
committerWe-unite <3205135446@qq.com>2025-03-08 22:04:20 +0800
commita07bb8fd1299070229f0e8f3dcb57ffd5ef9870a (patch)
tree84f21bd0bf7071bc5fc7dd989e77d7ceb5476682 /arch/mips/power
downloadohosKernel-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/Makefile2
-rw-r--r--arch/mips/power/cpu.c42
-rw-r--r--arch/mips/power/hibernate.c11
-rw-r--r--arch/mips/power/hibernate_asm.S60
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
2obj-$(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
13static u32 saved_status;
14struct pt_regs saved_regs;
15
16void 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
26void 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
36int 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
4extern int restore_image(void);
5
6int 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
14LEAF(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
29END(swsusp_arch_suspend)
30
31LEAF(restore_image)
32 PTR_L t0, restore_pblist
330:
34 PTR_L t1, PBE_ADDRESS(t0) /* source */
35 PTR_L t2, PBE_ORIG_ADDRESS(t0) /* destination */
36 PTR_ADDU t3, t1, _PAGE_SIZE
371:
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
60END(restore_image)