2009-04-30 04:44:58 +04:00
/*
* TI DaVinci DM644x chip specific setup
*
* Author : Kevin Hilman , Deep Root Systems , LLC
*
* 2007 ( c ) Deep Root Systems , LLC . This file is licensed under
* the terms of the GNU General Public License version 2. This program
* is licensed " as is " without any warranty of any kind , whether express
* or implied .
*/
2011-06-16 15:01:34 +04:00
# include <linux/dma-mapping.h>
2016-02-02 15:43:17 +03:00
# include <linux/dmaengine.h>
2009-04-30 04:44:58 +04:00
# include <linux/init.h>
# include <linux/clk.h>
2009-03-18 20:36:08 +03:00
# include <linux/serial_8250.h>
2009-04-30 04:44:58 +04:00
# include <linux/platform_device.h>
2013-03-06 20:15:31 +04:00
# include <linux/platform_data/edma.h>
2013-08-18 09:19:00 +04:00
# include <linux/platform_data/gpio-davinci.h>
2009-04-30 04:44:58 +04:00
2009-04-15 23:38:58 +04:00
# include <asm/mach/map.h>
2009-04-30 04:44:58 +04:00
# include <mach/cputype.h>
# include <mach/irqs.h>
2015-01-30 12:45:33 +03:00
# include "psc.h"
2009-04-30 04:44:58 +04:00
# include <mach/mux.h>
2009-04-15 23:40:11 +04:00
# include <mach/time.h>
2009-03-18 20:36:08 +03:00
# include <mach/serial.h>
2009-04-15 23:38:58 +04:00
# include <mach/common.h>
2009-04-30 04:44:58 +04:00
2011-12-21 17:43:35 +04:00
# include "davinci.h"
2009-04-30 04:44:58 +04:00
# include "clock.h"
# include "mux.h"
2012-08-27 17:26:41 +04:00
# include "asp.h"
2009-04-30 04:44:58 +04:00
2009-09-16 21:15:30 +04:00
# define DAVINCI_VPIF_BASE (0x01C12000)
# define VDD3P3V_VID_MASK (BIT_MASK(3) | BIT_MASK(2) | BIT_MASK(1) |\
BIT_MASK ( 0 ) )
# define VSCLKDIS_MASK (BIT_MASK(11) | BIT_MASK(10) | BIT_MASK(9) |\
BIT_MASK ( 8 ) )
2009-04-30 04:44:58 +04:00
/*
* Device specific clocks
*/
2011-06-14 19:33:20 +04:00
# define DM646X_REF_FREQ 27000000
2009-04-30 04:44:58 +04:00
# define DM646X_AUX_FREQ 24000000
2011-12-15 16:11:51 +04:00
# define DM646X_EMAC_BASE 0x01c80000
# define DM646X_EMAC_MDIO_BASE (DM646X_EMAC_BASE + 0x4000)
# define DM646X_EMAC_CNTRL_OFFSET 0x0000
# define DM646X_EMAC_CNTRL_MOD_OFFSET 0x1000
# define DM646X_EMAC_CNTRL_RAM_OFFSET 0x2000
# define DM646X_EMAC_CNTRL_RAM_SIZE 0x2000
2009-04-30 04:44:58 +04:00
static struct pll_data pll1_data = {
. num = 1 ,
. phys_base = DAVINCI_PLL1_BASE ,
} ;
static struct pll_data pll2_data = {
. num = 2 ,
. phys_base = DAVINCI_PLL2_BASE ,
} ;
static struct clk ref_clk = {
. name = " ref_clk " ,
2011-06-14 19:33:20 +04:00
. rate = DM646X_REF_FREQ ,
. set_rate = davinci_simple_set_rate ,
2009-04-30 04:44:58 +04:00
} ;
static struct clk aux_clkin = {
. name = " aux_clkin " ,
. rate = DM646X_AUX_FREQ ,
} ;
static struct clk pll1_clk = {
. name = " pll1 " ,
. parent = & ref_clk ,
. pll_data = & pll1_data ,
. flags = CLK_PLL ,
} ;
static struct clk pll1_sysclk1 = {
. name = " pll1_sysclk1 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV1 ,
} ;
static struct clk pll1_sysclk2 = {
. name = " pll1_sysclk2 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV2 ,
} ;
static struct clk pll1_sysclk3 = {
. name = " pll1_sysclk3 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV3 ,
} ;
static struct clk pll1_sysclk4 = {
. name = " pll1_sysclk4 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV4 ,
} ;
static struct clk pll1_sysclk5 = {
. name = " pll1_sysclk5 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV5 ,
} ;
static struct clk pll1_sysclk6 = {
. name = " pll1_sysclk6 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV6 ,
} ;
static struct clk pll1_sysclk8 = {
. name = " pll1_sysclk8 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV8 ,
} ;
static struct clk pll1_sysclk9 = {
. name = " pll1_sysclk9 " ,
. parent = & pll1_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV9 ,
} ;
static struct clk pll1_sysclkbp = {
. name = " pll1_sysclkbp " ,
. parent = & pll1_clk ,
. flags = CLK_PLL | PRE_PLL ,
. div_reg = BPDIV ,
} ;
static struct clk pll1_aux_clk = {
. name = " pll1_aux_clk " ,
. parent = & pll1_clk ,
. flags = CLK_PLL | PRE_PLL ,
} ;
static struct clk pll2_clk = {
. name = " pll2_clk " ,
. parent = & ref_clk ,
. pll_data = & pll2_data ,
. flags = CLK_PLL ,
} ;
static struct clk pll2_sysclk1 = {
. name = " pll2_sysclk1 " ,
. parent = & pll2_clk ,
. flags = CLK_PLL ,
. div_reg = PLLDIV1 ,
} ;
static struct clk dsp_clk = {
. name = " dsp " ,
. parent = & pll1_sysclk1 ,
. lpsc = DM646X_LPSC_C64X_CPU ,
. usecount = 1 , /* REVISIT how to disable? */
} ;
static struct clk arm_clk = {
. name = " arm " ,
. parent = & pll1_sysclk2 ,
. lpsc = DM646X_LPSC_ARM ,
. flags = ALWAYS_ENABLED ,
} ;
2009-06-02 11:38:26 +04:00
static struct clk edma_cc_clk = {
. name = " edma_cc " ,
. parent = & pll1_sysclk2 ,
. lpsc = DM646X_LPSC_TPCC ,
. flags = ALWAYS_ENABLED ,
} ;
static struct clk edma_tc0_clk = {
. name = " edma_tc0 " ,
. parent = & pll1_sysclk2 ,
. lpsc = DM646X_LPSC_TPTC0 ,
. flags = ALWAYS_ENABLED ,
} ;
static struct clk edma_tc1_clk = {
. name = " edma_tc1 " ,
. parent = & pll1_sysclk2 ,
. lpsc = DM646X_LPSC_TPTC1 ,
. flags = ALWAYS_ENABLED ,
} ;
static struct clk edma_tc2_clk = {
. name = " edma_tc2 " ,
. parent = & pll1_sysclk2 ,
. lpsc = DM646X_LPSC_TPTC2 ,
. flags = ALWAYS_ENABLED ,
} ;
static struct clk edma_tc3_clk = {
. name = " edma_tc3 " ,
. parent = & pll1_sysclk2 ,
. lpsc = DM646X_LPSC_TPTC3 ,
. flags = ALWAYS_ENABLED ,
} ;
2009-04-30 04:44:58 +04:00
static struct clk uart0_clk = {
. name = " uart0 " ,
. parent = & aux_clkin ,
. lpsc = DM646X_LPSC_UART0 ,
} ;
static struct clk uart1_clk = {
. name = " uart1 " ,
. parent = & aux_clkin ,
. lpsc = DM646X_LPSC_UART1 ,
} ;
static struct clk uart2_clk = {
. name = " uart2 " ,
. parent = & aux_clkin ,
. lpsc = DM646X_LPSC_UART2 ,
} ;
static struct clk i2c_clk = {
. name = " I2CCLK " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_I2C ,
} ;
static struct clk gpio_clk = {
. name = " gpio " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_GPIO ,
} ;
2009-05-28 13:09:21 +04:00
static struct clk mcasp0_clk = {
. name = " mcasp0 " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_McASP0 ,
} ;
static struct clk mcasp1_clk = {
. name = " mcasp1 " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_McASP1 ,
} ;
2009-04-30 04:44:58 +04:00
static struct clk aemif_clk = {
. name = " aemif " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_AEMIF ,
. flags = ALWAYS_ENABLED ,
} ;
static struct clk emac_clk = {
. name = " emac " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_EMAC ,
} ;
static struct clk pwm0_clk = {
. name = " pwm0 " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_PWM0 ,
. usecount = 1 , /* REVIST: disabling hangs system */
} ;
static struct clk pwm1_clk = {
. name = " pwm1 " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_PWM1 ,
. usecount = 1 , /* REVIST: disabling hangs system */
} ;
static struct clk timer0_clk = {
. name = " timer0 " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_TIMER0 ,
} ;
static struct clk timer1_clk = {
. name = " timer1 " ,
. parent = & pll1_sysclk3 ,
. lpsc = DM646X_LPSC_TIMER1 ,
} ;
static struct clk timer2_clk = {
. name = " timer2 " ,
. parent = & pll1_sysclk3 ,
. flags = ALWAYS_ENABLED , /* no LPSC, always enabled; c.f. spruep9a */
} ;
2009-07-07 18:19:41 +04:00
static struct clk ide_clk = {
. name = " ide " ,
. parent = & pll1_sysclk4 ,
. lpsc = DAVINCI_LPSC_ATA ,
} ;
2009-04-30 04:44:58 +04:00
static struct clk vpif0_clk = {
. name = " vpif0 " ,
. parent = & ref_clk ,
. lpsc = DM646X_LPSC_VPSSMSTR ,
. flags = ALWAYS_ENABLED ,
} ;
static struct clk vpif1_clk = {
. name = " vpif1 " ,
. parent = & ref_clk ,
. lpsc = DM646X_LPSC_VPSSSLV ,
. flags = ALWAYS_ENABLED ,
} ;
2010-02-26 02:36:38 +03:00
static struct clk_lookup dm646x_clks [ ] = {
2009-04-30 04:44:58 +04:00
CLK ( NULL , " ref " , & ref_clk ) ,
CLK ( NULL , " aux " , & aux_clkin ) ,
CLK ( NULL , " pll1 " , & pll1_clk ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk1 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk2 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk3 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk4 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk5 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk6 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk8 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclk9 ) ,
CLK ( NULL , " pll1_sysclk " , & pll1_sysclkbp ) ,
CLK ( NULL , " pll1_aux " , & pll1_aux_clk ) ,
CLK ( NULL , " pll2 " , & pll2_clk ) ,
CLK ( NULL , " pll2_sysclk1 " , & pll2_sysclk1 ) ,
CLK ( NULL , " dsp " , & dsp_clk ) ,
CLK ( NULL , " arm " , & arm_clk ) ,
2009-06-02 11:38:26 +04:00
CLK ( NULL , " edma_cc " , & edma_cc_clk ) ,
CLK ( NULL , " edma_tc0 " , & edma_tc0_clk ) ,
CLK ( NULL , " edma_tc1 " , & edma_tc1_clk ) ,
CLK ( NULL , " edma_tc2 " , & edma_tc2_clk ) ,
CLK ( NULL , " edma_tc3 " , & edma_tc3_clk ) ,
2013-06-19 13:15:38 +04:00
CLK ( " serial8250.0 " , NULL , & uart0_clk ) ,
CLK ( " serial8250.1 " , NULL , & uart1_clk ) ,
CLK ( " serial8250.2 " , NULL , & uart2_clk ) ,
2009-04-30 04:44:58 +04:00
CLK ( " i2c_davinci.1 " , NULL , & i2c_clk ) ,
CLK ( NULL , " gpio " , & gpio_clk ) ,
2009-07-15 19:47:48 +04:00
CLK ( " davinci-mcasp.0 " , NULL , & mcasp0_clk ) ,
CLK ( " davinci-mcasp.1 " , NULL , & mcasp1_clk ) ,
2009-04-30 04:44:58 +04:00
CLK ( NULL , " aemif " , & aemif_clk ) ,
CLK ( " davinci_emac.1 " , NULL , & emac_clk ) ,
2013-08-15 10:01:33 +04:00
CLK ( " davinci_mdio.0 " , " fck " , & emac_clk ) ,
2009-04-30 04:44:58 +04:00
CLK ( NULL , " pwm0 " , & pwm0_clk ) ,
CLK ( NULL , " pwm1 " , & pwm1_clk ) ,
CLK ( NULL , " timer0 " , & timer0_clk ) ,
CLK ( NULL , " timer1 " , & timer1_clk ) ,
2013-11-27 17:31:53 +04:00
CLK ( " davinci-wdt " , NULL , & timer2_clk ) ,
2009-07-07 18:19:41 +04:00
CLK ( " palm_bk3710 " , NULL , & ide_clk ) ,
2009-04-30 04:44:58 +04:00
CLK ( NULL , " vpif0 " , & vpif0_clk ) ,
CLK ( NULL , " vpif1 " , & vpif1_clk ) ,
CLK ( NULL , NULL , NULL ) ,
} ;
2009-04-15 23:40:56 +04:00
static struct emac_platform_data dm646x_emac_pdata = {
. ctrl_reg_offset = DM646X_EMAC_CNTRL_OFFSET ,
. ctrl_mod_reg_offset = DM646X_EMAC_CNTRL_MOD_OFFSET ,
. ctrl_ram_offset = DM646X_EMAC_CNTRL_RAM_OFFSET ,
. ctrl_ram_size = DM646X_EMAC_CNTRL_RAM_SIZE ,
. version = EMAC_VERSION_2 ,
} ;
2009-05-07 17:19:40 +04:00
static struct resource dm646x_emac_resources [ ] = {
{
. start = DM646X_EMAC_BASE ,
2010-09-15 18:11:22 +04:00
. end = DM646X_EMAC_BASE + SZ_16K - 1 ,
2009-05-07 17:19:40 +04:00
. flags = IORESOURCE_MEM ,
} ,
{
. start = IRQ_DM646X_EMACRXTHINT ,
. end = IRQ_DM646X_EMACRXTHINT ,
. flags = IORESOURCE_IRQ ,
} ,
{
. start = IRQ_DM646X_EMACRXINT ,
. end = IRQ_DM646X_EMACRXINT ,
. flags = IORESOURCE_IRQ ,
} ,
{
. start = IRQ_DM646X_EMACTXINT ,
. end = IRQ_DM646X_EMACTXINT ,
. flags = IORESOURCE_IRQ ,
} ,
{
. start = IRQ_DM646X_EMACMISCINT ,
. end = IRQ_DM646X_EMACMISCINT ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device dm646x_emac_device = {
. name = " davinci_emac " ,
. id = 1 ,
2009-04-15 23:40:56 +04:00
. dev = {
. platform_data = & dm646x_emac_pdata ,
} ,
2009-05-07 17:19:40 +04:00
. num_resources = ARRAY_SIZE ( dm646x_emac_resources ) ,
. resource = dm646x_emac_resources ,
} ;
2010-09-15 18:11:22 +04:00
static struct resource dm646x_mdio_resources [ ] = {
{
. start = DM646X_EMAC_MDIO_BASE ,
. end = DM646X_EMAC_MDIO_BASE + SZ_4K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
} ;
static struct platform_device dm646x_mdio_device = {
. name = " davinci_mdio " ,
. id = 0 ,
. num_resources = ARRAY_SIZE ( dm646x_mdio_resources ) ,
. resource = dm646x_mdio_resources ,
} ;
2009-04-30 04:44:58 +04:00
/*
* Device specific mux setup
*
* soc description mux mode mode mux dbg
* reg offset mask mode
*/
static const struct mux_config dm646x_pins [ ] = {
2009-04-15 23:39:48 +04:00
# ifdef CONFIG_DAVINCI_MUX
2009-07-07 18:19:41 +04:00
MUX_CFG ( DM646X , ATAEN , 0 , 0 , 5 , 1 , true )
2009-04-30 04:44:58 +04:00
MUX_CFG ( DM646X , AUDCK1 , 0 , 29 , 1 , 0 , false )
MUX_CFG ( DM646X , AUDCK0 , 0 , 28 , 1 , 0 , false )
MUX_CFG ( DM646X , CRGMUX , 0 , 24 , 7 , 5 , true )
MUX_CFG ( DM646X , STSOMUX_DISABLE , 0 , 22 , 3 , 0 , true )
MUX_CFG ( DM646X , STSIMUX_DISABLE , 0 , 20 , 3 , 0 , true )
MUX_CFG ( DM646X , PTSOMUX_DISABLE , 0 , 18 , 3 , 0 , true )
MUX_CFG ( DM646X , PTSIMUX_DISABLE , 0 , 16 , 3 , 0 , true )
MUX_CFG ( DM646X , STSOMUX , 0 , 22 , 3 , 2 , true )
MUX_CFG ( DM646X , STSIMUX , 0 , 20 , 3 , 2 , true )
MUX_CFG ( DM646X , PTSOMUX_PARALLEL , 0 , 18 , 3 , 2 , true )
MUX_CFG ( DM646X , PTSIMUX_PARALLEL , 0 , 16 , 3 , 2 , true )
MUX_CFG ( DM646X , PTSOMUX_SERIAL , 0 , 18 , 3 , 3 , true )
MUX_CFG ( DM646X , PTSIMUX_SERIAL , 0 , 16 , 3 , 3 , true )
2009-04-15 23:39:48 +04:00
# endif
2009-04-30 04:44:58 +04:00
} ;
2009-04-15 23:40:00 +04:00
static u8 dm646x_default_priorities [ DAVINCI_N_AINTC_IRQ ] = {
[ IRQ_DM646X_VP_VERTINT0 ] = 7 ,
[ IRQ_DM646X_VP_VERTINT1 ] = 7 ,
[ IRQ_DM646X_VP_VERTINT2 ] = 7 ,
[ IRQ_DM646X_VP_VERTINT3 ] = 7 ,
[ IRQ_DM646X_VP_ERRINT ] = 7 ,
[ IRQ_DM646X_RESERVED_1 ] = 7 ,
[ IRQ_DM646X_RESERVED_2 ] = 7 ,
[ IRQ_DM646X_WDINT ] = 7 ,
[ IRQ_DM646X_CRGENINT0 ] = 7 ,
[ IRQ_DM646X_CRGENINT1 ] = 7 ,
[ IRQ_DM646X_TSIFINT0 ] = 7 ,
[ IRQ_DM646X_TSIFINT1 ] = 7 ,
[ IRQ_DM646X_VDCEINT ] = 7 ,
[ IRQ_DM646X_USBINT ] = 7 ,
[ IRQ_DM646X_USBDMAINT ] = 7 ,
[ IRQ_DM646X_PCIINT ] = 7 ,
[ IRQ_CCINT0 ] = 7 , /* dma */
[ IRQ_CCERRINT ] = 7 , /* dma */
[ IRQ_TCERRINT0 ] = 7 , /* dma */
[ IRQ_TCERRINT ] = 7 , /* dma */
[ IRQ_DM646X_TCERRINT2 ] = 7 ,
[ IRQ_DM646X_TCERRINT3 ] = 7 ,
[ IRQ_DM646X_IDE ] = 7 ,
[ IRQ_DM646X_HPIINT ] = 7 ,
[ IRQ_DM646X_EMACRXTHINT ] = 7 ,
[ IRQ_DM646X_EMACRXINT ] = 7 ,
[ IRQ_DM646X_EMACTXINT ] = 7 ,
[ IRQ_DM646X_EMACMISCINT ] = 7 ,
[ IRQ_DM646X_MCASP0TXINT ] = 7 ,
[ IRQ_DM646X_MCASP0RXINT ] = 7 ,
[ IRQ_DM646X_RESERVED_3 ] = 7 ,
[ IRQ_DM646X_MCASP1TXINT ] = 7 , /* clockevent */
[ IRQ_TINT0_TINT34 ] = 7 , /* clocksource */
[ IRQ_TINT1_TINT12 ] = 7 , /* DSP timer */
[ IRQ_TINT1_TINT34 ] = 7 , /* system tick */
[ IRQ_PWMINT0 ] = 7 ,
[ IRQ_PWMINT1 ] = 7 ,
[ IRQ_DM646X_VLQINT ] = 7 ,
[ IRQ_I2C ] = 7 ,
[ IRQ_UARTINT0 ] = 7 ,
[ IRQ_UARTINT1 ] = 7 ,
[ IRQ_DM646X_UARTINT2 ] = 7 ,
[ IRQ_DM646X_SPINT0 ] = 7 ,
[ IRQ_DM646X_SPINT1 ] = 7 ,
[ IRQ_DM646X_DSP2ARMINT ] = 7 ,
[ IRQ_DM646X_RESERVED_4 ] = 7 ,
[ IRQ_DM646X_PSCINT ] = 7 ,
[ IRQ_DM646X_GPIO0 ] = 7 ,
[ IRQ_DM646X_GPIO1 ] = 7 ,
[ IRQ_DM646X_GPIO2 ] = 7 ,
[ IRQ_DM646X_GPIO3 ] = 7 ,
[ IRQ_DM646X_GPIO4 ] = 7 ,
[ IRQ_DM646X_GPIO5 ] = 7 ,
[ IRQ_DM646X_GPIO6 ] = 7 ,
[ IRQ_DM646X_GPIO7 ] = 7 ,
[ IRQ_DM646X_GPIOBNK0 ] = 7 ,
[ IRQ_DM646X_GPIOBNK1 ] = 7 ,
[ IRQ_DM646X_GPIOBNK2 ] = 7 ,
[ IRQ_DM646X_DDRINT ] = 7 ,
[ IRQ_DM646X_AEMIFINT ] = 7 ,
[ IRQ_COMMTX ] = 7 ,
[ IRQ_COMMRX ] = 7 ,
[ IRQ_EMUINT ] = 7 ,
} ;
2009-04-30 04:44:58 +04:00
/*----------------------------------------------------------------------*/
2009-05-21 15:41:35 +04:00
/* Four Transfer Controllers on DM646x */
2015-10-14 14:42:46 +03:00
static s8 dm646x_queue_priority_mapping [ ] [ 2 ] = {
2009-05-21 15:41:35 +04:00
/* {event queue no, Priority} */
{ 0 , 4 } ,
{ 1 , 0 } ,
{ 2 , 5 } ,
{ 3 , 1 } ,
{ - 1 , - 1 } ,
} ;
2016-02-02 15:43:17 +03:00
static const struct dma_slave_map dm646x_edma_map [ ] = {
{ " davinci-mcasp.0 " , " tx " , EDMA_FILTER_PARAM ( 0 , 6 ) } ,
{ " davinci-mcasp.0 " , " rx " , EDMA_FILTER_PARAM ( 0 , 9 ) } ,
{ " davinci-mcasp.1 " , " tx " , EDMA_FILTER_PARAM ( 0 , 12 ) } ,
{ " spi_davinci " , " tx " , EDMA_FILTER_PARAM ( 0 , 16 ) } ,
{ " spi_davinci " , " rx " , EDMA_FILTER_PARAM ( 0 , 17 ) } ,
} ;
2015-10-14 14:42:46 +03:00
static struct edma_soc_info dm646x_edma_pdata = {
2010-06-29 10:05:12 +04:00
. queue_priority_mapping = dm646x_queue_priority_mapping ,
2011-07-10 17:14:35 +04:00
. default_queue = EVENTQ_1 ,
2016-02-02 15:43:17 +03:00
. slave_map = dm646x_edma_map ,
. slavecnt = ARRAY_SIZE ( dm646x_edma_map ) ,
2010-06-29 10:05:12 +04:00
} ;
2009-04-30 04:44:58 +04:00
static struct resource edma_resources [ ] = {
{
2015-10-14 14:42:46 +03:00
. name = " edma3_cc " ,
2009-04-30 04:44:58 +04:00
. start = 0x01c00000 ,
. end = 0x01c00000 + SZ_64K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
2015-10-14 14:42:46 +03:00
. name = " edma3_tc0 " ,
2009-04-30 04:44:58 +04:00
. start = 0x01c10000 ,
. end = 0x01c10000 + SZ_1K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
2015-10-14 14:42:46 +03:00
. name = " edma3_tc1 " ,
2009-04-30 04:44:58 +04:00
. start = 0x01c10400 ,
. end = 0x01c10400 + SZ_1K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
2015-10-14 14:42:46 +03:00
. name = " edma3_tc2 " ,
2009-04-30 04:44:58 +04:00
. start = 0x01c10800 ,
. end = 0x01c10800 + SZ_1K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
2015-10-14 14:42:46 +03:00
. name = " edma3_tc3 " ,
2009-04-30 04:44:58 +04:00
. start = 0x01c10c00 ,
. end = 0x01c10c00 + SZ_1K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
2015-10-14 14:42:46 +03:00
. name = " edma3_ccint " ,
2009-04-30 04:44:58 +04:00
. start = IRQ_CCINT0 ,
. flags = IORESOURCE_IRQ ,
} ,
{
2015-10-14 14:42:46 +03:00
. name = " edma3_ccerrint " ,
2009-04-30 04:44:58 +04:00
. start = IRQ_CCERRINT ,
. flags = IORESOURCE_IRQ ,
} ,
/* not using TC*_ERR */
} ;
2015-10-14 14:42:51 +03:00
static const struct platform_device_info dm646x_edma_device __initconst = {
. name = " edma " ,
. id = 0 ,
2015-10-14 14:42:52 +03:00
. dma_mask = DMA_BIT_MASK ( 32 ) ,
2015-10-14 14:42:51 +03:00
. res = edma_resources ,
. num_res = ARRAY_SIZE ( edma_resources ) ,
. data = & dm646x_edma_pdata ,
. size_data = sizeof ( dm646x_edma_pdata ) ,
2009-04-30 04:44:58 +04:00
} ;
2009-06-05 14:28:08 +04:00
static struct resource dm646x_mcasp0_resources [ ] = {
{
2013-11-13 18:48:17 +04:00
. name = " mpu " ,
2009-06-05 14:28:08 +04:00
. start = DAVINCI_DM646X_MCASP0_REG_BASE ,
. end = DAVINCI_DM646X_MCASP0_REG_BASE + ( SZ_1K < < 1 ) - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
2015-03-12 11:06:29 +03:00
. name = " tx " ,
2009-06-05 14:28:08 +04:00
. start = DAVINCI_DM646X_DMA_MCASP0_AXEVT0 ,
. end = DAVINCI_DM646X_DMA_MCASP0_AXEVT0 ,
. flags = IORESOURCE_DMA ,
} ,
{
2015-03-12 11:06:29 +03:00
. name = " rx " ,
2009-06-05 14:28:08 +04:00
. start = DAVINCI_DM646X_DMA_MCASP0_AREVT0 ,
. end = DAVINCI_DM646X_DMA_MCASP0_AREVT0 ,
. flags = IORESOURCE_DMA ,
} ,
2015-03-12 11:06:31 +03:00
{
. name = " tx " ,
. start = IRQ_DM646X_MCASP0TXINT ,
. flags = IORESOURCE_IRQ ,
} ,
{
. name = " rx " ,
. start = IRQ_DM646X_MCASP0RXINT ,
. flags = IORESOURCE_IRQ ,
} ,
2009-06-05 14:28:08 +04:00
} ;
2015-03-12 11:06:29 +03:00
/* DIT mode only, rx is not supported */
2009-06-05 14:28:08 +04:00
static struct resource dm646x_mcasp1_resources [ ] = {
{
2013-11-13 18:48:17 +04:00
. name = " mpu " ,
2009-06-05 14:28:08 +04:00
. start = DAVINCI_DM646X_MCASP1_REG_BASE ,
. end = DAVINCI_DM646X_MCASP1_REG_BASE + ( SZ_1K < < 1 ) - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
2015-03-12 11:06:29 +03:00
. name = " tx " ,
2009-06-05 14:28:08 +04:00
. start = DAVINCI_DM646X_DMA_MCASP1_AXEVT1 ,
. end = DAVINCI_DM646X_DMA_MCASP1_AXEVT1 ,
. flags = IORESOURCE_DMA ,
} ,
2015-03-12 11:06:31 +03:00
{
. name = " tx " ,
. start = IRQ_DM646X_MCASP1TXINT ,
. flags = IORESOURCE_IRQ ,
} ,
2009-06-05 14:28:08 +04:00
} ;
static struct platform_device dm646x_mcasp0_device = {
. name = " davinci-mcasp " ,
. id = 0 ,
. num_resources = ARRAY_SIZE ( dm646x_mcasp0_resources ) ,
. resource = dm646x_mcasp0_resources ,
} ;
static struct platform_device dm646x_mcasp1_device = {
. name = " davinci-mcasp " ,
. id = 1 ,
. num_resources = ARRAY_SIZE ( dm646x_mcasp1_resources ) ,
. resource = dm646x_mcasp1_resources ,
} ;
static struct platform_device dm646x_dit_device = {
. name = " spdif-dit " ,
. id = - 1 ,
} ;
2009-09-16 21:15:30 +04:00
static u64 vpif_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource vpif_resource [ ] = {
{
. start = DAVINCI_VPIF_BASE ,
. end = DAVINCI_VPIF_BASE + 0x03ff ,
. flags = IORESOURCE_MEM ,
}
} ;
static struct platform_device vpif_dev = {
. name = " vpif " ,
. id = - 1 ,
. dev = {
. dma_mask = & vpif_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = vpif_resource ,
. num_resources = ARRAY_SIZE ( vpif_resource ) ,
} ;
static struct resource vpif_display_resource [ ] = {
{
. start = IRQ_DM646X_VP_VERTINT2 ,
. end = IRQ_DM646X_VP_VERTINT2 ,
. flags = IORESOURCE_IRQ ,
} ,
{
. start = IRQ_DM646X_VP_VERTINT3 ,
. end = IRQ_DM646X_VP_VERTINT3 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device vpif_display_dev = {
. name = " vpif_display " ,
. id = - 1 ,
. dev = {
. dma_mask = & vpif_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = vpif_display_resource ,
. num_resources = ARRAY_SIZE ( vpif_display_resource ) ,
} ;
static struct resource vpif_capture_resource [ ] = {
{
. start = IRQ_DM646X_VP_VERTINT0 ,
. end = IRQ_DM646X_VP_VERTINT0 ,
. flags = IORESOURCE_IRQ ,
} ,
{
. start = IRQ_DM646X_VP_VERTINT1 ,
. end = IRQ_DM646X_VP_VERTINT1 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device vpif_capture_dev = {
. name = " vpif_capture " ,
. id = - 1 ,
. dev = {
. dma_mask = & vpif_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = vpif_capture_resource ,
. num_resources = ARRAY_SIZE ( vpif_capture_resource ) ,
} ;
2013-08-18 09:19:00 +04:00
static struct resource dm646x_gpio_resources [ ] = {
{ /* registers */
. start = DAVINCI_GPIO_BASE ,
. end = DAVINCI_GPIO_BASE + SZ_4K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{ /* interrupt */
. start = IRQ_DM646X_GPIOBNK0 ,
. end = IRQ_DM646X_GPIOBNK2 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct davinci_gpio_platform_data dm646x_gpio_platform_data = {
. ngpio = 43 ,
} ;
int __init dm646x_gpio_register ( void )
{
return davinci_gpio_register ( dm646x_gpio_resources ,
2013-11-08 10:45:56 +04:00
ARRAY_SIZE ( dm646x_gpio_resources ) ,
2013-08-18 09:19:00 +04:00
& dm646x_gpio_platform_data ) ;
}
2009-04-30 04:44:58 +04:00
/*----------------------------------------------------------------------*/
2009-04-15 23:38:58 +04:00
static struct map_desc dm646x_io_desc [ ] = {
{
. virtual = IO_VIRT ,
. pfn = __phys_to_pfn ( IO_PHYS ) ,
. length = IO_SIZE ,
. type = MT_DEVICE
} ,
} ;
2009-04-15 23:39:09 +04:00
/* Contents of JTAG ID register used to identify exact cpu type */
static struct davinci_id dm646x_ids [ ] = {
{
. variant = 0x0 ,
. part_no = 0xb770 ,
. manufacturer = 0x017 ,
. cpu_id = DAVINCI_CPU_ID_DM6467 ,
2009-09-02 15:19:35 +04:00
. name = " dm6467_rev1.x " ,
} ,
{
. variant = 0x1 ,
. part_no = 0xb770 ,
. manufacturer = 0x017 ,
. cpu_id = DAVINCI_CPU_ID_DM6467 ,
. name = " dm6467_rev3.x " ,
2009-04-15 23:39:09 +04:00
} ,
} ;
2010-05-08 01:06:36 +04:00
static u32 dm646x_psc_bases [ ] = { DAVINCI_PWR_SLEEP_CNTRL_BASE } ;
2009-04-15 23:39:33 +04:00
2009-04-15 23:40:11 +04:00
/*
* T0_BOT : Timer 0 , bottom : clockevent source for hrtimers
* T0_TOP : Timer 0 , top : clocksource for generic timekeeping
* T1_BOT : Timer 1 , bottom : ( used by DSP in TI DSPLink code )
* T1_TOP : Timer 1 , top : < unused >
*/
2010-02-26 02:36:38 +03:00
static struct davinci_timer_info dm646x_timer_info = {
2009-04-15 23:40:11 +04:00
. timers = davinci_timer_instance ,
. clockevent_id = T0_BOT ,
. clocksource_id = T0_TOP ,
} ;
2013-06-19 13:15:38 +04:00
static struct plat_serial8250_port dm646x_serial0_platform_data [ ] = {
2009-03-18 20:36:08 +03:00
{
. mapbase = DAVINCI_UART0_BASE ,
. irq = IRQ_UARTINT0 ,
. flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST |
UPF_IOREMAP ,
. iotype = UPIO_MEM32 ,
. regshift = 2 ,
} ,
2013-06-19 13:15:38 +04:00
{
. flags = 0 ,
}
} ;
static struct plat_serial8250_port dm646x_serial1_platform_data [ ] = {
2009-03-18 20:36:08 +03:00
{
. mapbase = DAVINCI_UART1_BASE ,
. irq = IRQ_UARTINT1 ,
. flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST |
UPF_IOREMAP ,
. iotype = UPIO_MEM32 ,
. regshift = 2 ,
} ,
2013-06-19 13:15:38 +04:00
{
. flags = 0 ,
}
} ;
static struct plat_serial8250_port dm646x_serial2_platform_data [ ] = {
2009-03-18 20:36:08 +03:00
{
. mapbase = DAVINCI_UART2_BASE ,
. irq = IRQ_DM646X_UARTINT2 ,
. flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST |
UPF_IOREMAP ,
. iotype = UPIO_MEM32 ,
. regshift = 2 ,
} ,
{
2013-06-19 13:15:38 +04:00
. flags = 0 ,
}
2009-03-18 20:36:08 +03:00
} ;
2013-06-19 13:15:42 +04:00
struct platform_device dm646x_serial_device [ ] = {
2013-06-19 13:15:38 +04:00
{
. name = " serial8250 " ,
. id = PLAT8250_DEV_PLATFORM ,
. dev = {
. platform_data = dm646x_serial0_platform_data ,
}
} ,
{
. name = " serial8250 " ,
. id = PLAT8250_DEV_PLATFORM1 ,
. dev = {
. platform_data = dm646x_serial1_platform_data ,
}
2009-03-18 20:36:08 +03:00
} ,
2013-06-19 13:15:38 +04:00
{
. name = " serial8250 " ,
. id = PLAT8250_DEV_PLATFORM2 ,
. dev = {
. platform_data = dm646x_serial2_platform_data ,
}
} ,
{
}
2009-03-18 20:36:08 +03:00
} ;
2009-04-15 23:38:58 +04:00
static struct davinci_soc_info davinci_soc_info_dm646x = {
. io_desc = dm646x_io_desc ,
. io_desc_num = ARRAY_SIZE ( dm646x_io_desc ) ,
2010-05-08 01:06:34 +04:00
. jtag_id_reg = 0x01c40028 ,
2009-04-15 23:39:09 +04:00
. ids = dm646x_ids ,
. ids_num = ARRAY_SIZE ( dm646x_ids ) ,
2009-04-15 23:39:23 +04:00
. cpu_clks = dm646x_clks ,
2009-04-15 23:39:33 +04:00
. psc_bases = dm646x_psc_bases ,
. psc_bases_num = ARRAY_SIZE ( dm646x_psc_bases ) ,
2010-05-08 01:06:38 +04:00
. pinmux_base = DAVINCI_SYSTEM_MODULE_BASE ,
2009-04-15 23:39:48 +04:00
. pinmux_pins = dm646x_pins ,
. pinmux_pins_num = ARRAY_SIZE ( dm646x_pins ) ,
2010-05-08 01:06:37 +04:00
. intc_base = DAVINCI_ARM_INTC_BASE ,
2009-04-15 23:40:00 +04:00
. intc_type = DAVINCI_INTC_TYPE_AINTC ,
. intc_irq_prios = dm646x_default_priorities ,
. intc_irq_num = DAVINCI_N_AINTC_IRQ ,
2009-04-15 23:40:11 +04:00
. timer_info = & dm646x_timer_info ,
2009-04-15 23:40:56 +04:00
. emac_pdata = & dm646x_emac_pdata ,
2009-05-01 04:35:48 +04:00
. sram_dma = 0x10010000 ,
. sram_len = SZ_32K ,
2009-04-15 23:38:58 +04:00
} ;
2009-06-05 14:28:08 +04:00
void __init dm646x_init_mcasp0 ( struct snd_platform_data * pdata )
{
dm646x_mcasp0_device . dev . platform_data = pdata ;
platform_device_register ( & dm646x_mcasp0_device ) ;
}
void __init dm646x_init_mcasp1 ( struct snd_platform_data * pdata )
{
dm646x_mcasp1_device . dev . platform_data = pdata ;
platform_device_register ( & dm646x_mcasp1_device ) ;
platform_device_register ( & dm646x_dit_device ) ;
}
2009-09-16 21:15:30 +04:00
void dm646x_setup_vpif ( struct vpif_display_config * display_config ,
struct vpif_capture_config * capture_config )
{
unsigned int value ;
2011-12-21 17:43:36 +04:00
value = __raw_readl ( DAVINCI_SYSMOD_VIRT ( SYSMOD_VSCLKDIS ) ) ;
2009-09-16 21:15:30 +04:00
value & = ~ VSCLKDIS_MASK ;
2011-12-21 17:43:36 +04:00
__raw_writel ( value , DAVINCI_SYSMOD_VIRT ( SYSMOD_VSCLKDIS ) ) ;
2009-09-16 21:15:30 +04:00
2011-12-21 17:43:36 +04:00
value = __raw_readl ( DAVINCI_SYSMOD_VIRT ( SYSMOD_VDD3P3VPWDN ) ) ;
2009-09-16 21:15:30 +04:00
value & = ~ VDD3P3V_VID_MASK ;
2011-12-21 17:43:36 +04:00
__raw_writel ( value , DAVINCI_SYSMOD_VIRT ( SYSMOD_VDD3P3VPWDN ) ) ;
2009-09-16 21:15:30 +04:00
davinci_cfg_reg ( DM646X_STSOMUX_DISABLE ) ;
davinci_cfg_reg ( DM646X_STSIMUX_DISABLE ) ;
davinci_cfg_reg ( DM646X_PTSOMUX_DISABLE ) ;
davinci_cfg_reg ( DM646X_PTSIMUX_DISABLE ) ;
vpif_display_dev . dev . platform_data = display_config ;
vpif_capture_dev . dev . platform_data = capture_config ;
platform_device_register ( & vpif_dev ) ;
platform_device_register ( & vpif_display_dev ) ;
platform_device_register ( & vpif_capture_dev ) ;
}
2010-06-29 10:05:15 +04:00
int __init dm646x_init_edma ( struct edma_rsv_info * rsv )
{
2015-10-14 14:42:51 +03:00
struct platform_device * edma_pdev ;
2015-10-14 14:42:46 +03:00
dm646x_edma_pdata . rsv = rsv ;
2010-06-29 10:05:15 +04:00
2015-10-14 14:42:51 +03:00
edma_pdev = platform_device_register_full ( & dm646x_edma_device ) ;
return IS_ERR ( edma_pdev ) ? PTR_ERR ( edma_pdev ) : 0 ;
2010-06-29 10:05:15 +04:00
}
2009-04-30 04:44:58 +04:00
void __init dm646x_init ( void )
{
2009-04-15 23:38:58 +04:00
davinci_common_init ( & davinci_soc_info_dm646x ) ;
2011-12-21 17:43:36 +04:00
davinci_map_sysmod ( ) ;
2016-04-14 22:13:35 +03:00
davinci_clk_init ( davinci_soc_info_dm646x . cpu_clks ) ;
2009-04-30 04:44:58 +04:00
}
static int __init dm646x_init_devices ( void )
{
2014-02-26 08:59:43 +04:00
int ret = 0 ;
2009-04-30 04:44:58 +04:00
if ( ! cpu_is_davinci_dm646x ( ) )
return 0 ;
2010-09-15 18:11:22 +04:00
platform_device_register ( & dm646x_mdio_device ) ;
2009-04-15 23:40:56 +04:00
platform_device_register ( & dm646x_emac_device ) ;
2010-09-15 18:11:22 +04:00
2014-02-26 08:59:43 +04:00
ret = davinci_init_wdt ( ) ;
if ( ret )
pr_warn ( " %s: watchdog init failed: %d \n " , __func__ , ret ) ;
return ret ;
2009-04-30 04:44:58 +04:00
}
postcore_initcall ( dm646x_init_devices ) ;