Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 1 | /* |
Robin Getz | 96f1050 | 2009-09-24 14:11:24 +0000 | [diff] [blame] | 2 | * Miscellaneous IOCTL commands for Dynamic Power Management Controller Driver |
| 3 | * |
Michael Hennerich | 14b0320 | 2008-05-07 11:41:26 +0800 | [diff] [blame] | 4 | * Copyright (C) 2004-2008 Analog Device Inc. |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 5 | * |
Robin Getz | 96f1050 | 2009-09-24 14:11:24 +0000 | [diff] [blame] | 6 | * Licensed under the GPL-2 |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 7 | */ |
Robin Getz | 96f1050 | 2009-09-24 14:11:24 +0000 | [diff] [blame] | 8 | |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 9 | #ifndef _BLACKFIN_DPMC_H_ |
| 10 | #define _BLACKFIN_DPMC_H_ |
| 11 | |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 12 | #ifdef __KERNEL__ |
Michael Hennerich | 1efc80b | 2008-07-19 16:57:32 +0800 | [diff] [blame] | 13 | #ifndef __ASSEMBLY__ |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 14 | |
Michael Hennerich | cfefe3c | 2008-02-09 04:12:37 +0800 | [diff] [blame] | 15 | void sleep_mode(u32 sic_iwr0, u32 sic_iwr1, u32 sic_iwr2); |
Michael Hennerich | cfefe3c | 2008-02-09 04:12:37 +0800 | [diff] [blame] | 16 | void hibernate_mode(u32 sic_iwr0, u32 sic_iwr1, u32 sic_iwr2); |
| 17 | void sleep_deeper(u32 sic_iwr0, u32 sic_iwr1, u32 sic_iwr2); |
Michael Hennerich | 1efc80b | 2008-07-19 16:57:32 +0800 | [diff] [blame] | 18 | void do_hibernate(int wakeup); |
| 19 | void set_dram_srfs(void); |
| 20 | void unset_dram_srfs(void); |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 21 | |
Michael Hennerich | 1efc80b | 2008-07-19 16:57:32 +0800 | [diff] [blame] | 22 | #define VRPAIR(vlev, freq) (((vlev) << 16) | ((freq) >> 16)) |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 23 | |
Michael Hennerich | 14b0320 | 2008-05-07 11:41:26 +0800 | [diff] [blame] | 24 | struct bfin_dpmc_platform_data { |
| 25 | const unsigned int *tuple_tab; |
| 26 | unsigned short tabsize; |
| 27 | unsigned short vr_settling_time; /* in us */ |
| 28 | }; |
| 29 | |
Michael Hennerich | 1efc80b | 2008-07-19 16:57:32 +0800 | [diff] [blame] | 30 | #else |
Michael Hennerich | 14b0320 | 2008-05-07 11:41:26 +0800 | [diff] [blame] | 31 | |
Michael Hennerich | 1efc80b | 2008-07-19 16:57:32 +0800 | [diff] [blame] | 32 | #define PM_PUSH(x) \ |
| 33 | R0 = [P0 + (x - SRAM_BASE_ADDRESS)];\ |
| 34 | [--SP] = R0;\ |
| 35 | |
| 36 | #define PM_POP(x) \ |
| 37 | R0 = [SP++];\ |
| 38 | [P0 + (x - SRAM_BASE_ADDRESS)] = R0;\ |
| 39 | |
| 40 | #define PM_SYS_PUSH(x) \ |
| 41 | R0 = [P0 + (x - PLL_CTL)];\ |
| 42 | [--SP] = R0;\ |
| 43 | |
| 44 | #define PM_SYS_POP(x) \ |
| 45 | R0 = [SP++];\ |
| 46 | [P0 + (x - PLL_CTL)] = R0;\ |
| 47 | |
| 48 | #define PM_SYS_PUSH16(x) \ |
| 49 | R0 = w[P0 + (x - PLL_CTL)];\ |
| 50 | [--SP] = R0;\ |
| 51 | |
| 52 | #define PM_SYS_POP16(x) \ |
| 53 | R0 = [SP++];\ |
| 54 | w[P0 + (x - PLL_CTL)] = R0;\ |
| 55 | |
| 56 | #endif |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 57 | #endif /* __KERNEL__ */ |
| 58 | |
| 59 | #endif /*_BLACKFIN_DPMC_H_*/ |