diff options
Diffstat (limited to 'drivers/spi/spi-fsl-espi.c')
-rw-r--r-- | drivers/spi/spi-fsl-espi.c | 59 |
1 files changed, 41 insertions, 18 deletions
diff --git a/drivers/spi/spi-fsl-espi.c b/drivers/spi/spi-fsl-espi.c index a7f94b6a9e70..56cadf13519e 100644 --- a/drivers/spi/spi-fsl-espi.c +++ b/drivers/spi/spi-fsl-espi.c | |||
@@ -411,7 +411,8 @@ static void fsl_espi_rw_trans(struct spi_message *m, | |||
411 | kfree(local_buf); | 411 | kfree(local_buf); |
412 | } | 412 | } |
413 | 413 | ||
414 | static void fsl_espi_do_one_msg(struct spi_message *m) | 414 | static int fsl_espi_do_one_msg(struct spi_master *master, |
415 | struct spi_message *m) | ||
415 | { | 416 | { |
416 | struct spi_transfer *t; | 417 | struct spi_transfer *t; |
417 | u8 *rx_buf = NULL; | 418 | u8 *rx_buf = NULL; |
@@ -441,8 +442,8 @@ static void fsl_espi_do_one_msg(struct spi_message *m) | |||
441 | 442 | ||
442 | m->actual_length = espi_trans.actual_length; | 443 | m->actual_length = espi_trans.actual_length; |
443 | m->status = espi_trans.status; | 444 | m->status = espi_trans.status; |
444 | if (m->complete) | 445 | spi_finalize_current_message(master); |
445 | m->complete(m->context); | 446 | return 0; |
446 | } | 447 | } |
447 | 448 | ||
448 | static int fsl_espi_setup(struct spi_device *spi) | 449 | static int fsl_espi_setup(struct spi_device *spi) |
@@ -587,6 +588,38 @@ static void fsl_espi_remove(struct mpc8xxx_spi *mspi) | |||
587 | iounmap(mspi->reg_base); | 588 | iounmap(mspi->reg_base); |
588 | } | 589 | } |
589 | 590 | ||
591 | static int fsl_espi_suspend(struct spi_master *master) | ||
592 | { | ||
593 | struct mpc8xxx_spi *mpc8xxx_spi; | ||
594 | struct fsl_espi_reg *reg_base; | ||
595 | u32 regval; | ||
596 | |||
597 | mpc8xxx_spi = spi_master_get_devdata(master); | ||
598 | reg_base = mpc8xxx_spi->reg_base; | ||
599 | |||
600 | regval = mpc8xxx_spi_read_reg(®_base->mode); | ||
601 | regval &= ~SPMODE_ENABLE; | ||
602 | mpc8xxx_spi_write_reg(®_base->mode, regval); | ||
603 | |||
604 | return 0; | ||
605 | } | ||
606 | |||
607 | static int fsl_espi_resume(struct spi_master *master) | ||
608 | { | ||
609 | struct mpc8xxx_spi *mpc8xxx_spi; | ||
610 | struct fsl_espi_reg *reg_base; | ||
611 | u32 regval; | ||
612 | |||
613 | mpc8xxx_spi = spi_master_get_devdata(master); | ||
614 | reg_base = mpc8xxx_spi->reg_base; | ||
615 | |||
616 | regval = mpc8xxx_spi_read_reg(®_base->mode); | ||
617 | regval |= SPMODE_ENABLE; | ||
618 | mpc8xxx_spi_write_reg(®_base->mode, regval); | ||
619 | |||
620 | return 0; | ||
621 | } | ||
622 | |||
590 | static struct spi_master * fsl_espi_probe(struct device *dev, | 623 | static struct spi_master * fsl_espi_probe(struct device *dev, |
591 | struct resource *mem, unsigned int irq) | 624 | struct resource *mem, unsigned int irq) |
592 | { | 625 | { |
@@ -607,16 +640,16 @@ static struct spi_master * fsl_espi_probe(struct device *dev, | |||
607 | 640 | ||
608 | dev_set_drvdata(dev, master); | 641 | dev_set_drvdata(dev, master); |
609 | 642 | ||
610 | ret = mpc8xxx_spi_probe(dev, mem, irq); | 643 | mpc8xxx_spi_probe(dev, mem, irq); |
611 | if (ret) | ||
612 | goto err_probe; | ||
613 | 644 | ||
614 | master->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 16); | 645 | master->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 16); |
615 | master->setup = fsl_espi_setup; | 646 | master->setup = fsl_espi_setup; |
616 | master->cleanup = fsl_espi_cleanup; | 647 | master->cleanup = fsl_espi_cleanup; |
648 | master->transfer_one_message = fsl_espi_do_one_msg; | ||
649 | master->prepare_transfer_hardware = fsl_espi_resume; | ||
650 | master->unprepare_transfer_hardware = fsl_espi_suspend; | ||
617 | 651 | ||
618 | mpc8xxx_spi = spi_master_get_devdata(master); | 652 | mpc8xxx_spi = spi_master_get_devdata(master); |
619 | mpc8xxx_spi->spi_do_one_msg = fsl_espi_do_one_msg; | ||
620 | mpc8xxx_spi->spi_remove = fsl_espi_remove; | 653 | mpc8xxx_spi->spi_remove = fsl_espi_remove; |
621 | 654 | ||
622 | mpc8xxx_spi->reg_base = ioremap(mem->start, resource_size(mem)); | 655 | mpc8xxx_spi->reg_base = ioremap(mem->start, resource_size(mem)); |
@@ -762,25 +795,15 @@ static int of_fsl_espi_remove(struct platform_device *dev) | |||
762 | static int of_fsl_espi_suspend(struct device *dev) | 795 | static int of_fsl_espi_suspend(struct device *dev) |
763 | { | 796 | { |
764 | struct spi_master *master = dev_get_drvdata(dev); | 797 | struct spi_master *master = dev_get_drvdata(dev); |
765 | struct mpc8xxx_spi *mpc8xxx_spi; | ||
766 | struct fsl_espi_reg *reg_base; | ||
767 | u32 regval; | ||
768 | int ret; | 798 | int ret; |
769 | 799 | ||
770 | mpc8xxx_spi = spi_master_get_devdata(master); | ||
771 | reg_base = mpc8xxx_spi->reg_base; | ||
772 | |||
773 | ret = spi_master_suspend(master); | 800 | ret = spi_master_suspend(master); |
774 | if (ret) { | 801 | if (ret) { |
775 | dev_warn(dev, "cannot suspend master\n"); | 802 | dev_warn(dev, "cannot suspend master\n"); |
776 | return ret; | 803 | return ret; |
777 | } | 804 | } |
778 | 805 | ||
779 | regval = mpc8xxx_spi_read_reg(®_base->mode); | 806 | return fsl_espi_suspend(master); |
780 | regval &= ~SPMODE_ENABLE; | ||
781 | mpc8xxx_spi_write_reg(®_base->mode, regval); | ||
782 | |||
783 | return 0; | ||
784 | } | 807 | } |
785 | 808 | ||
786 | static int of_fsl_espi_resume(struct device *dev) | 809 | static int of_fsl_espi_resume(struct device *dev) |