2019-06-04 11:11:33 +03:00
// SPDX-License-Identifier: GPL-2.0-only
2009-02-16 20:40:55 +03:00
/*
* Support for Cogent CSB726
*
* Copyright ( c ) 2008 Dmitry Eremin - Solenikov
*/
# include <linux/kernel.h>
# include <linux/init.h>
# include <linux/io.h>
2018-12-02 11:43:22 +03:00
# include <linux/gpio/machine.h>
2009-02-16 20:40:55 +03:00
# include <linux/platform_device.h>
# include <linux/mtd/physmap.h>
# include <linux/mtd/partitions.h>
# include <linux/sm501.h>
2009-04-22 00:43:21 +04:00
# include <linux/smsc911x.h>
2017-11-13 20:27:39 +03:00
# include <linux/platform_data/i2c-pxa.h>
2009-02-16 20:40:55 +03:00
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
2019-09-01 23:26:10 +03:00
2015-01-30 12:45:33 +03:00
# include "csb726.h"
# include "pxa27x.h"
2012-08-24 17:16:48 +04:00
# include <linux/platform_data/mmc-pxamci.h>
# include <linux/platform_data/usb-ohci-pxa27x.h>
2019-09-02 01:02:08 +03:00
# include <linux/platform_data/asoc-pxa.h>
2010-11-03 18:29:35 +03:00
# include <mach/smemc.h>
2009-02-16 20:40:55 +03:00
# include "generic.h"
# include "devices.h"
/*
* n / a : 2 , 5 , 6 , 7 , 8 , 23 , 24 , 25 , 26 , 27 , 87 , 88 , 89 ,
* nu : 58 - - 77 , 90 , 91 , 93 , 102 , 105 - 108 , 114 - 116 ,
* XXX : 21 ,
* XXX : 79 CS_3 for LAN9215 or PSKTSEL on R2 , R3
* XXX : 33 CS_5 for LAN9215 on R1
*/
static unsigned long csb726_pin_config [ ] = {
GPIO78_nCS_2 , /* EXP_CS */
GPIO79_nCS_3 , /* SMSC9215 */
GPIO80_nCS_4 , /* SM501 */
GPIO52_GPIO , /* #SMSC9251 int */
GPIO53_GPIO , /* SM501 int */
GPIO1_GPIO , /* GPIO0 */
GPIO11_GPIO , /* GPIO1 */
GPIO9_GPIO , /* GPIO2 */
GPIO10_GPIO , /* GPIO3 */
GPIO16_PWM0_OUT , /* or GPIO4 */
GPIO17_PWM1_OUT , /* or GPIO5 */
GPIO94_GPIO , /* GPIO6 */
GPIO95_GPIO , /* GPIO7 */
GPIO96_GPIO , /* GPIO8 */
GPIO97_GPIO , /* GPIO9 */
GPIO15_GPIO , /* EXP_IRQ */
GPIO18_RDY , /* EXP_WAIT */
GPIO0_GPIO , /* PWR_INT */
GPIO104_GPIO , /* PWR_OFF */
GPIO12_GPIO , /* touch irq */
GPIO13_SSP2_TXD ,
GPIO14_SSP2_SFRM ,
MFP_CFG_OUT ( GPIO19 , AF1 , DRIVE_LOW ) , /* SSP2_SYSCLK */
GPIO22_SSP2_SCLK ,
GPIO81_SSP3_TXD ,
GPIO82_SSP3_RXD ,
GPIO83_SSP3_SFRM ,
GPIO84_SSP3_SCLK ,
GPIO20_GPIO , /* SDIO int */
GPIO32_MMC_CLK ,
GPIO92_MMC_DAT_0 ,
GPIO109_MMC_DAT_1 ,
GPIO110_MMC_DAT_2 ,
GPIO111_MMC_DAT_3 ,
GPIO112_MMC_CMD ,
GPIO100_GPIO , /* SD CD */
GPIO101_GPIO , /* SD WP */
GPIO28_AC97_BITCLK ,
GPIO29_AC97_SDATA_IN_0 ,
GPIO30_AC97_SDATA_OUT ,
GPIO31_AC97_SYNC ,
GPIO113_AC97_nRESET ,
GPIO34_FFUART_RXD ,
GPIO35_FFUART_CTS ,
GPIO36_FFUART_DCD ,
GPIO37_FFUART_DSR ,
GPIO38_FFUART_RI ,
GPIO39_FFUART_TXD ,
GPIO40_FFUART_DTR ,
GPIO41_FFUART_RTS ,
GPIO42_BTUART_RXD ,
GPIO43_BTUART_TXD ,
GPIO44_BTUART_CTS ,
GPIO45_BTUART_RTS ,
GPIO46_STUART_RXD ,
GPIO47_STUART_TXD ,
GPIO48_nPOE ,
GPIO49_nPWE ,
GPIO50_nPIOR ,
GPIO51_nPIOW ,
GPIO54_nPCE_2 ,
GPIO55_nPREG ,
GPIO56_nPWAIT ,
GPIO57_nIOIS16 , /* maybe unused */
GPIO85_nPCE_1 ,
GPIO98_GPIO , /* CF IRQ */
GPIO99_GPIO , /* CF CD */
GPIO103_GPIO , /* Reset */
GPIO117_I2C_SCL ,
GPIO118_I2C_SDA ,
} ;
static struct pxamci_platform_data csb726_mci = {
2010-04-14 03:00:42 +04:00
. detect_delay_ms = 500 ,
2009-07-07 00:16:42 +04:00
. ocr_mask = MMC_VDD_32_33 | MMC_VDD_33_34 ,
2009-02-16 20:40:55 +03:00
/* FIXME setpower */
} ;
2018-12-02 11:43:22 +03:00
static struct gpiod_lookup_table csb726_mci_gpio_table = {
. dev_id = " pxa2xx-mci.0 " ,
. table = {
/* Card detect on GPIO 100 */
GPIO_LOOKUP ( " gpio-pxa " , CSB726_GPIO_MMC_DETECT ,
" cd " , GPIO_ACTIVE_LOW ) ,
/* Write protect on GPIO 101 */
GPIO_LOOKUP ( " gpio-pxa " , CSB726_GPIO_MMC_RO ,
" wp " , GPIO_ACTIVE_LOW ) ,
{ } ,
} ,
} ;
2009-02-16 20:40:55 +03:00
static struct pxaohci_platform_data csb726_ohci_platform_data = {
. port_mode = PMM_NPS_MODE ,
. flags = ENABLE_PORT1 | NO_OC_PROTECTION ,
} ;
static struct mtd_partition csb726_flash_partitions [ ] = {
{
. name = " Bootloader " ,
. offset = 0 ,
. size = CSB726_FLASH_uMON ,
. mask_flags = MTD_WRITEABLE /* force read-only */
} ,
{
. name = " root " ,
. offset = MTDPART_OFS_APPEND ,
. size = MTDPART_SIZ_FULL ,
}
} ;
static struct physmap_flash_data csb726_flash_data = {
. width = 2 ,
. parts = csb726_flash_partitions ,
. nr_parts = ARRAY_SIZE ( csb726_flash_partitions ) ,
} ;
static struct resource csb726_flash_resources [ ] = {
{
. start = PXA_CS0_PHYS ,
. end = PXA_CS0_PHYS + CSB726_FLASH_SIZE - 1 ,
. flags = IORESOURCE_MEM ,
}
} ;
static struct platform_device csb726_flash = {
. name = " physmap-flash " ,
. dev = {
. platform_data = & csb726_flash_data ,
} ,
. resource = csb726_flash_resources ,
. num_resources = ARRAY_SIZE ( csb726_flash_resources ) ,
} ;
static struct resource csb726_sm501_resources [ ] = {
{
. start = PXA_CS4_PHYS ,
. end = PXA_CS4_PHYS + SZ_8M - 1 ,
. flags = IORESOURCE_MEM ,
. name = " sm501-localmem " ,
} ,
{
. start = PXA_CS4_PHYS + SZ_64M - SZ_2M ,
. end = PXA_CS4_PHYS + SZ_64M - 1 ,
. flags = IORESOURCE_MEM ,
. name = " sm501-regs " ,
} ,
{
. start = CSB726_IRQ_SM501 ,
. end = CSB726_IRQ_SM501 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct sm501_initdata csb726_sm501_initdata = {
/* .devices = SM501_USE_USB_HOST, */
. devices = SM501_USE_USB_HOST | SM501_USE_UART0 | SM501_USE_UART1 ,
} ;
static struct sm501_platdata csb726_sm501_platdata = {
. init = & csb726_sm501_initdata ,
} ;
static struct platform_device csb726_sm501 = {
. name = " sm501 " ,
. id = 0 ,
. num_resources = ARRAY_SIZE ( csb726_sm501_resources ) ,
. resource = csb726_sm501_resources ,
. dev = {
. platform_data = & csb726_sm501_platdata ,
} ,
} ;
static struct resource csb726_lan_resources [ ] = {
{
. start = PXA_CS3_PHYS ,
. end = PXA_CS3_PHYS + SZ_64K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
. start = CSB726_IRQ_LAN ,
. end = CSB726_IRQ_LAN ,
2009-04-22 00:43:21 +04:00
. flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWEDGE ,
2009-02-16 20:40:55 +03:00
} ,
} ;
2009-04-22 00:43:21 +04:00
struct smsc911x_platform_config csb726_lan_config = {
2009-09-16 13:06:52 +04:00
. irq_polarity = SMSC911X_IRQ_POLARITY_ACTIVE_LOW ,
2009-04-22 00:43:21 +04:00
. irq_type = SMSC911X_IRQ_TYPE_PUSH_PULL ,
. flags = SMSC911X_USE_32BIT ,
. phy_interface = PHY_INTERFACE_MODE_MII ,
} ;
2009-02-16 20:40:55 +03:00
static struct platform_device csb726_lan = {
2009-04-22 00:43:21 +04:00
. name = " smsc911x " ,
2009-02-16 20:40:55 +03:00
. id = - 1 ,
. num_resources = ARRAY_SIZE ( csb726_lan_resources ) ,
. resource = csb726_lan_resources ,
2009-04-22 00:43:21 +04:00
. dev = {
. platform_data = & csb726_lan_config ,
} ,
2009-02-16 20:40:55 +03:00
} ;
static struct platform_device * devices [ ] __initdata = {
& csb726_flash ,
& csb726_sm501 ,
& csb726_lan ,
} ;
static void __init csb726_init ( void )
{
pxa2xx_mfp_config ( ARRAY_AND_SIZE ( csb726_pin_config ) ) ;
2010-11-03 18:29:35 +03:00
/* __raw_writel(0x7ffc3ffc, MSC1); */ /* LAN9215/EXP_CS */
/* __raw_writel(0x06697ff4, MSC2); */ /* none/SM501 */
__raw_writel ( ( __raw_readl ( MSC2 ) & ~ 0xffff ) | 0x7ff4 , MSC2 ) ; /* SM501 */
2009-02-16 20:40:55 +03:00
2009-11-09 08:34:08 +03:00
pxa_set_ffuart_info ( NULL ) ;
pxa_set_btuart_info ( NULL ) ;
pxa_set_stuart_info ( NULL ) ;
2009-02-16 20:40:55 +03:00
pxa_set_i2c_info ( NULL ) ;
pxa27x_set_i2c_power_info ( NULL ) ;
2018-12-02 11:43:22 +03:00
gpiod_add_lookup_table ( & csb726_mci_gpio_table ) ;
2009-02-16 20:40:55 +03:00
pxa_set_mci_info ( & csb726_mci ) ;
pxa_set_ohci_info ( & csb726_ohci_platform_data ) ;
2009-04-22 00:43:22 +04:00
pxa_set_ac97_info ( NULL ) ;
2009-02-16 20:40:55 +03:00
platform_add_devices ( devices , ARRAY_SIZE ( devices ) ) ;
}
MACHINE_START ( CSB726 , " Cogent CSB726 " )
2011-07-06 06:38:15 +04:00
. atag_offset = 0x100 ,
2010-10-11 04:20:19 +04:00
. map_io = pxa27x_map_io ,
2012-01-04 02:53:48 +04:00
. nr_irqs = PXA_NR_IRQS ,
2009-02-16 20:40:55 +03:00
. init_irq = pxa27x_init_irq ,
2011-05-18 17:30:04 +04:00
. handle_irq = pxa27x_handle_irq ,
2009-02-16 20:40:55 +03:00
. init_machine = csb726_init ,
2012-11-08 23:40:59 +04:00
. init_time = pxa_timer_init ,
2011-11-04 18:15:53 +04:00
. restart = pxa_restart ,
2009-02-16 20:40:55 +03:00
MACHINE_END