1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * intel-nhlt.h - Intel HDA Platform NHLT header
4 *
5 * Copyright (c) 2015-2019 Intel Corporation
6 */
7
8 #ifndef __INTEL_NHLT_H__
9 #define __INTEL_NHLT_H__
10
11 #include <linux/acpi.h>
12
13 enum nhlt_link_type {
14 NHLT_LINK_HDA = 0,
15 NHLT_LINK_DSP = 1,
16 NHLT_LINK_DMIC = 2,
17 NHLT_LINK_SSP = 3,
18 NHLT_LINK_INVALID
19 };
20
21 enum nhlt_device_type {
22 NHLT_DEVICE_BT = 0,
23 NHLT_DEVICE_DMIC = 1,
24 NHLT_DEVICE_I2S = 4,
25 NHLT_DEVICE_INVALID
26 };
27
28 struct wav_fmt {
29 u16 fmt_tag;
30 u16 channels;
31 u32 samples_per_sec;
32 u32 avg_bytes_per_sec;
33 u16 block_align;
34 u16 bits_per_sample;
35 u16 cb_size;
36 } __packed;
37
38 struct wav_fmt_ext {
39 struct wav_fmt fmt;
40 union samples {
41 u16 valid_bits_per_sample;
42 u16 samples_per_block;
43 u16 reserved;
44 } sample;
45 u32 channel_mask;
46 u8 sub_fmt[16];
47 } __packed;
48
49 struct nhlt_specific_cfg {
50 u32 size;
51 u8 caps[];
52 } __packed;
53
54 struct nhlt_fmt_cfg {
55 struct wav_fmt_ext fmt_ext;
56 struct nhlt_specific_cfg config;
57 } __packed;
58
59 struct nhlt_fmt {
60 u8 fmt_count;
61 struct nhlt_fmt_cfg fmt_config[];
62 } __packed;
63
64 struct nhlt_endpoint {
65 u32 length;
66 u8 linktype;
67 u8 instance_id;
68 u16 vendor_id;
69 u16 device_id;
70 u16 revision_id;
71 u32 subsystem_id;
72 u8 device_type;
73 u8 direction;
74 u8 virtual_bus_id;
75 struct nhlt_specific_cfg config;
76 } __packed;
77
78 struct nhlt_acpi_table {
79 struct acpi_table_header header;
80 u8 endpoint_count;
81 struct nhlt_endpoint desc[];
82 } __packed;
83
84 struct nhlt_resource_desc {
85 u32 extra;
86 u16 flags;
87 u64 addr_spc_gra;
88 u64 min_addr;
89 u64 max_addr;
90 u64 addr_trans_offset;
91 u64 length;
92 } __packed;
93
94 #define MIC_ARRAY_2CH 2
95 #define MIC_ARRAY_4CH 4
96
97 struct nhlt_device_specific_config {
98 u8 virtual_slot;
99 u8 config_type;
100 } __packed;
101
102 struct nhlt_dmic_array_config {
103 struct nhlt_device_specific_config device_config;
104 u8 array_type;
105 } __packed;
106
107 struct nhlt_vendor_dmic_array_config {
108 struct nhlt_dmic_array_config dmic_config;
109 u8 nb_mics;
110 /* TODO add vendor mic config */
111 } __packed;
112
113 enum {
114 NHLT_CONFIG_TYPE_GENERIC = 0,
115 NHLT_CONFIG_TYPE_MIC_ARRAY = 1
116 };
117
118 enum {
119 NHLT_MIC_ARRAY_2CH_SMALL = 0xa,
120 NHLT_MIC_ARRAY_2CH_BIG = 0xb,
121 NHLT_MIC_ARRAY_4CH_1ST_GEOM = 0xc,
122 NHLT_MIC_ARRAY_4CH_L_SHAPED = 0xd,
123 NHLT_MIC_ARRAY_4CH_2ND_GEOM = 0xe,
124 NHLT_MIC_ARRAY_VENDOR_DEFINED = 0xf,
125 };
126
127 #if IS_ENABLED(CONFIG_ACPI) && IS_ENABLED(CONFIG_SND_INTEL_NHLT)
128
129 struct nhlt_acpi_table *intel_nhlt_init(struct device *dev);
130
131 void intel_nhlt_free(struct nhlt_acpi_table *addr);
132
133 int intel_nhlt_get_dmic_geo(struct device *dev, struct nhlt_acpi_table *nhlt);
134
135 bool intel_nhlt_has_endpoint_type(struct nhlt_acpi_table *nhlt, u8 link_type);
136
137 int intel_nhlt_ssp_endpoint_mask(struct nhlt_acpi_table *nhlt, u8 device_type);
138
139 int intel_nhlt_ssp_mclk_mask(struct nhlt_acpi_table *nhlt, int ssp_num);
140
141 struct nhlt_specific_cfg *
142 intel_nhlt_get_endpoint_blob(struct device *dev, struct nhlt_acpi_table *nhlt,
143 u32 bus_id, u8 link_type, u8 vbps, u8 bps,
144 u8 num_ch, u32 rate, u8 dir, u8 dev_type);
145
146 int intel_nhlt_ssp_device_type(struct device *dev, struct nhlt_acpi_table *nhlt,
147 u8 virtual_bus_id);
148
149 #else
150
intel_nhlt_init(struct device * dev)151 static inline struct nhlt_acpi_table *intel_nhlt_init(struct device *dev)
152 {
153 return NULL;
154 }
155
intel_nhlt_free(struct nhlt_acpi_table * addr)156 static inline void intel_nhlt_free(struct nhlt_acpi_table *addr)
157 {
158 }
159
intel_nhlt_get_dmic_geo(struct device * dev,struct nhlt_acpi_table * nhlt)160 static inline int intel_nhlt_get_dmic_geo(struct device *dev,
161 struct nhlt_acpi_table *nhlt)
162 {
163 return 0;
164 }
165
intel_nhlt_has_endpoint_type(struct nhlt_acpi_table * nhlt,u8 link_type)166 static inline bool intel_nhlt_has_endpoint_type(struct nhlt_acpi_table *nhlt,
167 u8 link_type)
168 {
169 return false;
170 }
171
intel_nhlt_ssp_endpoint_mask(struct nhlt_acpi_table * nhlt,u8 device_type)172 static inline int intel_nhlt_ssp_endpoint_mask(struct nhlt_acpi_table *nhlt, u8 device_type)
173 {
174 return 0;
175 }
176
intel_nhlt_ssp_mclk_mask(struct nhlt_acpi_table * nhlt,int ssp_num)177 static inline int intel_nhlt_ssp_mclk_mask(struct nhlt_acpi_table *nhlt, int ssp_num)
178 {
179 return 0;
180 }
181
182 static inline struct nhlt_specific_cfg *
intel_nhlt_get_endpoint_blob(struct device * dev,struct nhlt_acpi_table * nhlt,u32 bus_id,u8 link_type,u8 vbps,u8 bps,u8 num_ch,u32 rate,u8 dir,u8 dev_type)183 intel_nhlt_get_endpoint_blob(struct device *dev, struct nhlt_acpi_table *nhlt,
184 u32 bus_id, u8 link_type, u8 vbps, u8 bps,
185 u8 num_ch, u32 rate, u8 dir, u8 dev_type)
186 {
187 return NULL;
188 }
189
intel_nhlt_ssp_device_type(struct device * dev,struct nhlt_acpi_table * nhlt,u8 virtual_bus_id)190 static inline int intel_nhlt_ssp_device_type(struct device *dev,
191 struct nhlt_acpi_table *nhlt,
192 u8 virtual_bus_id)
193 {
194 return -EINVAL;
195 }
196
197 #endif
198
199 #endif
200