| /* |
| * Enter and leave sleep state on chips with 6xx-style HID0 |
| * power management bits, which don't leave sleep state via reset. |
| * |
| * Author: Scott Wood <scottwood@freescale.com> |
| * |
| * Copyright (c) 2006-2007 Freescale Semiconductor, Inc. |
| * |
| * 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 <asm/ppc_asm.h> |
| #include <asm/reg.h> |
| #include <asm/thread_info.h> |
| #include <asm/asm-offsets.h> |
| |
| _GLOBAL(mpc6xx_enter_standby) |
| mflr r4 |
| |
| mfspr r5, SPRN_HID0 |
| rlwinm r5, r5, 0, ~(HID0_DOZE | HID0_NAP) |
| oris r5, r5, HID0_SLEEP@h |
| mtspr SPRN_HID0, r5 |
| isync |
| |
| lis r5, ret_from_standby@h |
| ori r5, r5, ret_from_standby@l |
| mtlr r5 |
| |
| rlwinm r5, r1, 0, 0, 31-THREAD_SHIFT |
| lwz r6, TI_LOCAL_FLAGS(r5) |
| ori r6, r6, _TLF_SLEEPING |
| stw r6, TI_LOCAL_FLAGS(r5) |
| |
| mfmsr r5 |
| ori r5, r5, MSR_EE |
| oris r5, r5, MSR_POW@h |
| sync |
| mtmsr r5 |
| isync |
| |
| 1: b 1b |
| |
| ret_from_standby: |
| mfspr r5, SPRN_HID0 |
| rlwinm r5, r5, 0, ~HID0_SLEEP |
| mtspr SPRN_HID0, r5 |
| |
| mtlr r4 |
| blr |