1 /* 2 * linux/arch/arm/mach-mmp/include/mach/regs-apbc.h 3 * 4 * Application Peripheral Bus Clock Unit 5 * 6 * This program is free software; you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License version 2 as 8 * published by the Free Software Foundation. 9 */ 10 11 #ifndef __ASM_MACH_REGS_APBC_H 12 #define __ASM_MACH_REGS_APBC_H 13 14 #include <mach/addr-map.h> 15 16 #define APBC_VIRT_BASE (APB_VIRT_BASE + 0x015000) 17 #define APBC_REG(x) (APBC_VIRT_BASE + (x)) 18 19 /* 20 * APB clock register offsets for PXA168 21 */ 22 #define APBC_PXA168_UART1 APBC_REG(0x000) 23 #define APBC_PXA168_UART2 APBC_REG(0x004) 24 #define APBC_PXA168_GPIO APBC_REG(0x008) 25 #define APBC_PXA168_PWM1 APBC_REG(0x00c) 26 #define APBC_PXA168_PWM2 APBC_REG(0x010) 27 #define APBC_PXA168_PWM3 APBC_REG(0x014) 28 #define APBC_PXA168_PWM4 APBC_REG(0x018) 29 #define APBC_PXA168_RTC APBC_REG(0x028) 30 #define APBC_PXA168_TWSI0 APBC_REG(0x02c) 31 #define APBC_PXA168_KPC APBC_REG(0x030) 32 #define APBC_PXA168_TIMERS APBC_REG(0x034) 33 #define APBC_PXA168_AIB APBC_REG(0x03c) 34 #define APBC_PXA168_SW_JTAG APBC_REG(0x040) 35 #define APBC_PXA168_ONEWIRE APBC_REG(0x048) 36 #define APBC_PXA168_ASFAR APBC_REG(0x050) 37 #define APBC_PXA168_ASSAR APBC_REG(0x054) 38 #define APBC_PXA168_TWSI1 APBC_REG(0x06c) 39 #define APBC_PXA168_UART3 APBC_REG(0x070) 40 #define APBC_PXA168_AC97 APBC_REG(0x084) 41 #define APBC_PXA168_SSP1 APBC_REG(0x81c) 42 #define APBC_PXA168_SSP2 APBC_REG(0x820) 43 #define APBC_PXA168_SSP3 APBC_REG(0x84c) 44 #define APBC_PXA168_SSP4 APBC_REG(0x858) 45 #define APBC_PXA168_SSP5 APBC_REG(0x85c) 46 47 /* 48 * APB Clock register offsets for PXA910 49 */ 50 #define APBC_PXA910_UART0 APBC_REG(0x000) 51 #define APBC_PXA910_UART1 APBC_REG(0x004) 52 #define APBC_PXA910_GPIO APBC_REG(0x008) 53 #define APBC_PXA910_PWM1 APBC_REG(0x00c) 54 #define APBC_PXA910_PWM2 APBC_REG(0x010) 55 #define APBC_PXA910_PWM3 APBC_REG(0x014) 56 #define APBC_PXA910_PWM4 APBC_REG(0x018) 57 #define APBC_PXA910_SSP1 APBC_REG(0x01c) 58 #define APBC_PXA910_SSP2 APBC_REG(0x020) 59 #define APBC_PXA910_IPC APBC_REG(0x024) 60 #define APBC_PXA910_RTC APBC_REG(0x028) 61 #define APBC_PXA910_TWSI0 APBC_REG(0x02c) 62 #define APBC_PXA910_KPC APBC_REG(0x030) 63 #define APBC_PXA910_TIMERS APBC_REG(0x034) 64 #define APBC_PXA910_TBROT APBC_REG(0x038) 65 #define APBC_PXA910_AIB APBC_REG(0x03c) 66 #define APBC_PXA910_SW_JTAG APBC_REG(0x040) 67 #define APBC_PXA910_TIMERS1 APBC_REG(0x044) 68 #define APBC_PXA910_ONEWIRE APBC_REG(0x048) 69 #define APBC_PXA910_SSP3 APBC_REG(0x04c) 70 #define APBC_PXA910_ASFAR APBC_REG(0x050) 71 #define APBC_PXA910_ASSAR APBC_REG(0x054) 72 73 /* 74 * APB Clock register offsets for MMP2 75 */ 76 #define APBC_MMP2_RTC APBC_REG(0x000) 77 #define APBC_MMP2_TWSI1 APBC_REG(0x004) 78 #define APBC_MMP2_TWSI2 APBC_REG(0x008) 79 #define APBC_MMP2_TWSI3 APBC_REG(0x00c) 80 #define APBC_MMP2_TWSI4 APBC_REG(0x010) 81 #define APBC_MMP2_ONEWIRE APBC_REG(0x014) 82 #define APBC_MMP2_KPC APBC_REG(0x018) 83 #define APBC_MMP2_TB_ROTARY APBC_REG(0x01c) 84 #define APBC_MMP2_SW_JTAG APBC_REG(0x020) 85 #define APBC_MMP2_TIMERS APBC_REG(0x024) 86 #define APBC_MMP2_UART1 APBC_REG(0x02c) 87 #define APBC_MMP2_UART2 APBC_REG(0x030) 88 #define APBC_MMP2_UART3 APBC_REG(0x034) 89 #define APBC_MMP2_GPIO APBC_REG(0x038) 90 #define APBC_MMP2_PWM0 APBC_REG(0x03c) 91 #define APBC_MMP2_PWM1 APBC_REG(0x040) 92 #define APBC_MMP2_PWM2 APBC_REG(0x044) 93 #define APBC_MMP2_PWM3 APBC_REG(0x048) 94 #define APBC_MMP2_SSP0 APBC_REG(0x04c) 95 #define APBC_MMP2_SSP1 APBC_REG(0x050) 96 #define APBC_MMP2_SSP2 APBC_REG(0x054) 97 #define APBC_MMP2_SSP3 APBC_REG(0x058) 98 #define APBC_MMP2_SSP4 APBC_REG(0x05c) 99 #define APBC_MMP2_SSP5 APBC_REG(0x060) 100 #define APBC_MMP2_AIB APBC_REG(0x064) 101 #define APBC_MMP2_ASFAR APBC_REG(0x068) 102 #define APBC_MMP2_ASSAR APBC_REG(0x06c) 103 #define APBC_MMP2_USIM APBC_REG(0x070) 104 #define APBC_MMP2_MPMU APBC_REG(0x074) 105 #define APBC_MMP2_IPC APBC_REG(0x078) 106 #define APBC_MMP2_TWSI5 APBC_REG(0x07c) 107 #define APBC_MMP2_TWSI6 APBC_REG(0x080) 108 #define APBC_MMP2_TWSI_INTSTS APBC_REG(0x084) 109 #define APBC_MMP2_UART4 APBC_REG(0x088) 110 #define APBC_MMP2_RIPC APBC_REG(0x08c) 111 #define APBC_MMP2_THSENS1 APBC_REG(0x090) /* Thermal Sensor */ 112 #define APBC_MMP2_THSENS_INTSTS APBC_REG(0x0a4) 113 114 /* Common APB clock register bit definitions */ 115 #define APBC_APBCLK (1 << 0) /* APB Bus Clock Enable */ 116 #define APBC_FNCLK (1 << 1) /* Functional Clock Enable */ 117 #define APBC_RST (1 << 2) /* Reset Generation */ 118 119 /* Functional Clock Selection Mask */ 120 #define APBC_FNCLKSEL(x) (((x) & 0xf) << 4) 121 122 #endif /* __ASM_MACH_REGS_APBC_H */ 123