diff options
Diffstat (limited to 'drivers/spi/mxc_spi.c')
| -rw-r--r-- | drivers/spi/mxc_spi.c | 12 | 
1 files changed, 5 insertions, 7 deletions
| diff --git a/drivers/spi/mxc_spi.c b/drivers/spi/mxc_spi.c index 859c43fee..cb48019a4 100644 --- a/drivers/spi/mxc_spi.c +++ b/drivers/spi/mxc_spi.c @@ -137,11 +137,11 @@ static s32 spi_cfg_mxc(struct mxc_spi_slave *mxcs, unsigned int cs,  		return -1;  	} -	reg_ctrl = reg_read(®s->ctrl); -  	/* Reset spi */ -	reg_write(®s->ctrl, (reg_ctrl & ~MXC_CSPICTRL_EN)); -	reg_write(®s->ctrl, (reg_ctrl | MXC_CSPICTRL_EN)); +	reg_write(®s->ctrl, 0); +	reg_write(®s->ctrl, MXC_CSPICTRL_EN); + +	reg_ctrl = reg_read(®s->ctrl);  	/*  	 * The following computation is taken directly from Freescale's code. @@ -408,7 +408,7 @@ struct spi_slave *spi_setup_slave(unsigned int bus, unsigned int cs,  	if (bus >= ARRAY_SIZE(spi_bases))  		return NULL; -	mxcs = calloc(sizeof(struct mxc_spi_slave), 1); +	mxcs = spi_alloc_slave(struct mxc_spi_slave, bus, cs);  	if (!mxcs) {  		puts("mxc_spi: SPI Slave not allocated !\n");  		return NULL; @@ -424,8 +424,6 @@ struct spi_slave *spi_setup_slave(unsigned int bus, unsigned int cs,  	cs = ret; -	mxcs->slave.bus = bus; -	mxcs->slave.cs = cs;  	mxcs->base = spi_bases[bus];  	ret = spi_cfg_mxc(mxcs, cs, max_hz, mode); |