2009-07-16 06:42:18 -04:00
/*
* TI DA850 / OMAP - L138 EVM board
*
2020-07-19 12:20:20 +02:00
* Copyright ( C ) 2009 Texas Instruments Incorporated - https : //www.ti.com/
2009-07-16 06:42:18 -04:00
*
* Derived from : arch / arm / mach - davinci / board - da830 - evm . c
* Original Copyrights follow :
*
* 2007 , 2009 ( c ) MontaVista Software , Inc . 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 .
*/
# include <linux/console.h>
2012-10-05 13:04:45 -04:00
# include <linux/delay.h>
# include <linux/gpio.h>
# include <linux/gpio_keys.h>
2016-11-24 16:04:53 +01:00
# include <linux/gpio/machine.h>
2012-10-05 13:04:45 -04:00
# include <linux/init.h>
# include <linux/kernel.h>
2017-01-13 14:14:03 +01:00
# include <linux/leds.h>
2009-07-16 06:42:18 -04:00
# include <linux/i2c.h>
2013-08-29 15:24:14 -04:00
# include <linux/platform_data/pca953x.h>
2010-12-09 16:51:04 -05:00
# include <linux/input.h>
2012-10-05 13:04:45 -04:00
# include <linux/input/tps6507x-ts.h>
2010-04-05 20:23:57 -06:00
# include <linux/mfd/tps6507x.h>
2009-08-13 16:21:11 -04:00
# include <linux/mtd/mtd.h>
2017-08-04 17:29:10 +02:00
# include <linux/mtd/rawnand.h>
2009-08-13 16:21:11 -04:00
# include <linux/mtd/partitions.h>
2018-11-13 15:01:16 +01:00
# include <linux/nvmem-provider.h>
2009-08-13 17:36:25 -04:00
# include <linux/mtd/physmap.h>
2012-10-05 13:04:45 -04:00
# include <linux/platform_device.h>
2013-08-18 10:49:01 +05:30
# include <linux/platform_data/gpio-davinci.h>
2012-10-05 13:04:45 -04:00
# include <linux/platform_data/mtd-davinci.h>
# include <linux/platform_data/mtd-davinci-aemif.h>
2018-06-28 11:57:42 +02:00
# include <linux/platform_data/ti-aemif.h>
2012-10-05 13:04:45 -04:00
# include <linux/platform_data/spi-davinci.h>
2012-10-08 09:54:42 -04:00
# include <linux/platform_data/uio_pruss.h>
2019-07-22 15:44:17 +02:00
# include <linux/property.h>
2009-09-22 21:14:04 +05:30
# include <linux/regulator/machine.h>
2010-07-12 17:56:21 +05:30
# include <linux/regulator/tps6507x.h>
2014-07-28 14:24:38 +03:00
# include <linux/regulator/fixed.h>
2011-02-24 10:39:27 +05:30
# include <linux/spi/spi.h>
# include <linux/spi/flash.h>
2009-07-16 06:42:18 -04:00
2013-08-18 10:49:01 +05:30
# include <mach/common.h>
2009-07-16 06:42:18 -04:00
# include <mach/da8xx.h>
2009-09-15 17:46:14 -04:00
# include <mach/mux.h>
2019-02-14 15:52:03 +01:00
# include "irqs.h"
2015-01-30 10:45:33 +01:00
# include "sram.h"
2012-10-05 13:04:45 -04:00
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/system_info.h>
2009-07-16 06:42:18 -04:00
2015-11-10 12:01:44 -02:00
# include <media/i2c/tvp514x.h>
# include <media/i2c/adv7343.h>
2012-07-23 08:00:58 -03:00
2012-01-21 02:48:17 +05:30
# define DA850_EVM_PHY_ID "davinci_mdio-0:00"
2009-09-15 17:46:14 -04:00
# define DA850_LCD_PWR_PIN GPIO_TO_PIN(2, 8)
2009-08-13 14:33:14 -04:00
# define DA850_LCD_BL_PIN GPIO_TO_PIN(2, 15)
2009-09-30 17:00:53 -04:00
# define DA850_MII_MDIO_CLKEN_PIN GPIO_TO_PIN(2, 6)
2011-02-24 10:39:27 +05:30
static struct mtd_partition da850evm_spiflash_part [ ] = {
[ 0 ] = {
. name = " UBL " ,
. offset = 0 ,
. size = SZ_64K ,
. mask_flags = MTD_WRITEABLE ,
} ,
[ 1 ] = {
. name = " U-Boot " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_512K ,
. mask_flags = MTD_WRITEABLE ,
} ,
[ 2 ] = {
. name = " U-Boot-Env " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_64K ,
. mask_flags = MTD_WRITEABLE ,
} ,
[ 3 ] = {
. name = " Kernel " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_2M + SZ_512K ,
. mask_flags = 0 ,
} ,
[ 4 ] = {
. name = " Filesystem " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_4M ,
. mask_flags = 0 ,
} ,
[ 5 ] = {
. name = " MAC-Address " ,
. offset = SZ_8M - SZ_64K ,
. size = SZ_64K ,
. mask_flags = MTD_WRITEABLE ,
} ,
} ;
2018-11-13 15:01:16 +01:00
static struct nvmem_cell_info da850evm_nvmem_cells [ ] = {
{
. name = " macaddr " ,
. offset = 0x0 ,
. bytes = ETH_ALEN ,
}
} ;
static struct nvmem_cell_table da850evm_nvmem_cell_table = {
/*
* The nvmem name differs from the partition name because of the
* internal works of the nvmem framework .
*/
. nvmem_name = " MAC-Address0 " ,
. cells = da850evm_nvmem_cells ,
. ncells = ARRAY_SIZE ( da850evm_nvmem_cells ) ,
} ;
static struct nvmem_cell_lookup da850evm_nvmem_cell_lookup = {
. nvmem_name = " MAC-Address0 " ,
. cell_name = " macaddr " ,
. dev_id = " davinci_emac.1 " ,
. con_id = " mac-address " ,
} ;
2011-02-24 10:39:27 +05:30
static struct flash_platform_data da850evm_spiflash_data = {
. name = " m25p80 " ,
. parts = da850evm_spiflash_part ,
. nr_parts = ARRAY_SIZE ( da850evm_spiflash_part ) ,
. type = " m25p64 " ,
} ;
static struct davinci_spi_config da850evm_spiflash_cfg = {
. io_type = SPI_IO_TYPE_DMA ,
. c2tdelay = 8 ,
. t2cdelay = 8 ,
} ;
static struct spi_board_info da850evm_spi_info [ ] = {
{
. modalias = " m25p80 " ,
. platform_data = & da850evm_spiflash_data ,
. controller_data = & da850evm_spiflash_cfg ,
. mode = SPI_MODE_0 ,
. max_speed_hz = 30000000 ,
. bus_num = 1 ,
. chip_select = 0 ,
} ,
} ;
2009-08-13 17:36:25 -04:00
static struct mtd_partition da850_evm_norflash_partition [ ] = {
{
2009-11-18 11:48:37 +05:30
. name = " bootloaders + env " ,
2009-08-13 17:36:25 -04:00
. offset = 0 ,
2009-11-18 11:48:37 +05:30
. size = SZ_512K ,
. mask_flags = MTD_WRITEABLE ,
} ,
{
. name = " kernel " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_2M ,
. mask_flags = 0 ,
} ,
{
. name = " filesystem " ,
. offset = MTDPART_OFS_APPEND ,
2009-08-13 17:36:25 -04:00
. size = MTDPART_SIZ_FULL ,
. mask_flags = 0 ,
} ,
} ;
static struct physmap_flash_data da850_evm_norflash_data = {
. width = 2 ,
. parts = da850_evm_norflash_partition ,
. nr_parts = ARRAY_SIZE ( da850_evm_norflash_partition ) ,
} ;
static struct resource da850_evm_norflash_resource [ ] = {
{
. start = DA8XX_AEMIF_CS2_BASE ,
. end = DA8XX_AEMIF_CS2_BASE + SZ_32M - 1 ,
. flags = IORESOURCE_MEM ,
} ,
} ;
2009-08-13 16:21:11 -04:00
/* DA850/OMAP-L138 EVM includes a 512 MByte large-page NAND flash
* ( 128 K blocks ) . It may be used instead of the ( default ) SPI flash
* to boot , using TI ' s tools to install the secondary boot loader
* ( UBL ) and U - Boot .
*/
2010-06-28 17:16:38 +05:30
static struct mtd_partition da850_evm_nandflash_partition [ ] = {
2009-08-13 16:21:11 -04:00
{
. name = " u-boot env " ,
. offset = 0 ,
. size = SZ_128K ,
. mask_flags = MTD_WRITEABLE ,
} ,
{
. name = " UBL " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_128K ,
. mask_flags = MTD_WRITEABLE ,
} ,
{
. name = " u-boot " ,
. offset = MTDPART_OFS_APPEND ,
. size = 4 * SZ_128K ,
. mask_flags = MTD_WRITEABLE ,
} ,
{
. name = " kernel " ,
. offset = 0x200000 ,
. size = SZ_2M ,
. mask_flags = 0 ,
} ,
{
. name = " filesystem " ,
. offset = MTDPART_OFS_APPEND ,
. size = MTDPART_SIZ_FULL ,
. mask_flags = 0 ,
} ,
} ;
2010-08-09 15:46:39 +05:30
static struct davinci_aemif_timing da850_evm_nandflash_timing = {
. wsetup = 24 ,
. wstrobe = 21 ,
. whold = 14 ,
. rsetup = 19 ,
. rstrobe = 50 ,
. rhold = 0 ,
. ta = 20 ,
} ;
2009-08-13 16:21:11 -04:00
static struct davinci_nand_pdata da850_evm_nandflash_data = {
2018-04-30 10:24:44 +02:00
. core_chipsel = 1 ,
2009-08-13 16:21:11 -04:00
. parts = da850_evm_nandflash_partition ,
. nr_parts = ARRAY_SIZE ( da850_evm_nandflash_partition ) ,
2020-08-27 10:51:58 +02:00
. engine_type = NAND_ECC_ENGINE_TYPE_ON_HOST ,
2009-11-18 12:11:41 +05:30
. ecc_bits = 4 ,
2011-05-31 16:31:23 -07:00
. bbt_options = NAND_BBT_USE_FLASH ,
2010-08-09 15:46:39 +05:30
. timing = & da850_evm_nandflash_timing ,
2009-08-13 16:21:11 -04:00
} ;
static struct resource da850_evm_nandflash_resource [ ] = {
{
. start = DA8XX_AEMIF_CS3_BASE ,
. end = DA8XX_AEMIF_CS3_BASE + SZ_512K + 2 * SZ_1K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
. start = DA8XX_AEMIF_CTL_BASE ,
. end = DA8XX_AEMIF_CTL_BASE + SZ_32K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
} ;
2018-06-28 11:57:42 +02:00
static struct resource da850_evm_aemif_resource [ ] = {
{
. start = DA8XX_AEMIF_CTL_BASE ,
. end = DA8XX_AEMIF_CTL_BASE + SZ_32K ,
. flags = IORESOURCE_MEM ,
}
2009-08-13 16:21:11 -04:00
} ;
2018-06-28 11:57:42 +02:00
static struct aemif_abus_data da850_evm_aemif_abus_data [ ] = {
{
. cs = 3 ,
}
2009-11-03 11:51:09 +05:30
} ;
2018-06-28 11:57:42 +02:00
static struct platform_device da850_evm_aemif_devices [ ] = {
{
. name = " davinci_nand " ,
. id = 1 ,
. dev = {
. platform_data = & da850_evm_nandflash_data ,
} ,
. num_resources = ARRAY_SIZE ( da850_evm_nandflash_resource ) ,
. resource = da850_evm_nandflash_resource ,
} ,
{
. name = " physmap-flash " ,
. id = 0 ,
. dev = {
. platform_data = & da850_evm_norflash_data ,
} ,
. num_resources = 1 ,
. resource = da850_evm_norflash_resource ,
}
} ;
2009-11-03 11:51:09 +05:30
2018-06-28 11:57:42 +02:00
static struct aemif_platform_data da850_evm_aemif_pdata = {
. cs_offset = 2 ,
. abus_data = da850_evm_aemif_abus_data ,
. num_abus_data = ARRAY_SIZE ( da850_evm_aemif_abus_data ) ,
. sub_devices = da850_evm_aemif_devices ,
. num_sub_devices = ARRAY_SIZE ( da850_evm_aemif_devices ) ,
} ;
2009-11-03 11:51:09 +05:30
2018-06-28 11:57:42 +02:00
static struct platform_device da850_evm_aemif_device = {
. name = " ti-aemif " ,
. id = - 1 ,
. dev = {
. platform_data = & da850_evm_aemif_pdata ,
} ,
. resource = da850_evm_aemif_resource ,
. num_resources = ARRAY_SIZE ( da850_evm_aemif_resource ) ,
} ;
2009-11-03 11:51:09 +05:30
2010-08-01 21:15:16 +04:00
static const short da850_evm_nand_pins [ ] = {
DA850_EMA_D_0 , DA850_EMA_D_1 , DA850_EMA_D_2 , DA850_EMA_D_3 ,
DA850_EMA_D_4 , DA850_EMA_D_5 , DA850_EMA_D_6 , DA850_EMA_D_7 ,
DA850_EMA_A_1 , DA850_EMA_A_2 , DA850_NEMA_CS_3 , DA850_NEMA_CS_4 ,
DA850_NEMA_WE , DA850_NEMA_OE ,
- 1
} ;
static const short da850_evm_nor_pins [ ] = {
DA850_EMA_BA_1 , DA850_EMA_CLK , DA850_EMA_WAIT_1 , DA850_NEMA_CS_2 ,
DA850_NEMA_WE , DA850_NEMA_OE , DA850_EMA_D_0 , DA850_EMA_D_1 ,
DA850_EMA_D_2 , DA850_EMA_D_3 , DA850_EMA_D_4 , DA850_EMA_D_5 ,
DA850_EMA_D_6 , DA850_EMA_D_7 , DA850_EMA_D_8 , DA850_EMA_D_9 ,
DA850_EMA_D_10 , DA850_EMA_D_11 , DA850_EMA_D_12 , DA850_EMA_D_13 ,
DA850_EMA_D_14 , DA850_EMA_D_15 , DA850_EMA_A_0 , DA850_EMA_A_1 ,
DA850_EMA_A_2 , DA850_EMA_A_3 , DA850_EMA_A_4 , DA850_EMA_A_5 ,
DA850_EMA_A_6 , DA850_EMA_A_7 , DA850_EMA_A_8 , DA850_EMA_A_9 ,
DA850_EMA_A_10 , DA850_EMA_A_11 , DA850_EMA_A_12 , DA850_EMA_A_13 ,
DA850_EMA_A_14 , DA850_EMA_A_15 , DA850_EMA_A_16 , DA850_EMA_A_17 ,
DA850_EMA_A_18 , DA850_EMA_A_19 , DA850_EMA_A_20 , DA850_EMA_A_21 ,
DA850_EMA_A_22 , DA850_EMA_A_23 ,
- 1
} ;
2013-04-01 12:43:44 +05:30
# define HAS_MMC IS_ENABLED(CONFIG_MMC_DAVINCI)
2009-11-03 11:51:09 +05:30
2010-08-01 21:15:16 +04:00
static inline void da850_evm_setup_nor_nand ( void )
2009-11-03 11:51:09 +05:30
{
int ret = 0 ;
2011-02-25 12:26:36 +05:30
if ( ! HAS_MMC ) {
2010-08-01 21:15:16 +04:00
ret = davinci_cfg_reg_list ( da850_evm_nand_pins ) ;
2009-11-03 11:51:09 +05:30
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: NAND mux setup failed: %d \n " ,
__func__ , ret ) ;
2009-11-03 11:51:09 +05:30
2010-08-01 21:15:16 +04:00
ret = davinci_cfg_reg_list ( da850_evm_nor_pins ) ;
2009-11-03 11:51:09 +05:30
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: NOR mux setup failed: %d \n " ,
__func__ , ret ) ;
2009-11-03 11:51:09 +05:30
2018-06-28 11:57:42 +02:00
ret = platform_device_register ( & da850_evm_aemif_device ) ;
if ( ret )
pr_warn ( " %s: registering aemif failed: %d \n " ,
__func__ , ret ) ;
2009-11-03 11:51:09 +05:30
}
}
2009-09-30 17:00:28 -04:00
2009-10-21 21:18:22 +05:30
# ifdef CONFIG_DA850_UI_RMII
static inline void da850_evm_setup_emac_rmii ( int rmii_sel )
{
struct davinci_soc_info * soc_info = & davinci_soc_info ;
soc_info - > emac_pdata - > rmii_en = 1 ;
2010-11-15 09:42:52 -05:00
gpio_set_value_cansleep ( rmii_sel , 0 ) ;
2009-10-21 21:18:22 +05:30
}
# else
static inline void da850_evm_setup_emac_rmii ( int rmii_sel ) { }
# endif
2010-12-09 16:51:04 -05:00
# define DA850_KEYS_DEBOUNCE_MS 10
/*
* At 200 ms polling interval it is possible to miss an
* event by tapping very lightly on the push button but most
* pushes do result in an event ; longer intervals require the
* user to hold the button whereas shorter intervals require
* more CPU time for polling .
*/
# define DA850_GPIO_KEYS_POLL_MS 200
enum da850_evm_ui_exp_pins {
DA850_EVM_UI_EXP_SEL_C = 5 ,
DA850_EVM_UI_EXP_SEL_B ,
DA850_EVM_UI_EXP_SEL_A ,
DA850_EVM_UI_EXP_PB8 ,
DA850_EVM_UI_EXP_PB7 ,
DA850_EVM_UI_EXP_PB6 ,
DA850_EVM_UI_EXP_PB5 ,
DA850_EVM_UI_EXP_PB4 ,
DA850_EVM_UI_EXP_PB3 ,
DA850_EVM_UI_EXP_PB2 ,
DA850_EVM_UI_EXP_PB1 ,
} ;
2013-04-10 14:57:12 +05:30
static const char * const da850_evm_ui_exp [ ] = {
2010-12-09 16:51:04 -05:00
[ DA850_EVM_UI_EXP_SEL_C ] = " sel_c " ,
[ DA850_EVM_UI_EXP_SEL_B ] = " sel_b " ,
[ DA850_EVM_UI_EXP_SEL_A ] = " sel_a " ,
[ DA850_EVM_UI_EXP_PB8 ] = " pb8 " ,
[ DA850_EVM_UI_EXP_PB7 ] = " pb7 " ,
[ DA850_EVM_UI_EXP_PB6 ] = " pb6 " ,
[ DA850_EVM_UI_EXP_PB5 ] = " pb5 " ,
[ DA850_EVM_UI_EXP_PB4 ] = " pb4 " ,
[ DA850_EVM_UI_EXP_PB3 ] = " pb3 " ,
[ DA850_EVM_UI_EXP_PB2 ] = " pb2 " ,
[ DA850_EVM_UI_EXP_PB1 ] = " pb1 " ,
} ;
# define DA850_N_UI_PB 8
static struct gpio_keys_button da850_evm_ui_keys [ ] = {
[ 0 . . . DA850_N_UI_PB - 1 ] = {
. type = EV_KEY ,
. active_low = 1 ,
. wakeup = 0 ,
. debounce_interval = DA850_KEYS_DEBOUNCE_MS ,
. code = - 1 , /* assigned at runtime */
. gpio = - 1 , /* assigned at runtime */
. desc = NULL , /* assigned at runtime */
} ,
} ;
static struct gpio_keys_platform_data da850_evm_ui_keys_pdata = {
. buttons = da850_evm_ui_keys ,
. nbuttons = ARRAY_SIZE ( da850_evm_ui_keys ) ,
. poll_interval = DA850_GPIO_KEYS_POLL_MS ,
} ;
static struct platform_device da850_evm_ui_keys_device = {
. name = " gpio-keys-polled " ,
. id = 0 ,
. dev = {
. platform_data = & da850_evm_ui_keys_pdata
} ,
} ;
static void da850_evm_ui_keys_init ( unsigned gpio )
{
int i ;
struct gpio_keys_button * button ;
for ( i = 0 ; i < DA850_N_UI_PB ; i + + ) {
button = & da850_evm_ui_keys [ i ] ;
button - > code = KEY_F8 - i ;
2014-10-21 16:53:31 +02:00
button - > desc = da850_evm_ui_exp [ DA850_EVM_UI_EXP_PB8 + i ] ;
2010-12-09 16:51:04 -05:00
button - > gpio = gpio + DA850_EVM_UI_EXP_PB8 + i ;
}
}
2012-07-23 08:00:58 -03:00
# ifdef CONFIG_DA850_UI_SD_VIDEO_PORT
static inline void da850_evm_setup_video_port ( int video_sel )
{
gpio_set_value_cansleep ( video_sel , 0 ) ;
}
# else
static inline void da850_evm_setup_video_port ( int video_sel ) { }
# endif
2009-09-30 17:00:28 -04:00
static int da850_evm_ui_expander_setup ( struct i2c_client * client , unsigned gpio ,
unsigned ngpio , void * c )
{
int sel_a , sel_b , sel_c , ret ;
2010-12-09 16:51:05 -05:00
sel_a = gpio + DA850_EVM_UI_EXP_SEL_A ;
sel_b = gpio + DA850_EVM_UI_EXP_SEL_B ;
sel_c = gpio + DA850_EVM_UI_EXP_SEL_C ;
2009-09-30 17:00:28 -04:00
2010-12-09 16:51:05 -05:00
ret = gpio_request ( sel_a , da850_evm_ui_exp [ DA850_EVM_UI_EXP_SEL_A ] ) ;
2009-09-30 17:00:28 -04:00
if ( ret ) {
2013-01-10 16:23:19 -08:00
pr_warn ( " Cannot open UI expander pin %d \n " , sel_a ) ;
2009-09-30 17:00:28 -04:00
goto exp_setup_sela_fail ;
}
2010-12-09 16:51:05 -05:00
ret = gpio_request ( sel_b , da850_evm_ui_exp [ DA850_EVM_UI_EXP_SEL_B ] ) ;
2009-09-30 17:00:28 -04:00
if ( ret ) {
2013-01-10 16:23:19 -08:00
pr_warn ( " Cannot open UI expander pin %d \n " , sel_b ) ;
2009-09-30 17:00:28 -04:00
goto exp_setup_selb_fail ;
}
2010-12-09 16:51:05 -05:00
ret = gpio_request ( sel_c , da850_evm_ui_exp [ DA850_EVM_UI_EXP_SEL_C ] ) ;
2009-09-30 17:00:28 -04:00
if ( ret ) {
2013-01-10 16:23:19 -08:00
pr_warn ( " Cannot open UI expander pin %d \n " , sel_c ) ;
2009-09-30 17:00:28 -04:00
goto exp_setup_selc_fail ;
}
/* deselect all functionalities */
gpio_direction_output ( sel_a , 1 ) ;
gpio_direction_output ( sel_b , 1 ) ;
gpio_direction_output ( sel_c , 1 ) ;
2010-12-09 16:51:04 -05:00
da850_evm_ui_keys_init ( gpio ) ;
ret = platform_device_register ( & da850_evm_ui_keys_device ) ;
if ( ret ) {
2013-01-10 16:23:19 -08:00
pr_warn ( " Could not register UI GPIO expander push-buttons " ) ;
2010-12-09 16:51:04 -05:00
goto exp_setup_keys_fail ;
}
2009-09-30 17:00:28 -04:00
pr_info ( " DA850/OMAP-L138 EVM UI card detected \n " ) ;
da850_evm_setup_nor_nand ( ) ;
2009-10-21 21:18:22 +05:30
da850_evm_setup_emac_rmii ( sel_a ) ;
2009-09-30 17:00:53 -04:00
2012-07-23 08:00:58 -03:00
da850_evm_setup_video_port ( sel_c ) ;
2009-09-30 17:00:28 -04:00
return 0 ;
2010-12-09 16:51:04 -05:00
exp_setup_keys_fail :
gpio_free ( sel_c ) ;
2009-09-30 17:00:28 -04:00
exp_setup_selc_fail :
gpio_free ( sel_b ) ;
exp_setup_selb_fail :
gpio_free ( sel_a ) ;
exp_setup_sela_fail :
return ret ;
}
static int da850_evm_ui_expander_teardown ( struct i2c_client * client ,
unsigned gpio , unsigned ngpio , void * c )
{
2010-12-09 16:51:04 -05:00
platform_device_unregister ( & da850_evm_ui_keys_device ) ;
2009-09-30 17:00:28 -04:00
/* deselect all functionalities */
2010-12-09 16:51:05 -05:00
gpio_set_value_cansleep ( gpio + DA850_EVM_UI_EXP_SEL_C , 1 ) ;
gpio_set_value_cansleep ( gpio + DA850_EVM_UI_EXP_SEL_B , 1 ) ;
gpio_set_value_cansleep ( gpio + DA850_EVM_UI_EXP_SEL_A , 1 ) ;
2009-09-30 17:00:28 -04:00
2010-12-09 16:51:05 -05:00
gpio_free ( gpio + DA850_EVM_UI_EXP_SEL_C ) ;
gpio_free ( gpio + DA850_EVM_UI_EXP_SEL_B ) ;
gpio_free ( gpio + DA850_EVM_UI_EXP_SEL_A ) ;
2009-09-30 17:00:28 -04:00
return 0 ;
}
2010-12-09 16:51:06 -05:00
/* assign the baseboard expander's GPIOs after the UI board's */
# define DA850_UI_EXPANDER_N_GPIOS ARRAY_SIZE(da850_evm_ui_exp)
# define DA850_BB_EXPANDER_GPIO_BASE (DAVINCI_N_GPIO + DA850_UI_EXPANDER_N_GPIOS)
enum da850_evm_bb_exp_pins {
DA850_EVM_BB_EXP_DEEP_SLEEP_EN = 0 ,
DA850_EVM_BB_EXP_SW_RST ,
DA850_EVM_BB_EXP_TP_23 ,
DA850_EVM_BB_EXP_TP_22 ,
DA850_EVM_BB_EXP_TP_21 ,
DA850_EVM_BB_EXP_USER_PB1 ,
DA850_EVM_BB_EXP_USER_LED2 ,
DA850_EVM_BB_EXP_USER_LED1 ,
DA850_EVM_BB_EXP_USER_SW1 ,
DA850_EVM_BB_EXP_USER_SW2 ,
DA850_EVM_BB_EXP_USER_SW3 ,
DA850_EVM_BB_EXP_USER_SW4 ,
DA850_EVM_BB_EXP_USER_SW5 ,
DA850_EVM_BB_EXP_USER_SW6 ,
DA850_EVM_BB_EXP_USER_SW7 ,
DA850_EVM_BB_EXP_USER_SW8
} ;
2013-04-10 14:57:12 +05:30
static const char * const da850_evm_bb_exp [ ] = {
2010-12-09 16:51:06 -05:00
[ DA850_EVM_BB_EXP_DEEP_SLEEP_EN ] = " deep_sleep_en " ,
[ DA850_EVM_BB_EXP_SW_RST ] = " sw_rst " ,
[ DA850_EVM_BB_EXP_TP_23 ] = " tp_23 " ,
[ DA850_EVM_BB_EXP_TP_22 ] = " tp_22 " ,
[ DA850_EVM_BB_EXP_TP_21 ] = " tp_21 " ,
[ DA850_EVM_BB_EXP_USER_PB1 ] = " user_pb1 " ,
[ DA850_EVM_BB_EXP_USER_LED2 ] = " user_led2 " ,
[ DA850_EVM_BB_EXP_USER_LED1 ] = " user_led1 " ,
[ DA850_EVM_BB_EXP_USER_SW1 ] = " user_sw1 " ,
[ DA850_EVM_BB_EXP_USER_SW2 ] = " user_sw2 " ,
[ DA850_EVM_BB_EXP_USER_SW3 ] = " user_sw3 " ,
[ DA850_EVM_BB_EXP_USER_SW4 ] = " user_sw4 " ,
[ DA850_EVM_BB_EXP_USER_SW5 ] = " user_sw5 " ,
[ DA850_EVM_BB_EXP_USER_SW6 ] = " user_sw6 " ,
[ DA850_EVM_BB_EXP_USER_SW7 ] = " user_sw7 " ,
[ DA850_EVM_BB_EXP_USER_SW8 ] = " user_sw8 " ,
} ;
# define DA850_N_BB_USER_SW 8
static struct gpio_keys_button da850_evm_bb_keys [ ] = {
[ 0 ] = {
. type = EV_KEY ,
. active_low = 1 ,
. wakeup = 0 ,
. debounce_interval = DA850_KEYS_DEBOUNCE_MS ,
. code = KEY_PROG1 ,
. desc = NULL , /* assigned at runtime */
. gpio = - 1 , /* assigned at runtime */
} ,
[ 1 . . . DA850_N_BB_USER_SW ] = {
. type = EV_SW ,
. active_low = 1 ,
. wakeup = 0 ,
. debounce_interval = DA850_KEYS_DEBOUNCE_MS ,
. code = - 1 , /* assigned at runtime */
. desc = NULL , /* assigned at runtime */
. gpio = - 1 , /* assigned at runtime */
} ,
} ;
static struct gpio_keys_platform_data da850_evm_bb_keys_pdata = {
. buttons = da850_evm_bb_keys ,
. nbuttons = ARRAY_SIZE ( da850_evm_bb_keys ) ,
. poll_interval = DA850_GPIO_KEYS_POLL_MS ,
} ;
static struct platform_device da850_evm_bb_keys_device = {
. name = " gpio-keys-polled " ,
. id = 1 ,
. dev = {
. platform_data = & da850_evm_bb_keys_pdata
} ,
} ;
static void da850_evm_bb_keys_init ( unsigned gpio )
{
int i ;
struct gpio_keys_button * button ;
button = & da850_evm_bb_keys [ 0 ] ;
2014-10-21 16:53:31 +02:00
button - > desc = da850_evm_bb_exp [ DA850_EVM_BB_EXP_USER_PB1 ] ;
2010-12-09 16:51:06 -05:00
button - > gpio = gpio + DA850_EVM_BB_EXP_USER_PB1 ;
for ( i = 0 ; i < DA850_N_BB_USER_SW ; i + + ) {
button = & da850_evm_bb_keys [ i + 1 ] ;
button - > code = SW_LID + i ;
2014-10-21 16:53:31 +02:00
button - > desc = da850_evm_bb_exp [ DA850_EVM_BB_EXP_USER_SW1 + i ] ;
2010-12-09 16:51:06 -05:00
button - > gpio = gpio + DA850_EVM_BB_EXP_USER_SW1 + i ;
}
}
static struct gpio_led da850_evm_bb_leds [ ] = {
2019-06-01 00:43:33 +02:00
{
. name = " user_led2 " ,
} ,
{
. name = " user_led1 " ,
2010-12-09 16:51:06 -05:00
} ,
} ;
static struct gpio_led_platform_data da850_evm_bb_leds_pdata = {
. leds = da850_evm_bb_leds ,
. num_leds = ARRAY_SIZE ( da850_evm_bb_leds ) ,
} ;
2019-06-01 00:43:33 +02:00
static struct gpiod_lookup_table da850_evm_bb_leds_gpio_table = {
. dev_id = " leds-gpio " ,
. table = {
GPIO_LOOKUP_IDX ( " i2c-bb-expander " ,
DA850_EVM_BB_EXP_USER_LED2 , NULL ,
0 , GPIO_ACTIVE_LOW ) ,
GPIO_LOOKUP_IDX ( " i2c-bb-expander " ,
DA850_EVM_BB_EXP_USER_LED2 + 1 , NULL ,
1 , GPIO_ACTIVE_LOW ) ,
{ } ,
} ,
} ;
2010-12-09 16:51:06 -05:00
static struct platform_device da850_evm_bb_leds_device = {
. name = " leds-gpio " ,
. id = - 1 ,
. dev = {
. platform_data = & da850_evm_bb_leds_pdata
}
} ;
static int da850_evm_bb_expander_setup ( struct i2c_client * client ,
unsigned gpio , unsigned ngpio ,
void * c )
{
int ret ;
/*
* Register the switches and pushbutton on the baseboard as a gpio - keys
* device .
*/
da850_evm_bb_keys_init ( gpio ) ;
ret = platform_device_register ( & da850_evm_bb_keys_device ) ;
if ( ret ) {
2013-01-10 16:23:19 -08:00
pr_warn ( " Could not register baseboard GPIO expander keys " ) ;
2010-12-09 16:51:06 -05:00
goto io_exp_setup_sw_fail ;
}
2019-06-01 00:43:33 +02:00
gpiod_add_lookup_table ( & da850_evm_bb_leds_gpio_table ) ;
2010-12-09 16:51:06 -05:00
ret = platform_device_register ( & da850_evm_bb_leds_device ) ;
if ( ret ) {
2013-01-10 16:23:19 -08:00
pr_warn ( " Could not register baseboard GPIO expander LEDs " ) ;
2010-12-09 16:51:06 -05:00
goto io_exp_setup_leds_fail ;
}
return 0 ;
io_exp_setup_leds_fail :
platform_device_unregister ( & da850_evm_bb_keys_device ) ;
io_exp_setup_sw_fail :
return ret ;
}
static int da850_evm_bb_expander_teardown ( struct i2c_client * client ,
unsigned gpio , unsigned ngpio , void * c )
{
platform_device_unregister ( & da850_evm_bb_leds_device ) ;
platform_device_unregister ( & da850_evm_bb_keys_device ) ;
return 0 ;
}
2009-09-30 17:00:28 -04:00
static struct pca953x_platform_data da850_evm_ui_expander_info = {
. gpio_base = DAVINCI_N_GPIO ,
. setup = da850_evm_ui_expander_setup ,
. teardown = da850_evm_ui_expander_teardown ,
2010-12-09 16:51:04 -05:00
. names = da850_evm_ui_exp ,
2009-09-30 17:00:28 -04:00
} ;
2010-12-09 16:51:06 -05:00
static struct pca953x_platform_data da850_evm_bb_expander_info = {
. gpio_base = DA850_BB_EXPANDER_GPIO_BASE ,
. setup = da850_evm_bb_expander_setup ,
. teardown = da850_evm_bb_expander_teardown ,
. names = da850_evm_bb_exp ,
} ;
2009-08-25 15:20:05 +03:00
static struct i2c_board_info __initdata da850_evm_i2c_devices [ ] = {
{
I2C_BOARD_INFO ( " tlv320aic3x " , 0x18 ) ,
2009-09-30 17:00:28 -04:00
} ,
{
I2C_BOARD_INFO ( " tca6416 " , 0x20 ) ,
2019-06-01 00:43:33 +02:00
. dev_name = " ui-expander " ,
2009-09-30 17:00:28 -04:00
. platform_data = & da850_evm_ui_expander_info ,
} ,
2010-12-09 16:51:06 -05:00
{
I2C_BOARD_INFO ( " tca6416 " , 0x21 ) ,
2019-06-01 00:43:33 +02:00
. dev_name = " bb-expander " ,
2010-12-09 16:51:06 -05:00
. platform_data = & da850_evm_bb_expander_info ,
} ,
2009-08-25 15:20:05 +03:00
} ;
2009-07-16 06:42:18 -04:00
static struct davinci_i2c_platform_data da850_evm_i2c_0_pdata = {
. bus_freq = 100 , /* kHz */
. bus_delay = 0 , /* usec */
} ;
2009-08-11 17:03:25 -04:00
/* davinci da850 evm audio machine driver */
static u8 da850_iis_serializer_direction [ ] = {
INACTIVE_MODE , INACTIVE_MODE , INACTIVE_MODE , INACTIVE_MODE ,
INACTIVE_MODE , INACTIVE_MODE , INACTIVE_MODE , INACTIVE_MODE ,
INACTIVE_MODE , INACTIVE_MODE , INACTIVE_MODE , TX_MODE ,
RX_MODE , INACTIVE_MODE , INACTIVE_MODE , INACTIVE_MODE ,
} ;
static struct snd_platform_data da850_evm_snd_data = {
2012-10-17 16:08:04 +02:00
. tx_dma_offset = 0x2000 ,
. rx_dma_offset = 0x2000 ,
. op_mode = DAVINCI_MCASP_IIS_MODE ,
. num_serializer = ARRAY_SIZE ( da850_iis_serializer_direction ) ,
. tdm_slots = 2 ,
. serial_dir = da850_iis_serializer_direction ,
. asp_chan_q = EVENTQ_0 ,
. ram_chan_q = EVENTQ_1 ,
. version = MCASP_VERSION_2 ,
. txnumevt = 1 ,
. rxnumevt = 1 ,
. sram_size_playback = SZ_8K ,
. sram_size_capture = SZ_8K ,
2009-08-11 17:03:25 -04:00
} ;
2011-01-18 12:21:44 -05:00
static const short da850_evm_mcasp_pins [ ] __initconst = {
DA850_AHCLKX , DA850_ACLKX , DA850_AFSX ,
DA850_AHCLKR , DA850_ACLKR , DA850_AFSR , DA850_AMUTE ,
DA850_AXR_11 , DA850_AXR_12 ,
- 1
} ;
2018-04-24 20:05:04 +05:30
# define DA850_MMCSD_CD_PIN GPIO_TO_PIN(4, 0)
# define DA850_MMCSD_WP_PIN GPIO_TO_PIN(4, 1)
2016-11-24 16:04:53 +01:00
static struct gpiod_lookup_table mmc_gpios_table = {
. dev_id = " da830-mmc.0 " ,
. table = {
/* gpio chip 2 contains gpio range 64-95 */
2019-01-03 16:11:01 +01:00
GPIO_LOOKUP ( " davinci_gpio " , DA850_MMCSD_CD_PIN , " cd " ,
2018-04-24 20:05:04 +05:30
GPIO_ACTIVE_LOW ) ,
2019-01-03 16:11:01 +01:00
GPIO_LOOKUP ( " davinci_gpio " , DA850_MMCSD_WP_PIN , " wp " ,
2018-05-17 20:20:52 -05:00
GPIO_ACTIVE_HIGH ) ,
2019-04-12 14:36:35 +02:00
{ }
2016-11-24 16:04:53 +01:00
} ,
} ;
2009-08-13 15:16:23 -04:00
static struct davinci_mmc_config da850_mmc_config = {
. wires = 4 ,
2009-11-03 15:46:14 +05:30
. max_freq = 50000000 ,
. caps = MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED ,
2009-08-13 15:16:23 -04:00
} ;
2011-01-18 12:21:45 -05:00
static const short da850_evm_mmcsd0_pins [ ] __initconst = {
DA850_MMCSD0_DAT_0 , DA850_MMCSD0_DAT_1 , DA850_MMCSD0_DAT_2 ,
DA850_MMCSD0_DAT_3 , DA850_MMCSD0_CLK , DA850_MMCSD0_CMD ,
DA850_GPIO4_0 , DA850_GPIO4_1 ,
- 1
} ;
2019-07-22 15:44:17 +02:00
static struct property_entry da850_lcd_backlight_props [ ] = {
PROPERTY_ENTRY_BOOL ( " default-on " ) ,
{ }
} ;
static struct gpiod_lookup_table da850_lcd_backlight_gpio_table = {
. dev_id = " gpio-backlight " ,
. table = {
GPIO_LOOKUP ( " davinci_gpio " , DA850_LCD_BL_PIN , NULL , 0 ) ,
{ }
} ,
} ;
static const struct platform_device_info da850_lcd_backlight_info = {
. name = " gpio-backlight " ,
. id = PLATFORM_DEVID_NONE ,
. properties = da850_lcd_backlight_props ,
} ;
2019-07-22 15:44:19 +02:00
static struct regulator_consumer_supply da850_lcd_supplies [ ] = {
REGULATOR_SUPPLY ( " lcd " , NULL ) ,
} ;
static struct regulator_init_data da850_lcd_supply_data = {
. consumer_supplies = da850_lcd_supplies ,
. num_consumer_supplies = ARRAY_SIZE ( da850_lcd_supplies ) ,
. constraints = {
. valid_ops_mask = REGULATOR_CHANGE_STATUS ,
} ,
} ;
static struct fixed_voltage_config da850_lcd_supply = {
. supply_name = " lcd " ,
. microvolts = 33000000 ,
. init_data = & da850_lcd_supply_data ,
} ;
static struct platform_device da850_lcd_supply_device = {
. name = " reg-fixed-voltage " ,
. id = 1 , /* Dummy fixed regulator is 0 */
. dev = {
. platform_data = & da850_lcd_supply ,
} ,
} ;
static struct gpiod_lookup_table da850_lcd_supply_gpio_table = {
. dev_id = " reg-fixed-voltage.1 " ,
. table = {
GPIO_LOOKUP ( " davinci_gpio " , DA850_LCD_PWR_PIN , NULL , 0 ) ,
{ }
} ,
} ;
static struct gpiod_lookup_table * da850_lcd_gpio_lookups [ ] = {
& da850_lcd_backlight_gpio_table ,
& da850_lcd_supply_gpio_table ,
} ;
2009-08-13 14:33:14 -04:00
static int da850_lcd_hw_init ( void )
{
2019-07-22 15:44:17 +02:00
struct platform_device * backlight ;
2009-08-13 14:33:14 -04:00
int status ;
2019-07-22 15:44:19 +02:00
gpiod_add_lookup_tables ( da850_lcd_gpio_lookups ,
ARRAY_SIZE ( da850_lcd_gpio_lookups ) ) ;
2019-07-22 15:44:17 +02:00
backlight = platform_device_register_full ( & da850_lcd_backlight_info ) ;
if ( IS_ERR ( backlight ) )
return PTR_ERR ( backlight ) ;
2009-08-13 14:33:14 -04:00
2019-07-22 15:44:19 +02:00
status = platform_device_register ( & da850_lcd_supply_device ) ;
if ( status )
2009-08-13 14:33:14 -04:00
return status ;
return 0 ;
}
2009-08-11 17:03:25 -04:00
2014-07-28 14:24:38 +03:00
/* Fixed regulator support */
static struct regulator_consumer_supply fixed_supplies [ ] = {
/* Baseboard 3.3V: 5V -> TPS73701DCQ -> 3.3V */
REGULATOR_SUPPLY ( " AVDD " , " 1-0018 " ) ,
REGULATOR_SUPPLY ( " DRVDD " , " 1-0018 " ) ,
/* Baseboard 1.8V: 5V -> TPS73701DCQ -> 1.8V */
REGULATOR_SUPPLY ( " DVDD " , " 1-0018 " ) ,
2017-02-28 17:01:59 +01:00
/* UI card 3.3V: 5V -> TPS73701DCQ -> 3.3V */
REGULATOR_SUPPLY ( " vcc " , " 1-0020 " ) ,
2014-07-28 14:24:38 +03:00
} ;
2009-09-22 21:14:04 +05:30
/* TPS65070 voltage regulator support */
/* 3.3V */
2010-06-28 17:16:38 +05:30
static struct regulator_consumer_supply tps65070_dcdc1_consumers [ ] = {
2009-09-22 21:14:04 +05:30
{
. supply = " usb0_vdda33 " ,
} ,
{
. supply = " usb1_vdda33 " ,
} ,
} ;
/* 3.3V or 1.8V */
2010-06-28 17:16:38 +05:30
static struct regulator_consumer_supply tps65070_dcdc2_consumers [ ] = {
2009-09-22 21:14:04 +05:30
{
. supply = " dvdd3318_a " ,
} ,
{
. supply = " dvdd3318_b " ,
} ,
{
. supply = " dvdd3318_c " ,
} ,
2014-07-28 14:24:38 +03:00
REGULATOR_SUPPLY ( " IOVDD " , " 1-0018 " ) ,
2009-09-22 21:14:04 +05:30
} ;
/* 1.2V */
2010-06-28 17:16:38 +05:30
static struct regulator_consumer_supply tps65070_dcdc3_consumers [ ] = {
2009-09-22 21:14:04 +05:30
{
. supply = " cvdd " ,
} ,
} ;
/* 1.8V LDO */
2010-06-28 17:16:38 +05:30
static struct regulator_consumer_supply tps65070_ldo1_consumers [ ] = {
2009-09-22 21:14:04 +05:30
{
. supply = " sata_vddr " ,
} ,
{
. supply = " usb0_vdda18 " ,
} ,
{
. supply = " usb1_vdda18 " ,
} ,
{
. supply = " ddr_dvdd18 " ,
} ,
} ;
/* 1.2V LDO */
2010-06-28 17:16:38 +05:30
static struct regulator_consumer_supply tps65070_ldo2_consumers [ ] = {
2009-09-22 21:14:04 +05:30
{
. supply = " sata_vdd " ,
} ,
{
. supply = " pll0_vdda " ,
} ,
{
. supply = " pll1_vdda " ,
} ,
{
. supply = " usbs_cvdd " ,
} ,
{
. supply = " vddarnwa1 " ,
} ,
} ;
2010-07-12 17:56:21 +05:30
/* We take advantage of the fact that both defdcdc{2,3} are tied high */
static struct tps6507x_reg_platform_data tps6507x_platform_data = {
. defdcdc_default = true ,
} ;
2010-06-28 17:16:38 +05:30
static struct regulator_init_data tps65070_regulator_data [ ] = {
2009-09-22 21:14:04 +05:30
/* dcdc1 */
{
. constraints = {
. min_uV = 3150000 ,
. max_uV = 3450000 ,
. valid_ops_mask = ( REGULATOR_CHANGE_VOLTAGE |
REGULATOR_CHANGE_STATUS ) ,
. boot_on = 1 ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( tps65070_dcdc1_consumers ) ,
. consumer_supplies = tps65070_dcdc1_consumers ,
} ,
/* dcdc2 */
{
. constraints = {
. min_uV = 1710000 ,
. max_uV = 3450000 ,
. valid_ops_mask = ( REGULATOR_CHANGE_VOLTAGE |
REGULATOR_CHANGE_STATUS ) ,
. boot_on = 1 ,
2014-07-28 14:24:37 +03:00
. always_on = 1 ,
2009-09-22 21:14:04 +05:30
} ,
. num_consumer_supplies = ARRAY_SIZE ( tps65070_dcdc2_consumers ) ,
. consumer_supplies = tps65070_dcdc2_consumers ,
2010-07-12 17:56:21 +05:30
. driver_data = & tps6507x_platform_data ,
2009-09-22 21:14:04 +05:30
} ,
/* dcdc3 */
{
. constraints = {
. min_uV = 950000 ,
2010-12-20 21:31:34 +05:30
. max_uV = 1350000 ,
2009-09-22 21:14:04 +05:30
. valid_ops_mask = ( REGULATOR_CHANGE_VOLTAGE |
REGULATOR_CHANGE_STATUS ) ,
. boot_on = 1 ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( tps65070_dcdc3_consumers ) ,
. consumer_supplies = tps65070_dcdc3_consumers ,
2010-07-12 17:56:21 +05:30
. driver_data = & tps6507x_platform_data ,
2009-09-22 21:14:04 +05:30
} ,
/* ldo1 */
{
. constraints = {
. min_uV = 1710000 ,
. max_uV = 1890000 ,
. valid_ops_mask = ( REGULATOR_CHANGE_VOLTAGE |
REGULATOR_CHANGE_STATUS ) ,
. boot_on = 1 ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( tps65070_ldo1_consumers ) ,
. consumer_supplies = tps65070_ldo1_consumers ,
} ,
/* ldo2 */
{
. constraints = {
. min_uV = 1140000 ,
. max_uV = 1320000 ,
. valid_ops_mask = ( REGULATOR_CHANGE_VOLTAGE |
REGULATOR_CHANGE_STATUS ) ,
. boot_on = 1 ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( tps65070_ldo2_consumers ) ,
. consumer_supplies = tps65070_ldo2_consumers ,
} ,
} ;
2010-04-05 17:53:13 -06:00
static struct touchscreen_init_data tps6507x_touchscreen_data = {
. poll_period = 30 , /* ms between touch samples */
. min_pressure = 0x30 , /* minimum pressure to trigger touch */
. vendor = 0 , /* /sys/class/input/input?/id/vendor */
. product = 65070 , /* /sys/class/input/input?/id/product */
. version = 0x100 , /* /sys/class/input/input?/id/version */
} ;
2010-04-05 20:23:57 -06:00
static struct tps6507x_board tps_board = {
. tps6507x_pmic_init_data = & tps65070_regulator_data [ 0 ] ,
2010-04-05 17:53:13 -06:00
. tps6507x_ts_init_data = & tps6507x_touchscreen_data ,
2010-04-05 20:23:57 -06:00
} ;
2010-11-19 16:43:04 -05:00
static struct i2c_board_info __initdata da850_evm_tps65070_info [ ] = {
2009-09-22 21:14:04 +05:30
{
I2C_BOARD_INFO ( " tps6507x " , 0x48 ) ,
2010-04-05 20:23:57 -06:00
. platform_data = & tps_board ,
2009-09-22 21:14:04 +05:30
} ,
} ;
static int __init pmic_tps65070_init ( void )
{
2010-11-19 16:43:04 -05:00
return i2c_register_board_info ( 1 , da850_evm_tps65070_info ,
ARRAY_SIZE ( da850_evm_tps65070_info ) ) ;
2009-09-22 21:14:04 +05:30
}
2009-09-15 17:46:14 -04:00
static const short da850_evm_lcdc_pins [ ] = {
DA850_GPIO2_8 , DA850_GPIO2_15 ,
- 1
} ;
2010-08-01 21:17:00 +04:00
static const short da850_evm_mii_pins [ ] = {
DA850_MII_TXEN , DA850_MII_TXCLK , DA850_MII_COL , DA850_MII_TXD_3 ,
DA850_MII_TXD_2 , DA850_MII_TXD_1 , DA850_MII_TXD_0 , DA850_MII_RXER ,
DA850_MII_CRS , DA850_MII_RXCLK , DA850_MII_RXDV , DA850_MII_RXD_3 ,
DA850_MII_RXD_2 , DA850_MII_RXD_1 , DA850_MII_RXD_0 , DA850_MDIO_CLK ,
DA850_MDIO_D ,
- 1
} ;
static const short da850_evm_rmii_pins [ ] = {
DA850_RMII_TXD_0 , DA850_RMII_TXD_1 , DA850_RMII_TXEN ,
DA850_RMII_CRS_DV , DA850_RMII_RXD_0 , DA850_RMII_RXD_1 ,
DA850_RMII_RXER , DA850_RMII_MHZ_50_CLK , DA850_MDIO_CLK ,
DA850_MDIO_D ,
- 1
} ;
2019-02-05 10:49:37 +01:00
static struct gpiod_hog da850_evm_emac_gpio_hogs [ ] = {
{
. chip_label = " davinci_gpio " ,
. chip_hwnum = DA850_MII_MDIO_CLKEN_PIN ,
. line_name = " mdio_clk_en " ,
. lflags = 0 ,
/* dflags set in da850_evm_config_emac() */
} ,
{ }
} ;
2009-10-21 21:18:22 +05:30
static int __init da850_evm_config_emac ( void )
2009-09-30 17:00:53 -04:00
{
void __iomem * cfg_chip3_base ;
int ret ;
u32 val ;
2009-10-21 21:18:22 +05:30
struct davinci_soc_info * soc_info = & davinci_soc_info ;
u8 rmii_en = soc_info - > emac_pdata - > rmii_en ;
if ( ! machine_is_davinci_da850_evm ( ) )
return 0 ;
2009-09-30 17:00:53 -04:00
2009-11-16 17:21:32 +05:30
cfg_chip3_base = DA8XX_SYSCFG0_VIRT ( DA8XX_CFGCHIP3_REG ) ;
2009-09-30 17:00:53 -04:00
val = __raw_readl ( cfg_chip3_base ) ;
2009-10-21 21:18:24 +05:30
if ( rmii_en ) {
2009-09-30 17:00:53 -04:00
val | = BIT ( 8 ) ;
2010-08-01 21:17:00 +04:00
ret = davinci_cfg_reg_list ( da850_evm_rmii_pins ) ;
2009-10-21 21:18:24 +05:30
pr_info ( " EMAC: RMII PHY configured, MII PHY will not be "
" functional \n " ) ;
} else {
2009-09-30 17:00:53 -04:00
val & = ~ BIT ( 8 ) ;
2010-08-01 21:17:00 +04:00
ret = davinci_cfg_reg_list ( da850_evm_mii_pins ) ;
2009-10-21 21:18:24 +05:30
pr_info ( " EMAC: MII PHY configured, RMII PHY will not be "
" functional \n " ) ;
}
2009-09-30 17:00:53 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: CPGMAC/RMII mux setup failed: %d \n " ,
__func__ , ret ) ;
2009-09-30 17:00:53 -04:00
2009-10-21 21:18:24 +05:30
/* configure the CFGCHIP3 register for RMII or MII */
__raw_writel ( val , cfg_chip3_base ) ;
2009-09-30 17:00:53 -04:00
ret = davinci_cfg_reg ( DA850_GPIO2_6 ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s:GPIO(2,6) mux setup failed \n " , __func__ ) ;
2009-09-30 17:00:53 -04:00
2019-02-05 10:49:37 +01:00
da850_evm_emac_gpio_hogs [ 0 ] . dflags = rmii_en ? GPIOD_OUT_HIGH
: GPIOD_OUT_LOW ;
gpiod_add_hogs ( da850_evm_emac_gpio_hogs ) ;
2009-09-30 17:00:53 -04:00
2010-09-15 10:11:25 -04:00
soc_info - > emac_pdata - > phy_id = DA850_EVM_PHY_ID ;
2009-10-21 21:18:22 +05:30
ret = da8xx_register_emac ( ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: EMAC registration failed: %d \n " , __func__ , ret ) ;
2009-10-21 21:18:22 +05:30
2009-09-30 17:00:53 -04:00
return 0 ;
}
2009-10-21 21:18:22 +05:30
device_initcall ( da850_evm_config_emac ) ;
2009-09-30 17:00:53 -04:00
2010-06-29 11:35:14 +05:30
/*
* The following EDMA channels / slots are not being used by drivers ( for
* example : Timer , GPIO , UART events etc ) on da850 / omap - l138 EVM , hence
* they are being reserved for codecs on the DSP side .
*/
static const s16 da850_dma0_rsv_chans [ ] [ 2 ] = {
/* (offset, number) */
{ 8 , 6 } ,
{ 24 , 4 } ,
{ 30 , 2 } ,
{ - 1 , - 1 }
} ;
static const s16 da850_dma0_rsv_slots [ ] [ 2 ] = {
/* (offset, number) */
{ 8 , 6 } ,
{ 24 , 4 } ,
{ 30 , 50 } ,
{ - 1 , - 1 }
} ;
static const s16 da850_dma1_rsv_chans [ ] [ 2 ] = {
/* (offset, number) */
{ 0 , 28 } ,
{ 30 , 2 } ,
{ - 1 , - 1 }
} ;
static const s16 da850_dma1_rsv_slots [ ] [ 2 ] = {
/* (offset, number) */
{ 0 , 28 } ,
{ 30 , 90 } ,
{ - 1 , - 1 }
} ;
static struct edma_rsv_info da850_edma_cc0_rsv = {
. rsv_chans = da850_dma0_rsv_chans ,
. rsv_slots = da850_dma0_rsv_slots ,
} ;
static struct edma_rsv_info da850_edma_cc1_rsv = {
. rsv_chans = da850_dma1_rsv_chans ,
. rsv_slots = da850_dma1_rsv_slots ,
} ;
static struct edma_rsv_info * da850_edma_rsv [ 2 ] = {
& da850_edma_cc0_rsv ,
& da850_edma_cc1_rsv ,
} ;
2010-12-20 21:31:34 +05:30
# ifdef CONFIG_CPU_FREQ
static __init int da850_evm_init_cpufreq ( void )
{
switch ( system_rev & 0xF ) {
case 3 :
da850_max_speed = 456000 ;
break ;
case 2 :
da850_max_speed = 408000 ;
break ;
case 1 :
da850_max_speed = 372000 ;
break ;
}
return da850_register_cpufreq ( " pll0_sysclk3 " ) ;
}
# else
static __init int da850_evm_init_cpufreq ( void ) { return 0 ; }
# endif
2012-07-23 08:00:58 -03:00
# if defined(CONFIG_DA850_UI_SD_VIDEO_PORT)
# define TVP5147_CH0 "tvp514x-0"
# define TVP5147_CH1 "tvp514x-1"
/* VPIF capture configuration */
static struct tvp514x_platform_data tvp5146_pdata = {
. clk_polarity = 0 ,
. hs_polarity = 1 ,
. vs_polarity = 1 ,
} ;
# define TVP514X_STD_ALL (V4L2_STD_NTSC | V4L2_STD_PAL)
2017-06-09 10:00:17 +02:00
static struct vpif_input da850_ch0_inputs [ ] = {
2012-07-23 08:00:58 -03:00
{
. input = {
. index = 0 ,
. name = " Composite " ,
. type = V4L2_INPUT_TYPE_CAMERA ,
2012-09-20 09:06:25 -03:00
. capabilities = V4L2_IN_CAP_STD ,
2012-07-23 08:00:58 -03:00
. std = TVP514X_STD_ALL ,
} ,
2012-09-20 09:06:25 -03:00
. input_route = INPUT_CVBS_VI2B ,
. output_route = OUTPUT_10BIT_422_EMBEDDED_SYNC ,
2012-07-23 08:00:58 -03:00
. subdev_name = TVP5147_CH0 ,
} ,
} ;
2017-06-09 10:00:17 +02:00
static struct vpif_input da850_ch1_inputs [ ] = {
2012-07-23 08:00:58 -03:00
{
. input = {
. index = 0 ,
. name = " S-Video " ,
. type = V4L2_INPUT_TYPE_CAMERA ,
2012-09-20 09:06:25 -03:00
. capabilities = V4L2_IN_CAP_STD ,
2012-07-23 08:00:58 -03:00
. std = TVP514X_STD_ALL ,
} ,
2012-09-20 09:06:25 -03:00
. input_route = INPUT_SVIDEO_VI2C_VI1C ,
. output_route = OUTPUT_10BIT_422_EMBEDDED_SYNC ,
2012-07-23 08:00:58 -03:00
. subdev_name = TVP5147_CH1 ,
} ,
} ;
static struct vpif_subdev_info da850_vpif_capture_sdev_info [ ] = {
{
. name = TVP5147_CH0 ,
. board_info = {
I2C_BOARD_INFO ( " tvp5146 " , 0x5d ) ,
. platform_data = & tvp5146_pdata ,
} ,
} ,
{
. name = TVP5147_CH1 ,
. board_info = {
I2C_BOARD_INFO ( " tvp5146 " , 0x5c ) ,
. platform_data = & tvp5146_pdata ,
} ,
} ,
} ;
static struct vpif_capture_config da850_vpif_capture_config = {
. subdev_info = da850_vpif_capture_sdev_info ,
. subdev_count = ARRAY_SIZE ( da850_vpif_capture_sdev_info ) ,
2017-02-28 17:01:56 +01:00
. i2c_adapter_id = 1 ,
2012-07-23 08:00:58 -03:00
. chan_config [ 0 ] = {
. inputs = da850_ch0_inputs ,
. input_count = ARRAY_SIZE ( da850_ch0_inputs ) ,
2012-09-20 09:06:32 -03:00
. vpif_if = {
. if_type = VPIF_IF_BT656 ,
. hd_pol = 1 ,
. vd_pol = 1 ,
. fid_pol = 0 ,
} ,
2012-07-23 08:00:58 -03:00
} ,
. chan_config [ 1 ] = {
. inputs = da850_ch1_inputs ,
. input_count = ARRAY_SIZE ( da850_ch1_inputs ) ,
2012-09-20 09:06:32 -03:00
. vpif_if = {
. if_type = VPIF_IF_BT656 ,
. hd_pol = 1 ,
. vd_pol = 1 ,
. fid_pol = 0 ,
} ,
2012-07-23 08:00:58 -03:00
} ,
. card_name = " DA850/OMAP-L138 Video Capture " ,
} ;
/* VPIF display configuration */
2013-01-15 05:04:41 -03:00
static struct adv7343_platform_data adv7343_pdata = {
. mode_config = {
2013-07-20 02:21:05 -03:00
. dac = { 1 , 1 , 1 } ,
2013-01-15 05:04:41 -03:00
} ,
. sd_config = {
2013-07-20 02:21:05 -03:00
. sd_dac_out = { 1 } ,
2013-01-15 05:04:41 -03:00
} ,
} ;
2012-07-23 08:00:58 -03:00
static struct vpif_subdev_info da850_vpif_subdev [ ] = {
{
. name = " adv7343 " ,
. board_info = {
I2C_BOARD_INFO ( " adv7343 " , 0x2a ) ,
2013-01-15 05:04:41 -03:00
. platform_data = & adv7343_pdata ,
2012-07-23 08:00:58 -03:00
} ,
} ,
} ;
2012-09-25 08:11:49 -03:00
static const struct vpif_output da850_ch0_outputs [ ] = {
{
. output = {
. index = 0 ,
. name = " Composite " ,
. type = V4L2_OUTPUT_TYPE_ANALOG ,
. capabilities = V4L2_OUT_CAP_STD ,
. std = V4L2_STD_ALL ,
} ,
. subdev_name = " adv7343 " ,
. output_route = ADV7343_COMPOSITE_ID ,
} ,
{
. output = {
. index = 1 ,
. name = " S-Video " ,
. type = V4L2_OUTPUT_TYPE_ANALOG ,
. capabilities = V4L2_OUT_CAP_STD ,
. std = V4L2_STD_ALL ,
} ,
. subdev_name = " adv7343 " ,
. output_route = ADV7343_SVIDEO_ID ,
} ,
2012-07-23 08:00:58 -03:00
} ;
static struct vpif_display_config da850_vpif_display_config = {
. subdevinfo = da850_vpif_subdev ,
. subdev_count = ARRAY_SIZE ( da850_vpif_subdev ) ,
2012-09-25 08:11:49 -03:00
. chan_config [ 0 ] = {
. outputs = da850_ch0_outputs ,
. output_count = ARRAY_SIZE ( da850_ch0_outputs ) ,
} ,
2012-07-23 08:00:58 -03:00
. card_name = " DA850/OMAP-L138 Video Display " ,
2017-02-16 16:08:01 -02:00
. i2c_adapter_id = 1 ,
2012-07-23 08:00:58 -03:00
} ;
static __init void da850_vpif_init ( void )
{
int ret ;
ret = da850_register_vpif ( ) ;
if ( ret )
pr_warn ( " da850_evm_init: VPIF setup failed: %d \n " , ret ) ;
ret = davinci_cfg_reg_list ( da850_vpif_capture_pins ) ;
if ( ret )
pr_warn ( " da850_evm_init: VPIF capture mux setup failed: %d \n " ,
ret ) ;
ret = da850_register_vpif_capture ( & da850_vpif_capture_config ) ;
if ( ret )
pr_warn ( " da850_evm_init: VPIF capture setup failed: %d \n " , ret ) ;
ret = davinci_cfg_reg_list ( da850_vpif_display_pins ) ;
if ( ret )
pr_warn ( " da850_evm_init: VPIF display mux setup failed: %d \n " ,
ret ) ;
ret = da850_register_vpif_display ( & da850_vpif_display_config ) ;
if ( ret )
pr_warn ( " da850_evm_init: VPIF display setup failed: %d \n " , ret ) ;
}
# else
static __init void da850_vpif_init ( void ) { }
# endif
2011-07-06 06:01:24 +00:00
# define DA850EVM_SATA_REFCLKPN_RATE (100 * 1000 * 1000)
2009-07-16 06:42:18 -04:00
static __init void da850_evm_init ( void )
{
int ret ;
2018-05-18 11:48:08 -05:00
da850_register_clocks ( ) ;
2013-08-18 10:49:01 +05:30
ret = da850_register_gpio ( ) ;
if ( ret )
pr_warn ( " %s: GPIO init failed: %d \n " , __func__ , ret ) ;
2014-07-28 14:24:38 +03:00
regulator_register_fixed ( 0 , fixed_supplies , ARRAY_SIZE ( fixed_supplies ) ) ;
2009-09-22 21:14:04 +05:30
ret = pmic_tps65070_init ( ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: TPS65070 PMIC init failed: %d \n " , __func__ , ret ) ;
2009-09-22 21:14:04 +05:30
2010-06-29 11:35:14 +05:30
ret = da850_register_edma ( da850_edma_rsv ) ;
2009-07-16 06:42:18 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: EDMA registration failed: %d \n " , __func__ , ret ) ;
2009-07-16 06:42:18 -04:00
2010-03-25 17:43:48 -04:00
ret = davinci_cfg_reg_list ( da850_i2c0_pins ) ;
2009-07-16 06:42:18 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: I2C0 mux setup failed: %d \n " , __func__ , ret ) ;
2009-07-16 06:42:18 -04:00
ret = da8xx_register_i2c ( 0 , & da850_evm_i2c_0_pdata ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: I2C0 registration failed: %d \n " , __func__ , ret ) ;
2009-07-16 06:42:18 -04:00
2009-07-17 04:47:10 -04:00
2009-07-16 06:42:18 -04:00
ret = da8xx_register_watchdog ( ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: watchdog registration failed: %d \n " ,
__func__ , ret ) ;
2009-07-16 06:42:18 -04:00
2009-08-13 18:16:28 -04:00
if ( HAS_MMC ) {
2011-01-18 12:21:45 -05:00
ret = davinci_cfg_reg_list ( da850_evm_mmcsd0_pins ) ;
2009-08-13 18:16:28 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: MMCSD0 mux setup failed: %d \n " ,
__func__ , ret ) ;
2009-08-13 18:16:28 -04:00
2016-11-24 16:04:53 +01:00
gpiod_add_lookup_table ( & mmc_gpios_table ) ;
2009-08-13 18:16:28 -04:00
ret = da8xx_register_mmcsd0 ( & da850_mmc_config ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: MMCSD0 registration failed: %d \n " ,
__func__ , ret ) ;
2009-08-13 18:16:28 -04:00
}
2009-08-13 15:16:23 -04:00
2013-06-19 14:45:42 +05:30
davinci_serial_init ( da8xx_serial_device ) ;
2009-07-16 06:42:18 -04:00
2018-11-13 15:01:16 +01:00
nvmem_add_cell_table ( & da850evm_nvmem_cell_table ) ;
nvmem_add_cell_lookups ( & da850evm_nvmem_cell_lookup , 1 ) ;
2009-08-25 15:20:05 +03:00
i2c_register_board_info ( 1 , da850_evm_i2c_devices ,
ARRAY_SIZE ( da850_evm_i2c_devices ) ) ;
2009-07-16 06:42:18 -04:00
/*
* shut down uart 0 and 1 ; they are not used on the board and
* accessing them causes endless " too much work in irq53 " messages
* with arago fs
*/
__raw_writel ( 0 , IO_ADDRESS ( DA8XX_UART1_BASE ) + 0x30 ) ;
__raw_writel ( 0 , IO_ADDRESS ( DA8XX_UART0_BASE ) + 0x30 ) ;
2009-08-11 17:03:25 -04:00
2011-01-18 12:21:44 -05:00
ret = davinci_cfg_reg_list ( da850_evm_mcasp_pins ) ;
2009-08-11 17:03:25 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: McASP mux setup failed: %d \n " , __func__ , ret ) ;
2009-08-11 17:03:25 -04:00
2012-10-17 16:08:04 +02:00
da850_evm_snd_data . sram_pool = sram_get_gen_pool ( ) ;
2009-08-28 15:05:02 -07:00
da8xx_register_mcasp ( 0 , & da850_evm_snd_data ) ;
2009-08-13 14:33:14 -04:00
2010-03-25 17:43:48 -04:00
ret = davinci_cfg_reg_list ( da850_lcdcntl_pins ) ;
2009-08-13 14:33:14 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: LCDC mux setup failed: %d \n " , __func__ , ret ) ;
2009-08-13 14:33:14 -04:00
2012-10-08 09:54:42 -04:00
ret = da8xx_register_uio_pruss ( ) ;
if ( ret )
pr_warn ( " da850_evm_init: pruss initialization failed: %d \n " ,
ret ) ;
2009-09-15 17:46:14 -04:00
/* Handle board specific muxing for LCD here */
2010-03-25 17:43:48 -04:00
ret = davinci_cfg_reg_list ( da850_evm_lcdc_pins ) ;
2009-09-15 17:46:14 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: EVM specific LCD mux setup failed: %d \n " ,
__func__ , ret ) ;
2009-09-15 17:46:14 -04:00
2009-08-13 14:33:14 -04:00
ret = da850_lcd_hw_init ( ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: LCD initialization failed: %d \n " , __func__ , ret ) ;
2009-08-13 14:33:14 -04:00
2009-09-15 18:14:19 -07:00
ret = da8xx_register_lcdc ( & sharp_lk043t1dg01_pdata ) ;
2009-08-13 14:33:14 -04:00
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: LCDC registration failed: %d \n " , __func__ , ret ) ;
2009-09-15 18:15:54 -07:00
ret = da8xx_register_rtc ( ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: RTC setup failed: %d \n " , __func__ , ret ) ;
2009-09-22 21:14:03 +05:30
2010-12-20 21:31:34 +05:30
ret = da850_evm_init_cpufreq ( ) ;
2009-09-22 21:14:03 +05:30
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: cpufreq registration failed: %d \n " , __func__ , ret ) ;
2009-10-22 15:12:15 +05:30
ret = da8xx_register_cpuidle ( ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: cpuidle registration failed: %d \n " , __func__ , ret ) ;
2009-12-17 18:29:33 +05:30
2016-11-15 11:54:19 -08:00
davinci_pm_init ( ) ;
2012-07-23 08:00:58 -03:00
da850_vpif_init ( ) ;
ARM: davinci: da8xx_register_spi() should not register SPI board info
Without this patch, da8xx_register_spi() registers the SPI board info,
the SPI controller, and sets its number of chipselect to the size of the
static spi_board_info array. This is bad because a SPI board info may
declare devices for different SPI buses, and because other code can also
call spi_register_board_info() (e.g. a daughter board might provide
additional SPI devices).
This patch removes the spi_register_board_info() call from
da8xx_register_spi(), renames this last one to da8xx_register_spi_bus()
to be more explicit, takes the number of chipselect as a function
parameter, and updates the impacted board-da8{3,5}0-evm.c, and
board-mityomapl138.c files accordingly. It also sets the SPI platform
data static, as it doesn't need to be exported.
Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com>
[nsekhar@ti.com: fixed conflicts with v3.7-rc7, converted to use pr_warn(),
modified print messages to use __func__]
Signed-off-by: Sekhar Nori <nsekhar@ti.com>
2012-09-10 20:29:13 -04:00
ret = spi_register_board_info ( da850evm_spi_info ,
ARRAY_SIZE ( da850evm_spi_info ) ) ;
if ( ret )
pr_warn ( " %s: spi info registration failed: %d \n " , __func__ ,
ret ) ;
ret = da8xx_register_spi_bus ( 1 , ARRAY_SIZE ( da850evm_spi_info ) ) ;
2011-02-24 10:39:27 +05:30
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: SPI 1 registration failed: %d \n " , __func__ , ret ) ;
2011-07-06 06:01:24 +00:00
ret = da850_register_sata ( DA850EVM_SATA_REFCLKPN_RATE ) ;
if ( ret )
2013-01-10 16:23:19 -08:00
pr_warn ( " %s: SATA registration failed: %d \n " , __func__ , ret ) ;
2011-07-12 15:58:53 +05:30
2013-03-28 18:41:47 -07:00
ret = da8xx_register_rproc ( ) ;
if ( ret )
pr_warn ( " %s: dsp/rproc registration failed: %d \n " ,
__func__ , ret ) ;
2019-06-07 11:02:01 +02:00
regulator_has_full_constraints ( ) ;
2009-07-16 06:42:18 -04:00
}
# ifdef CONFIG_SERIAL_8250_CONSOLE
static int __init da850_evm_console_init ( void )
{
2010-08-31 14:30:15 -04:00
if ( ! machine_is_davinci_da850_evm ( ) )
return 0 ;
2009-07-16 06:42:18 -04:00
return add_preferred_console ( " ttyS " , 2 , " 115200 " ) ;
}
console_initcall ( da850_evm_console_init ) ;
# endif
static void __init da850_evm_map_io ( void )
{
da850_init ( ) ;
}
2010-07-01 19:00:50 +05:30
MACHINE_START ( DAVINCI_DA850_EVM , " DaVinci DA850/OMAP-L138/AM18x EVM " )
2011-07-05 22:38:11 -04:00
. atag_offset = 0x100 ,
2009-07-16 06:42:18 -04:00
. map_io = da850_evm_map_io ,
2019-02-14 15:52:18 +01:00
. init_irq = da850_init_irq ,
2018-01-19 21:20:22 -06:00
. init_time = da850_init_time ,
2009-07-16 06:42:18 -04:00
. init_machine = da850_evm_init ,
2012-04-26 09:45:39 +08:00
. init_late = davinci_init_late ,
2011-07-05 22:28:08 -04:00
. dma_zone_size = SZ_128M ,
2013-03-28 18:41:47 -07:00
. reserve = da8xx_rproc_reserve_cma ,
2009-07-16 06:42:18 -04:00
MACHINE_END