2013-09-25 15:44:39 -07:00
/*
* Legacy platform_data quirks
*
* Copyright ( C ) 2013 Texas Instruments
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*/
# include <linux/clk.h>
2013-12-06 10:53:04 -08:00
# include <linux/davinci_emac.h>
2013-09-25 15:44:40 -07:00
# include <linux/gpio.h>
2013-09-25 15:44:39 -07:00
# include <linux/init.h>
# include <linux/kernel.h>
2013-10-10 15:45:12 -07:00
# include <linux/of_platform.h>
2013-09-25 15:44:40 -07:00
# include <linux/wl12xx.h>
2013-09-25 15:44:39 -07:00
2013-10-10 15:45:13 -07:00
# include <linux/platform_data/pinctrl-single.h>
2013-12-06 10:53:04 -08:00
# include "am35xx.h"
2013-09-25 15:44:39 -07:00
# include "common.h"
# include "common-board-devices.h"
# include "dss-common.h"
2013-09-24 22:28:15 +03:00
# include "control.h"
2013-09-25 15:44:39 -07:00
struct pdata_init {
const char * compatible ;
void ( * fn ) ( void ) ;
} ;
2013-11-25 15:17:10 -08:00
struct of_dev_auxdata omap_auxdata_lookup [ ] ;
2013-12-06 10:52:58 -08:00
static struct twl4030_gpio_platform_data twl_gpio_auxdata ;
2013-11-25 15:17:10 -08:00
2013-09-25 15:44:39 -07:00
/*
* Create alias for USB host PHY clock .
* Remove this when clock phandle can be provided via DT
*/
static void __init __used legacy_init_ehci_clk ( char * clkname )
{
int ret ;
ret = clk_add_alias ( " main_clk " , NULL , clkname , NULL ) ;
if ( ret )
pr_err ( " %s:Failed to add main_clk alias to %s :%d \n " ,
__func__ , clkname , ret ) ;
}
2013-09-25 15:44:40 -07:00
# if IS_ENABLED(CONFIG_WL12XX)
static struct wl12xx_platform_data wl12xx __initdata ;
static void __init __used legacy_init_wl12xx ( unsigned ref_clock ,
unsigned tcxo_clock ,
int gpio )
{
int res ;
wl12xx . board_ref_clock = ref_clock ;
wl12xx . board_tcxo_clock = tcxo_clock ;
wl12xx . irq = gpio_to_irq ( gpio ) ;
res = wl12xx_set_platform_data ( & wl12xx ) ;
if ( res ) {
pr_err ( " error setting wl12xx data: %d \n " , res ) ;
return ;
}
}
# else
static inline void legacy_init_wl12xx ( unsigned ref_clock ,
unsigned tcxo_clock ,
int gpio )
{
}
# endif
2013-11-25 15:17:10 -08:00
# ifdef CONFIG_MACH_NOKIA_N8X0
static void __init omap2420_n8x0_legacy_init ( void )
{
omap_auxdata_lookup [ 0 ] . platform_data = n8x0_legacy_init ( ) ;
}
# else
# define omap2420_n8x0_legacy_init NULL
# endif
2013-09-24 22:28:15 +03:00
# ifdef CONFIG_ARCH_OMAP3
static void __init hsmmc2_internal_input_clk ( void )
{
u32 reg ;
reg = omap_ctrl_readl ( OMAP343X_CONTROL_DEVCONF1 ) ;
reg | = OMAP2_MMCSDIO2ADPCLKISEL ;
omap_ctrl_writel ( reg , OMAP343X_CONTROL_DEVCONF1 ) ;
}
2013-10-09 11:19:18 +02:00
2013-12-18 13:13:21 -08:00
static int omap3_sbc_t3730_twl_callback ( struct device * dev ,
unsigned gpio ,
unsigned ngpio )
{
int res ;
res = gpio_request_one ( gpio + 2 , GPIOF_OUT_INIT_HIGH ,
2014-01-12 15:22:45 +02:00
" wlan pwr " ) ;
2013-12-18 13:13:21 -08:00
if ( res )
return res ;
gpio_export ( gpio , 0 ) ;
return 0 ;
}
static void __init omap3_sbc_t3730_twl_init ( void )
{
twl_gpio_auxdata . setup = omap3_sbc_t3730_twl_callback ;
}
static void __init omap3_sbc_t3730_legacy_init ( void )
{
legacy_init_wl12xx ( WL12XX_REFCLOCK_38 , 0 , 136 ) ;
omap_ads7846_init ( 1 , 57 , 0 , NULL ) ;
}
2014-01-12 15:22:53 +02:00
static void __init omap3_sbc_t3530_legacy_init ( void )
{
omap_ads7846_init ( 1 , 57 , 0 , NULL ) ;
}
2013-10-09 11:19:18 +02:00
static void __init omap3_igep0020_legacy_init ( void )
{
omap3_igep2_display_init_of ( ) ;
}
2013-10-11 09:20:54 -07:00
static void __init omap3_evm_legacy_init ( void )
{
legacy_init_wl12xx ( WL12XX_REFCLOCK_38 , 0 , 149 ) ;
}
static void __init omap3_zoom_legacy_init ( void )
{
legacy_init_wl12xx ( WL12XX_REFCLOCK_26 , 0 , 162 ) ;
}
2013-12-06 10:53:04 -08:00
static void am35xx_enable_emac_int ( void )
{
u32 v ;
v = omap_ctrl_readl ( AM35XX_CONTROL_LVL_INTR_CLEAR ) ;
v | = ( AM35XX_CPGMAC_C0_RX_PULSE_CLR | AM35XX_CPGMAC_C0_TX_PULSE_CLR |
AM35XX_CPGMAC_C0_MISC_PULSE_CLR | AM35XX_CPGMAC_C0_RX_THRESH_CLR ) ;
omap_ctrl_writel ( v , AM35XX_CONTROL_LVL_INTR_CLEAR ) ;
omap_ctrl_readl ( AM35XX_CONTROL_LVL_INTR_CLEAR ) ; /* OCP barrier */
}
static void am35xx_disable_emac_int ( void )
{
u32 v ;
v = omap_ctrl_readl ( AM35XX_CONTROL_LVL_INTR_CLEAR ) ;
v | = ( AM35XX_CPGMAC_C0_RX_PULSE_CLR | AM35XX_CPGMAC_C0_TX_PULSE_CLR ) ;
omap_ctrl_writel ( v , AM35XX_CONTROL_LVL_INTR_CLEAR ) ;
omap_ctrl_readl ( AM35XX_CONTROL_LVL_INTR_CLEAR ) ; /* OCP barrier */
}
static struct emac_platform_data am35xx_emac_pdata = {
. interrupt_enable = am35xx_enable_emac_int ,
. interrupt_disable = am35xx_disable_emac_int ,
} ;
2014-01-12 15:22:54 +02:00
static void __init am35xx_emac_reset ( void )
2013-12-06 10:53:04 -08:00
{
u32 v ;
v = omap_ctrl_readl ( AM35XX_CONTROL_IP_SW_RESET ) ;
v & = ~ AM35XX_CPGMACSS_SW_RST ;
omap_ctrl_writel ( v , AM35XX_CONTROL_IP_SW_RESET ) ;
omap_ctrl_readl ( AM35XX_CONTROL_IP_SW_RESET ) ; /* OCP barrier */
}
2014-01-12 15:22:54 +02:00
static struct gpio cm_t3517_wlan_gpios [ ] __initdata = {
{ 56 , GPIOF_OUT_INIT_HIGH , " wlan pwr " } ,
{ 4 , GPIOF_OUT_INIT_HIGH , " xcvr noe " } ,
} ;
static void __init omap3_sbc_t3517_wifi_init ( void )
{
int err = gpio_request_array ( cm_t3517_wlan_gpios ,
ARRAY_SIZE ( cm_t3517_wlan_gpios ) ) ;
if ( err ) {
pr_err ( " SBC-T3517: wl12xx gpios request failed: %d \n " , err ) ;
return ;
}
gpio_export ( cm_t3517_wlan_gpios [ 0 ] . gpio , 0 ) ;
gpio_export ( cm_t3517_wlan_gpios [ 1 ] . gpio , 0 ) ;
msleep ( 100 ) ;
gpio_set_value ( cm_t3517_wlan_gpios [ 1 ] . gpio , 0 ) ;
}
static void __init omap3_sbc_t3517_legacy_init ( void )
{
am35xx_emac_reset ( ) ;
hsmmc2_internal_input_clk ( ) ;
omap3_sbc_t3517_wifi_init ( ) ;
legacy_init_wl12xx ( WL12XX_REFCLOCK_38 , 0 , 145 ) ;
omap_ads7846_init ( 1 , 57 , 0 , NULL ) ;
}
static void __init am3517_evm_legacy_init ( void )
{
am35xx_emac_reset ( ) ;
}
2013-09-24 22:28:15 +03:00
# endif /* CONFIG_ARCH_OMAP3 */
2013-09-25 15:44:39 -07:00
# ifdef CONFIG_ARCH_OMAP4
static void __init omap4_sdp_legacy_init ( void )
{
omap_4430sdp_display_init_of ( ) ;
2013-09-25 15:44:40 -07:00
legacy_init_wl12xx ( WL12XX_REFCLOCK_26 ,
WL12XX_TCXOCLOCK_26 , 53 ) ;
2013-09-25 15:44:39 -07:00
}
static void __init omap4_panda_legacy_init ( void )
{
omap4_panda_display_init_of ( ) ;
legacy_init_ehci_clk ( " auxclk3_ck " ) ;
2013-09-25 15:44:40 -07:00
legacy_init_wl12xx ( WL12XX_REFCLOCK_38 , 0 , 53 ) ;
2013-09-25 15:44:39 -07:00
}
# endif
# ifdef CONFIG_SOC_OMAP5
static void __init omap5_uevm_legacy_init ( void )
{
legacy_init_ehci_clk ( " auxclk1_ck " ) ;
}
# endif
2013-10-10 15:45:13 -07:00
static struct pcs_pdata pcs_pdata ;
void omap_pcs_legacy_init ( int irq , void ( * rearm ) ( void ) )
{
pcs_pdata . irq = irq ;
pcs_pdata . rearm = rearm ;
}
2013-12-06 10:52:58 -08:00
/*
* GPIOs for TWL are initialized by the I2C bus and need custom
* handing until DSS has device tree bindings .
*/
void omap_auxdata_legacy_init ( struct device * dev )
{
if ( dev - > platform_data )
return ;
if ( strcmp ( " twl4030-gpio " , dev_name ( dev ) ) )
return ;
dev - > platform_data = & twl_gpio_auxdata ;
}
2013-11-25 15:17:09 -08:00
/*
* Few boards still need auxdata populated before we populate
* the dev entries in of_platform_populate ( ) .
*/
static struct pdata_init auxdata_quirks [ ] __initdata = {
2013-11-25 15:17:10 -08:00
# ifdef CONFIG_SOC_OMAP2420
{ " nokia,n800 " , omap2420_n8x0_legacy_init , } ,
{ " nokia,n810 " , omap2420_n8x0_legacy_init , } ,
{ " nokia,n810-wimax " , omap2420_n8x0_legacy_init , } ,
2013-12-18 13:13:21 -08:00
# endif
# ifdef CONFIG_ARCH_OMAP3
{ " compulab,omap3-sbc-t3730 " , omap3_sbc_t3730_twl_init , } ,
2013-11-25 15:17:10 -08:00
# endif
2013-11-25 15:17:09 -08:00
{ /* sentinel */ } ,
} ;
2013-10-10 15:45:12 -07:00
struct of_dev_auxdata omap_auxdata_lookup [ ] __initdata = {
2013-11-25 15:17:09 -08:00
# ifdef CONFIG_MACH_NOKIA_N8X0
OF_DEV_AUXDATA ( " ti,omap2420-mmc " , 0x4809c000 , " mmci-omap.0 " , NULL ) ,
# endif
2013-10-10 15:45:13 -07:00
# ifdef CONFIG_ARCH_OMAP3
OF_DEV_AUXDATA ( " ti,omap3-padconf " , 0x48002030 , " 48002030.pinmux " , & pcs_pdata ) ,
OF_DEV_AUXDATA ( " ti,omap3-padconf " , 0x48002a00 , " 48002a00.pinmux " , & pcs_pdata ) ,
2013-12-06 10:53:04 -08:00
/* Only on am3517 */
OF_DEV_AUXDATA ( " ti,davinci_mdio " , 0x5c030000 , " davinci_mdio.0 " , NULL ) ,
OF_DEV_AUXDATA ( " ti,am3517-emac " , 0x5c000000 , " davinci_emac.0 " ,
& am35xx_emac_pdata ) ,
2013-10-10 15:45:13 -07:00
# endif
# ifdef CONFIG_ARCH_OMAP4
OF_DEV_AUXDATA ( " ti,omap4-padconf " , 0x4a100040 , " 4a100040.pinmux " , & pcs_pdata ) ,
OF_DEV_AUXDATA ( " ti,omap4-padconf " , 0x4a31e040 , " 4a31e040.pinmux " , & pcs_pdata ) ,
# endif
2013-10-10 15:45:12 -07:00
{ /* sentinel */ } ,
} ;
2013-11-25 15:17:09 -08:00
/*
* Few boards still need to initialize some legacy devices with
* platform data until the drivers support device tree .
*/
2013-09-25 15:44:39 -07:00
static struct pdata_init pdata_quirks [ ] __initdata = {
2013-09-24 22:28:15 +03:00
# ifdef CONFIG_ARCH_OMAP3
2014-01-12 15:22:54 +02:00
{ " compulab,omap3-sbc-t3517 " , omap3_sbc_t3517_legacy_init , } ,
2014-01-12 15:22:53 +02:00
{ " compulab,omap3-sbc-t3530 " , omap3_sbc_t3530_legacy_init , } ,
2013-12-18 13:13:21 -08:00
{ " compulab,omap3-sbc-t3730 " , omap3_sbc_t3730_legacy_init , } ,
2013-11-25 14:23:45 -08:00
{ " nokia,omap3-n900 " , hsmmc2_internal_input_clk , } ,
2013-09-24 22:28:15 +03:00
{ " nokia,omap3-n9 " , hsmmc2_internal_input_clk , } ,
{ " nokia,omap3-n950 " , hsmmc2_internal_input_clk , } ,
2013-10-09 11:19:18 +02:00
{ " isee,omap3-igep0020 " , omap3_igep0020_legacy_init , } ,
2013-10-11 09:20:54 -07:00
{ " ti,omap3-evm-37xx " , omap3_evm_legacy_init , } ,
{ " ti,omap3-zoom3 " , omap3_zoom_legacy_init , } ,
2013-12-06 10:53:04 -08:00
{ " ti,am3517-evm " , am3517_evm_legacy_init , } ,
2013-09-24 22:28:15 +03:00
# endif
2013-09-25 15:44:39 -07:00
# ifdef CONFIG_ARCH_OMAP4
{ " ti,omap4-sdp " , omap4_sdp_legacy_init , } ,
{ " ti,omap4-panda " , omap4_panda_legacy_init , } ,
# endif
# ifdef CONFIG_SOC_OMAP5
{ " ti,omap5-uevm " , omap5_uevm_legacy_init , } ,
# endif
2013-09-25 15:44:39 -07:00
{ /* sentinel */ } ,
} ;
2013-11-25 15:17:09 -08:00
static void pdata_quirks_check ( struct pdata_init * quirks )
2013-09-25 15:44:39 -07:00
{
while ( quirks - > compatible ) {
if ( of_machine_is_compatible ( quirks - > compatible ) ) {
if ( quirks - > fn )
quirks - > fn ( ) ;
break ;
}
quirks + + ;
}
}
2013-11-25 15:17:09 -08:00
void __init pdata_quirks_init ( struct of_device_id * omap_dt_match_table )
{
omap_sdrc_init ( NULL , NULL ) ;
pdata_quirks_check ( auxdata_quirks ) ;
of_platform_populate ( NULL , omap_dt_match_table ,
omap_auxdata_lookup , NULL ) ;
pdata_quirks_check ( pdata_quirks ) ;
}