diff options
author | Michael Holzheu <holzheu@linux.vnet.ibm.com> | 2013-04-08 10:09:31 -0400 |
---|---|---|
committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2013-04-17 08:07:30 -0400 |
commit | 91c15a951091a64a5f048ff93292057e3b590b6f (patch) | |
tree | 33e7f36ede3deaa958d14736d83b401b0bc03123 /arch/s390/kernel/swsusp_asm64.S | |
parent | 5294ee00a16567355c85b849742e5219aad880d0 (diff) |
s390/hibernate: Save and restore absolute zero pages
Since commit 5f954c34 ([S390] hibernation: fix lowcore handling)
the absolute zero lowcore is lost during suspend/resume.
For example, this leads to the problem that the re-IPL device
for kdump is no longer set after resume.
With this patch during suspend a buffer is allocated in the new PM
notifier "suspend_pm_cb" and then the absolute zero lowcore is saved
to that buffer. The resume code then copies back this buffer to
absolute zero and afterwards the PM notifier releases the memory.
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'arch/s390/kernel/swsusp_asm64.S')
-rw-r--r-- | arch/s390/kernel/swsusp_asm64.S | 29 |
1 files changed, 26 insertions, 3 deletions
diff --git a/arch/s390/kernel/swsusp_asm64.S b/arch/s390/kernel/swsusp_asm64.S index d4ca4e0617b5..c487be4cfc81 100644 --- a/arch/s390/kernel/swsusp_asm64.S +++ b/arch/s390/kernel/swsusp_asm64.S | |||
@@ -36,8 +36,8 @@ ENTRY(swsusp_arch_suspend) | |||
36 | /* Store prefix register on stack */ | 36 | /* Store prefix register on stack */ |
37 | stpx __SF_EMPTY(%r15) | 37 | stpx __SF_EMPTY(%r15) |
38 | 38 | ||
39 | /* Save prefix register contents for lowcore */ | 39 | /* Save prefix register contents for lowcore copy */ |
40 | llgf %r4,__SF_EMPTY(%r15) | 40 | llgf %r10,__SF_EMPTY(%r15) |
41 | 41 | ||
42 | /* Get pointer to save area */ | 42 | /* Get pointer to save area */ |
43 | lghi %r1,0x1000 | 43 | lghi %r1,0x1000 |
@@ -91,7 +91,18 @@ ENTRY(swsusp_arch_suspend) | |||
91 | xc __SF_EMPTY(4,%r15),__SF_EMPTY(%r15) | 91 | xc __SF_EMPTY(4,%r15),__SF_EMPTY(%r15) |
92 | spx __SF_EMPTY(%r15) | 92 | spx __SF_EMPTY(%r15) |
93 | 93 | ||
94 | /* Save absolute zero pages */ | ||
95 | larl %r2,suspend_zero_pages | ||
96 | lg %r2,0(%r2) | ||
97 | lghi %r4,0 | ||
98 | lghi %r3,2*PAGE_SIZE | ||
99 | lghi %r5,2*PAGE_SIZE | ||
100 | 1: mvcle %r2,%r4,0 | ||
101 | jo 1b | ||
102 | |||
103 | /* Copy lowcore to absolute zero lowcore */ | ||
94 | lghi %r2,0 | 104 | lghi %r2,0 |
105 | lgr %r4,%r10 | ||
95 | lghi %r3,2*PAGE_SIZE | 106 | lghi %r3,2*PAGE_SIZE |
96 | lghi %r5,2*PAGE_SIZE | 107 | lghi %r5,2*PAGE_SIZE |
97 | 1: mvcle %r2,%r4,0 | 108 | 1: mvcle %r2,%r4,0 |
@@ -248,8 +259,20 @@ restore_registers: | |||
248 | /* Load old stack */ | 259 | /* Load old stack */ |
249 | lg %r15,0x2f8(%r13) | 260 | lg %r15,0x2f8(%r13) |
250 | 261 | ||
262 | /* Save prefix register */ | ||
263 | mvc __SF_EMPTY(4,%r15),0x318(%r13) | ||
264 | |||
265 | /* Restore absolute zero pages */ | ||
266 | lghi %r2,0 | ||
267 | larl %r4,suspend_zero_pages | ||
268 | lg %r4,0(%r4) | ||
269 | lghi %r3,2*PAGE_SIZE | ||
270 | lghi %r5,2*PAGE_SIZE | ||
271 | 1: mvcle %r2,%r4,0 | ||
272 | jo 1b | ||
273 | |||
251 | /* Restore prefix register */ | 274 | /* Restore prefix register */ |
252 | spx 0x318(%r13) | 275 | spx __SF_EMPTY(%r15) |
253 | 276 | ||
254 | /* Activate DAT */ | 277 | /* Activate DAT */ |
255 | stosm __SF_EMPTY(%r15),0x04 | 278 | stosm __SF_EMPTY(%r15),0x04 |