spi_mpc83xx: rework chip selects handling

The main purpose of this patch is to pass 'struct spi_device' to the chip
select handling routines.  This is needed so that we could implement
full-fledged OpenFirmware support for this driver.

While at it, also:
- Replace two {de,activate}_cs routines by single cs_contol().
- Don't duplicate platform data callbacks in mpc83xx_spi struct.

Signed-off-by: Anton Vorontsov <avorontsov@ru.mvista.com>
Cc: David Brownell <david-b@pacbell.net>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Kumar Gala <galak@gate.crashing.org>
Cc: Grant Likely <grant.likely@secretlab.ca>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Anton Vorontsov 2009-03-31 15:24:36 -07:00 коммит произвёл Linus Torvalds
Родитель 34c8a20c6e
Коммит 364fdbc00f
5 изменённых файлов: 23 добавлений и 37 удалений

Просмотреть файл

@ -39,16 +39,10 @@
#endif #endif
#ifdef CONFIG_QUICC_ENGINE #ifdef CONFIG_QUICC_ENGINE
static void mpc83xx_spi_activate_cs(u8 cs, u8 polarity) static void mpc83xx_spi_cs_control(struct spi_device *spi, bool on)
{ {
pr_debug("%s %d %d\n", __func__, cs, polarity); pr_debug("%s %d %d\n", __func__, spi->chip_select, on);
par_io_data_set(3, 13, polarity); par_io_data_set(3, 13, on);
}
static void mpc83xx_spi_deactivate_cs(u8 cs, u8 polarity)
{
pr_debug("%s %d %d\n", __func__, cs, polarity);
par_io_data_set(3, 13, !polarity);
} }
static struct mmc_spi_platform_data mpc832x_mmc_pdata = { static struct mmc_spi_platform_data mpc832x_mmc_pdata = {
@ -74,9 +68,7 @@ static int __init mpc832x_spi_init(void)
par_io_config_pin(3, 14, 2, 0, 0, 0); /* SD_INSERT, I */ par_io_config_pin(3, 14, 2, 0, 0, 0); /* SD_INSERT, I */
par_io_config_pin(3, 15, 2, 0, 0, 0); /* SD_PROTECT,I */ par_io_config_pin(3, 15, 2, 0, 0, 0); /* SD_PROTECT,I */
return fsl_spi_init(&mpc832x_spi_boardinfo, 1, return fsl_spi_init(&mpc832x_spi_boardinfo, 1, mpc83xx_spi_cs_control);
mpc83xx_spi_activate_cs,
mpc83xx_spi_deactivate_cs);
} }
machine_device_initcall(mpc832x_rdb, mpc832x_spi_init); machine_device_initcall(mpc832x_rdb, mpc832x_spi_init);
#endif /* CONFIG_QUICC_ENGINE */ #endif /* CONFIG_QUICC_ENGINE */

Просмотреть файл

@ -420,8 +420,8 @@ arch_initcall(fsl_usb_of_init);
static int __init of_fsl_spi_probe(char *type, char *compatible, u32 sysclk, static int __init of_fsl_spi_probe(char *type, char *compatible, u32 sysclk,
struct spi_board_info *board_infos, struct spi_board_info *board_infos,
unsigned int num_board_infos, unsigned int num_board_infos,
void (*activate_cs)(u8 cs, u8 polarity), void (*cs_control)(struct spi_device *dev,
void (*deactivate_cs)(u8 cs, u8 polarity)) bool on))
{ {
struct device_node *np; struct device_node *np;
unsigned int i = 0; unsigned int i = 0;
@ -433,8 +433,7 @@ static int __init of_fsl_spi_probe(char *type, char *compatible, u32 sysclk,
struct resource res[2]; struct resource res[2];
struct platform_device *pdev; struct platform_device *pdev;
struct fsl_spi_platform_data pdata = { struct fsl_spi_platform_data pdata = {
.activate_cs = activate_cs, .cs_control = cs_control,
.deactivate_cs = deactivate_cs,
}; };
memset(res, 0, sizeof(res)); memset(res, 0, sizeof(res));
@ -501,8 +500,7 @@ next:
int __init fsl_spi_init(struct spi_board_info *board_infos, int __init fsl_spi_init(struct spi_board_info *board_infos,
unsigned int num_board_infos, unsigned int num_board_infos,
void (*activate_cs)(u8 cs, u8 polarity), void (*cs_control)(struct spi_device *spi, bool on))
void (*deactivate_cs)(u8 cs, u8 polarity))
{ {
u32 sysclk = -1; u32 sysclk = -1;
int ret; int ret;
@ -518,10 +516,10 @@ int __init fsl_spi_init(struct spi_board_info *board_infos,
} }
ret = of_fsl_spi_probe(NULL, "fsl,spi", sysclk, board_infos, ret = of_fsl_spi_probe(NULL, "fsl,spi", sysclk, board_infos,
num_board_infos, activate_cs, deactivate_cs); num_board_infos, cs_control);
if (!ret) if (!ret)
of_fsl_spi_probe("spi", "fsl_spi", sysclk, board_infos, of_fsl_spi_probe("spi", "fsl_spi", sysclk, board_infos,
num_board_infos, activate_cs, deactivate_cs); num_board_infos, cs_control);
return spi_register_board_info(board_infos, num_board_infos); return spi_register_board_info(board_infos, num_board_infos);
} }

Просмотреть файл

@ -4,6 +4,8 @@
#include <asm/mmu.h> #include <asm/mmu.h>
struct spi_device;
extern phys_addr_t get_immrbase(void); extern phys_addr_t get_immrbase(void);
#if defined(CONFIG_CPM2) || defined(CONFIG_QUICC_ENGINE) || defined(CONFIG_8xx) #if defined(CONFIG_CPM2) || defined(CONFIG_QUICC_ENGINE) || defined(CONFIG_8xx)
extern u32 get_brgfreq(void); extern u32 get_brgfreq(void);
@ -19,8 +21,7 @@ struct device_node;
extern int fsl_spi_init(struct spi_board_info *board_infos, extern int fsl_spi_init(struct spi_board_info *board_infos,
unsigned int num_board_infos, unsigned int num_board_infos,
void (*activate_cs)(u8 cs, u8 polarity), void (*cs_control)(struct spi_device *spi, bool on));
void (*deactivate_cs)(u8 cs, u8 polarity));
extern void fsl_rstcr_restart(char *cmd); extern void fsl_rstcr_restart(char *cmd);

Просмотреть файл

@ -89,9 +89,6 @@ struct mpc83xx_spi {
bool qe_mode; bool qe_mode;
void (*activate_cs) (u8 cs, u8 polarity);
void (*deactivate_cs) (u8 cs, u8 polarity);
u8 busy; u8 busy;
struct workqueue_struct *workqueue; struct workqueue_struct *workqueue;
@ -153,15 +150,14 @@ MPC83XX_SPI_TX_BUF(u32)
static void mpc83xx_spi_chipselect(struct spi_device *spi, int value) static void mpc83xx_spi_chipselect(struct spi_device *spi, int value)
{ {
struct mpc83xx_spi *mpc83xx_spi; struct mpc83xx_spi *mpc83xx_spi = spi_master_get_devdata(spi->master);
u8 pol = spi->mode & SPI_CS_HIGH ? 1 : 0; struct fsl_spi_platform_data *pdata = spi->dev.parent->platform_data;
bool pol = spi->mode & SPI_CS_HIGH;
struct spi_mpc83xx_cs *cs = spi->controller_state; struct spi_mpc83xx_cs *cs = spi->controller_state;
mpc83xx_spi = spi_master_get_devdata(spi->master);
if (value == BITBANG_CS_INACTIVE) { if (value == BITBANG_CS_INACTIVE) {
if (mpc83xx_spi->deactivate_cs) if (pdata->cs_control)
mpc83xx_spi->deactivate_cs(spi->chip_select, pol); pdata->cs_control(spi, !pol);
} }
if (value == BITBANG_CS_ACTIVE) { if (value == BITBANG_CS_ACTIVE) {
@ -186,8 +182,8 @@ static void mpc83xx_spi_chipselect(struct spi_device *spi, int value)
mpc83xx_spi_write_reg(mode, regval); mpc83xx_spi_write_reg(mode, regval);
local_irq_restore(flags); local_irq_restore(flags);
} }
if (mpc83xx_spi->activate_cs) if (pdata->cs_control)
mpc83xx_spi->activate_cs(spi->chip_select, pol); pdata->cs_control(spi, pol);
} }
} }
@ -582,8 +578,6 @@ static int __init mpc83xx_spi_probe(struct platform_device *dev)
master->cleanup = mpc83xx_spi_cleanup; master->cleanup = mpc83xx_spi_cleanup;
mpc83xx_spi = spi_master_get_devdata(master); mpc83xx_spi = spi_master_get_devdata(master);
mpc83xx_spi->activate_cs = pdata->activate_cs;
mpc83xx_spi->deactivate_cs = pdata->deactivate_cs;
mpc83xx_spi->qe_mode = pdata->qe_mode; mpc83xx_spi->qe_mode = pdata->qe_mode;
mpc83xx_spi->get_rx = mpc83xx_spi_rx_buf_u8; mpc83xx_spi->get_rx = mpc83xx_spi_rx_buf_u8;
mpc83xx_spi->get_tx = mpc83xx_spi_tx_buf_u8; mpc83xx_spi->get_tx = mpc83xx_spi_tx_buf_u8;

Просмотреть файл

@ -95,14 +95,15 @@ struct fsl_usb2_platform_data {
#define FSL_USB2_PORT0_ENABLED 0x00000001 #define FSL_USB2_PORT0_ENABLED 0x00000001
#define FSL_USB2_PORT1_ENABLED 0x00000002 #define FSL_USB2_PORT1_ENABLED 0x00000002
struct spi_device;
struct fsl_spi_platform_data { struct fsl_spi_platform_data {
u32 initial_spmode; /* initial SPMODE value */ u32 initial_spmode; /* initial SPMODE value */
u16 bus_num; u16 bus_num;
bool qe_mode; bool qe_mode;
/* board specific information */ /* board specific information */
u16 max_chipselect; u16 max_chipselect;
void (*activate_cs)(u8 cs, u8 polarity); void (*cs_control)(struct spi_device *spi, bool on);
void (*deactivate_cs)(u8 cs, u8 polarity);
u32 sysclk; u32 sysclk;
}; };