1 /* SPDX-License-Identifier: MIT */
2 /*
3  * Copyright © 2022 Intel Corporation
4  */
5 
6 #ifndef __INTEL_AUDIO_REGS_H__
7 #define __INTEL_AUDIO_REGS_H__
8 
9 #include "intel_display_reg_defs.h"
10 
11 #define G4X_AUD_CNTL_ST			_MMIO(0x620B4)
12 #define   G4X_ELD_VALID			REG_BIT(14)
13 #define   G4X_ELD_BUFFER_SIZE_MASK	REG_GENMASK(13, 9)
14 #define   G4X_ELD_ADDRESS_MASK		REG_GENMASK(8, 5)
15 #define   G4X_ELD_ACK			REG_BIT(4)
16 #define G4X_HDMIW_HDMIEDID		_MMIO(0x6210C)
17 
18 #define _IBX_HDMIW_HDMIEDID_A		0xE2050
19 #define _IBX_HDMIW_HDMIEDID_B		0xE2150
20 #define IBX_HDMIW_HDMIEDID(pipe)	_MMIO_PIPE(pipe, _IBX_HDMIW_HDMIEDID_A, \
21 						  _IBX_HDMIW_HDMIEDID_B)
22 #define _IBX_AUD_CNTL_ST_A		0xE20B4
23 #define _IBX_AUD_CNTL_ST_B		0xE21B4
24 #define IBX_AUD_CNTL_ST(pipe)		_MMIO_PIPE(pipe, _IBX_AUD_CNTL_ST_A, \
25 						  _IBX_AUD_CNTL_ST_B)
26 #define   IBX_ELD_BUFFER_SIZE_MASK	REG_GENMASK(14, 10)
27 #define   IBX_ELD_ADDRESS_MASK		REG_GENMASK(9, 5)
28 #define   IBX_ELD_ACK			REG_BIT(4)
29 #define IBX_AUD_CNTL_ST2		_MMIO(0xE20C0)
30 #define   IBX_CP_READY(port)		REG_BIT(((port) - 1) * 4 + 1)
31 #define   IBX_ELD_VALID(port)		REG_BIT(((port) - 1) * 4 + 0)
32 
33 #define _CPT_HDMIW_HDMIEDID_A		0xE5050
34 #define _CPT_HDMIW_HDMIEDID_B		0xE5150
35 #define CPT_HDMIW_HDMIEDID(pipe)	_MMIO_PIPE(pipe, _CPT_HDMIW_HDMIEDID_A, _CPT_HDMIW_HDMIEDID_B)
36 #define _CPT_AUD_CNTL_ST_A		0xE50B4
37 #define _CPT_AUD_CNTL_ST_B		0xE51B4
38 #define CPT_AUD_CNTL_ST(pipe)		_MMIO_PIPE(pipe, _CPT_AUD_CNTL_ST_A, _CPT_AUD_CNTL_ST_B)
39 #define CPT_AUD_CNTRL_ST2		_MMIO(0xE50C0)
40 
41 #define _VLV_HDMIW_HDMIEDID_A		(VLV_DISPLAY_BASE + 0x62050)
42 #define _VLV_HDMIW_HDMIEDID_B		(VLV_DISPLAY_BASE + 0x62150)
43 #define VLV_HDMIW_HDMIEDID(pipe)	_MMIO_PIPE(pipe, _VLV_HDMIW_HDMIEDID_A, _VLV_HDMIW_HDMIEDID_B)
44 #define _VLV_AUD_CNTL_ST_A		(VLV_DISPLAY_BASE + 0x620B4)
45 #define _VLV_AUD_CNTL_ST_B		(VLV_DISPLAY_BASE + 0x621B4)
46 #define VLV_AUD_CNTL_ST(pipe)		_MMIO_PIPE(pipe, _VLV_AUD_CNTL_ST_A, _VLV_AUD_CNTL_ST_B)
47 #define VLV_AUD_CNTL_ST2		_MMIO(VLV_DISPLAY_BASE + 0x620C0)
48 
49 #define _IBX_AUD_CONFIG_A		0xe2000
50 #define _IBX_AUD_CONFIG_B		0xe2100
51 #define IBX_AUD_CFG(pipe)		_MMIO_PIPE(pipe, _IBX_AUD_CONFIG_A, _IBX_AUD_CONFIG_B)
52 #define _CPT_AUD_CONFIG_A		0xe5000
53 #define _CPT_AUD_CONFIG_B		0xe5100
54 #define CPT_AUD_CFG(pipe)		_MMIO_PIPE(pipe, _CPT_AUD_CONFIG_A, _CPT_AUD_CONFIG_B)
55 #define _VLV_AUD_CONFIG_A		(VLV_DISPLAY_BASE + 0x62000)
56 #define _VLV_AUD_CONFIG_B		(VLV_DISPLAY_BASE + 0x62100)
57 #define VLV_AUD_CFG(pipe)		_MMIO_PIPE(pipe, _VLV_AUD_CONFIG_A, _VLV_AUD_CONFIG_B)
58 #define   AUD_CONFIG_N_VALUE_INDEX		REG_BIT(29)
59 #define   AUD_CONFIG_N_PROG_ENABLE		REG_BIT(28)
60 #define   AUD_CONFIG_UPPER_N_MASK		REG_GENMASK(27, 20)
61 #define   AUD_CONFIG_LOWER_N_MASK		REG_GENMASK(15, 4)
62 #define   AUD_CONFIG_N_MASK			(AUD_CONFIG_UPPER_N_MASK | \
63 						 AUD_CONFIG_LOWER_N_MASK)
64 #define   AUD_CONFIG_N(n)			(REG_FIELD_PREP(AUD_CONFIG_UPPER_N_MASK, (n) >> 12) | \
65 						 REG_FIELD_PREP(AUD_CONFIG_LOWER_N_MASK, (n) & 0xfff))
66 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK	REG_GENMASK(19, 16)
67 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_25175	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 0)
68 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_25200	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 1)
69 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_27000	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 2)
70 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_27027	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 3)
71 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_54000	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 4)
72 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_54054	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 5)
73 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_74176	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 6)
74 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_74250	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 7)
75 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_148352	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 8)
76 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_148500	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 9)
77 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_296703	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 10)
78 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_297000	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 11)
79 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_593407	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 12)
80 #define   AUD_CONFIG_PIXEL_CLOCK_HDMI_594000	REG_FIELD_PREP(AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK, 13)
81 #define   AUD_CONFIG_DISABLE_NCTS		REG_BIT(3)
82 
83 #define _HSW_AUD_CONFIG_A		0x65000
84 #define _HSW_AUD_CONFIG_B		0x65100
85 #define HSW_AUD_CFG(trans)		_MMIO_TRANS(trans, _HSW_AUD_CONFIG_A, _HSW_AUD_CONFIG_B)
86 
87 #define _HSW_AUD_MISC_CTRL_A		0x65010
88 #define _HSW_AUD_MISC_CTRL_B		0x65110
89 #define HSW_AUD_MISC_CTRL(trans)	_MMIO_TRANS(trans, _HSW_AUD_MISC_CTRL_A, _HSW_AUD_MISC_CTRL_B)
90 
91 #define _HSW_AUD_M_CTS_ENABLE_A		0x65028
92 #define _HSW_AUD_M_CTS_ENABLE_B		0x65128
93 #define HSW_AUD_M_CTS_ENABLE(trans)	_MMIO_TRANS(trans, _HSW_AUD_M_CTS_ENABLE_A, _HSW_AUD_M_CTS_ENABLE_B)
94 #define   AUD_M_CTS_M_VALUE_INDEX	REG_BIT(21)
95 #define   AUD_M_CTS_M_PROG_ENABLE	REG_BIT(20)
96 #define   AUD_CONFIG_M_MASK		REG_GENMASK(19, 0)
97 
98 #define _HSW_AUD_DIP_ELD_CTRL_ST_A	0x650b4
99 #define _HSW_AUD_DIP_ELD_CTRL_ST_B	0x651b4
100 #define HSW_AUD_DIP_ELD_CTRL(trans)	_MMIO_TRANS(trans, _HSW_AUD_DIP_ELD_CTRL_ST_A, _HSW_AUD_DIP_ELD_CTRL_ST_B)
101 
102 /* Audio Digital Converter */
103 #define _HSW_AUD_DIG_CNVT_1		0x65080
104 #define _HSW_AUD_DIG_CNVT_2		0x65180
105 #define AUD_DIG_CNVT(trans)		_MMIO_TRANS(trans, _HSW_AUD_DIG_CNVT_1, _HSW_AUD_DIG_CNVT_2)
106 #define DIP_PORT_SEL_MASK		0x3
107 
108 #define _HSW_AUD_EDID_DATA_A		0x65050
109 #define _HSW_AUD_EDID_DATA_B		0x65150
110 #define HSW_AUD_EDID_DATA(trans)	_MMIO_TRANS(trans, _HSW_AUD_EDID_DATA_A, _HSW_AUD_EDID_DATA_B)
111 
112 #define HSW_AUD_PIPE_CONV_CFG		_MMIO(0x6507c)
113 #define HSW_AUD_PIN_ELD_CP_VLD		_MMIO(0x650c0)
114 #define   AUDIO_INACTIVE(trans)		((1 << 3) << ((trans) * 4))
115 #define   AUDIO_OUTPUT_ENABLE(trans)	((1 << 2) << ((trans) * 4))
116 #define   AUDIO_CP_READY(trans)		((1 << 1) << ((trans) * 4))
117 #define   AUDIO_ELD_VALID(trans)	((1 << 0) << ((trans) * 4))
118 
119 #define _AUD_TCA_DP_2DOT0_CTRL		0x650bc
120 #define _AUD_TCB_DP_2DOT0_CTRL		0x651bc
121 #define AUD_DP_2DOT0_CTRL(trans)	_MMIO_TRANS(trans, _AUD_TCA_DP_2DOT0_CTRL, _AUD_TCB_DP_2DOT0_CTRL)
122 #define  AUD_ENABLE_SDP_SPLIT		REG_BIT(31)
123 
124 #define HSW_AUD_CHICKENBIT		_MMIO(0x65f10)
125 #define   SKL_AUD_CODEC_WAKE_SIGNAL	REG_BIT(15)
126 
127 #define AUD_FREQ_CNTRL			_MMIO(0x65900)
128 #define AUD_PIN_BUF_CTL			_MMIO(0x48414)
129 #define   AUD_PIN_BUF_ENABLE		REG_BIT(31)
130 
131 #define AUD_TS_CDCLK_M			_MMIO(0x65ea0)
132 #define   AUD_TS_CDCLK_M_EN		REG_BIT(31)
133 #define AUD_TS_CDCLK_N			_MMIO(0x65ea4)
134 
135 /* Display Audio Config Reg */
136 #define AUD_CONFIG_BE			_MMIO(0x65ef0)
137 #define HBLANK_EARLY_ENABLE_ICL(pipe)		(0x1 << (20 - (pipe)))
138 #define HBLANK_EARLY_ENABLE_TGL(pipe)		(0x1 << (24 + (pipe)))
139 #define HBLANK_START_COUNT_MASK(pipe)		(0x7 << (3 + ((pipe) * 6)))
140 #define HBLANK_START_COUNT(pipe, val)		(((val) & 0x7) << (3 + ((pipe)) * 6))
141 #define NUMBER_SAMPLES_PER_LINE_MASK(pipe)	(0x3 << ((pipe) * 6))
142 #define NUMBER_SAMPLES_PER_LINE(pipe, val)	(((val) & 0x3) << ((pipe) * 6))
143 
144 #define HBLANK_START_COUNT_8	0
145 #define HBLANK_START_COUNT_16	1
146 #define HBLANK_START_COUNT_32	2
147 #define HBLANK_START_COUNT_64	3
148 #define HBLANK_START_COUNT_96	4
149 #define HBLANK_START_COUNT_128	5
150 
151 #endif /* __INTEL_AUDIO_REGS_H__ */
152