blob: 7b41a5e9bc3197bc0a1150050e65584f67cdd2d1 [file] [log] [blame]
Mark A. Greer55c79a42009-06-03 18:36:54 -07001/*
2 * Chip specific defines for DA8XX/OMAP L1XX SoC
3 *
4 * Author: Mark A. Greer <mgreer@mvista.com>
5 *
Sergei Shtylyov75392dd2010-03-26 17:56:58 +03006 * 2007, 2009-2010 (c) MontaVista Software, Inc. This file is licensed under
Mark A. Greer55c79a42009-06-03 18:36:54 -07007 * 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. Greerb9e63422009-09-15 18:14:19 -070014#include <video/da8xx-fb.h>
15
Sergei Shtylyov75392dd2010-03-26 17:56:58 +030016#include <linux/platform_device.h>
Sriramakrishnan8ee2bf92009-11-19 15:58:25 +053017#include <linux/davinci_emac.h>
Michael Williamson54ce6882011-02-24 10:18:28 +053018#include <linux/spi/spi.h>
Hebbar, Gururaja896f66b2012-08-27 18:56:41 +053019#include <linux/platform_data/davinci_asp.h>
Robin Holt7b6d8642013-07-08 16:01:40 -070020#include <linux/reboot.h>
Manjunath Hadli154d54a2012-01-23 06:17:24 -030021#include <linux/videodev2.h>
Sergei Shtylyov75392dd2010-03-26 17:56:58 +030022
Mark A. Greer55c79a42009-06-03 18:36:54 -070023#include <mach/serial.h>
Sekhar Nori044ca012009-12-17 18:29:32 +053024#include <mach/pm.h>
Matt Porter3ad7a422013-03-06 11:15:31 -050025#include <linux/platform_data/edma.h>
Arnd Bergmannec2a0832012-08-24 15:11:34 +020026#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 Porter8e0d72d2012-10-08 09:53:08 -040030#include <linux/platform_data/uio_pruss.h>
Mark A. Greer55c79a42009-06-03 18:36:54 -070031
Manjunath Hadli154d54a2012-01-23 06:17:24 -030032#include <media/davinci/vpif_types.h>
33
Sekhar Norid2de0582009-11-16 17:21:32 +053034extern void __iomem *da8xx_syscfg0_base;
35extern void __iomem *da8xx_syscfg1_base;
Sekhar Nori6a28adef2009-08-31 15:47:59 +053036
Mark A. Greer55c79a42009-06-03 18:36:54 -070037/*
Sekhar Nori39e14552010-12-20 21:31:33 +053038 * 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 */
42extern unsigned int da850_max_speed;
43
44/*
Mark A. Greer55c79a42009-06-03 18:36:54 -070045 * 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 Norid2de0582009-11-16 17:21:32 +053055#define DA8XX_SYSCFG0_BASE (IO_PHYS + 0x14000)
56#define DA8XX_SYSCFG0_VIRT(x) (da8xx_syscfg0_base + (x))
Sekhar Noricd874442009-08-31 15:48:00 +053057#define DA8XX_JTAG_ID_REG 0x18
Robert Tivy5c71d612013-03-28 18:41:46 -070058#define DA8XX_HOST1CFG_REG 0x44
59#define DA8XX_CHIPSIG_REG 0x174
Sekhar Nori683b1e12009-09-22 21:14:01 +053060#define DA8XX_CFGCHIP0_REG 0x17c
Philip Avinashbb170e62013-03-25 13:19:48 +053061#define DA8XX_CFGCHIP1_REG 0x180
Sergei Shtylyov371b53e02009-09-25 22:24:57 +040062#define DA8XX_CFGCHIP2_REG 0x184
Sekhar Nori5d36a332009-08-31 15:48:05 +053063#define DA8XX_CFGCHIP3_REG 0x188
Mark A. Greer55c79a42009-06-03 18:36:54 -070064
Sekhar Norid2de0582009-11-16 17:21:32 +053065#define DA8XX_SYSCFG1_BASE (IO_PHYS + 0x22C000)
66#define DA8XX_SYSCFG1_VIRT(x) (da8xx_syscfg1_base + (x))
Sekhar Nori044ca012009-12-17 18:29:32 +053067#define DA8XX_DEEPSLEEP_REG 0x8
Sekhar Noricbb2c962011-07-06 06:01:23 +000068#define DA8XX_PWRDN_REG 0x18
Sekhar Norid2de0582009-11-16 17:21:32 +053069
Rajashekhara, Sudhakarbea238f2009-07-10 02:08:31 -040070#define DA8XX_PSC0_BASE 0x01c10000
71#define DA8XX_PLL0_BASE 0x01c11000
Rajashekhara, Sudhakarbea238f2009-07-10 02:08:31 -040072#define DA8XX_TIMER64P0_BASE 0x01c20000
73#define DA8XX_TIMER64P1_BASE 0x01c21000
Manjunath Hadli154d54a2012-01-23 06:17:24 -030074#define DA8XX_VPIF_BASE 0x01e17000
Rajashekhara, Sudhakarbea238f2009-07-10 02:08:31 -040075#define DA8XX_GPIO_BASE 0x01e26000
76#define DA8XX_PSC1_BASE 0x01e27000
Sudhakar Rajashekhara7c5ec602009-08-13 17:36:25 -040077#define DA8XX_AEMIF_CS2_BASE 0x60000000
Sudhakar Rajashekhara38beb922009-08-13 16:21:11 -040078#define DA8XX_AEMIF_CS3_BASE 0x62000000
79#define DA8XX_AEMIF_CTL_BASE 0x68000000
Subhasish Ghoshc94472d2012-10-05 13:04:42 -040080#define DA8XX_SHARED_RAM_BASE 0x80000000
Sekhar Nori60cd02e2009-11-16 17:21:39 +053081#define DA8XX_ARM_RAM_BASE 0xffff0000
Rajashekhara, Sudhakarbea238f2009-07-10 02:08:31 -040082
Lad, Prabhakarb464e3c2013-04-01 17:03:36 +053083void da830_init(void);
84void da850_init(void);
Mark A. Greer55c79a42009-06-03 18:36:54 -070085
Rajashekhara, Sudhakara941c502010-06-29 11:35:14 +053086int da830_register_edma(struct edma_rsv_info *rsv);
87int da850_register_edma(struct edma_rsv_info *rsv[2]);
Mark A. Greer55c79a42009-06-03 18:36:54 -070088int da8xx_register_i2c(int instance, struct davinci_i2c_platform_data *pdata);
Vivien Didelot02736122012-09-10 20:29:13 -040089int da8xx_register_spi_bus(int instance, unsigned num_chipselect);
Mark A. Greer55c79a42009-06-03 18:36:54 -070090int da8xx_register_watchdog(void);
Sergei Shtylyovb0ea26e2009-10-30 23:49:44 +040091int da8xx_register_usb20(unsigned mA, unsigned potpgt);
Sergei Shtylyove5d3d252009-09-25 23:14:02 +040092int da8xx_register_usb11(struct da8xx_ohci_root_hub *pdata);
Mark A. Greer55c79a42009-06-03 18:36:54 -070093int da8xx_register_emac(void);
Matt Porter8e0d72d2012-10-08 09:53:08 -040094int da8xx_register_uio_pruss(void);
Mark A. Greerb9e63422009-09-15 18:14:19 -070095int da8xx_register_lcdc(struct da8xx_lcdc_platform_data *pdata);
Sudhakar Rajashekhara700691f2009-08-13 15:16:23 -040096int da8xx_register_mmcsd0(struct davinci_mmc_config *config);
Juha Kuikkab8241ae2010-08-26 12:40:47 -070097int da850_register_mmcsd1(struct davinci_mmc_config *config);
Lad, Prabhakarb464e3c2013-04-01 17:03:36 +053098void da8xx_register_mcasp(int id, struct snd_platform_data *pdata);
Mark A. Greerc51df702009-09-15 18:15:54 -070099int da8xx_register_rtc(void);
Sekhar Norib987c4b2010-07-20 16:46:51 +0530100int da850_register_cpufreq(char *async_clk);
Sekhar Nori1960e692009-10-22 15:12:14 +0530101int da8xx_register_cpuidle(void);
Lad, Prabhakarb464e3c2013-04-01 17:03:36 +0530102void __iomem *da8xx_get_mem_ctlr(void);
Sekhar Nori044ca012009-12-17 18:29:32 +0530103int da850_register_pm(struct platform_device *pdev);
Lad, Prabhakarb464e3c2013-04-01 17:03:36 +0530104int da850_register_sata(unsigned long refclkpn);
105int da850_register_vpif(void);
106int da850_register_vpif_display
Manjunath Hadli154d54a2012-01-23 06:17:24 -0300107 (struct vpif_display_config *display_config);
Lad, Prabhakarb464e3c2013-04-01 17:03:36 +0530108int da850_register_vpif_capture
Manjunath Hadli154d54a2012-01-23 06:17:24 -0300109 (struct vpif_capture_config *capture_config);
Robin Holt7b6d8642013-07-08 16:01:40 -0700110void da8xx_restart(enum reboot_mode mode, const char *cmd);
Robert Tivy5c71d612013-03-28 18:41:46 -0700111void da8xx_rproc_reserve_cma(void);
112int da8xx_register_rproc(void);
Mark A. Greer55c79a42009-06-03 18:36:54 -0700113
114extern struct platform_device da8xx_serial_device;
115extern struct emac_platform_data da8xx_emac_pdata;
Mark A. Greerb9e63422009-09-15 18:14:19 -0700116extern struct da8xx_lcdc_platform_data sharp_lcd035q3dg01_pdata;
117extern struct da8xx_lcdc_platform_data sharp_lk043t1dg01_pdata;
Mark A. Greer55c79a42009-06-03 18:36:54 -0700118
Cyril Chemparathyc78a5bc2010-05-01 18:38:28 -0400119
Mark A. Greer55c79a42009-06-03 18:36:54 -0700120extern const short da830_emif25_pins[];
121extern const short da830_spi0_pins[];
122extern const short da830_spi1_pins[];
123extern const short da830_mmc_sd_pins[];
124extern const short da830_uart0_pins[];
125extern const short da830_uart1_pins[];
126extern const short da830_uart2_pins[];
127extern const short da830_usb20_pins[];
128extern const short da830_usb11_pins[];
129extern const short da830_uhpi_pins[];
130extern const short da830_cpgmac_pins[];
131extern const short da830_emif3c_pins[];
132extern const short da830_mcasp0_pins[];
133extern const short da830_mcasp1_pins[];
134extern const short da830_mcasp2_pins[];
135extern const short da830_i2c0_pins[];
136extern const short da830_i2c1_pins[];
137extern const short da830_lcdcntl_pins[];
138extern const short da830_pwm_pins[];
139extern const short da830_ecap0_pins[];
140extern const short da830_ecap1_pins[];
141extern const short da830_ecap2_pins[];
142extern const short da830_eqep0_pins[];
143extern const short da830_eqep1_pins[];
Manjunath Hadli154d54a2012-01-23 06:17:24 -0300144extern const short da850_vpif_capture_pins[];
145extern const short da850_vpif_display_pins[];
Mark A. Greer55c79a42009-06-03 18:36:54 -0700146
Sudhakar Rajashekharae1a8d7e2009-07-16 06:41:54 -0400147extern const short da850_i2c0_pins[];
148extern const short da850_i2c1_pins[];
Sudhakar Rajashekhara5cbdf272009-08-13 14:33:14 -0400149extern const short da850_lcdcntl_pins[];
Sudhakar Rajashekharae1a8d7e2009-07-16 06:41:54 -0400150
Mark A. Greer55c79a42009-06-03 18:36:54 -0700151#endif /* __ASM_ARCH_DAVINCI_DA8XX_H */