| /* |
| * linux/arch/unicore32/kernel/hibernate_asm.S |
| * |
| * Code specific to PKUnity SoC and UniCore ISA |
| * |
| * Maintained by GUAN Xue-tao <gxt@mprc.pku.edu.cn> |
| * Copyright (C) 2001-2010 Guan Xuetao |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 as |
| * published by the Free Software Foundation. |
| */ |
| |
| #include <linux/sys.h> |
| #include <linux/errno.h> |
| #include <linux/linkage.h> |
| #include <generated/asm-offsets.h> |
| #include <asm/page.h> |
| #include <asm/pgtable.h> |
| #include <asm/assembler.h> |
| |
| @ restore_image(pgd_t *resume_pg_dir, struct pbe *restore_pblist) |
| @ r0: resume_pg_dir |
| @ r1: restore_pblist |
| @ copy restore_pblist pages |
| @ restore registers from swsusp_arch_regs_cpu0 |
| @ |
| ENTRY(restore_image) |
| sub r0, r0, #PAGE_OFFSET |
| mov r5, #0 |
| movc p0.c6, r5, #6 @invalidate ITLB & DTLB |
| movc p0.c2, r0, #0 |
| nop |
| nop |
| nop |
| nop |
| nop |
| nop |
| nop |
| |
| .p2align 4,,7 |
| 101: |
| csub.a r1, #0 |
| beq 109f |
| |
| ldw r6, [r1+], #PBE_ADDRESS |
| ldw r7, [r1+], #PBE_ORIN_ADDRESS |
| |
| movl ip, #128 |
| 102: ldm.w (r8 - r15), [r6]+ |
| stm.w (r8 - r15), [r7]+ |
| sub.a ip, ip, #1 |
| bne 102b |
| |
| ldw r1, [r1+], #PBE_NEXT |
| b 101b |
| |
| .p2align 4,,7 |
| 109: |
| /* go back to the original page tables */ |
| ldw r0, =swapper_pg_dir |
| sub r0, r0, #PAGE_OFFSET |
| mov r5, #0 |
| movc p0.c6, r5, #6 |
| movc p0.c2, r0, #0 |
| nop |
| nop |
| nop |
| nop |
| nop |
| nop |
| nop |
| |
| #ifdef CONFIG_UNICORE_FPU_F64 |
| ldw ip, 1f |
| add ip, ip, #SWSUSP_FPSTATE |
| lfm.w (f0 - f7 ), [ip]+ |
| lfm.w (f8 - f15), [ip]+ |
| lfm.w (f16 - f23), [ip]+ |
| lfm.w (f24 - f31), [ip]+ |
| ldw r4, [ip] |
| ctf r4, s31 |
| #endif |
| mov r0, #0x0 |
| ldw ip, 1f |
| add ip, ip, #SWSUSP_CPU |
| ldm.w (r4 - r15), [ip]+ |
| ldm (r16 - r27, sp, pc), [ip]+ @ Load all regs saved previously |
| |
| .align 2 |
| 1: .long swsusp_arch_regs_cpu0 |
| |
| |
| @ swsusp_arch_suspend() |
| @ - prepare pc for resume, return from function without swsusp_save on resume |
| @ - save registers in swsusp_arch_regs_cpu0 |
| @ - call swsusp_save write suspend image |
| |
| ENTRY(swsusp_arch_suspend) |
| ldw ip, 1f |
| add ip, ip, #SWSUSP_CPU |
| stm.w (r4 - r15), [ip]+ |
| stm.w (r16 - r27, sp, lr), [ip]+ |
| |
| #ifdef CONFIG_UNICORE_FPU_F64 |
| ldw ip, 1f |
| add ip, ip, #SWSUSP_FPSTATE |
| sfm.w (f0 - f7 ), [ip]+ |
| sfm.w (f8 - f15), [ip]+ |
| sfm.w (f16 - f23), [ip]+ |
| sfm.w (f24 - f31), [ip]+ |
| cff r4, s31 |
| stw r4, [ip] |
| #endif |
| b swsusp_save @ no return |
| |
| 1: .long swsusp_arch_regs_cpu0 |