aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sound/soc/sh/fsi.c22
1 files changed, 15 insertions, 7 deletions
diff --git a/sound/soc/sh/fsi.c b/sound/soc/sh/fsi.c
index 913916a3f716..3260d54413c8 100644
--- a/sound/soc/sh/fsi.c
+++ b/sound/soc/sh/fsi.c
@@ -1991,15 +1991,16 @@ static struct snd_soc_platform_driver fsi_soc_platform = {
1991/* 1991/*
1992 * platform function 1992 * platform function
1993 */ 1993 */
1994static void fsi_handler_init(struct fsi_priv *fsi) 1994static void fsi_handler_init(struct fsi_priv *fsi,
1995 struct sh_fsi_port_info *info)
1995{ 1996{
1996 fsi->playback.handler = &fsi_pio_push_handler; /* default PIO */ 1997 fsi->playback.handler = &fsi_pio_push_handler; /* default PIO */
1997 fsi->playback.priv = fsi; 1998 fsi->playback.priv = fsi;
1998 fsi->capture.handler = &fsi_pio_pop_handler; /* default PIO */ 1999 fsi->capture.handler = &fsi_pio_pop_handler; /* default PIO */
1999 fsi->capture.priv = fsi; 2000 fsi->capture.priv = fsi;
2000 2001
2001 if (fsi->info->tx_id) { 2002 if (info->tx_id) {
2002 fsi->playback.slave.shdma_slave.slave_id = fsi->info->tx_id; 2003 fsi->playback.slave.shdma_slave.slave_id = info->tx_id;
2003 fsi->playback.handler = &fsi_dma_push_handler; 2004 fsi->playback.handler = &fsi_dma_push_handler;
2004 } 2005 }
2005} 2006}
@@ -2009,11 +2010,16 @@ static int fsi_probe(struct platform_device *pdev)
2009 struct fsi_master *master; 2010 struct fsi_master *master;
2010 const struct platform_device_id *id_entry; 2011 const struct platform_device_id *id_entry;
2011 struct sh_fsi_platform_info *info = pdev->dev.platform_data; 2012 struct sh_fsi_platform_info *info = pdev->dev.platform_data;
2013 struct sh_fsi_port_info nul_info, *pinfo;
2012 struct fsi_priv *fsi; 2014 struct fsi_priv *fsi;
2013 struct resource *res; 2015 struct resource *res;
2014 unsigned int irq; 2016 unsigned int irq;
2015 int ret; 2017 int ret;
2016 2018
2019 nul_info.flags = 0;
2020 nul_info.tx_id = 0;
2021 nul_info.rx_id = 0;
2022
2017 id_entry = pdev->id_entry; 2023 id_entry = pdev->id_entry;
2018 if (!id_entry) { 2024 if (!id_entry) {
2019 dev_err(&pdev->dev, "unknown fsi device\n"); 2025 dev_err(&pdev->dev, "unknown fsi device\n");
@@ -2046,11 +2052,12 @@ static int fsi_probe(struct platform_device *pdev)
2046 spin_lock_init(&master->lock); 2052 spin_lock_init(&master->lock);
2047 2053
2048 /* FSI A setting */ 2054 /* FSI A setting */
2055 pinfo = (info) ? &info->port_a : &nul_info;
2049 fsi = &master->fsia; 2056 fsi = &master->fsia;
2050 fsi->base = master->base; 2057 fsi->base = master->base;
2051 fsi->master = master; 2058 fsi->master = master;
2052 fsi->info = &info->port_a; 2059 fsi->info = pinfo;
2053 fsi_handler_init(fsi); 2060 fsi_handler_init(fsi, pinfo);
2054 ret = fsi_stream_probe(fsi, &pdev->dev); 2061 ret = fsi_stream_probe(fsi, &pdev->dev);
2055 if (ret < 0) { 2062 if (ret < 0) {
2056 dev_err(&pdev->dev, "FSIA stream probe failed\n"); 2063 dev_err(&pdev->dev, "FSIA stream probe failed\n");
@@ -2058,11 +2065,12 @@ static int fsi_probe(struct platform_device *pdev)
2058 } 2065 }
2059 2066
2060 /* FSI B setting */ 2067 /* FSI B setting */
2068 pinfo = (info) ? &info->port_b : &nul_info;
2061 fsi = &master->fsib; 2069 fsi = &master->fsib;
2062 fsi->base = master->base + 0x40; 2070 fsi->base = master->base + 0x40;
2063 fsi->master = master; 2071 fsi->master = master;
2064 fsi->info = &info->port_b; 2072 fsi->info = pinfo;
2065 fsi_handler_init(fsi); 2073 fsi_handler_init(fsi, pinfo);
2066 ret = fsi_stream_probe(fsi, &pdev->dev); 2074 ret = fsi_stream_probe(fsi, &pdev->dev);
2067 if (ret < 0) { 2075 if (ret < 0) {
2068 dev_err(&pdev->dev, "FSIB stream probe failed\n"); 2076 dev_err(&pdev->dev, "FSIB stream probe failed\n");