2010-11-24 10:17:14 +01:00
/*
* CE4100 ' s SPI device is more or less the same one as found on PXA
*
*/
# include <linux/pci.h>
# include <linux/platform_device.h>
# include <linux/of_device.h>
2011-07-03 15:44:29 -04:00
# include <linux/module.h>
2010-11-24 10:17:14 +01:00
# include <linux/spi/pxa2xx_spi.h>
2014-04-18 00:26:06 +08:00
enum {
PORT_CE4100 ,
PORT_BYT ,
} ;
struct pxa_spi_info {
enum pxa_ssp_type type ;
int port_id ;
int num_chipselect ;
int tx_slave_id ;
int tx_chan_id ;
int rx_slave_id ;
int rx_chan_id ;
} ;
static struct pxa_spi_info spi_info_configs [ ] = {
[ PORT_CE4100 ] = {
. type = PXA25x_SSP ,
. port_id = - 1 ,
. num_chipselect = - 1 ,
. tx_slave_id = - 1 ,
. tx_chan_id = - 1 ,
. rx_slave_id = - 1 ,
. rx_chan_id = - 1 ,
} ,
[ PORT_BYT ] = {
. type = LPSS_SSP ,
. port_id = 0 ,
. num_chipselect = 1 ,
. tx_slave_id = 0 ,
. tx_chan_id = 0 ,
. rx_slave_id = 1 ,
. rx_chan_id = 1 ,
} ,
} ;
static int pxa2xx_spi_pci_probe ( struct pci_dev * dev ,
2010-11-24 10:17:14 +01:00
const struct pci_device_id * ent )
{
2013-01-07 12:44:32 +02:00
struct platform_device_info pi ;
2010-11-24 10:17:14 +01:00
int ret ;
struct platform_device * pdev ;
2011-02-03 00:31:21 +05:30
struct pxa2xx_spi_master spi_pdata ;
2010-11-24 10:17:14 +01:00
struct ssp_device * ssp ;
2014-04-18 00:26:06 +08:00
struct pxa_spi_info * c ;
2010-11-24 10:17:14 +01:00
2013-01-07 12:44:32 +02:00
ret = pcim_enable_device ( dev ) ;
2010-11-24 10:17:14 +01:00
if ( ret )
return ret ;
2013-01-07 12:44:32 +02:00
ret = pcim_iomap_regions ( dev , 1 < < 0 , " PXA2xx SPI " ) ;
2013-03-05 12:05:16 +02:00
if ( ret )
2010-11-24 10:17:14 +01:00
return ret ;
2014-04-18 00:26:06 +08:00
c = & spi_info_configs [ ent - > driver_data ] ;
2011-02-03 00:31:21 +05:30
memset ( & spi_pdata , 0 , sizeof ( spi_pdata ) ) ;
2014-04-18 00:26:06 +08:00
spi_pdata . num_chipselect = ( c - > num_chipselect > 0 ) ?
c - > num_chipselect : dev - > devfn ;
spi_pdata . tx_slave_id = c - > tx_slave_id ;
spi_pdata . tx_chan_id = c - > tx_chan_id ;
spi_pdata . rx_slave_id = c - > rx_slave_id ;
spi_pdata . rx_chan_id = c - > rx_chan_id ;
spi_pdata . enable_dma = c - > rx_slave_id > = 0 & & c - > tx_slave_id > = 0 ;
2010-11-24 10:17:14 +01:00
2013-01-07 12:44:33 +02:00
ssp = & spi_pdata . ssp ;
2010-11-24 10:17:14 +01:00
ssp - > phys_base = pci_resource_start ( dev , 0 ) ;
2013-01-07 12:44:32 +02:00
ssp - > mmio_base = pcim_iomap_table ( dev ) [ 0 ] ;
2010-11-24 10:17:14 +01:00
if ( ! ssp - > mmio_base ) {
2013-01-07 12:44:32 +02:00
dev_err ( & dev - > dev , " failed to ioremap() registers \n " ) ;
return - EIO ;
2010-11-24 10:17:14 +01:00
}
ssp - > irq = dev - > irq ;
2014-04-18 00:26:06 +08:00
ssp - > port_id = ( c - > port_id > = 0 ) ? c - > port_id : dev - > devfn ;
ssp - > type = c - > type ;
2010-11-24 10:17:14 +01:00
2013-01-07 12:44:32 +02:00
memset ( & pi , 0 , sizeof ( pi ) ) ;
pi . parent = & dev - > dev ;
pi . name = " pxa2xx-spi " ;
pi . id = ssp - > port_id ;
pi . data = & spi_pdata ;
pi . size_data = sizeof ( spi_pdata ) ;
2010-11-24 10:17:14 +01:00
2013-01-07 12:44:32 +02:00
pdev = platform_device_register_full ( & pi ) ;
2013-02-22 10:52:35 +08:00
if ( IS_ERR ( pdev ) )
return PTR_ERR ( pdev ) ;
2010-11-24 10:17:14 +01:00
2013-01-07 12:44:33 +02:00
pci_set_drvdata ( dev , pdev ) ;
2010-11-24 10:17:14 +01:00
2013-01-07 12:44:32 +02:00
return 0 ;
2010-11-24 10:17:14 +01:00
}
2014-04-18 00:26:06 +08:00
static void pxa2xx_spi_pci_remove ( struct pci_dev * dev )
2010-11-24 10:17:14 +01:00
{
2013-01-07 12:44:33 +02:00
struct platform_device * pdev = pci_get_drvdata ( dev ) ;
2010-11-24 10:17:14 +01:00
2013-01-07 12:44:33 +02:00
platform_device_unregister ( pdev ) ;
2010-11-24 10:17:14 +01:00
}
2014-04-18 00:26:06 +08:00
static const struct pci_device_id pxa2xx_spi_pci_devices [ ] = {
{ PCI_VDEVICE ( INTEL , 0x2e6a ) , PORT_CE4100 } ,
{ PCI_VDEVICE ( INTEL , 0x0f0e ) , PORT_BYT } ,
2010-11-24 10:17:14 +01:00
{ } ,
} ;
2014-04-18 00:26:06 +08:00
MODULE_DEVICE_TABLE ( pci , pxa2xx_spi_pci_devices ) ;
2010-11-24 10:17:14 +01:00
2014-04-18 00:26:06 +08:00
static struct pci_driver pxa2xx_spi_pci_driver = {
. name = " pxa2xx_spi_pci " ,
. id_table = pxa2xx_spi_pci_devices ,
. probe = pxa2xx_spi_pci_probe ,
. remove = pxa2xx_spi_pci_remove ,
2010-11-24 10:17:14 +01:00
} ;
2014-04-18 00:26:06 +08:00
module_pci_driver ( pxa2xx_spi_pci_driver ) ;
2010-11-24 10:17:14 +01:00
2014-04-18 00:26:06 +08:00
MODULE_DESCRIPTION ( " CE4100/LPSS PCI-SPI glue code for PXA's driver " ) ;
2010-11-24 10:17:14 +01:00
MODULE_LICENSE ( " GPL v2 " ) ;
MODULE_AUTHOR ( " Sebastian Andrzej Siewior <bigeasy@linutronix.de> " ) ;