Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Chip specific defines for DA8XX/OMAP L1XX SoC |
| 3 | * |
| 4 | * Author: Mark A. Greer <mgreer@mvista.com> |
| 5 | * |
Sergei Shtylyov | 75392dd | 2010-03-26 17:56:58 +0300 | [diff] [blame] | 6 | * 2007, 2009-2010 (c) MontaVista Software, Inc. This file is licensed under |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 7 | * the terms of the GNU General Public License version 2. This program |
| 8 | * is licensed "as is" without any warranty of any kind, whether express |
| 9 | * or implied. |
| 10 | */ |
| 11 | #ifndef __ASM_ARCH_DAVINCI_DA8XX_H |
| 12 | #define __ASM_ARCH_DAVINCI_DA8XX_H |
| 13 | |
Mark A. Greer | b9e6342 | 2009-09-15 18:14:19 -0700 | [diff] [blame] | 14 | #include <video/da8xx-fb.h> |
| 15 | |
Sergei Shtylyov | 75392dd | 2010-03-26 17:56:58 +0300 | [diff] [blame] | 16 | #include <linux/platform_device.h> |
Sriramakrishnan | 8ee2bf9 | 2009-11-19 15:58:25 +0530 | [diff] [blame] | 17 | #include <linux/davinci_emac.h> |
Michael Williamson | 54ce688 | 2011-02-24 10:18:28 +0530 | [diff] [blame] | 18 | #include <linux/spi/spi.h> |
Hebbar, Gururaja | 896f66b | 2012-08-27 18:56:41 +0530 | [diff] [blame] | 19 | #include <linux/platform_data/davinci_asp.h> |
Robin Holt | 7b6d864 | 2013-07-08 16:01:40 -0700 | [diff] [blame] | 20 | #include <linux/reboot.h> |
Manjunath Hadli | 154d54a | 2012-01-23 06:17:24 -0300 | [diff] [blame] | 21 | #include <linux/videodev2.h> |
Sergei Shtylyov | 75392dd | 2010-03-26 17:56:58 +0300 | [diff] [blame] | 22 | |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 23 | #include <mach/serial.h> |
Sekhar Nori | 044ca01 | 2009-12-17 18:29:32 +0530 | [diff] [blame] | 24 | #include <mach/pm.h> |
Matt Porter | 3ad7a42 | 2013-03-06 11:15:31 -0500 | [diff] [blame] | 25 | #include <linux/platform_data/edma.h> |
Arnd Bergmann | ec2a083 | 2012-08-24 15:11:34 +0200 | [diff] [blame] | 26 | #include <linux/platform_data/i2c-davinci.h> |
| 27 | #include <linux/platform_data/mmc-davinci.h> |
| 28 | #include <linux/platform_data/usb-davinci.h> |
| 29 | #include <linux/platform_data/spi-davinci.h> |
Matt Porter | 8e0d72d | 2012-10-08 09:53:08 -0400 | [diff] [blame] | 30 | #include <linux/platform_data/uio_pruss.h> |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 31 | |
Manjunath Hadli | 154d54a | 2012-01-23 06:17:24 -0300 | [diff] [blame] | 32 | #include <media/davinci/vpif_types.h> |
| 33 | |
Sekhar Nori | d2de058 | 2009-11-16 17:21:32 +0530 | [diff] [blame] | 34 | extern void __iomem *da8xx_syscfg0_base; |
| 35 | extern void __iomem *da8xx_syscfg1_base; |
Sekhar Nori | 6a28adef | 2009-08-31 15:47:59 +0530 | [diff] [blame] | 36 | |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 37 | /* |
Sekhar Nori | 39e1455 | 2010-12-20 21:31:33 +0530 | [diff] [blame] | 38 | * If the DA850/OMAP-L138/AM18x SoC on board is of a higher speed grade |
| 39 | * (than the regular 300Mhz variant), the board code should set this up |
| 40 | * with the supported speed before calling da850_register_cpufreq(). |
| 41 | */ |
| 42 | extern unsigned int da850_max_speed; |
| 43 | |
| 44 | /* |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 45 | * The cp_intc interrupt controller for the da8xx isn't in the same |
| 46 | * chunk of physical memory space as the other registers (like it is |
| 47 | * on the davincis) so it needs to be mapped separately. It will be |
| 48 | * mapped early on when the I/O space is mapped and we'll put it just |
| 49 | * before the I/O space in the processor's virtual memory space. |
| 50 | */ |
| 51 | #define DA8XX_CP_INTC_BASE 0xfffee000 |
| 52 | #define DA8XX_CP_INTC_SIZE SZ_8K |
| 53 | #define DA8XX_CP_INTC_VIRT (IO_VIRT - DA8XX_CP_INTC_SIZE - SZ_4K) |
| 54 | |
Sekhar Nori | d2de058 | 2009-11-16 17:21:32 +0530 | [diff] [blame] | 55 | #define DA8XX_SYSCFG0_BASE (IO_PHYS + 0x14000) |
| 56 | #define DA8XX_SYSCFG0_VIRT(x) (da8xx_syscfg0_base + (x)) |
Sekhar Nori | cd87444 | 2009-08-31 15:48:00 +0530 | [diff] [blame] | 57 | #define DA8XX_JTAG_ID_REG 0x18 |
Robert Tivy | 5c71d61 | 2013-03-28 18:41:46 -0700 | [diff] [blame] | 58 | #define DA8XX_HOST1CFG_REG 0x44 |
| 59 | #define DA8XX_CHIPSIG_REG 0x174 |
Sekhar Nori | 683b1e1 | 2009-09-22 21:14:01 +0530 | [diff] [blame] | 60 | #define DA8XX_CFGCHIP0_REG 0x17c |
Philip Avinash | bb170e6 | 2013-03-25 13:19:48 +0530 | [diff] [blame] | 61 | #define DA8XX_CFGCHIP1_REG 0x180 |
Sergei Shtylyov | 371b53e0 | 2009-09-25 22:24:57 +0400 | [diff] [blame] | 62 | #define DA8XX_CFGCHIP2_REG 0x184 |
Sekhar Nori | 5d36a33 | 2009-08-31 15:48:05 +0530 | [diff] [blame] | 63 | #define DA8XX_CFGCHIP3_REG 0x188 |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 64 | |
Sekhar Nori | d2de058 | 2009-11-16 17:21:32 +0530 | [diff] [blame] | 65 | #define DA8XX_SYSCFG1_BASE (IO_PHYS + 0x22C000) |
| 66 | #define DA8XX_SYSCFG1_VIRT(x) (da8xx_syscfg1_base + (x)) |
Sekhar Nori | 044ca01 | 2009-12-17 18:29:32 +0530 | [diff] [blame] | 67 | #define DA8XX_DEEPSLEEP_REG 0x8 |
Sekhar Nori | cbb2c96 | 2011-07-06 06:01:23 +0000 | [diff] [blame] | 68 | #define DA8XX_PWRDN_REG 0x18 |
Sekhar Nori | d2de058 | 2009-11-16 17:21:32 +0530 | [diff] [blame] | 69 | |
Rajashekhara, Sudhakar | bea238f | 2009-07-10 02:08:31 -0400 | [diff] [blame] | 70 | #define DA8XX_PSC0_BASE 0x01c10000 |
| 71 | #define DA8XX_PLL0_BASE 0x01c11000 |
Rajashekhara, Sudhakar | bea238f | 2009-07-10 02:08:31 -0400 | [diff] [blame] | 72 | #define DA8XX_TIMER64P0_BASE 0x01c20000 |
| 73 | #define DA8XX_TIMER64P1_BASE 0x01c21000 |
Manjunath Hadli | 154d54a | 2012-01-23 06:17:24 -0300 | [diff] [blame] | 74 | #define DA8XX_VPIF_BASE 0x01e17000 |
Rajashekhara, Sudhakar | bea238f | 2009-07-10 02:08:31 -0400 | [diff] [blame] | 75 | #define DA8XX_GPIO_BASE 0x01e26000 |
| 76 | #define DA8XX_PSC1_BASE 0x01e27000 |
Sudhakar Rajashekhara | 7c5ec60 | 2009-08-13 17:36:25 -0400 | [diff] [blame] | 77 | #define DA8XX_AEMIF_CS2_BASE 0x60000000 |
Sudhakar Rajashekhara | 38beb92 | 2009-08-13 16:21:11 -0400 | [diff] [blame] | 78 | #define DA8XX_AEMIF_CS3_BASE 0x62000000 |
| 79 | #define DA8XX_AEMIF_CTL_BASE 0x68000000 |
Subhasish Ghosh | c94472d | 2012-10-05 13:04:42 -0400 | [diff] [blame] | 80 | #define DA8XX_SHARED_RAM_BASE 0x80000000 |
Sekhar Nori | 60cd02e | 2009-11-16 17:21:39 +0530 | [diff] [blame] | 81 | #define DA8XX_ARM_RAM_BASE 0xffff0000 |
Rajashekhara, Sudhakar | bea238f | 2009-07-10 02:08:31 -0400 | [diff] [blame] | 82 | |
Lad, Prabhakar | b464e3c | 2013-04-01 17:03:36 +0530 | [diff] [blame] | 83 | void da830_init(void); |
| 84 | void da850_init(void); |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 85 | |
Rajashekhara, Sudhakar | a941c50 | 2010-06-29 11:35:14 +0530 | [diff] [blame] | 86 | int da830_register_edma(struct edma_rsv_info *rsv); |
| 87 | int da850_register_edma(struct edma_rsv_info *rsv[2]); |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 88 | int da8xx_register_i2c(int instance, struct davinci_i2c_platform_data *pdata); |
Vivien Didelot | 0273612 | 2012-09-10 20:29:13 -0400 | [diff] [blame] | 89 | int da8xx_register_spi_bus(int instance, unsigned num_chipselect); |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 90 | int da8xx_register_watchdog(void); |
Sergei Shtylyov | b0ea26e | 2009-10-30 23:49:44 +0400 | [diff] [blame] | 91 | int da8xx_register_usb20(unsigned mA, unsigned potpgt); |
Sergei Shtylyov | e5d3d25 | 2009-09-25 23:14:02 +0400 | [diff] [blame] | 92 | int da8xx_register_usb11(struct da8xx_ohci_root_hub *pdata); |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 93 | int da8xx_register_emac(void); |
Matt Porter | 8e0d72d | 2012-10-08 09:53:08 -0400 | [diff] [blame] | 94 | int da8xx_register_uio_pruss(void); |
Mark A. Greer | b9e6342 | 2009-09-15 18:14:19 -0700 | [diff] [blame] | 95 | int da8xx_register_lcdc(struct da8xx_lcdc_platform_data *pdata); |
Sudhakar Rajashekhara | 700691f | 2009-08-13 15:16:23 -0400 | [diff] [blame] | 96 | int da8xx_register_mmcsd0(struct davinci_mmc_config *config); |
Juha Kuikka | b8241ae | 2010-08-26 12:40:47 -0700 | [diff] [blame] | 97 | int da850_register_mmcsd1(struct davinci_mmc_config *config); |
Lad, Prabhakar | b464e3c | 2013-04-01 17:03:36 +0530 | [diff] [blame] | 98 | void da8xx_register_mcasp(int id, struct snd_platform_data *pdata); |
Mark A. Greer | c51df70 | 2009-09-15 18:15:54 -0700 | [diff] [blame] | 99 | int da8xx_register_rtc(void); |
KV Sujith | f606d38 | 2013-08-18 10:48:59 +0530 | [diff] [blame] | 100 | int da8xx_register_gpio(void *pdata); |
Sekhar Nori | b987c4b | 2010-07-20 16:46:51 +0530 | [diff] [blame] | 101 | int da850_register_cpufreq(char *async_clk); |
Sekhar Nori | 1960e69 | 2009-10-22 15:12:14 +0530 | [diff] [blame] | 102 | int da8xx_register_cpuidle(void); |
Lad, Prabhakar | b464e3c | 2013-04-01 17:03:36 +0530 | [diff] [blame] | 103 | void __iomem *da8xx_get_mem_ctlr(void); |
Sekhar Nori | 044ca01 | 2009-12-17 18:29:32 +0530 | [diff] [blame] | 104 | int da850_register_pm(struct platform_device *pdev); |
Lad, Prabhakar | b464e3c | 2013-04-01 17:03:36 +0530 | [diff] [blame] | 105 | int da850_register_sata(unsigned long refclkpn); |
| 106 | int da850_register_vpif(void); |
| 107 | int da850_register_vpif_display |
Manjunath Hadli | 154d54a | 2012-01-23 06:17:24 -0300 | [diff] [blame] | 108 | (struct vpif_display_config *display_config); |
Lad, Prabhakar | b464e3c | 2013-04-01 17:03:36 +0530 | [diff] [blame] | 109 | int da850_register_vpif_capture |
Manjunath Hadli | 154d54a | 2012-01-23 06:17:24 -0300 | [diff] [blame] | 110 | (struct vpif_capture_config *capture_config); |
Robin Holt | 7b6d864 | 2013-07-08 16:01:40 -0700 | [diff] [blame] | 111 | void da8xx_restart(enum reboot_mode mode, const char *cmd); |
Robert Tivy | 5c71d61 | 2013-03-28 18:41:46 -0700 | [diff] [blame] | 112 | void da8xx_rproc_reserve_cma(void); |
| 113 | int da8xx_register_rproc(void); |
KV Sujith | f606d38 | 2013-08-18 10:48:59 +0530 | [diff] [blame] | 114 | int da850_register_gpio(void); |
| 115 | int da830_register_gpio(void); |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 116 | |
Manjunathappa, Prakash | 19955c3 | 2013-06-19 14:45:38 +0530 | [diff] [blame] | 117 | extern struct platform_device da8xx_serial_device[]; |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 118 | extern struct emac_platform_data da8xx_emac_pdata; |
Mark A. Greer | b9e6342 | 2009-09-15 18:14:19 -0700 | [diff] [blame] | 119 | extern struct da8xx_lcdc_platform_data sharp_lcd035q3dg01_pdata; |
| 120 | extern struct da8xx_lcdc_platform_data sharp_lk043t1dg01_pdata; |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 121 | |
Cyril Chemparathy | c78a5bc | 2010-05-01 18:38:28 -0400 | [diff] [blame] | 122 | |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 123 | extern const short da830_emif25_pins[]; |
| 124 | extern const short da830_spi0_pins[]; |
| 125 | extern const short da830_spi1_pins[]; |
| 126 | extern const short da830_mmc_sd_pins[]; |
| 127 | extern const short da830_uart0_pins[]; |
| 128 | extern const short da830_uart1_pins[]; |
| 129 | extern const short da830_uart2_pins[]; |
| 130 | extern const short da830_usb20_pins[]; |
| 131 | extern const short da830_usb11_pins[]; |
| 132 | extern const short da830_uhpi_pins[]; |
| 133 | extern const short da830_cpgmac_pins[]; |
| 134 | extern const short da830_emif3c_pins[]; |
| 135 | extern const short da830_mcasp0_pins[]; |
| 136 | extern const short da830_mcasp1_pins[]; |
| 137 | extern const short da830_mcasp2_pins[]; |
| 138 | extern const short da830_i2c0_pins[]; |
| 139 | extern const short da830_i2c1_pins[]; |
| 140 | extern const short da830_lcdcntl_pins[]; |
| 141 | extern const short da830_pwm_pins[]; |
| 142 | extern const short da830_ecap0_pins[]; |
| 143 | extern const short da830_ecap1_pins[]; |
| 144 | extern const short da830_ecap2_pins[]; |
| 145 | extern const short da830_eqep0_pins[]; |
| 146 | extern const short da830_eqep1_pins[]; |
Manjunath Hadli | 154d54a | 2012-01-23 06:17:24 -0300 | [diff] [blame] | 147 | extern const short da850_vpif_capture_pins[]; |
| 148 | extern const short da850_vpif_display_pins[]; |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 149 | |
Sudhakar Rajashekhara | e1a8d7e | 2009-07-16 06:41:54 -0400 | [diff] [blame] | 150 | extern const short da850_i2c0_pins[]; |
| 151 | extern const short da850_i2c1_pins[]; |
Sudhakar Rajashekhara | 5cbdf27 | 2009-08-13 14:33:14 -0400 | [diff] [blame] | 152 | extern const short da850_lcdcntl_pins[]; |
Sudhakar Rajashekhara | e1a8d7e | 2009-07-16 06:41:54 -0400 | [diff] [blame] | 153 | |
Mark A. Greer | 55c79a4 | 2009-06-03 18:36:54 -0700 | [diff] [blame] | 154 | #endif /* __ASM_ARCH_DAVINCI_DA8XX_H */ |