aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/spi
diff options
context:
space:
mode:
authorHeiner Kallweit <hkallweit1@gmail.com>2014-12-03 01:56:19 -0500
committerMark Brown <broonie@kernel.org>2014-12-03 08:05:47 -0500
commit75506d0e0084ee7f074be3c5da6d5de98ce347b6 (patch)
tree61bb3916c2f3f04206bc0639e287b50ee23e2a0e /drivers/spi
parentc592becbe704127ef0b89233ff7f285637491154 (diff)
spi: fsl-espi: add (un)prepare_transfer_hardware calls to save power if SPI is not in use
Use (un)prepare_transfer_hardware calls to set fsl-espi to low-power idle if not in use. Reference manual states: "The eSPI is in a idle state and consumes minimal power. The eSPI BRG is not functioning and the input clock is disabled" Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com> Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'drivers/spi')
-rw-r--r--drivers/spi/spi-fsl-espi.c46
1 files changed, 35 insertions, 11 deletions
diff --git a/drivers/spi/spi-fsl-espi.c b/drivers/spi/spi-fsl-espi.c
index 90be6405e789..56cadf13519e 100644
--- a/drivers/spi/spi-fsl-espi.c
+++ b/drivers/spi/spi-fsl-espi.c
@@ -588,6 +588,38 @@ static void fsl_espi_remove(struct mpc8xxx_spi *mspi)
588 iounmap(mspi->reg_base); 588 iounmap(mspi->reg_base);
589} 589}
590 590
591static 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(&reg_base->mode);
601 regval &= ~SPMODE_ENABLE;
602 mpc8xxx_spi_write_reg(&reg_base->mode, regval);
603
604 return 0;
605}
606
607static 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(&reg_base->mode);
617 regval |= SPMODE_ENABLE;
618 mpc8xxx_spi_write_reg(&reg_base->mode, regval);
619
620 return 0;
621}
622
591static struct spi_master * fsl_espi_probe(struct device *dev, 623static struct spi_master * fsl_espi_probe(struct device *dev,
592 struct resource *mem, unsigned int irq) 624 struct resource *mem, unsigned int irq)
593{ 625{
@@ -614,6 +646,8 @@ static struct spi_master * fsl_espi_probe(struct device *dev,
614 master->setup = fsl_espi_setup; 646 master->setup = fsl_espi_setup;
615 master->cleanup = fsl_espi_cleanup; 647 master->cleanup = fsl_espi_cleanup;
616 master->transfer_one_message = fsl_espi_do_one_msg; 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_remove = fsl_espi_remove; 653 mpc8xxx_spi->spi_remove = fsl_espi_remove;
@@ -761,25 +795,15 @@ static int of_fsl_espi_remove(struct platform_device *dev)
761static int of_fsl_espi_suspend(struct device *dev) 795static int of_fsl_espi_suspend(struct device *dev)
762{ 796{
763 struct spi_master *master = dev_get_drvdata(dev); 797 struct spi_master *master = dev_get_drvdata(dev);
764 struct mpc8xxx_spi *mpc8xxx_spi;
765 struct fsl_espi_reg *reg_base;
766 u32 regval;
767 int ret; 798 int ret;
768 799
769 mpc8xxx_spi = spi_master_get_devdata(master);
770 reg_base = mpc8xxx_spi->reg_base;
771
772 ret = spi_master_suspend(master); 800 ret = spi_master_suspend(master);
773 if (ret) { 801 if (ret) {
774 dev_warn(dev, "cannot suspend master\n"); 802 dev_warn(dev, "cannot suspend master\n");
775 return ret; 803 return ret;
776 } 804 }
777 805
778 regval = mpc8xxx_spi_read_reg(&reg_base->mode); 806 return fsl_espi_suspend(master);
779 regval &= ~SPMODE_ENABLE;
780 mpc8xxx_spi_write_reg(&reg_base->mode, regval);
781
782 return 0;
783} 807}
784 808
785static int of_fsl_espi_resume(struct device *dev) 809static int of_fsl_espi_resume(struct device *dev)