2020-05-01 17:58:50 +03:00
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
2019-10-26 01:41:11 +03:00
/*
* This file is provided under a dual BSD / GPLv2 license . When using or
* redistributing this file , you may do so under either license .
*
* Copyright ( c ) 2019 Intel Corporation . All rights reserved .
*
* Author : Keyon Jie < yang . jie @ linux . intel . com >
*/
# ifndef __SOF_INTEL_HDA_IPC_H
# define __SOF_INTEL_HDA_IPC_H
/*
* Primary register , mapped to
* - DIPCTDR ( HIPCIDR ) in sideband IPC ( cAVS 1.8 + )
* - DIPCT in cAVS 1.5 IPC
*
* Secondary register , mapped to :
* - DIPCTDD ( HIPCIDD ) in sideband IPC ( cAVS 1.8 + )
* - DIPCTE in cAVS 1.5 IPC
*/
/* Common bits in primary register */
/* Reserved for doorbell */
# define HDA_IPC_RSVD_31 BIT(31)
/* Target, 0 - normal message, 1 - compact message(cAVS compatible) */
# define HDA_IPC_MSG_COMPACT BIT(30)
/* Direction, 0 - request, 1 - response */
# define HDA_IPC_RSP BIT(29)
# define HDA_IPC_TYPE_SHIFT 24
# define HDA_IPC_TYPE_MASK GENMASK(28, 24)
# define HDA_IPC_TYPE(x) ((x) << HDA_IPC_TYPE_SHIFT)
# define HDA_IPC_PM_GATE HDA_IPC_TYPE(0x8U)
/* Command specific payload bits in secondary register */
/* Disable DMA tracing (0 - keep tracing, 1 - to disable DMA trace) */
# define HDA_PM_NO_DMA_TRACE BIT(4)
/* Prevent clock gating (0 - cg allowed, 1 - DSP clock always on) */
# define HDA_PM_PCG BIT(3)
/* Prevent power gating (0 - deep power state transitions allowed) */
# define HDA_PM_PPG BIT(2)
/* Indicates whether streaming is active */
# define HDA_PM_PG_STREAMING BIT(1)
# define HDA_PM_PG_RSVD BIT(0)
2020-08-26 21:45:31 +03:00
irqreturn_t cnl_ipc_irq_thread ( int irq , void * context ) ;
int cnl_ipc_send_msg ( struct snd_sof_dev * sdev , struct snd_sof_ipc_msg * msg ) ;
void cnl_ipc_dump ( struct snd_sof_dev * sdev ) ;
2019-10-26 01:41:11 +03:00
# endif