Commit fed25395 authored by Mark Brown's avatar Mark Brown

Merge remote-tracking branches 'asoc/topic/davinci', 'asoc/topic/doc',...

Merge remote-tracking branches 'asoc/topic/davinci', 'asoc/topic/doc', 'asoc/topic/dpcm', 'asoc/topic/dwc' and 'asoc/topic/fsi' into asoc-next
...@@ -32,7 +32,7 @@ Optional properties: ...@@ -32,7 +32,7 @@ Optional properties:
- rx-num-evt : FIFO levels. - rx-num-evt : FIFO levels.
- sram-size-playback : size of sram to be allocated during playback - sram-size-playback : size of sram to be allocated during playback
- sram-size-capture : size of sram to be allocated during capture - sram-size-capture : size of sram to be allocated during capture
- interrupts : Interrupt numbers for McASP, currently not used by the driver - interrupts : Interrupt numbers for McASP
- interrupt-names : Known interrupt names are "tx" and "rx" - interrupt-names : Known interrupt names are "tx" and "rx"
- pinctrl-0: Should specify pin control group used for this controller. - pinctrl-0: Should specify pin control group used for this controller.
- pinctrl-names: Should contain only one value - "default", for more details - pinctrl-names: Should contain only one value - "default", for more details
......
This diff is collapsed.
...@@ -256,6 +256,7 @@ ...@@ -256,6 +256,7 @@
* DAVINCI_MCASP_TXSTAT_REG - Transmitter Status Register Bits * DAVINCI_MCASP_TXSTAT_REG - Transmitter Status Register Bits
* DAVINCI_MCASP_RXSTAT_REG - Receiver Status Register Bits * DAVINCI_MCASP_RXSTAT_REG - Receiver Status Register Bits
*/ */
#define XRERR BIT(8) /* Transmit/Receive error */
#define XRDATA BIT(5) /* Transmit/Receive data ready */ #define XRDATA BIT(5) /* Transmit/Receive data ready */
/* /*
...@@ -284,6 +285,16 @@ ...@@ -284,6 +285,16 @@
*/ */
#define TXDATADMADIS BIT(0) #define TXDATADMADIS BIT(0)
/*
* DAVINCI_MCASP_EVTCTLR_REG - Receiver Interrupt Control Register Bits
*/
#define ROVRN BIT(0)
/*
* DAVINCI_MCASP_EVTCTLX_REG - Transmitter Interrupt Control Register Bits
*/
#define XUNDRN BIT(0)
/* /*
* DAVINCI_MCASP_W[R]FIFOCTL - Write/Read FIFO Control Register bits * DAVINCI_MCASP_W[R]FIFOCTL - Write/Read FIFO Control Register bits
*/ */
......
...@@ -338,31 +338,34 @@ static int dw_i2s_probe(struct platform_device *pdev) ...@@ -338,31 +338,34 @@ static int dw_i2s_probe(struct platform_device *pdev)
return -EINVAL; return -EINVAL;
} }
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
if (!res) {
dev_err(&pdev->dev, "no i2s resource defined\n");
return -ENODEV;
}
if (!devm_request_mem_region(&pdev->dev, res->start,
resource_size(res), pdev->name)) {
dev_err(&pdev->dev, "i2s region already claimed\n");
return -EBUSY;
}
dev = devm_kzalloc(&pdev->dev, sizeof(*dev), GFP_KERNEL); dev = devm_kzalloc(&pdev->dev, sizeof(*dev), GFP_KERNEL);
if (!dev) { if (!dev) {
dev_warn(&pdev->dev, "kzalloc fail\n"); dev_warn(&pdev->dev, "kzalloc fail\n");
return -ENOMEM; return -ENOMEM;
} }
dev->i2s_base = devm_ioremap(&pdev->dev, res->start, dw_i2s_dai = devm_kzalloc(&pdev->dev, sizeof(*dw_i2s_dai), GFP_KERNEL);
resource_size(res)); if (!dw_i2s_dai) {
if (!dev->i2s_base) { dev_err(&pdev->dev, "mem allocation failed for dai driver\n");
dev_err(&pdev->dev, "ioremap fail for i2s_region\n");
return -ENOMEM; return -ENOMEM;
} }
dw_i2s_dai->ops = &dw_i2s_dai_ops;
dw_i2s_dai->suspend = dw_i2s_suspend;
dw_i2s_dai->resume = dw_i2s_resume;
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
if (!res) {
dev_err(&pdev->dev, "no i2s resource defined\n");
return -ENODEV;
}
dev->i2s_base = devm_ioremap_resource(&pdev->dev, res);
if (IS_ERR(dev->i2s_base)) {
dev_err(&pdev->dev, "ioremap fail for i2s_region\n");
return PTR_ERR(dev->i2s_base);
}
cap = pdata->cap; cap = pdata->cap;
dev->capability = cap; dev->capability = cap;
dev->i2s_clk_cfg = pdata->i2s_clk_cfg; dev->i2s_clk_cfg = pdata->i2s_clk_cfg;
...@@ -388,13 +391,6 @@ static int dw_i2s_probe(struct platform_device *pdev) ...@@ -388,13 +391,6 @@ static int dw_i2s_probe(struct platform_device *pdev)
if (ret < 0) if (ret < 0)
goto err_clk_put; goto err_clk_put;
dw_i2s_dai = devm_kzalloc(&pdev->dev, sizeof(*dw_i2s_dai), GFP_KERNEL);
if (!dw_i2s_dai) {
dev_err(&pdev->dev, "mem allocation failed for dai driver\n");
ret = -ENOMEM;
goto err_clk_disable;
}
if (cap & DWC_I2S_PLAY) { if (cap & DWC_I2S_PLAY) {
dev_dbg(&pdev->dev, " designware: play supported\n"); dev_dbg(&pdev->dev, " designware: play supported\n");
dw_i2s_dai->playback.channels_min = MIN_CHANNEL_NUM; dw_i2s_dai->playback.channels_min = MIN_CHANNEL_NUM;
...@@ -411,10 +407,6 @@ static int dw_i2s_probe(struct platform_device *pdev) ...@@ -411,10 +407,6 @@ static int dw_i2s_probe(struct platform_device *pdev)
dw_i2s_dai->capture.rates = pdata->snd_rates; dw_i2s_dai->capture.rates = pdata->snd_rates;
} }
dw_i2s_dai->ops = &dw_i2s_dai_ops;
dw_i2s_dai->suspend = dw_i2s_suspend;
dw_i2s_dai->resume = dw_i2s_resume;
dev->dev = &pdev->dev; dev->dev = &pdev->dev;
dev_set_drvdata(&pdev->dev, dev); dev_set_drvdata(&pdev->dev, dev);
ret = snd_soc_register_component(&pdev->dev, &dw_i2s_component, ret = snd_soc_register_component(&pdev->dev, &dw_i2s_component,
......
...@@ -842,12 +842,9 @@ static int fsi_clk_disable(struct device *dev, ...@@ -842,12 +842,9 @@ static int fsi_clk_disable(struct device *dev,
return -EINVAL; return -EINVAL;
if (1 == clock->count--) { if (1 == clock->count--) {
if (clock->xck) clk_disable(clock->xck);
clk_disable(clock->xck); clk_disable(clock->ick);
if (clock->ick) clk_disable(clock->div);
clk_disable(clock->ick);
if (clock->div)
clk_disable(clock->div);
} }
return 0; return 0;
......
...@@ -116,7 +116,7 @@ EXPORT_SYMBOL_GPL(snd_soc_jack_report); ...@@ -116,7 +116,7 @@ EXPORT_SYMBOL_GPL(snd_soc_jack_report);
* *
* @jack: ASoC jack * @jack: ASoC jack
* @count: Number of zones * @count: Number of zones
* @zone: Array of zones * @zones: Array of zones
* *
* After this function has been called the zones specified in the * After this function has been called the zones specified in the
* array will be associated with the jack. * array will be associated with the jack.
......
...@@ -2295,7 +2295,13 @@ int soc_dpcm_runtime_update(struct snd_soc_card *card) ...@@ -2295,7 +2295,13 @@ int soc_dpcm_runtime_update(struct snd_soc_card *card)
fe->dai_link->name); fe->dai_link->name);
/* skip if FE doesn't have playback capability */ /* skip if FE doesn't have playback capability */
if (!fe->cpu_dai->driver->playback.channels_min) if (!fe->cpu_dai->driver->playback.channels_min
|| !fe->codec_dai->driver->playback.channels_min)
goto capture;
/* skip if FE isn't currently playing */
if (!fe->cpu_dai->playback_active
|| !fe->codec_dai->playback_active)
goto capture; goto capture;
paths = dpcm_path_get(fe, SNDRV_PCM_STREAM_PLAYBACK, &list); paths = dpcm_path_get(fe, SNDRV_PCM_STREAM_PLAYBACK, &list);
...@@ -2325,7 +2331,13 @@ int soc_dpcm_runtime_update(struct snd_soc_card *card) ...@@ -2325,7 +2331,13 @@ int soc_dpcm_runtime_update(struct snd_soc_card *card)
dpcm_path_put(&list); dpcm_path_put(&list);
capture: capture:
/* skip if FE doesn't have capture capability */ /* skip if FE doesn't have capture capability */
if (!fe->cpu_dai->driver->capture.channels_min) if (!fe->cpu_dai->driver->capture.channels_min
|| !fe->codec_dai->driver->capture.channels_min)
continue;
/* skip if FE isn't currently capturing */
if (!fe->cpu_dai->capture_active
|| !fe->codec_dai->capture_active)
continue; continue;
paths = dpcm_path_get(fe, SNDRV_PCM_STREAM_CAPTURE, &list); paths = dpcm_path_get(fe, SNDRV_PCM_STREAM_CAPTURE, &list);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment