Commit 7f2f4caa authored by Mark Brown's avatar Mark Brown

spi: pxa2xx: Clean up linux/spi/pxa2xx_spi.h

Merge series from Andy Shevchenko <andriy.shevchenko@linux.intel.com>:

A couple of cleanups against linux/spi/pxa2xx_spi.h.

I'm sending this as v3 to land in the SPI subsystem. Meanwhile I'm
preparing an update to make linux/spi/pxa2xx_spi.h private to the
subsystem (PXA2xx driver). But the second part will be presented later
on (likely after v6.9-rc1). That said, this can be routed either via
SoC tree or SPI, up to respective maintainers.
parents 9b163e0d b5867a5c
...@@ -24,7 +24,7 @@ arch/.../mach-*/board-*.c as a "platform device". The host controller configurat ...@@ -24,7 +24,7 @@ arch/.../mach-*/board-*.c as a "platform device". The host controller configurat
is passed to the driver via a table found in include/linux/spi/pxa2xx_spi.h:: is passed to the driver via a table found in include/linux/spi/pxa2xx_spi.h::
struct pxa2xx_spi_controller { struct pxa2xx_spi_controller {
u16 num_chipselect; u8 num_chipselect;
u8 enable_dma; u8 enable_dma;
... ...
}; };
......
...@@ -7,7 +7,6 @@ ...@@ -7,7 +7,6 @@
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
#include <linux/dma-mapping.h> #include <linux/dma-mapping.h>
#include <linux/dmaengine.h> #include <linux/dmaengine.h>
#include <linux/spi/pxa2xx_spi.h>
#include <linux/platform_data/i2c-pxa.h> #include <linux/platform_data/i2c-pxa.h>
#include <linux/soc/pxa/cpu.h> #include <linux/soc/pxa/cpu.h>
...@@ -665,23 +664,6 @@ struct platform_device pxa27x_device_gpio = { ...@@ -665,23 +664,6 @@ struct platform_device pxa27x_device_gpio = {
.resource = pxa_resource_gpio, .resource = pxa_resource_gpio,
}; };
/* pxa2xx-spi platform-device ID equals respective SSP platform-device ID + 1.
* See comment in arch/arm/mach-pxa/ssp.c::ssp_probe() */
void __init pxa2xx_set_spi_info(unsigned id, struct pxa2xx_spi_controller *info)
{
struct platform_device *pd;
pd = platform_device_alloc("pxa2xx-spi", id);
if (pd == NULL) {
printk(KERN_ERR "pxa2xx-spi: failed to allocate device id %d\n",
id);
return;
}
pd->dev.platform_data = info;
platform_device_add(pd);
}
static struct resource pxa_dma_resource[] = { static struct resource pxa_dma_resource[] = {
[0] = { [0] = {
.start = 0x40000000, .start = 0x40000000,
......
...@@ -585,6 +585,9 @@ static struct gpiod_lookup_table spitz_spi_gpio_table = { ...@@ -585,6 +585,9 @@ static struct gpiod_lookup_table spitz_spi_gpio_table = {
static void __init spitz_spi_init(void) static void __init spitz_spi_init(void)
{ {
struct platform_device *pd;
int id = 2;
if (machine_is_akita()) if (machine_is_akita())
gpiod_add_lookup_table(&akita_lcdcon_gpio_table); gpiod_add_lookup_table(&akita_lcdcon_gpio_table);
else else
...@@ -592,7 +595,16 @@ static void __init spitz_spi_init(void) ...@@ -592,7 +595,16 @@ static void __init spitz_spi_init(void)
gpiod_add_lookup_table(&spitz_ads7846_gpio_table); gpiod_add_lookup_table(&spitz_ads7846_gpio_table);
gpiod_add_lookup_table(&spitz_spi_gpio_table); gpiod_add_lookup_table(&spitz_spi_gpio_table);
pxa2xx_set_spi_info(2, &spitz_spi_info);
/* pxa2xx-spi platform-device ID equals respective SSP platform-device ID + 1 */
pd = platform_device_alloc("pxa2xx-spi", id);
if (pd == NULL) {
pr_err("pxa2xx-spi: failed to allocate device id %d\n", id);
} else {
pd->dev.platform_data = &spitz_spi_info;
platform_device_add(pd);
}
spi_register_board_info(ARRAY_AND_SIZE(spitz_spi_devices)); spi_register_board_info(ARRAY_AND_SIZE(spitz_spi_devices));
} }
#else #else
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/err.h> #include <linux/err.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/spi/pxa2xx_spi.h> #include <linux/pxa2xx_ssp.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_device.h> #include <linux/of_device.h>
......
...@@ -17,7 +17,7 @@ struct dma_chan; ...@@ -17,7 +17,7 @@ struct dma_chan;
* (resides in device.platform_data). * (resides in device.platform_data).
*/ */
struct pxa2xx_spi_controller { struct pxa2xx_spi_controller {
u16 num_chipselect; u8 num_chipselect;
u8 enable_dma; u8 enable_dma;
u8 dma_burst_size; u8 dma_burst_size;
bool is_target; bool is_target;
...@@ -45,12 +45,4 @@ struct pxa2xx_spi_chip { ...@@ -45,12 +45,4 @@ struct pxa2xx_spi_chip {
u32 timeout; u32 timeout;
}; };
#if defined(CONFIG_ARCH_PXA) || defined(CONFIG_ARCH_MMP)
#include <linux/clk.h>
extern void pxa2xx_set_spi_info(unsigned id, struct pxa2xx_spi_controller *info);
#endif
#endif /* __LINUX_SPI_PXA2XX_SPI_H */ #endif /* __LINUX_SPI_PXA2XX_SPI_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment