Jan Beulich | ec7fd34 | 2013-03-11 10:06:12 +0000 | [diff] [blame] | 1 | .text |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | #include <linux/linkage.h> |
| 3 | #include <asm/segment.h> |
Jeremy Fitzhardinge | 0341c14 | 2009-02-13 11:14:01 -0800 | [diff] [blame] | 4 | #include <asm/page_types.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 5 | |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 6 | # Copyright 2003, 2008 Pavel Machek <pavel@suse.cz>, distribute under GPLv2 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 8 | .code32 |
| 9 | ALIGN |
| 10 | |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 11 | ENTRY(wakeup_pmode_return) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 | wakeup_pmode_return: |
| 13 | movw $__KERNEL_DS, %ax |
| 14 | movw %ax, %ss |
| 15 | movw %ax, %ds |
| 16 | movw %ax, %es |
| 17 | movw %ax, %fs |
| 18 | movw %ax, %gs |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | |
| 20 | # reload the gdt, as we need the full 32 bit address |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 21 | lidt saved_idt |
| 22 | lldt saved_ldt |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 23 | ljmp $(__KERNEL_CS), $1f |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | 1: |
| 25 | movl %cr3, %eax |
| 26 | movl %eax, %cr3 |
| 27 | wbinvd |
| 28 | |
| 29 | # and restore the stack ... but you need gdt for this to work |
| 30 | movl saved_context_esp, %esp |
| 31 | |
| 32 | movl %cs:saved_magic, %eax |
| 33 | cmpl $0x12345678, %eax |
| 34 | jne bogus_magic |
| 35 | |
| 36 | # jump to place where we left off |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 37 | movl saved_eip, %eax |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 38 | jmp *%eax |
| 39 | |
| 40 | bogus_magic: |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 41 | jmp bogus_magic |
| 42 | |
| 43 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 44 | |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 45 | save_registers: |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 46 | sidt saved_idt |
| 47 | sldt saved_ldt |
| 48 | str saved_tss |
| 49 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 50 | leal 4(%esp), %eax |
| 51 | movl %eax, saved_context_esp |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 52 | movl %ebx, saved_context_ebx |
| 53 | movl %ebp, saved_context_ebp |
| 54 | movl %esi, saved_context_esi |
| 55 | movl %edi, saved_context_edi |
| 56 | pushfl |
| 57 | popl saved_context_eflags |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 58 | |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 59 | movl $ret_point, saved_eip |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 60 | ret |
| 61 | |
| 62 | |
| 63 | restore_registers: |
Pavel Machek | e44b7b7 | 2008-04-10 23:28:10 +0200 | [diff] [blame] | 64 | movl saved_context_ebp, %ebp |
| 65 | movl saved_context_ebx, %ebx |
| 66 | movl saved_context_esi, %esi |
| 67 | movl saved_context_edi, %edi |
| 68 | pushl saved_context_eflags |
| 69 | popfl |
| 70 | ret |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 71 | |
| 72 | ENTRY(do_suspend_lowlevel) |
| 73 | call save_processor_state |
| 74 | call save_registers |
Len Brown | 3b6961b | 2012-07-26 19:40:08 -0400 | [diff] [blame] | 75 | pushl $3 |
Lv Zheng | 40bce10 | 2013-10-31 09:31:18 +0800 | [diff] [blame^] | 76 | call x86_acpi_enter_sleep_state |
Len Brown | 3b6961b | 2012-07-26 19:40:08 -0400 | [diff] [blame] | 77 | addl $4, %esp |
William Morrrow | 4e6e650 | 2006-08-14 22:37:31 -0700 | [diff] [blame] | 78 | |
| 79 | # In case of S3 failure, we'll emerge here. Jump |
| 80 | # to ret_point to recover |
| 81 | jmp ret_point |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 82 | .p2align 4,,7 |
| 83 | ret_point: |
| 84 | call restore_registers |
| 85 | call restore_processor_state |
| 86 | ret |
| 87 | |
Shaohua Li | daacf8b | 2006-06-23 02:04:50 -0700 | [diff] [blame] | 88 | .data |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 89 | ALIGN |
Shaohua Li | daacf8b | 2006-06-23 02:04:50 -0700 | [diff] [blame] | 90 | ENTRY(saved_magic) .long 0 |
| 91 | ENTRY(saved_eip) .long 0 |
| 92 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 93 | # saved registers |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 94 | saved_idt: .long 0,0 |
| 95 | saved_ldt: .long 0 |
| 96 | saved_tss: .long 0 |
| 97 | |