1 // SPDX-License-Identifier: GPL-2.0
3 * Greybus Audio Device Class Protocol helpers
5 * Copyright 2015-2016 Google Inc.
9 #include "greybus_protocols.h"
10 #include "operation.h"
11 #include "audio_codec.h"
13 /* TODO: Split into separate calls */
14 int gb_audio_gb_get_topology(struct gb_connection *connection,
15 struct gb_audio_topology **topology)
17 struct gb_audio_get_topology_size_response size_resp;
18 struct gb_audio_topology *topo;
22 ret = gb_operation_sync(connection, GB_AUDIO_TYPE_GET_TOPOLOGY_SIZE,
23 NULL, 0, &size_resp, sizeof(size_resp));
27 size = le16_to_cpu(size_resp.size);
28 if (size < sizeof(*topo))
31 topo = kzalloc(size, GFP_KERNEL);
35 ret = gb_operation_sync(connection, GB_AUDIO_TYPE_GET_TOPOLOGY, NULL, 0,
46 EXPORT_SYMBOL_GPL(gb_audio_gb_get_topology);
48 int gb_audio_gb_get_control(struct gb_connection *connection,
49 u8 control_id, u8 index,
50 struct gb_audio_ctl_elem_value *value)
52 struct gb_audio_get_control_request req;
53 struct gb_audio_get_control_response resp;
56 req.control_id = control_id;
59 ret = gb_operation_sync(connection, GB_AUDIO_TYPE_GET_CONTROL,
60 &req, sizeof(req), &resp, sizeof(resp));
64 memcpy(value, &resp.value, sizeof(*value));
68 EXPORT_SYMBOL_GPL(gb_audio_gb_get_control);
70 int gb_audio_gb_set_control(struct gb_connection *connection,
71 u8 control_id, u8 index,
72 struct gb_audio_ctl_elem_value *value)
74 struct gb_audio_set_control_request req;
76 req.control_id = control_id;
78 memcpy(&req.value, value, sizeof(req.value));
80 return gb_operation_sync(connection, GB_AUDIO_TYPE_SET_CONTROL,
81 &req, sizeof(req), NULL, 0);
83 EXPORT_SYMBOL_GPL(gb_audio_gb_set_control);
85 int gb_audio_gb_enable_widget(struct gb_connection *connection,
88 struct gb_audio_enable_widget_request req;
90 req.widget_id = widget_id;
92 return gb_operation_sync(connection, GB_AUDIO_TYPE_ENABLE_WIDGET,
93 &req, sizeof(req), NULL, 0);
95 EXPORT_SYMBOL_GPL(gb_audio_gb_enable_widget);
97 int gb_audio_gb_disable_widget(struct gb_connection *connection,
100 struct gb_audio_disable_widget_request req;
102 req.widget_id = widget_id;
104 return gb_operation_sync(connection, GB_AUDIO_TYPE_DISABLE_WIDGET,
105 &req, sizeof(req), NULL, 0);
107 EXPORT_SYMBOL_GPL(gb_audio_gb_disable_widget);
109 int gb_audio_gb_get_pcm(struct gb_connection *connection, u16 data_cport,
110 u32 *format, u32 *rate, u8 *channels,
113 struct gb_audio_get_pcm_request req;
114 struct gb_audio_get_pcm_response resp;
117 req.data_cport = cpu_to_le16(data_cport);
119 ret = gb_operation_sync(connection, GB_AUDIO_TYPE_GET_PCM,
120 &req, sizeof(req), &resp, sizeof(resp));
124 *format = le32_to_cpu(resp.format);
125 *rate = le32_to_cpu(resp.rate);
126 *channels = resp.channels;
127 *sig_bits = resp.sig_bits;
131 EXPORT_SYMBOL_GPL(gb_audio_gb_get_pcm);
133 int gb_audio_gb_set_pcm(struct gb_connection *connection, u16 data_cport,
134 u32 format, u32 rate, u8 channels,
137 struct gb_audio_set_pcm_request req;
139 req.data_cport = cpu_to_le16(data_cport);
140 req.format = cpu_to_le32(format);
141 req.rate = cpu_to_le32(rate);
142 req.channels = channels;
143 req.sig_bits = sig_bits;
145 return gb_operation_sync(connection, GB_AUDIO_TYPE_SET_PCM,
146 &req, sizeof(req), NULL, 0);
148 EXPORT_SYMBOL_GPL(gb_audio_gb_set_pcm);
150 int gb_audio_gb_set_tx_data_size(struct gb_connection *connection,
151 u16 data_cport, u16 size)
153 struct gb_audio_set_tx_data_size_request req;
155 req.data_cport = cpu_to_le16(data_cport);
156 req.size = cpu_to_le16(size);
158 return gb_operation_sync(connection, GB_AUDIO_TYPE_SET_TX_DATA_SIZE,
159 &req, sizeof(req), NULL, 0);
161 EXPORT_SYMBOL_GPL(gb_audio_gb_set_tx_data_size);
163 int gb_audio_gb_activate_tx(struct gb_connection *connection,
166 struct gb_audio_activate_tx_request req;
168 req.data_cport = cpu_to_le16(data_cport);
170 return gb_operation_sync(connection, GB_AUDIO_TYPE_ACTIVATE_TX,
171 &req, sizeof(req), NULL, 0);
173 EXPORT_SYMBOL_GPL(gb_audio_gb_activate_tx);
175 int gb_audio_gb_deactivate_tx(struct gb_connection *connection,
178 struct gb_audio_deactivate_tx_request req;
180 req.data_cport = cpu_to_le16(data_cport);
182 return gb_operation_sync(connection, GB_AUDIO_TYPE_DEACTIVATE_TX,
183 &req, sizeof(req), NULL, 0);
185 EXPORT_SYMBOL_GPL(gb_audio_gb_deactivate_tx);
187 int gb_audio_gb_set_rx_data_size(struct gb_connection *connection,
188 u16 data_cport, u16 size)
190 struct gb_audio_set_rx_data_size_request req;
192 req.data_cport = cpu_to_le16(data_cport);
193 req.size = cpu_to_le16(size);
195 return gb_operation_sync(connection, GB_AUDIO_TYPE_SET_RX_DATA_SIZE,
196 &req, sizeof(req), NULL, 0);
198 EXPORT_SYMBOL_GPL(gb_audio_gb_set_rx_data_size);
200 int gb_audio_gb_activate_rx(struct gb_connection *connection,
203 struct gb_audio_activate_rx_request req;
205 req.data_cport = cpu_to_le16(data_cport);
207 return gb_operation_sync(connection, GB_AUDIO_TYPE_ACTIVATE_RX,
208 &req, sizeof(req), NULL, 0);
210 EXPORT_SYMBOL_GPL(gb_audio_gb_activate_rx);
212 int gb_audio_gb_deactivate_rx(struct gb_connection *connection,
215 struct gb_audio_deactivate_rx_request req;
217 req.data_cport = cpu_to_le16(data_cport);
219 return gb_operation_sync(connection, GB_AUDIO_TYPE_DEACTIVATE_RX,
220 &req, sizeof(req), NULL, 0);
222 EXPORT_SYMBOL_GPL(gb_audio_gb_deactivate_rx);
224 MODULE_LICENSE("GPL v2");
225 MODULE_ALIAS("greybus:audio-gb");
226 MODULE_DESCRIPTION("Greybus Audio Device Class Protocol library");