Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 1 | /* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */ |
| 2 | /* |
| 3 | * This file is provided under a dual BSD/GPLv2 license. When using or |
| 4 | * redistributing this file, you may do so under either license. |
| 5 | * |
| 6 | * Copyright(c) 2019 Intel Corporation. All rights reserved. |
| 7 | * |
| 8 | * Author: Keyon Jie <yang.jie@linux.intel.com> |
| 9 | */ |
| 10 | |
| 11 | #ifndef __SOF_INTEL_HDA_IPC_H |
| 12 | #define __SOF_INTEL_HDA_IPC_H |
| 13 | |
| 14 | /* |
| 15 | * Primary register, mapped to |
| 16 | * - DIPCTDR (HIPCIDR) in sideband IPC (cAVS 1.8+) |
| 17 | * - DIPCT in cAVS 1.5 IPC |
| 18 | * |
| 19 | * Secondary register, mapped to: |
| 20 | * - DIPCTDD (HIPCIDD) in sideband IPC (cAVS 1.8+) |
| 21 | * - DIPCTE in cAVS 1.5 IPC |
| 22 | */ |
| 23 | |
| 24 | /* Common bits in primary register */ |
| 25 | |
| 26 | /* Reserved for doorbell */ |
| 27 | #define HDA_IPC_RSVD_31 BIT(31) |
| 28 | /* Target, 0 - normal message, 1 - compact message(cAVS compatible) */ |
| 29 | #define HDA_IPC_MSG_COMPACT BIT(30) |
| 30 | /* Direction, 0 - request, 1 - response */ |
| 31 | #define HDA_IPC_RSP BIT(29) |
| 32 | |
| 33 | #define HDA_IPC_TYPE_SHIFT 24 |
| 34 | #define HDA_IPC_TYPE_MASK GENMASK(28, 24) |
| 35 | #define HDA_IPC_TYPE(x) ((x) << HDA_IPC_TYPE_SHIFT) |
| 36 | |
| 37 | #define HDA_IPC_PM_GATE HDA_IPC_TYPE(0x8U) |
| 38 | |
| 39 | /* Command specific payload bits in secondary register */ |
| 40 | |
| 41 | /* Disable DMA tracing (0 - keep tracing, 1 - to disable DMA trace) */ |
| 42 | #define HDA_PM_NO_DMA_TRACE BIT(4) |
| 43 | /* Prevent clock gating (0 - cg allowed, 1 - DSP clock always on) */ |
| 44 | #define HDA_PM_PCG BIT(3) |
| 45 | /* Prevent power gating (0 - deep power state transitions allowed) */ |
| 46 | #define HDA_PM_PPG BIT(2) |
| 47 | /* Indicates whether streaming is active */ |
| 48 | #define HDA_PM_PG_STREAMING BIT(1) |
| 49 | #define HDA_PM_PG_RSVD BIT(0) |
| 50 | |
| 51 | irqreturn_t cnl_ipc_irq_thread(int irq, void *context); |
| 52 | int cnl_ipc_send_msg(struct snd_sof_dev *sdev, struct snd_sof_ipc_msg *msg); |
| 53 | void cnl_ipc_dump(struct snd_sof_dev *sdev); |
| 54 | |
| 55 | #endif |