hda-ipc.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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 <[email protected]>
  9. */
  10. #ifndef __SOF_INTEL_HDA_IPC_H
  11. #define __SOF_INTEL_HDA_IPC_H
  12. /*
  13. * Primary register, mapped to
  14. * - DIPCTDR (HIPCIDR) in sideband IPC (cAVS 1.8+)
  15. * - DIPCT in cAVS 1.5 IPC
  16. *
  17. * Secondary register, mapped to:
  18. * - DIPCTDD (HIPCIDD) in sideband IPC (cAVS 1.8+)
  19. * - DIPCTE in cAVS 1.5 IPC
  20. */
  21. /* Common bits in primary register */
  22. /* Reserved for doorbell */
  23. #define HDA_IPC_RSVD_31 BIT(31)
  24. /* Target, 0 - normal message, 1 - compact message(cAVS compatible) */
  25. #define HDA_IPC_MSG_COMPACT BIT(30)
  26. /* Direction, 0 - request, 1 - response */
  27. #define HDA_IPC_RSP BIT(29)
  28. #define HDA_IPC_TYPE_SHIFT 24
  29. #define HDA_IPC_TYPE_MASK GENMASK(28, 24)
  30. #define HDA_IPC_TYPE(x) ((x) << HDA_IPC_TYPE_SHIFT)
  31. #define HDA_IPC_PM_GATE HDA_IPC_TYPE(0x8U)
  32. /* Command specific payload bits in secondary register */
  33. /* Disable DMA tracing (0 - keep tracing, 1 - to disable DMA trace) */
  34. #define HDA_PM_NO_DMA_TRACE BIT(4)
  35. /* Prevent clock gating (0 - cg allowed, 1 - DSP clock always on) */
  36. #define HDA_PM_PCG BIT(3)
  37. /* Prevent power gating (0 - deep power state transitions allowed) */
  38. #define HDA_PM_PPG BIT(2)
  39. /* Indicates whether streaming is active */
  40. #define HDA_PM_PG_STREAMING BIT(1)
  41. #define HDA_PM_PG_RSVD BIT(0)
  42. irqreturn_t cnl_ipc_irq_thread(int irq, void *context);
  43. int cnl_ipc_send_msg(struct snd_sof_dev *sdev, struct snd_sof_ipc_msg *msg);
  44. void cnl_ipc_dump(struct snd_sof_dev *sdev);
  45. void cnl_ipc4_dump(struct snd_sof_dev *sdev);
  46. #endif