Merge remote-tracking branches 'asoc/topic/pistachio', 'asoc/topic/pxa', 'asoc/topic/rsnd', 'asoc/topic/rt274' and 'asoc/topic/rt286' into asoc-next
This commit is contained in:
@@ -93,6 +93,15 @@
|
||||
* [mod]->fn() -> [mod]->fn() -> [mod]->fn()...
|
||||
*
|
||||
*/
|
||||
|
||||
/*
|
||||
* you can enable below define if you don't need
|
||||
* DAI status debug message when debugging
|
||||
* see rsnd_dbg_dai_call()
|
||||
*
|
||||
* #define RSND_DEBUG_NO_DAI_CALL 1
|
||||
*/
|
||||
|
||||
#include <linux/pm_runtime.h>
|
||||
#include "rsnd.h"
|
||||
|
||||
@@ -468,7 +477,7 @@ static int rsnd_status_update(u32 *status,
|
||||
__rsnd_mod_shift_##fn, \
|
||||
__rsnd_mod_add_##fn, \
|
||||
__rsnd_mod_call_##fn); \
|
||||
dev_dbg(dev, "%s[%d]\t0x%08x %s\n", \
|
||||
rsnd_dbg_dai_call(dev, "%s[%d]\t0x%08x %s\n", \
|
||||
rsnd_mod_name(mod), rsnd_mod_id(mod), *status, \
|
||||
(func_call && (mod)->ops->fn) ? #fn : ""); \
|
||||
if (func_call && (mod)->ops->fn) \
|
||||
@@ -1546,8 +1555,7 @@ static int rsnd_resume(struct device *dev)
|
||||
}
|
||||
|
||||
static const struct dev_pm_ops rsnd_pm_ops = {
|
||||
.suspend = rsnd_suspend,
|
||||
.resume = rsnd_resume,
|
||||
SET_SYSTEM_SLEEP_PM_OPS(rsnd_suspend, rsnd_resume)
|
||||
};
|
||||
|
||||
static struct platform_driver rsnd_driver = {
|
||||
|
@@ -788,4 +788,24 @@ void rsnd_mod_make_sure(struct rsnd_mod *mod, enum rsnd_mod_type type);
|
||||
#define rsnd_mod_confirm_dvc(mdvc)
|
||||
#endif
|
||||
|
||||
/*
|
||||
* If you don't need interrupt status debug message,
|
||||
* define RSND_DEBUG_NO_IRQ_STATUS as 1 on top of src.c/ssi.c
|
||||
*
|
||||
* #define RSND_DEBUG_NO_IRQ_STATUS 1
|
||||
*/
|
||||
#define rsnd_dbg_irq_status(dev, param...) \
|
||||
if (!IS_BUILTIN(RSND_DEBUG_NO_IRQ_STATUS)) \
|
||||
dev_dbg(dev, param)
|
||||
|
||||
/*
|
||||
* If you don't need rsnd_dai_call debug message,
|
||||
* define RSND_DEBUG_NO_DAI_CALL as 1 on top of core.c
|
||||
*
|
||||
* #define RSND_DEBUG_NO_DAI_CALL 1
|
||||
*/
|
||||
#define rsnd_dbg_dai_call(dev, param...) \
|
||||
if (!IS_BUILTIN(RSND_DEBUG_NO_DAI_CALL)) \
|
||||
dev_dbg(dev, param)
|
||||
|
||||
#endif
|
||||
|
@@ -8,6 +8,15 @@
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
/*
|
||||
* you can enable below define if you don't need
|
||||
* SSI interrupt status debug message when debugging
|
||||
* see rsnd_dbg_irq_status()
|
||||
*
|
||||
* #define RSND_DEBUG_NO_IRQ_STATUS 1
|
||||
*/
|
||||
|
||||
#include "rsnd.h"
|
||||
|
||||
#define SRC_NAME "src"
|
||||
@@ -325,7 +334,10 @@ static void rsnd_src_status_clear(struct rsnd_mod *mod)
|
||||
|
||||
static bool rsnd_src_error_occurred(struct rsnd_mod *mod)
|
||||
{
|
||||
struct rsnd_priv *priv = rsnd_mod_to_priv(mod);
|
||||
struct device *dev = rsnd_priv_to_dev(priv);
|
||||
u32 val0, val1;
|
||||
u32 status0, status1;
|
||||
bool ret = false;
|
||||
|
||||
val0 = val1 = OUF_SRC(rsnd_mod_id(mod));
|
||||
@@ -338,9 +350,15 @@ static bool rsnd_src_error_occurred(struct rsnd_mod *mod)
|
||||
if (rsnd_src_sync_is_enabled(mod))
|
||||
val0 = val0 & 0xffff;
|
||||
|
||||
if ((rsnd_mod_read(mod, SCU_SYS_STATUS0) & val0) ||
|
||||
(rsnd_mod_read(mod, SCU_SYS_STATUS1) & val1))
|
||||
status0 = rsnd_mod_read(mod, SCU_SYS_STATUS0);
|
||||
status1 = rsnd_mod_read(mod, SCU_SYS_STATUS1);
|
||||
if ((status0 & val0) || (status1 & val1)) {
|
||||
rsnd_dbg_irq_status(dev, "%s[%d] err status : 0x%08x, 0x%08x\n",
|
||||
rsnd_mod_name(mod), rsnd_mod_id(mod),
|
||||
status0, status1);
|
||||
|
||||
ret = true;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
@@ -11,6 +11,15 @@
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
/*
|
||||
* you can enable below define if you don't need
|
||||
* SSI interrupt status debug message when debugging
|
||||
* see rsnd_dbg_irq_status()
|
||||
*
|
||||
* #define RSND_DEBUG_NO_IRQ_STATUS 1
|
||||
*/
|
||||
|
||||
#include <sound/simple_card_utils.h>
|
||||
#include <linux/delay.h>
|
||||
#include "rsnd.h"
|
||||
@@ -603,6 +612,7 @@ static void __rsnd_ssi_interrupt(struct rsnd_mod *mod,
|
||||
struct rsnd_dai_stream *io)
|
||||
{
|
||||
struct rsnd_priv *priv = rsnd_mod_to_priv(mod);
|
||||
struct device *dev = rsnd_priv_to_dev(priv);
|
||||
int is_dma = rsnd_ssi_is_dma_mode(mod);
|
||||
u32 status;
|
||||
bool elapsed = false;
|
||||
@@ -621,8 +631,12 @@ static void __rsnd_ssi_interrupt(struct rsnd_mod *mod,
|
||||
elapsed = rsnd_ssi_pio_interrupt(mod, io);
|
||||
|
||||
/* DMA only */
|
||||
if (is_dma && (status & (UIRQ | OIRQ)))
|
||||
if (is_dma && (status & (UIRQ | OIRQ))) {
|
||||
rsnd_dbg_irq_status(dev, "%s[%d] err status : 0x%08x\n",
|
||||
rsnd_mod_name(mod), rsnd_mod_id(mod), status);
|
||||
|
||||
stop = true;
|
||||
}
|
||||
|
||||
rsnd_ssi_status_clear(mod);
|
||||
rsnd_ssi_interrupt_out:
|
||||
|
Reference in New Issue
Block a user