diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-17 15:50:54 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-17 15:50:54 -0400 |
commit | bfaf245022b4b8661af2e35f467cf0e91943c24c (patch) | |
tree | b5a6ee49a047557a791eb897c8c9545a155e36b7 /arch/mips/power/hibernate_asm.S | |
parent | 96d928ed75c4ba4253e82910a697ec7b06ace8b4 (diff) | |
parent | 3e20a26b02bd4f24945c87407df51948dd488620 (diff) |
Merge branch 'upstream' of git://git.linux-mips.org/pub/scm/ralf/upstream-linus
Pull MIPS updates from Ralf Baechle:
"This is the main pull request for MIPS for Linux 4.1. Most
noteworthy:
- Add more Octeon-optimized crypto functions
- Octeon crypto preemption and locking fixes
- Little endian support for Octeon
- Use correct CSR to soft reset Octeons
- Support LEDs on the Octeon-based DSR-1000N
- Fix PCI interrupt mapping for the Octeon-based DSR-1000N
- Mark prom_free_prom_memory() as __init for a number of systems
- Support for Imagination's Pistachio SOC. This includes arch and
CLK bits. I'd like to merge pinctrl bits later
- Improve parallelism of csum_partial for certain pipelines
- Organize DTB files in subdirs like other architectures
- Implement read_sched_clock for all MIPS platforms other than
Octeon
- Massive series of 38 fixes and cleanups for the FPU emulator /
kernel
- Further FPU remulator work to support new features. This sits on a
separate branch which also has been pulled into the 4.1 KVM branch
- Clean up and fixes for the SEAD3 eval board; remove unused file
- Various updates for Netlogic platforms
- A number of small updates for Loongson 3 platforms
- Increase the memory limit for ATH79 platforms to 256MB
- A fair number of fixes and updates for BCM47xx platforms
- Finish the implementation of XPA support
- MIPS FDC support. No, not floppy controller but Fast Debug Channel :)
- Detect the R16000 used in SGI legacy platforms
- Fix Kconfig dependencies for the SSB bus support"
* 'upstream' of git://git.linux-mips.org/pub/scm/ralf/upstream-linus: (265 commits)
MIPS: Makefile: Fix MIPS ASE detection code
MIPS: asm: elf: Set O32 default FPU flags
MIPS: BCM47XX: Fix detecting Microsoft MN-700 & Asus WL500G
MIPS: Kconfig: Disable SMP/CPS for 64-bit
MIPS: Hibernate: flush TLB entries earlier
MIPS: smp-cps: cpu_set FPU mask if FPU present
MIPS: lose_fpu(): Disable FPU when MSA enabled
MIPS: ralink: add missing symbol for RALINK_ILL_ACC
MIPS: ralink: Fix bad config symbol in PCI makefile.
SSB: fix Kconfig dependencies
MIPS: Malta: Detect and fix bad memsize values
Revert "MIPS: Avoid pipeline stalls on some MIPS32R2 cores."
MIPS: Octeon: Delete override of cpu_has_mips_r2_exec_hazard.
MIPS: Fix cpu_has_mips_r2_exec_hazard.
MIPS: kernel: entry.S: Set correct ISA level for mips_ihb
MIPS: asm: spinlock: Fix addiu instruction for R10000_LLSC_WAR case
MIPS: r4kcache: Use correct base register for MIPS R6 cache flushes
MIPS: Kconfig: Fix typo for the r2-to-r6 emulator kernel parameter
MIPS: unaligned: Fix regular load/store instruction emulation for EVA
MIPS: unaligned: Surround load/store macros in do {} while statements
...
Diffstat (limited to 'arch/mips/power/hibernate_asm.S')
-rw-r--r-- | arch/mips/power/hibernate_asm.S | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/arch/mips/power/hibernate_asm.S b/arch/mips/power/hibernate_asm.S new file mode 100644 index 000000000000..b1fab951100f --- /dev/null +++ b/arch/mips/power/hibernate_asm.S | |||
@@ -0,0 +1,61 @@ | |||
1 | /* | ||
2 | * Hibernation support specific for mips - temporary page tables | ||
3 | * | ||
4 | * Licensed under the GPLv2 | ||
5 | * | ||
6 | * Copyright (C) 2009 Lemote Inc. | ||
7 | * Author: Hu Hongbing <huhb@lemote.com> | ||
8 | * Wu Zhangjin <wuzhangjin@gmail.com> | ||
9 | */ | ||
10 | #include <asm/asm-offsets.h> | ||
11 | #include <asm/regdef.h> | ||
12 | #include <asm/asm.h> | ||
13 | |||
14 | .text | ||
15 | LEAF(swsusp_arch_suspend) | ||
16 | PTR_LA t0, saved_regs | ||
17 | PTR_S ra, PT_R31(t0) | ||
18 | PTR_S sp, PT_R29(t0) | ||
19 | PTR_S fp, PT_R30(t0) | ||
20 | PTR_S gp, PT_R28(t0) | ||
21 | PTR_S s0, PT_R16(t0) | ||
22 | PTR_S s1, PT_R17(t0) | ||
23 | PTR_S s2, PT_R18(t0) | ||
24 | PTR_S s3, PT_R19(t0) | ||
25 | PTR_S s4, PT_R20(t0) | ||
26 | PTR_S s5, PT_R21(t0) | ||
27 | PTR_S s6, PT_R22(t0) | ||
28 | PTR_S s7, PT_R23(t0) | ||
29 | j swsusp_save | ||
30 | END(swsusp_arch_suspend) | ||
31 | |||
32 | LEAF(restore_image) | ||
33 | PTR_L t0, restore_pblist | ||
34 | 0: | ||
35 | PTR_L t1, PBE_ADDRESS(t0) /* source */ | ||
36 | PTR_L t2, PBE_ORIG_ADDRESS(t0) /* destination */ | ||
37 | PTR_ADDU t3, t1, _PAGE_SIZE | ||
38 | 1: | ||
39 | REG_L t8, (t1) | ||
40 | REG_S t8, (t2) | ||
41 | PTR_ADDIU t1, t1, SZREG | ||
42 | PTR_ADDIU t2, t2, SZREG | ||
43 | bne t1, t3, 1b | ||
44 | PTR_L t0, PBE_NEXT(t0) | ||
45 | bnez t0, 0b | ||
46 | PTR_LA t0, saved_regs | ||
47 | PTR_L ra, PT_R31(t0) | ||
48 | PTR_L sp, PT_R29(t0) | ||
49 | PTR_L fp, PT_R30(t0) | ||
50 | PTR_L gp, PT_R28(t0) | ||
51 | PTR_L s0, PT_R16(t0) | ||
52 | PTR_L s1, PT_R17(t0) | ||
53 | PTR_L s2, PT_R18(t0) | ||
54 | PTR_L s3, PT_R19(t0) | ||
55 | PTR_L s4, PT_R20(t0) | ||
56 | PTR_L s5, PT_R21(t0) | ||
57 | PTR_L s6, PT_R22(t0) | ||
58 | PTR_L s7, PT_R23(t0) | ||
59 | PTR_LI v0, 0x0 | ||
60 | jr ra | ||
61 | END(restore_image) | ||