1 /* 2 * soc-topology.c -- ALSA SoC Topology 3 * 4 * Copyright (C) 2012 Texas Instruments Inc. 5 * Copyright (C) 2015 Intel Corporation. 6 * 7 * Authors: Liam Girdwood <liam.r.girdwood@linux.intel.com> 8 * K, Mythri P <mythri.p.k@intel.com> 9 * Prusty, Subhransu S <subhransu.s.prusty@intel.com> 10 * B, Jayachandran <jayachandran.b@intel.com> 11 * Abdullah, Omair M <omair.m.abdullah@intel.com> 12 * Jin, Yao <yao.jin@intel.com> 13 * Lin, Mengdong <mengdong.lin@intel.com> 14 * 15 * This program is free software; you can redistribute it and/or modify it 16 * under the terms of the GNU General Public License as published by the 17 * Free Software Foundation; either version 2 of the License, or (at your 18 * option) any later version. 19 * 20 * Add support to read audio firmware topology alongside firmware text. The 21 * topology data can contain kcontrols, DAPM graphs, widgets, DAIs, DAI links, 22 * equalizers, firmware, coefficients etc. 23 * 24 * This file only manages the core ALSA and ASoC components, all other bespoke 25 * firmware topology data is passed to component drivers for bespoke handling. 26 */ 27 28 #include <linux/kernel.h> 29 #include <linux/export.h> 30 #include <linux/list.h> 31 #include <linux/firmware.h> 32 #include <linux/slab.h> 33 #include <sound/soc.h> 34 #include <sound/soc-dapm.h> 35 #include <sound/soc-topology.h> 36 #include <sound/tlv.h> 37 38 /* 39 * We make several passes over the data (since it wont necessarily be ordered) 40 * and process objects in the following order. This guarantees the component 41 * drivers will be ready with any vendor data before the mixers and DAPM objects 42 * are loaded (that may make use of the vendor data). 43 */ 44 #define SOC_TPLG_PASS_MANIFEST 0 45 #define SOC_TPLG_PASS_VENDOR 1 46 #define SOC_TPLG_PASS_MIXER 2 47 #define SOC_TPLG_PASS_WIDGET 3 48 #define SOC_TPLG_PASS_PCM_DAI 4 49 #define SOC_TPLG_PASS_GRAPH 5 50 #define SOC_TPLG_PASS_PINS 6 51 #define SOC_TPLG_PASS_BE_DAI 7 52 #define SOC_TPLG_PASS_LINK 8 53 54 #define SOC_TPLG_PASS_START SOC_TPLG_PASS_MANIFEST 55 #define SOC_TPLG_PASS_END SOC_TPLG_PASS_LINK 56 57 /* 58 * Old version of ABI structs, supported for backward compatibility. 59 */ 60 61 /* Manifest v4 */ 62 struct snd_soc_tplg_manifest_v4 { 63 __le32 size; /* in bytes of this structure */ 64 __le32 control_elems; /* number of control elements */ 65 __le32 widget_elems; /* number of widget elements */ 66 __le32 graph_elems; /* number of graph elements */ 67 __le32 pcm_elems; /* number of PCM elements */ 68 __le32 dai_link_elems; /* number of DAI link elements */ 69 struct snd_soc_tplg_private priv; 70 } __packed; 71 72 /* Stream Capabilities v4 */ 73 struct snd_soc_tplg_stream_caps_v4 { 74 __le32 size; /* in bytes of this structure */ 75 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 76 __le64 formats; /* supported formats SNDRV_PCM_FMTBIT_* */ 77 __le32 rates; /* supported rates SNDRV_PCM_RATE_* */ 78 __le32 rate_min; /* min rate */ 79 __le32 rate_max; /* max rate */ 80 __le32 channels_min; /* min channels */ 81 __le32 channels_max; /* max channels */ 82 __le32 periods_min; /* min number of periods */ 83 __le32 periods_max; /* max number of periods */ 84 __le32 period_size_min; /* min period size bytes */ 85 __le32 period_size_max; /* max period size bytes */ 86 __le32 buffer_size_min; /* min buffer size bytes */ 87 __le32 buffer_size_max; /* max buffer size bytes */ 88 } __packed; 89 90 /* PCM v4 */ 91 struct snd_soc_tplg_pcm_v4 { 92 __le32 size; /* in bytes of this structure */ 93 char pcm_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 94 char dai_name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 95 __le32 pcm_id; /* unique ID - used to match with DAI link */ 96 __le32 dai_id; /* unique ID - used to match */ 97 __le32 playback; /* supports playback mode */ 98 __le32 capture; /* supports capture mode */ 99 __le32 compress; /* 1 = compressed; 0 = PCM */ 100 struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; /* for DAI link */ 101 __le32 num_streams; /* number of streams */ 102 struct snd_soc_tplg_stream_caps_v4 caps[2]; /* playback and capture for DAI */ 103 } __packed; 104 105 /* Physical link config v4 */ 106 struct snd_soc_tplg_link_config_v4 { 107 __le32 size; /* in bytes of this structure */ 108 __le32 id; /* unique ID - used to match */ 109 struct snd_soc_tplg_stream stream[SND_SOC_TPLG_STREAM_CONFIG_MAX]; /* supported configs playback and captrure */ 110 __le32 num_streams; /* number of streams */ 111 } __packed; 112 113 /* topology context */ 114 struct soc_tplg { 115 const struct firmware *fw; 116 117 /* runtime FW parsing */ 118 const u8 *pos; /* read postion */ 119 const u8 *hdr_pos; /* header position */ 120 unsigned int pass; /* pass number */ 121 122 /* component caller */ 123 struct device *dev; 124 struct snd_soc_component *comp; 125 u32 index; /* current block index */ 126 u32 req_index; /* required index, only loaded/free matching blocks */ 127 128 /* vendor specific kcontrol operations */ 129 const struct snd_soc_tplg_kcontrol_ops *io_ops; 130 int io_ops_count; 131 132 /* vendor specific bytes ext handlers, for TLV bytes controls */ 133 const struct snd_soc_tplg_bytes_ext_ops *bytes_ext_ops; 134 int bytes_ext_ops_count; 135 136 /* optional fw loading callbacks to component drivers */ 137 struct snd_soc_tplg_ops *ops; 138 }; 139 140 static int soc_tplg_process_headers(struct soc_tplg *tplg); 141 static void soc_tplg_complete(struct soc_tplg *tplg); 142 struct snd_soc_dapm_widget * 143 snd_soc_dapm_new_control_unlocked(struct snd_soc_dapm_context *dapm, 144 const struct snd_soc_dapm_widget *widget); 145 struct snd_soc_dapm_widget * 146 snd_soc_dapm_new_control(struct snd_soc_dapm_context *dapm, 147 const struct snd_soc_dapm_widget *widget); 148 149 /* check we dont overflow the data for this control chunk */ 150 static int soc_tplg_check_elem_count(struct soc_tplg *tplg, size_t elem_size, 151 unsigned int count, size_t bytes, const char *elem_type) 152 { 153 const u8 *end = tplg->pos + elem_size * count; 154 155 if (end > tplg->fw->data + tplg->fw->size) { 156 dev_err(tplg->dev, "ASoC: %s overflow end of data\n", 157 elem_type); 158 return -EINVAL; 159 } 160 161 /* check there is enough room in chunk for control. 162 extra bytes at the end of control are for vendor data here */ 163 if (elem_size * count > bytes) { 164 dev_err(tplg->dev, 165 "ASoC: %s count %d of size %zu is bigger than chunk %zu\n", 166 elem_type, count, elem_size, bytes); 167 return -EINVAL; 168 } 169 170 return 0; 171 } 172 173 static inline int soc_tplg_is_eof(struct soc_tplg *tplg) 174 { 175 const u8 *end = tplg->hdr_pos; 176 177 if (end >= tplg->fw->data + tplg->fw->size) 178 return 1; 179 return 0; 180 } 181 182 static inline unsigned long soc_tplg_get_hdr_offset(struct soc_tplg *tplg) 183 { 184 return (unsigned long)(tplg->hdr_pos - tplg->fw->data); 185 } 186 187 static inline unsigned long soc_tplg_get_offset(struct soc_tplg *tplg) 188 { 189 return (unsigned long)(tplg->pos - tplg->fw->data); 190 } 191 192 /* mapping of Kcontrol types and associated operations. */ 193 static const struct snd_soc_tplg_kcontrol_ops io_ops[] = { 194 {SND_SOC_TPLG_CTL_VOLSW, snd_soc_get_volsw, 195 snd_soc_put_volsw, snd_soc_info_volsw}, 196 {SND_SOC_TPLG_CTL_VOLSW_SX, snd_soc_get_volsw_sx, 197 snd_soc_put_volsw_sx, NULL}, 198 {SND_SOC_TPLG_CTL_ENUM, snd_soc_get_enum_double, 199 snd_soc_put_enum_double, snd_soc_info_enum_double}, 200 {SND_SOC_TPLG_CTL_ENUM_VALUE, snd_soc_get_enum_double, 201 snd_soc_put_enum_double, NULL}, 202 {SND_SOC_TPLG_CTL_BYTES, snd_soc_bytes_get, 203 snd_soc_bytes_put, snd_soc_bytes_info}, 204 {SND_SOC_TPLG_CTL_RANGE, snd_soc_get_volsw_range, 205 snd_soc_put_volsw_range, snd_soc_info_volsw_range}, 206 {SND_SOC_TPLG_CTL_VOLSW_XR_SX, snd_soc_get_xr_sx, 207 snd_soc_put_xr_sx, snd_soc_info_xr_sx}, 208 {SND_SOC_TPLG_CTL_STROBE, snd_soc_get_strobe, 209 snd_soc_put_strobe, NULL}, 210 {SND_SOC_TPLG_DAPM_CTL_VOLSW, snd_soc_dapm_get_volsw, 211 snd_soc_dapm_put_volsw, snd_soc_info_volsw}, 212 {SND_SOC_TPLG_DAPM_CTL_ENUM_DOUBLE, snd_soc_dapm_get_enum_double, 213 snd_soc_dapm_put_enum_double, snd_soc_info_enum_double}, 214 {SND_SOC_TPLG_DAPM_CTL_ENUM_VIRT, snd_soc_dapm_get_enum_double, 215 snd_soc_dapm_put_enum_double, NULL}, 216 {SND_SOC_TPLG_DAPM_CTL_ENUM_VALUE, snd_soc_dapm_get_enum_double, 217 snd_soc_dapm_put_enum_double, NULL}, 218 {SND_SOC_TPLG_DAPM_CTL_PIN, snd_soc_dapm_get_pin_switch, 219 snd_soc_dapm_put_pin_switch, snd_soc_dapm_info_pin_switch}, 220 }; 221 222 struct soc_tplg_map { 223 int uid; 224 int kid; 225 }; 226 227 /* mapping of widget types from UAPI IDs to kernel IDs */ 228 static const struct soc_tplg_map dapm_map[] = { 229 {SND_SOC_TPLG_DAPM_INPUT, snd_soc_dapm_input}, 230 {SND_SOC_TPLG_DAPM_OUTPUT, snd_soc_dapm_output}, 231 {SND_SOC_TPLG_DAPM_MUX, snd_soc_dapm_mux}, 232 {SND_SOC_TPLG_DAPM_MIXER, snd_soc_dapm_mixer}, 233 {SND_SOC_TPLG_DAPM_PGA, snd_soc_dapm_pga}, 234 {SND_SOC_TPLG_DAPM_OUT_DRV, snd_soc_dapm_out_drv}, 235 {SND_SOC_TPLG_DAPM_ADC, snd_soc_dapm_adc}, 236 {SND_SOC_TPLG_DAPM_DAC, snd_soc_dapm_dac}, 237 {SND_SOC_TPLG_DAPM_SWITCH, snd_soc_dapm_switch}, 238 {SND_SOC_TPLG_DAPM_PRE, snd_soc_dapm_pre}, 239 {SND_SOC_TPLG_DAPM_POST, snd_soc_dapm_post}, 240 {SND_SOC_TPLG_DAPM_AIF_IN, snd_soc_dapm_aif_in}, 241 {SND_SOC_TPLG_DAPM_AIF_OUT, snd_soc_dapm_aif_out}, 242 {SND_SOC_TPLG_DAPM_DAI_IN, snd_soc_dapm_dai_in}, 243 {SND_SOC_TPLG_DAPM_DAI_OUT, snd_soc_dapm_dai_out}, 244 {SND_SOC_TPLG_DAPM_DAI_LINK, snd_soc_dapm_dai_link}, 245 {SND_SOC_TPLG_DAPM_BUFFER, snd_soc_dapm_buffer}, 246 {SND_SOC_TPLG_DAPM_SCHEDULER, snd_soc_dapm_scheduler}, 247 {SND_SOC_TPLG_DAPM_EFFECT, snd_soc_dapm_effect}, 248 {SND_SOC_TPLG_DAPM_SIGGEN, snd_soc_dapm_siggen}, 249 {SND_SOC_TPLG_DAPM_SRC, snd_soc_dapm_src}, 250 {SND_SOC_TPLG_DAPM_ASRC, snd_soc_dapm_asrc}, 251 {SND_SOC_TPLG_DAPM_ENCODER, snd_soc_dapm_encoder}, 252 {SND_SOC_TPLG_DAPM_DECODER, snd_soc_dapm_decoder}, 253 }; 254 255 static int tplc_chan_get_reg(struct soc_tplg *tplg, 256 struct snd_soc_tplg_channel *chan, int map) 257 { 258 int i; 259 260 for (i = 0; i < SND_SOC_TPLG_MAX_CHAN; i++) { 261 if (chan[i].id == map) 262 return chan[i].reg; 263 } 264 265 return -EINVAL; 266 } 267 268 static int tplc_chan_get_shift(struct soc_tplg *tplg, 269 struct snd_soc_tplg_channel *chan, int map) 270 { 271 int i; 272 273 for (i = 0; i < SND_SOC_TPLG_MAX_CHAN; i++) { 274 if (chan[i].id == map) 275 return chan[i].shift; 276 } 277 278 return -EINVAL; 279 } 280 281 static int get_widget_id(int tplg_type) 282 { 283 int i; 284 285 for (i = 0; i < ARRAY_SIZE(dapm_map); i++) { 286 if (tplg_type == dapm_map[i].uid) 287 return dapm_map[i].kid; 288 } 289 290 return -EINVAL; 291 } 292 293 static inline void soc_bind_err(struct soc_tplg *tplg, 294 struct snd_soc_tplg_ctl_hdr *hdr, int index) 295 { 296 dev_err(tplg->dev, 297 "ASoC: invalid control type (g,p,i) %d:%d:%d index %d at 0x%lx\n", 298 hdr->ops.get, hdr->ops.put, hdr->ops.info, index, 299 soc_tplg_get_offset(tplg)); 300 } 301 302 static inline void soc_control_err(struct soc_tplg *tplg, 303 struct snd_soc_tplg_ctl_hdr *hdr, const char *name) 304 { 305 dev_err(tplg->dev, 306 "ASoC: no complete mixer IO handler for %s type (g,p,i) %d:%d:%d at 0x%lx\n", 307 name, hdr->ops.get, hdr->ops.put, hdr->ops.info, 308 soc_tplg_get_offset(tplg)); 309 } 310 311 /* pass vendor data to component driver for processing */ 312 static int soc_tplg_vendor_load_(struct soc_tplg *tplg, 313 struct snd_soc_tplg_hdr *hdr) 314 { 315 int ret = 0; 316 317 if (tplg->comp && tplg->ops && tplg->ops->vendor_load) 318 ret = tplg->ops->vendor_load(tplg->comp, hdr); 319 else { 320 dev_err(tplg->dev, "ASoC: no vendor load callback for ID %d\n", 321 hdr->vendor_type); 322 return -EINVAL; 323 } 324 325 if (ret < 0) 326 dev_err(tplg->dev, 327 "ASoC: vendor load failed at hdr offset %ld/0x%lx for type %d:%d\n", 328 soc_tplg_get_hdr_offset(tplg), 329 soc_tplg_get_hdr_offset(tplg), 330 hdr->type, hdr->vendor_type); 331 return ret; 332 } 333 334 /* pass vendor data to component driver for processing */ 335 static int soc_tplg_vendor_load(struct soc_tplg *tplg, 336 struct snd_soc_tplg_hdr *hdr) 337 { 338 if (tplg->pass != SOC_TPLG_PASS_VENDOR) 339 return 0; 340 341 return soc_tplg_vendor_load_(tplg, hdr); 342 } 343 344 /* optionally pass new dynamic widget to component driver. This is mainly for 345 * external widgets where we can assign private data/ops */ 346 static int soc_tplg_widget_load(struct soc_tplg *tplg, 347 struct snd_soc_dapm_widget *w, struct snd_soc_tplg_dapm_widget *tplg_w) 348 { 349 if (tplg->comp && tplg->ops && tplg->ops->widget_load) 350 return tplg->ops->widget_load(tplg->comp, w, tplg_w); 351 352 return 0; 353 } 354 355 /* optionally pass new dynamic widget to component driver. This is mainly for 356 * external widgets where we can assign private data/ops */ 357 static int soc_tplg_widget_ready(struct soc_tplg *tplg, 358 struct snd_soc_dapm_widget *w, struct snd_soc_tplg_dapm_widget *tplg_w) 359 { 360 if (tplg->comp && tplg->ops && tplg->ops->widget_ready) 361 return tplg->ops->widget_ready(tplg->comp, w, tplg_w); 362 363 return 0; 364 } 365 366 /* pass DAI configurations to component driver for extra initialization */ 367 static int soc_tplg_dai_load(struct soc_tplg *tplg, 368 struct snd_soc_dai_driver *dai_drv) 369 { 370 if (tplg->comp && tplg->ops && tplg->ops->dai_load) 371 return tplg->ops->dai_load(tplg->comp, dai_drv); 372 373 return 0; 374 } 375 376 /* pass link configurations to component driver for extra initialization */ 377 static int soc_tplg_dai_link_load(struct soc_tplg *tplg, 378 struct snd_soc_dai_link *link) 379 { 380 if (tplg->comp && tplg->ops && tplg->ops->link_load) 381 return tplg->ops->link_load(tplg->comp, link); 382 383 return 0; 384 } 385 386 /* tell the component driver that all firmware has been loaded in this request */ 387 static void soc_tplg_complete(struct soc_tplg *tplg) 388 { 389 if (tplg->comp && tplg->ops && tplg->ops->complete) 390 tplg->ops->complete(tplg->comp); 391 } 392 393 /* add a dynamic kcontrol */ 394 static int soc_tplg_add_dcontrol(struct snd_card *card, struct device *dev, 395 const struct snd_kcontrol_new *control_new, const char *prefix, 396 void *data, struct snd_kcontrol **kcontrol) 397 { 398 int err; 399 400 *kcontrol = snd_soc_cnew(control_new, data, control_new->name, prefix); 401 if (*kcontrol == NULL) { 402 dev_err(dev, "ASoC: Failed to create new kcontrol %s\n", 403 control_new->name); 404 return -ENOMEM; 405 } 406 407 err = snd_ctl_add(card, *kcontrol); 408 if (err < 0) { 409 dev_err(dev, "ASoC: Failed to add %s: %d\n", 410 control_new->name, err); 411 return err; 412 } 413 414 return 0; 415 } 416 417 /* add a dynamic kcontrol for component driver */ 418 static int soc_tplg_add_kcontrol(struct soc_tplg *tplg, 419 struct snd_kcontrol_new *k, struct snd_kcontrol **kcontrol) 420 { 421 struct snd_soc_component *comp = tplg->comp; 422 423 return soc_tplg_add_dcontrol(comp->card->snd_card, 424 comp->dev, k, NULL, comp, kcontrol); 425 } 426 427 /* remove a mixer kcontrol */ 428 static void remove_mixer(struct snd_soc_component *comp, 429 struct snd_soc_dobj *dobj, int pass) 430 { 431 struct snd_card *card = comp->card->snd_card; 432 struct soc_mixer_control *sm = 433 container_of(dobj, struct soc_mixer_control, dobj); 434 const unsigned int *p = NULL; 435 436 if (pass != SOC_TPLG_PASS_MIXER) 437 return; 438 439 if (dobj->ops && dobj->ops->control_unload) 440 dobj->ops->control_unload(comp, dobj); 441 442 if (sm->dobj.control.kcontrol->tlv.p) 443 p = sm->dobj.control.kcontrol->tlv.p; 444 snd_ctl_remove(card, sm->dobj.control.kcontrol); 445 list_del(&sm->dobj.list); 446 kfree(sm); 447 kfree(p); 448 } 449 450 /* remove an enum kcontrol */ 451 static void remove_enum(struct snd_soc_component *comp, 452 struct snd_soc_dobj *dobj, int pass) 453 { 454 struct snd_card *card = comp->card->snd_card; 455 struct soc_enum *se = container_of(dobj, struct soc_enum, dobj); 456 int i; 457 458 if (pass != SOC_TPLG_PASS_MIXER) 459 return; 460 461 if (dobj->ops && dobj->ops->control_unload) 462 dobj->ops->control_unload(comp, dobj); 463 464 snd_ctl_remove(card, se->dobj.control.kcontrol); 465 list_del(&se->dobj.list); 466 467 kfree(se->dobj.control.dvalues); 468 for (i = 0; i < se->items; i++) 469 kfree(se->dobj.control.dtexts[i]); 470 kfree(se); 471 } 472 473 /* remove a byte kcontrol */ 474 static void remove_bytes(struct snd_soc_component *comp, 475 struct snd_soc_dobj *dobj, int pass) 476 { 477 struct snd_card *card = comp->card->snd_card; 478 struct soc_bytes_ext *sb = 479 container_of(dobj, struct soc_bytes_ext, dobj); 480 481 if (pass != SOC_TPLG_PASS_MIXER) 482 return; 483 484 if (dobj->ops && dobj->ops->control_unload) 485 dobj->ops->control_unload(comp, dobj); 486 487 snd_ctl_remove(card, sb->dobj.control.kcontrol); 488 list_del(&sb->dobj.list); 489 kfree(sb); 490 } 491 492 /* remove a widget and it's kcontrols - routes must be removed first */ 493 static void remove_widget(struct snd_soc_component *comp, 494 struct snd_soc_dobj *dobj, int pass) 495 { 496 struct snd_card *card = comp->card->snd_card; 497 struct snd_soc_dapm_widget *w = 498 container_of(dobj, struct snd_soc_dapm_widget, dobj); 499 int i; 500 501 if (pass != SOC_TPLG_PASS_WIDGET) 502 return; 503 504 if (dobj->ops && dobj->ops->widget_unload) 505 dobj->ops->widget_unload(comp, dobj); 506 507 if (!w->kcontrols) 508 goto free_news; 509 510 /* 511 * Dynamic Widgets either have 1..N enum kcontrols or mixers. 512 * The enum may either have an array of values or strings. 513 */ 514 if (dobj->widget.kcontrol_type == SND_SOC_TPLG_TYPE_ENUM) { 515 /* enumerated widget mixer */ 516 for (i = 0; i < w->num_kcontrols; i++) { 517 struct snd_kcontrol *kcontrol = w->kcontrols[i]; 518 struct soc_enum *se = 519 (struct soc_enum *)kcontrol->private_value; 520 int j; 521 522 snd_ctl_remove(card, kcontrol); 523 524 kfree(se->dobj.control.dvalues); 525 for (j = 0; j < se->items; j++) 526 kfree(se->dobj.control.dtexts[j]); 527 528 kfree(se); 529 kfree(w->kcontrol_news[i].name); 530 } 531 } else { 532 /* volume mixer or bytes controls */ 533 for (i = 0; i < w->num_kcontrols; i++) { 534 struct snd_kcontrol *kcontrol = w->kcontrols[i]; 535 536 if (dobj->widget.kcontrol_type 537 == SND_SOC_TPLG_TYPE_MIXER) 538 kfree(kcontrol->tlv.p); 539 540 /* Private value is used as struct soc_mixer_control 541 * for volume mixers or soc_bytes_ext for bytes 542 * controls. 543 */ 544 kfree((void *)kcontrol->private_value); 545 snd_ctl_remove(card, kcontrol); 546 kfree(w->kcontrol_news[i].name); 547 } 548 } 549 550 free_news: 551 kfree(w->kcontrol_news); 552 553 /* widget w is freed by soc-dapm.c */ 554 } 555 556 /* remove DAI configurations */ 557 static void remove_dai(struct snd_soc_component *comp, 558 struct snd_soc_dobj *dobj, int pass) 559 { 560 struct snd_soc_dai_driver *dai_drv = 561 container_of(dobj, struct snd_soc_dai_driver, dobj); 562 563 if (pass != SOC_TPLG_PASS_PCM_DAI) 564 return; 565 566 if (dobj->ops && dobj->ops->dai_unload) 567 dobj->ops->dai_unload(comp, dobj); 568 569 kfree(dai_drv->name); 570 list_del(&dobj->list); 571 kfree(dai_drv); 572 } 573 574 /* remove link configurations */ 575 static void remove_link(struct snd_soc_component *comp, 576 struct snd_soc_dobj *dobj, int pass) 577 { 578 struct snd_soc_dai_link *link = 579 container_of(dobj, struct snd_soc_dai_link, dobj); 580 581 if (pass != SOC_TPLG_PASS_PCM_DAI) 582 return; 583 584 if (dobj->ops && dobj->ops->link_unload) 585 dobj->ops->link_unload(comp, dobj); 586 587 kfree(link->name); 588 kfree(link->stream_name); 589 kfree(link->cpu_dai_name); 590 591 list_del(&dobj->list); 592 snd_soc_remove_dai_link(comp->card, link); 593 kfree(link); 594 } 595 596 /* bind a kcontrol to it's IO handlers */ 597 static int soc_tplg_kcontrol_bind_io(struct snd_soc_tplg_ctl_hdr *hdr, 598 struct snd_kcontrol_new *k, 599 const struct soc_tplg *tplg) 600 { 601 const struct snd_soc_tplg_kcontrol_ops *ops; 602 const struct snd_soc_tplg_bytes_ext_ops *ext_ops; 603 int num_ops, i; 604 605 if (hdr->ops.info == SND_SOC_TPLG_CTL_BYTES 606 && k->iface & SNDRV_CTL_ELEM_IFACE_MIXER 607 && k->access & SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE 608 && k->access & SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK) { 609 struct soc_bytes_ext *sbe; 610 struct snd_soc_tplg_bytes_control *be; 611 612 sbe = (struct soc_bytes_ext *)k->private_value; 613 be = container_of(hdr, struct snd_soc_tplg_bytes_control, hdr); 614 615 /* TLV bytes controls need standard kcontrol info handler, 616 * TLV callback and extended put/get handlers. 617 */ 618 k->info = snd_soc_bytes_info_ext; 619 k->tlv.c = snd_soc_bytes_tlv_callback; 620 621 ext_ops = tplg->bytes_ext_ops; 622 num_ops = tplg->bytes_ext_ops_count; 623 for (i = 0; i < num_ops; i++) { 624 if (!sbe->put && ext_ops[i].id == be->ext_ops.put) 625 sbe->put = ext_ops[i].put; 626 if (!sbe->get && ext_ops[i].id == be->ext_ops.get) 627 sbe->get = ext_ops[i].get; 628 } 629 630 if (sbe->put && sbe->get) 631 return 0; 632 else 633 return -EINVAL; 634 } 635 636 /* try and map vendor specific kcontrol handlers first */ 637 ops = tplg->io_ops; 638 num_ops = tplg->io_ops_count; 639 for (i = 0; i < num_ops; i++) { 640 641 if (k->put == NULL && ops[i].id == hdr->ops.put) 642 k->put = ops[i].put; 643 if (k->get == NULL && ops[i].id == hdr->ops.get) 644 k->get = ops[i].get; 645 if (k->info == NULL && ops[i].id == hdr->ops.info) 646 k->info = ops[i].info; 647 } 648 649 /* vendor specific handlers found ? */ 650 if (k->put && k->get && k->info) 651 return 0; 652 653 /* none found so try standard kcontrol handlers */ 654 ops = io_ops; 655 num_ops = ARRAY_SIZE(io_ops); 656 for (i = 0; i < num_ops; i++) { 657 658 if (k->put == NULL && ops[i].id == hdr->ops.put) 659 k->put = ops[i].put; 660 if (k->get == NULL && ops[i].id == hdr->ops.get) 661 k->get = ops[i].get; 662 if (k->info == NULL && ops[i].id == hdr->ops.info) 663 k->info = ops[i].info; 664 } 665 666 /* standard handlers found ? */ 667 if (k->put && k->get && k->info) 668 return 0; 669 670 /* nothing to bind */ 671 return -EINVAL; 672 } 673 674 /* bind a widgets to it's evnt handlers */ 675 int snd_soc_tplg_widget_bind_event(struct snd_soc_dapm_widget *w, 676 const struct snd_soc_tplg_widget_events *events, 677 int num_events, u16 event_type) 678 { 679 int i; 680 681 w->event = NULL; 682 683 for (i = 0; i < num_events; i++) { 684 if (event_type == events[i].type) { 685 686 /* found - so assign event */ 687 w->event = events[i].event_handler; 688 return 0; 689 } 690 } 691 692 /* not found */ 693 return -EINVAL; 694 } 695 EXPORT_SYMBOL_GPL(snd_soc_tplg_widget_bind_event); 696 697 /* optionally pass new dynamic kcontrol to component driver. */ 698 static int soc_tplg_init_kcontrol(struct soc_tplg *tplg, 699 struct snd_kcontrol_new *k, struct snd_soc_tplg_ctl_hdr *hdr) 700 { 701 if (tplg->comp && tplg->ops && tplg->ops->control_load) 702 return tplg->ops->control_load(tplg->comp, k, hdr); 703 704 return 0; 705 } 706 707 708 static int soc_tplg_create_tlv_db_scale(struct soc_tplg *tplg, 709 struct snd_kcontrol_new *kc, struct snd_soc_tplg_tlv_dbscale *scale) 710 { 711 unsigned int item_len = 2 * sizeof(unsigned int); 712 unsigned int *p; 713 714 p = kzalloc(item_len + 2 * sizeof(unsigned int), GFP_KERNEL); 715 if (!p) 716 return -ENOMEM; 717 718 p[0] = SNDRV_CTL_TLVT_DB_SCALE; 719 p[1] = item_len; 720 p[2] = scale->min; 721 p[3] = (scale->step & TLV_DB_SCALE_MASK) 722 | (scale->mute ? TLV_DB_SCALE_MUTE : 0); 723 724 kc->tlv.p = (void *)p; 725 return 0; 726 } 727 728 static int soc_tplg_create_tlv(struct soc_tplg *tplg, 729 struct snd_kcontrol_new *kc, struct snd_soc_tplg_ctl_hdr *tc) 730 { 731 struct snd_soc_tplg_ctl_tlv *tplg_tlv; 732 733 if (!(tc->access & SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE)) 734 return 0; 735 736 if (!(tc->access & SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK)) { 737 tplg_tlv = &tc->tlv; 738 switch (tplg_tlv->type) { 739 case SNDRV_CTL_TLVT_DB_SCALE: 740 return soc_tplg_create_tlv_db_scale(tplg, kc, 741 &tplg_tlv->scale); 742 743 /* TODO: add support for other TLV types */ 744 default: 745 dev_dbg(tplg->dev, "Unsupported TLV type %d\n", 746 tplg_tlv->type); 747 return -EINVAL; 748 } 749 } 750 751 return 0; 752 } 753 754 static inline void soc_tplg_free_tlv(struct soc_tplg *tplg, 755 struct snd_kcontrol_new *kc) 756 { 757 kfree(kc->tlv.p); 758 } 759 760 static int soc_tplg_dbytes_create(struct soc_tplg *tplg, unsigned int count, 761 size_t size) 762 { 763 struct snd_soc_tplg_bytes_control *be; 764 struct soc_bytes_ext *sbe; 765 struct snd_kcontrol_new kc; 766 int i, err; 767 768 if (soc_tplg_check_elem_count(tplg, 769 sizeof(struct snd_soc_tplg_bytes_control), count, 770 size, "mixer bytes")) { 771 dev_err(tplg->dev, "ASoC: Invalid count %d for byte control\n", 772 count); 773 return -EINVAL; 774 } 775 776 for (i = 0; i < count; i++) { 777 be = (struct snd_soc_tplg_bytes_control *)tplg->pos; 778 779 /* validate kcontrol */ 780 if (strnlen(be->hdr.name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 781 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 782 return -EINVAL; 783 784 sbe = kzalloc(sizeof(*sbe), GFP_KERNEL); 785 if (sbe == NULL) 786 return -ENOMEM; 787 788 tplg->pos += (sizeof(struct snd_soc_tplg_bytes_control) + 789 be->priv.size); 790 791 dev_dbg(tplg->dev, 792 "ASoC: adding bytes kcontrol %s with access 0x%x\n", 793 be->hdr.name, be->hdr.access); 794 795 memset(&kc, 0, sizeof(kc)); 796 kc.name = be->hdr.name; 797 kc.private_value = (long)sbe; 798 kc.iface = SNDRV_CTL_ELEM_IFACE_MIXER; 799 kc.access = be->hdr.access; 800 801 sbe->max = be->max; 802 sbe->dobj.type = SND_SOC_DOBJ_BYTES; 803 sbe->dobj.ops = tplg->ops; 804 INIT_LIST_HEAD(&sbe->dobj.list); 805 806 /* map io handlers */ 807 err = soc_tplg_kcontrol_bind_io(&be->hdr, &kc, tplg); 808 if (err) { 809 soc_control_err(tplg, &be->hdr, be->hdr.name); 810 kfree(sbe); 811 continue; 812 } 813 814 /* pass control to driver for optional further init */ 815 err = soc_tplg_init_kcontrol(tplg, &kc, 816 (struct snd_soc_tplg_ctl_hdr *)be); 817 if (err < 0) { 818 dev_err(tplg->dev, "ASoC: failed to init %s\n", 819 be->hdr.name); 820 kfree(sbe); 821 continue; 822 } 823 824 /* register control here */ 825 err = soc_tplg_add_kcontrol(tplg, &kc, 826 &sbe->dobj.control.kcontrol); 827 if (err < 0) { 828 dev_err(tplg->dev, "ASoC: failed to add %s\n", 829 be->hdr.name); 830 kfree(sbe); 831 continue; 832 } 833 834 list_add(&sbe->dobj.list, &tplg->comp->dobj_list); 835 } 836 return 0; 837 838 } 839 840 static int soc_tplg_dmixer_create(struct soc_tplg *tplg, unsigned int count, 841 size_t size) 842 { 843 struct snd_soc_tplg_mixer_control *mc; 844 struct soc_mixer_control *sm; 845 struct snd_kcontrol_new kc; 846 int i, err; 847 848 if (soc_tplg_check_elem_count(tplg, 849 sizeof(struct snd_soc_tplg_mixer_control), 850 count, size, "mixers")) { 851 852 dev_err(tplg->dev, "ASoC: invalid count %d for controls\n", 853 count); 854 return -EINVAL; 855 } 856 857 for (i = 0; i < count; i++) { 858 mc = (struct snd_soc_tplg_mixer_control *)tplg->pos; 859 860 /* validate kcontrol */ 861 if (strnlen(mc->hdr.name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 862 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 863 return -EINVAL; 864 865 sm = kzalloc(sizeof(*sm), GFP_KERNEL); 866 if (sm == NULL) 867 return -ENOMEM; 868 tplg->pos += (sizeof(struct snd_soc_tplg_mixer_control) + 869 mc->priv.size); 870 871 dev_dbg(tplg->dev, 872 "ASoC: adding mixer kcontrol %s with access 0x%x\n", 873 mc->hdr.name, mc->hdr.access); 874 875 memset(&kc, 0, sizeof(kc)); 876 kc.name = mc->hdr.name; 877 kc.private_value = (long)sm; 878 kc.iface = SNDRV_CTL_ELEM_IFACE_MIXER; 879 kc.access = mc->hdr.access; 880 881 /* we only support FL/FR channel mapping atm */ 882 sm->reg = tplc_chan_get_reg(tplg, mc->channel, 883 SNDRV_CHMAP_FL); 884 sm->rreg = tplc_chan_get_reg(tplg, mc->channel, 885 SNDRV_CHMAP_FR); 886 sm->shift = tplc_chan_get_shift(tplg, mc->channel, 887 SNDRV_CHMAP_FL); 888 sm->rshift = tplc_chan_get_shift(tplg, mc->channel, 889 SNDRV_CHMAP_FR); 890 891 sm->max = mc->max; 892 sm->min = mc->min; 893 sm->invert = mc->invert; 894 sm->platform_max = mc->platform_max; 895 sm->dobj.index = tplg->index; 896 sm->dobj.ops = tplg->ops; 897 sm->dobj.type = SND_SOC_DOBJ_MIXER; 898 INIT_LIST_HEAD(&sm->dobj.list); 899 900 /* map io handlers */ 901 err = soc_tplg_kcontrol_bind_io(&mc->hdr, &kc, tplg); 902 if (err) { 903 soc_control_err(tplg, &mc->hdr, mc->hdr.name); 904 kfree(sm); 905 continue; 906 } 907 908 /* pass control to driver for optional further init */ 909 err = soc_tplg_init_kcontrol(tplg, &kc, 910 (struct snd_soc_tplg_ctl_hdr *) mc); 911 if (err < 0) { 912 dev_err(tplg->dev, "ASoC: failed to init %s\n", 913 mc->hdr.name); 914 kfree(sm); 915 continue; 916 } 917 918 /* create any TLV data */ 919 soc_tplg_create_tlv(tplg, &kc, &mc->hdr); 920 921 /* register control here */ 922 err = soc_tplg_add_kcontrol(tplg, &kc, 923 &sm->dobj.control.kcontrol); 924 if (err < 0) { 925 dev_err(tplg->dev, "ASoC: failed to add %s\n", 926 mc->hdr.name); 927 soc_tplg_free_tlv(tplg, &kc); 928 kfree(sm); 929 continue; 930 } 931 932 list_add(&sm->dobj.list, &tplg->comp->dobj_list); 933 } 934 935 return 0; 936 } 937 938 static int soc_tplg_denum_create_texts(struct soc_enum *se, 939 struct snd_soc_tplg_enum_control *ec) 940 { 941 int i, ret; 942 943 se->dobj.control.dtexts = 944 kzalloc(sizeof(char *) * ec->items, GFP_KERNEL); 945 if (se->dobj.control.dtexts == NULL) 946 return -ENOMEM; 947 948 for (i = 0; i < ec->items; i++) { 949 950 if (strnlen(ec->texts[i], SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 951 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) { 952 ret = -EINVAL; 953 goto err; 954 } 955 956 se->dobj.control.dtexts[i] = kstrdup(ec->texts[i], GFP_KERNEL); 957 if (!se->dobj.control.dtexts[i]) { 958 ret = -ENOMEM; 959 goto err; 960 } 961 } 962 963 se->texts = (const char * const *)se->dobj.control.dtexts; 964 return 0; 965 966 err: 967 for (--i; i >= 0; i--) 968 kfree(se->dobj.control.dtexts[i]); 969 kfree(se->dobj.control.dtexts); 970 return ret; 971 } 972 973 static int soc_tplg_denum_create_values(struct soc_enum *se, 974 struct snd_soc_tplg_enum_control *ec) 975 { 976 if (ec->items > sizeof(*ec->values)) 977 return -EINVAL; 978 979 se->dobj.control.dvalues = kmemdup(ec->values, 980 ec->items * sizeof(u32), 981 GFP_KERNEL); 982 if (!se->dobj.control.dvalues) 983 return -ENOMEM; 984 985 return 0; 986 } 987 988 static int soc_tplg_denum_create(struct soc_tplg *tplg, unsigned int count, 989 size_t size) 990 { 991 struct snd_soc_tplg_enum_control *ec; 992 struct soc_enum *se; 993 struct snd_kcontrol_new kc; 994 int i, ret, err; 995 996 if (soc_tplg_check_elem_count(tplg, 997 sizeof(struct snd_soc_tplg_enum_control), 998 count, size, "enums")) { 999 1000 dev_err(tplg->dev, "ASoC: invalid count %d for enum controls\n", 1001 count); 1002 return -EINVAL; 1003 } 1004 1005 for (i = 0; i < count; i++) { 1006 ec = (struct snd_soc_tplg_enum_control *)tplg->pos; 1007 tplg->pos += (sizeof(struct snd_soc_tplg_enum_control) + 1008 ec->priv.size); 1009 1010 /* validate kcontrol */ 1011 if (strnlen(ec->hdr.name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1012 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1013 return -EINVAL; 1014 1015 se = kzalloc((sizeof(*se)), GFP_KERNEL); 1016 if (se == NULL) 1017 return -ENOMEM; 1018 1019 dev_dbg(tplg->dev, "ASoC: adding enum kcontrol %s size %d\n", 1020 ec->hdr.name, ec->items); 1021 1022 memset(&kc, 0, sizeof(kc)); 1023 kc.name = ec->hdr.name; 1024 kc.private_value = (long)se; 1025 kc.iface = SNDRV_CTL_ELEM_IFACE_MIXER; 1026 kc.access = ec->hdr.access; 1027 1028 se->reg = tplc_chan_get_reg(tplg, ec->channel, SNDRV_CHMAP_FL); 1029 se->shift_l = tplc_chan_get_shift(tplg, ec->channel, 1030 SNDRV_CHMAP_FL); 1031 se->shift_r = tplc_chan_get_shift(tplg, ec->channel, 1032 SNDRV_CHMAP_FL); 1033 1034 se->items = ec->items; 1035 se->mask = ec->mask; 1036 se->dobj.index = tplg->index; 1037 se->dobj.type = SND_SOC_DOBJ_ENUM; 1038 se->dobj.ops = tplg->ops; 1039 INIT_LIST_HEAD(&se->dobj.list); 1040 1041 switch (ec->hdr.ops.info) { 1042 case SND_SOC_TPLG_DAPM_CTL_ENUM_VALUE: 1043 case SND_SOC_TPLG_CTL_ENUM_VALUE: 1044 err = soc_tplg_denum_create_values(se, ec); 1045 if (err < 0) { 1046 dev_err(tplg->dev, 1047 "ASoC: could not create values for %s\n", 1048 ec->hdr.name); 1049 kfree(se); 1050 continue; 1051 } 1052 /* fall through and create texts */ 1053 case SND_SOC_TPLG_CTL_ENUM: 1054 case SND_SOC_TPLG_DAPM_CTL_ENUM_DOUBLE: 1055 case SND_SOC_TPLG_DAPM_CTL_ENUM_VIRT: 1056 err = soc_tplg_denum_create_texts(se, ec); 1057 if (err < 0) { 1058 dev_err(tplg->dev, 1059 "ASoC: could not create texts for %s\n", 1060 ec->hdr.name); 1061 kfree(se); 1062 continue; 1063 } 1064 break; 1065 default: 1066 dev_err(tplg->dev, 1067 "ASoC: invalid enum control type %d for %s\n", 1068 ec->hdr.ops.info, ec->hdr.name); 1069 kfree(se); 1070 continue; 1071 } 1072 1073 /* map io handlers */ 1074 err = soc_tplg_kcontrol_bind_io(&ec->hdr, &kc, tplg); 1075 if (err) { 1076 soc_control_err(tplg, &ec->hdr, ec->hdr.name); 1077 kfree(se); 1078 continue; 1079 } 1080 1081 /* pass control to driver for optional further init */ 1082 err = soc_tplg_init_kcontrol(tplg, &kc, 1083 (struct snd_soc_tplg_ctl_hdr *) ec); 1084 if (err < 0) { 1085 dev_err(tplg->dev, "ASoC: failed to init %s\n", 1086 ec->hdr.name); 1087 kfree(se); 1088 continue; 1089 } 1090 1091 /* register control here */ 1092 ret = soc_tplg_add_kcontrol(tplg, 1093 &kc, &se->dobj.control.kcontrol); 1094 if (ret < 0) { 1095 dev_err(tplg->dev, "ASoC: could not add kcontrol %s\n", 1096 ec->hdr.name); 1097 kfree(se); 1098 continue; 1099 } 1100 1101 list_add(&se->dobj.list, &tplg->comp->dobj_list); 1102 } 1103 1104 return 0; 1105 } 1106 1107 static int soc_tplg_kcontrol_elems_load(struct soc_tplg *tplg, 1108 struct snd_soc_tplg_hdr *hdr) 1109 { 1110 struct snd_soc_tplg_ctl_hdr *control_hdr; 1111 int i; 1112 1113 if (tplg->pass != SOC_TPLG_PASS_MIXER) { 1114 tplg->pos += hdr->size + hdr->payload_size; 1115 return 0; 1116 } 1117 1118 dev_dbg(tplg->dev, "ASoC: adding %d kcontrols at 0x%lx\n", hdr->count, 1119 soc_tplg_get_offset(tplg)); 1120 1121 for (i = 0; i < hdr->count; i++) { 1122 1123 control_hdr = (struct snd_soc_tplg_ctl_hdr *)tplg->pos; 1124 1125 if (control_hdr->size != sizeof(*control_hdr)) { 1126 dev_err(tplg->dev, "ASoC: invalid control size\n"); 1127 return -EINVAL; 1128 } 1129 1130 switch (control_hdr->ops.info) { 1131 case SND_SOC_TPLG_CTL_VOLSW: 1132 case SND_SOC_TPLG_CTL_STROBE: 1133 case SND_SOC_TPLG_CTL_VOLSW_SX: 1134 case SND_SOC_TPLG_CTL_VOLSW_XR_SX: 1135 case SND_SOC_TPLG_CTL_RANGE: 1136 case SND_SOC_TPLG_DAPM_CTL_VOLSW: 1137 case SND_SOC_TPLG_DAPM_CTL_PIN: 1138 soc_tplg_dmixer_create(tplg, 1, hdr->payload_size); 1139 break; 1140 case SND_SOC_TPLG_CTL_ENUM: 1141 case SND_SOC_TPLG_CTL_ENUM_VALUE: 1142 case SND_SOC_TPLG_DAPM_CTL_ENUM_DOUBLE: 1143 case SND_SOC_TPLG_DAPM_CTL_ENUM_VIRT: 1144 case SND_SOC_TPLG_DAPM_CTL_ENUM_VALUE: 1145 soc_tplg_denum_create(tplg, 1, hdr->payload_size); 1146 break; 1147 case SND_SOC_TPLG_CTL_BYTES: 1148 soc_tplg_dbytes_create(tplg, 1, hdr->payload_size); 1149 break; 1150 default: 1151 soc_bind_err(tplg, control_hdr, i); 1152 return -EINVAL; 1153 } 1154 } 1155 1156 return 0; 1157 } 1158 1159 static int soc_tplg_dapm_graph_elems_load(struct soc_tplg *tplg, 1160 struct snd_soc_tplg_hdr *hdr) 1161 { 1162 struct snd_soc_dapm_context *dapm = &tplg->comp->dapm; 1163 struct snd_soc_dapm_route route; 1164 struct snd_soc_tplg_dapm_graph_elem *elem; 1165 int count = hdr->count, i; 1166 1167 if (tplg->pass != SOC_TPLG_PASS_GRAPH) { 1168 tplg->pos += hdr->size + hdr->payload_size; 1169 return 0; 1170 } 1171 1172 if (soc_tplg_check_elem_count(tplg, 1173 sizeof(struct snd_soc_tplg_dapm_graph_elem), 1174 count, hdr->payload_size, "graph")) { 1175 1176 dev_err(tplg->dev, "ASoC: invalid count %d for DAPM routes\n", 1177 count); 1178 return -EINVAL; 1179 } 1180 1181 dev_dbg(tplg->dev, "ASoC: adding %d DAPM routes for index %d\n", count, 1182 hdr->index); 1183 1184 for (i = 0; i < count; i++) { 1185 elem = (struct snd_soc_tplg_dapm_graph_elem *)tplg->pos; 1186 tplg->pos += sizeof(struct snd_soc_tplg_dapm_graph_elem); 1187 1188 /* validate routes */ 1189 if (strnlen(elem->source, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1190 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1191 return -EINVAL; 1192 if (strnlen(elem->sink, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1193 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1194 return -EINVAL; 1195 if (strnlen(elem->control, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1196 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1197 return -EINVAL; 1198 1199 route.source = elem->source; 1200 route.sink = elem->sink; 1201 route.connected = NULL; /* set to NULL atm for tplg users */ 1202 if (strnlen(elem->control, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 0) 1203 route.control = NULL; 1204 else 1205 route.control = elem->control; 1206 1207 /* add route, but keep going if some fail */ 1208 snd_soc_dapm_add_routes(dapm, &route, 1); 1209 } 1210 1211 return 0; 1212 } 1213 1214 static struct snd_kcontrol_new *soc_tplg_dapm_widget_dmixer_create( 1215 struct soc_tplg *tplg, int num_kcontrols) 1216 { 1217 struct snd_kcontrol_new *kc; 1218 struct soc_mixer_control *sm; 1219 struct snd_soc_tplg_mixer_control *mc; 1220 int i, err; 1221 1222 kc = kcalloc(num_kcontrols, sizeof(*kc), GFP_KERNEL); 1223 if (kc == NULL) 1224 return NULL; 1225 1226 for (i = 0; i < num_kcontrols; i++) { 1227 mc = (struct snd_soc_tplg_mixer_control *)tplg->pos; 1228 sm = kzalloc(sizeof(*sm), GFP_KERNEL); 1229 if (sm == NULL) 1230 goto err; 1231 1232 tplg->pos += (sizeof(struct snd_soc_tplg_mixer_control) + 1233 mc->priv.size); 1234 1235 /* validate kcontrol */ 1236 if (strnlen(mc->hdr.name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1237 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1238 goto err_str; 1239 1240 dev_dbg(tplg->dev, " adding DAPM widget mixer control %s at %d\n", 1241 mc->hdr.name, i); 1242 1243 kc[i].name = kstrdup(mc->hdr.name, GFP_KERNEL); 1244 if (kc[i].name == NULL) 1245 goto err_str; 1246 kc[i].private_value = (long)sm; 1247 kc[i].iface = SNDRV_CTL_ELEM_IFACE_MIXER; 1248 kc[i].access = mc->hdr.access; 1249 1250 /* we only support FL/FR channel mapping atm */ 1251 sm->reg = tplc_chan_get_reg(tplg, mc->channel, 1252 SNDRV_CHMAP_FL); 1253 sm->rreg = tplc_chan_get_reg(tplg, mc->channel, 1254 SNDRV_CHMAP_FR); 1255 sm->shift = tplc_chan_get_shift(tplg, mc->channel, 1256 SNDRV_CHMAP_FL); 1257 sm->rshift = tplc_chan_get_shift(tplg, mc->channel, 1258 SNDRV_CHMAP_FR); 1259 1260 sm->max = mc->max; 1261 sm->min = mc->min; 1262 sm->invert = mc->invert; 1263 sm->platform_max = mc->platform_max; 1264 sm->dobj.index = tplg->index; 1265 INIT_LIST_HEAD(&sm->dobj.list); 1266 1267 /* map io handlers */ 1268 err = soc_tplg_kcontrol_bind_io(&mc->hdr, &kc[i], tplg); 1269 if (err) { 1270 soc_control_err(tplg, &mc->hdr, mc->hdr.name); 1271 kfree(sm); 1272 continue; 1273 } 1274 1275 /* pass control to driver for optional further init */ 1276 err = soc_tplg_init_kcontrol(tplg, &kc[i], 1277 (struct snd_soc_tplg_ctl_hdr *)mc); 1278 if (err < 0) { 1279 dev_err(tplg->dev, "ASoC: failed to init %s\n", 1280 mc->hdr.name); 1281 kfree(sm); 1282 continue; 1283 } 1284 1285 /* create any TLV data */ 1286 soc_tplg_create_tlv(tplg, &kc[i], &mc->hdr); 1287 } 1288 return kc; 1289 1290 err_str: 1291 kfree(sm); 1292 err: 1293 for (--i; i >= 0; i--) { 1294 kfree((void *)kc[i].private_value); 1295 kfree(kc[i].name); 1296 } 1297 kfree(kc); 1298 return NULL; 1299 } 1300 1301 static struct snd_kcontrol_new *soc_tplg_dapm_widget_denum_create( 1302 struct soc_tplg *tplg, int num_kcontrols) 1303 { 1304 struct snd_kcontrol_new *kc; 1305 struct snd_soc_tplg_enum_control *ec; 1306 struct soc_enum *se; 1307 int i, j, err; 1308 1309 kc = kcalloc(num_kcontrols, sizeof(*kc), GFP_KERNEL); 1310 if (kc == NULL) 1311 return NULL; 1312 1313 for (i = 0; i < num_kcontrols; i++) { 1314 ec = (struct snd_soc_tplg_enum_control *)tplg->pos; 1315 /* validate kcontrol */ 1316 if (strnlen(ec->hdr.name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1317 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1318 goto err; 1319 1320 se = kzalloc(sizeof(*se), GFP_KERNEL); 1321 if (se == NULL) 1322 goto err; 1323 1324 dev_dbg(tplg->dev, " adding DAPM widget enum control %s\n", 1325 ec->hdr.name); 1326 1327 kc[i].name = kstrdup(ec->hdr.name, GFP_KERNEL); 1328 if (kc[i].name == NULL) 1329 goto err_se; 1330 kc[i].private_value = (long)se; 1331 kc[i].iface = SNDRV_CTL_ELEM_IFACE_MIXER; 1332 kc[i].access = ec->hdr.access; 1333 1334 /* we only support FL/FR channel mapping atm */ 1335 se->reg = tplc_chan_get_reg(tplg, ec->channel, SNDRV_CHMAP_FL); 1336 se->shift_l = tplc_chan_get_shift(tplg, ec->channel, 1337 SNDRV_CHMAP_FL); 1338 se->shift_r = tplc_chan_get_shift(tplg, ec->channel, 1339 SNDRV_CHMAP_FR); 1340 1341 se->items = ec->items; 1342 se->mask = ec->mask; 1343 se->dobj.index = tplg->index; 1344 1345 switch (ec->hdr.ops.info) { 1346 case SND_SOC_TPLG_CTL_ENUM_VALUE: 1347 case SND_SOC_TPLG_DAPM_CTL_ENUM_VALUE: 1348 err = soc_tplg_denum_create_values(se, ec); 1349 if (err < 0) { 1350 dev_err(tplg->dev, "ASoC: could not create values for %s\n", 1351 ec->hdr.name); 1352 goto err_se; 1353 } 1354 /* fall through to create texts */ 1355 case SND_SOC_TPLG_CTL_ENUM: 1356 case SND_SOC_TPLG_DAPM_CTL_ENUM_DOUBLE: 1357 case SND_SOC_TPLG_DAPM_CTL_ENUM_VIRT: 1358 err = soc_tplg_denum_create_texts(se, ec); 1359 if (err < 0) { 1360 dev_err(tplg->dev, "ASoC: could not create texts for %s\n", 1361 ec->hdr.name); 1362 goto err_se; 1363 } 1364 break; 1365 default: 1366 dev_err(tplg->dev, "ASoC: invalid enum control type %d for %s\n", 1367 ec->hdr.ops.info, ec->hdr.name); 1368 goto err_se; 1369 } 1370 1371 /* map io handlers */ 1372 err = soc_tplg_kcontrol_bind_io(&ec->hdr, &kc[i], tplg); 1373 if (err) { 1374 soc_control_err(tplg, &ec->hdr, ec->hdr.name); 1375 goto err_se; 1376 } 1377 1378 /* pass control to driver for optional further init */ 1379 err = soc_tplg_init_kcontrol(tplg, &kc[i], 1380 (struct snd_soc_tplg_ctl_hdr *)ec); 1381 if (err < 0) { 1382 dev_err(tplg->dev, "ASoC: failed to init %s\n", 1383 ec->hdr.name); 1384 goto err_se; 1385 } 1386 1387 tplg->pos += (sizeof(struct snd_soc_tplg_enum_control) + 1388 ec->priv.size); 1389 } 1390 1391 return kc; 1392 1393 err_se: 1394 for (; i >= 0; i--) { 1395 /* free values and texts */ 1396 se = (struct soc_enum *)kc[i].private_value; 1397 if (!se) 1398 continue; 1399 1400 kfree(se->dobj.control.dvalues); 1401 for (j = 0; j < ec->items; j++) 1402 kfree(se->dobj.control.dtexts[j]); 1403 1404 kfree(se); 1405 kfree(kc[i].name); 1406 } 1407 err: 1408 kfree(kc); 1409 1410 return NULL; 1411 } 1412 1413 static struct snd_kcontrol_new *soc_tplg_dapm_widget_dbytes_create( 1414 struct soc_tplg *tplg, int count) 1415 { 1416 struct snd_soc_tplg_bytes_control *be; 1417 struct soc_bytes_ext *sbe; 1418 struct snd_kcontrol_new *kc; 1419 int i, err; 1420 1421 kc = kcalloc(count, sizeof(*kc), GFP_KERNEL); 1422 if (!kc) 1423 return NULL; 1424 1425 for (i = 0; i < count; i++) { 1426 be = (struct snd_soc_tplg_bytes_control *)tplg->pos; 1427 1428 /* validate kcontrol */ 1429 if (strnlen(be->hdr.name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1430 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1431 goto err; 1432 1433 sbe = kzalloc(sizeof(*sbe), GFP_KERNEL); 1434 if (sbe == NULL) 1435 goto err; 1436 1437 tplg->pos += (sizeof(struct snd_soc_tplg_bytes_control) + 1438 be->priv.size); 1439 1440 dev_dbg(tplg->dev, 1441 "ASoC: adding bytes kcontrol %s with access 0x%x\n", 1442 be->hdr.name, be->hdr.access); 1443 1444 kc[i].name = kstrdup(be->hdr.name, GFP_KERNEL); 1445 if (kc[i].name == NULL) 1446 goto err; 1447 kc[i].private_value = (long)sbe; 1448 kc[i].iface = SNDRV_CTL_ELEM_IFACE_MIXER; 1449 kc[i].access = be->hdr.access; 1450 1451 sbe->max = be->max; 1452 INIT_LIST_HEAD(&sbe->dobj.list); 1453 1454 /* map standard io handlers and check for external handlers */ 1455 err = soc_tplg_kcontrol_bind_io(&be->hdr, &kc[i], tplg); 1456 if (err) { 1457 soc_control_err(tplg, &be->hdr, be->hdr.name); 1458 kfree(sbe); 1459 continue; 1460 } 1461 1462 /* pass control to driver for optional further init */ 1463 err = soc_tplg_init_kcontrol(tplg, &kc[i], 1464 (struct snd_soc_tplg_ctl_hdr *)be); 1465 if (err < 0) { 1466 dev_err(tplg->dev, "ASoC: failed to init %s\n", 1467 be->hdr.name); 1468 kfree(sbe); 1469 continue; 1470 } 1471 } 1472 1473 return kc; 1474 1475 err: 1476 for (--i; i >= 0; i--) { 1477 kfree((void *)kc[i].private_value); 1478 kfree(kc[i].name); 1479 } 1480 1481 kfree(kc); 1482 return NULL; 1483 } 1484 1485 static int soc_tplg_dapm_widget_create(struct soc_tplg *tplg, 1486 struct snd_soc_tplg_dapm_widget *w) 1487 { 1488 struct snd_soc_dapm_context *dapm = &tplg->comp->dapm; 1489 struct snd_soc_dapm_widget template, *widget; 1490 struct snd_soc_tplg_ctl_hdr *control_hdr; 1491 struct snd_soc_card *card = tplg->comp->card; 1492 unsigned int kcontrol_type; 1493 int ret = 0; 1494 1495 if (strnlen(w->name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1496 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1497 return -EINVAL; 1498 if (strnlen(w->sname, SNDRV_CTL_ELEM_ID_NAME_MAXLEN) == 1499 SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 1500 return -EINVAL; 1501 1502 dev_dbg(tplg->dev, "ASoC: creating DAPM widget %s id %d\n", 1503 w->name, w->id); 1504 1505 memset(&template, 0, sizeof(template)); 1506 1507 /* map user to kernel widget ID */ 1508 template.id = get_widget_id(w->id); 1509 if (template.id < 0) 1510 return template.id; 1511 1512 /* strings are allocated here, but used and freed by the widget */ 1513 template.name = kstrdup(w->name, GFP_KERNEL); 1514 if (!template.name) 1515 return -ENOMEM; 1516 template.sname = kstrdup(w->sname, GFP_KERNEL); 1517 if (!template.sname) { 1518 ret = -ENOMEM; 1519 goto err; 1520 } 1521 template.reg = w->reg; 1522 template.shift = w->shift; 1523 template.mask = w->mask; 1524 template.subseq = w->subseq; 1525 template.on_val = w->invert ? 0 : 1; 1526 template.off_val = w->invert ? 1 : 0; 1527 template.ignore_suspend = w->ignore_suspend; 1528 template.event_flags = w->event_flags; 1529 template.dobj.index = tplg->index; 1530 1531 tplg->pos += 1532 (sizeof(struct snd_soc_tplg_dapm_widget) + w->priv.size); 1533 if (w->num_kcontrols == 0) { 1534 kcontrol_type = 0; 1535 template.num_kcontrols = 0; 1536 goto widget; 1537 } 1538 1539 control_hdr = (struct snd_soc_tplg_ctl_hdr *)tplg->pos; 1540 dev_dbg(tplg->dev, "ASoC: template %s has %d controls of type %x\n", 1541 w->name, w->num_kcontrols, control_hdr->type); 1542 1543 switch (control_hdr->ops.info) { 1544 case SND_SOC_TPLG_CTL_VOLSW: 1545 case SND_SOC_TPLG_CTL_STROBE: 1546 case SND_SOC_TPLG_CTL_VOLSW_SX: 1547 case SND_SOC_TPLG_CTL_VOLSW_XR_SX: 1548 case SND_SOC_TPLG_CTL_RANGE: 1549 case SND_SOC_TPLG_DAPM_CTL_VOLSW: 1550 kcontrol_type = SND_SOC_TPLG_TYPE_MIXER; /* volume mixer */ 1551 template.num_kcontrols = w->num_kcontrols; 1552 template.kcontrol_news = 1553 soc_tplg_dapm_widget_dmixer_create(tplg, 1554 template.num_kcontrols); 1555 if (!template.kcontrol_news) { 1556 ret = -ENOMEM; 1557 goto hdr_err; 1558 } 1559 break; 1560 case SND_SOC_TPLG_CTL_ENUM: 1561 case SND_SOC_TPLG_CTL_ENUM_VALUE: 1562 case SND_SOC_TPLG_DAPM_CTL_ENUM_DOUBLE: 1563 case SND_SOC_TPLG_DAPM_CTL_ENUM_VIRT: 1564 case SND_SOC_TPLG_DAPM_CTL_ENUM_VALUE: 1565 kcontrol_type = SND_SOC_TPLG_TYPE_ENUM; /* enumerated mixer */ 1566 template.num_kcontrols = w->num_kcontrols; 1567 template.kcontrol_news = 1568 soc_tplg_dapm_widget_denum_create(tplg, 1569 template.num_kcontrols); 1570 if (!template.kcontrol_news) { 1571 ret = -ENOMEM; 1572 goto hdr_err; 1573 } 1574 break; 1575 case SND_SOC_TPLG_CTL_BYTES: 1576 kcontrol_type = SND_SOC_TPLG_TYPE_BYTES; /* bytes control */ 1577 template.num_kcontrols = w->num_kcontrols; 1578 template.kcontrol_news = 1579 soc_tplg_dapm_widget_dbytes_create(tplg, 1580 template.num_kcontrols); 1581 if (!template.kcontrol_news) { 1582 ret = -ENOMEM; 1583 goto hdr_err; 1584 } 1585 break; 1586 default: 1587 dev_err(tplg->dev, "ASoC: invalid widget control type %d:%d:%d\n", 1588 control_hdr->ops.get, control_hdr->ops.put, 1589 control_hdr->ops.info); 1590 ret = -EINVAL; 1591 goto hdr_err; 1592 } 1593 1594 widget: 1595 ret = soc_tplg_widget_load(tplg, &template, w); 1596 if (ret < 0) 1597 goto hdr_err; 1598 1599 /* card dapm mutex is held by the core if we are loading topology 1600 * data during sound card init. */ 1601 if (card->instantiated) 1602 widget = snd_soc_dapm_new_control(dapm, &template); 1603 else 1604 widget = snd_soc_dapm_new_control_unlocked(dapm, &template); 1605 if (IS_ERR(widget)) { 1606 ret = PTR_ERR(widget); 1607 /* Do not nag about probe deferrals */ 1608 if (ret != -EPROBE_DEFER) 1609 dev_err(tplg->dev, 1610 "ASoC: failed to create widget %s controls (%d)\n", 1611 w->name, ret); 1612 goto hdr_err; 1613 } 1614 if (widget == NULL) { 1615 dev_err(tplg->dev, "ASoC: failed to create widget %s controls\n", 1616 w->name); 1617 ret = -ENOMEM; 1618 goto hdr_err; 1619 } 1620 1621 widget->dobj.type = SND_SOC_DOBJ_WIDGET; 1622 widget->dobj.widget.kcontrol_type = kcontrol_type; 1623 widget->dobj.ops = tplg->ops; 1624 widget->dobj.index = tplg->index; 1625 list_add(&widget->dobj.list, &tplg->comp->dobj_list); 1626 1627 ret = soc_tplg_widget_ready(tplg, widget, w); 1628 if (ret < 0) 1629 goto ready_err; 1630 1631 return 0; 1632 1633 ready_err: 1634 snd_soc_tplg_widget_remove(widget); 1635 snd_soc_dapm_free_widget(widget); 1636 hdr_err: 1637 kfree(template.sname); 1638 err: 1639 kfree(template.name); 1640 return ret; 1641 } 1642 1643 static int soc_tplg_dapm_widget_elems_load(struct soc_tplg *tplg, 1644 struct snd_soc_tplg_hdr *hdr) 1645 { 1646 struct snd_soc_tplg_dapm_widget *widget; 1647 int ret, count = hdr->count, i; 1648 1649 if (tplg->pass != SOC_TPLG_PASS_WIDGET) 1650 return 0; 1651 1652 dev_dbg(tplg->dev, "ASoC: adding %d DAPM widgets\n", count); 1653 1654 for (i = 0; i < count; i++) { 1655 widget = (struct snd_soc_tplg_dapm_widget *) tplg->pos; 1656 if (widget->size != sizeof(*widget)) { 1657 dev_err(tplg->dev, "ASoC: invalid widget size\n"); 1658 return -EINVAL; 1659 } 1660 1661 ret = soc_tplg_dapm_widget_create(tplg, widget); 1662 if (ret < 0) { 1663 dev_err(tplg->dev, "ASoC: failed to load widget %s\n", 1664 widget->name); 1665 return ret; 1666 } 1667 } 1668 1669 return 0; 1670 } 1671 1672 static int soc_tplg_dapm_complete(struct soc_tplg *tplg) 1673 { 1674 struct snd_soc_card *card = tplg->comp->card; 1675 int ret; 1676 1677 /* Card might not have been registered at this point. 1678 * If so, just return success. 1679 */ 1680 if (!card || !card->instantiated) { 1681 dev_warn(tplg->dev, "ASoC: Parent card not yet available," 1682 " widget card binding deferred\n"); 1683 return 0; 1684 } 1685 1686 ret = snd_soc_dapm_new_widgets(card); 1687 if (ret < 0) 1688 dev_err(tplg->dev, "ASoC: failed to create new widgets %d\n", 1689 ret); 1690 1691 return 0; 1692 } 1693 1694 static void set_stream_info(struct snd_soc_pcm_stream *stream, 1695 struct snd_soc_tplg_stream_caps *caps) 1696 { 1697 stream->stream_name = kstrdup(caps->name, GFP_KERNEL); 1698 stream->channels_min = caps->channels_min; 1699 stream->channels_max = caps->channels_max; 1700 stream->rates = caps->rates; 1701 stream->rate_min = caps->rate_min; 1702 stream->rate_max = caps->rate_max; 1703 stream->formats = caps->formats; 1704 stream->sig_bits = caps->sig_bits; 1705 } 1706 1707 static void set_dai_flags(struct snd_soc_dai_driver *dai_drv, 1708 unsigned int flag_mask, unsigned int flags) 1709 { 1710 if (flag_mask & SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_RATES) 1711 dai_drv->symmetric_rates = 1712 flags & SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_RATES ? 1 : 0; 1713 1714 if (flag_mask & SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_CHANNELS) 1715 dai_drv->symmetric_channels = 1716 flags & SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_CHANNELS ? 1717 1 : 0; 1718 1719 if (flag_mask & SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_SAMPLEBITS) 1720 dai_drv->symmetric_samplebits = 1721 flags & SND_SOC_TPLG_DAI_FLGBIT_SYMMETRIC_SAMPLEBITS ? 1722 1 : 0; 1723 } 1724 1725 static int soc_tplg_dai_create(struct soc_tplg *tplg, 1726 struct snd_soc_tplg_pcm *pcm) 1727 { 1728 struct snd_soc_dai_driver *dai_drv; 1729 struct snd_soc_pcm_stream *stream; 1730 struct snd_soc_tplg_stream_caps *caps; 1731 int ret; 1732 1733 dai_drv = kzalloc(sizeof(struct snd_soc_dai_driver), GFP_KERNEL); 1734 if (dai_drv == NULL) 1735 return -ENOMEM; 1736 1737 if (strlen(pcm->dai_name)) 1738 dai_drv->name = kstrdup(pcm->dai_name, GFP_KERNEL); 1739 dai_drv->id = pcm->dai_id; 1740 1741 if (pcm->playback) { 1742 stream = &dai_drv->playback; 1743 caps = &pcm->caps[SND_SOC_TPLG_STREAM_PLAYBACK]; 1744 set_stream_info(stream, caps); 1745 } 1746 1747 if (pcm->capture) { 1748 stream = &dai_drv->capture; 1749 caps = &pcm->caps[SND_SOC_TPLG_STREAM_CAPTURE]; 1750 set_stream_info(stream, caps); 1751 } 1752 1753 /* pass control to component driver for optional further init */ 1754 ret = soc_tplg_dai_load(tplg, dai_drv); 1755 if (ret < 0) { 1756 dev_err(tplg->comp->dev, "ASoC: DAI loading failed\n"); 1757 kfree(dai_drv); 1758 return ret; 1759 } 1760 1761 dai_drv->dobj.index = tplg->index; 1762 dai_drv->dobj.ops = tplg->ops; 1763 dai_drv->dobj.type = SND_SOC_DOBJ_PCM; 1764 list_add(&dai_drv->dobj.list, &tplg->comp->dobj_list); 1765 1766 /* register the DAI to the component */ 1767 return snd_soc_register_dai(tplg->comp, dai_drv); 1768 } 1769 1770 static void set_link_flags(struct snd_soc_dai_link *link, 1771 unsigned int flag_mask, unsigned int flags) 1772 { 1773 if (flag_mask & SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_RATES) 1774 link->symmetric_rates = 1775 flags & SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_RATES ? 1 : 0; 1776 1777 if (flag_mask & SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_CHANNELS) 1778 link->symmetric_channels = 1779 flags & SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_CHANNELS ? 1780 1 : 0; 1781 1782 if (flag_mask & SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_SAMPLEBITS) 1783 link->symmetric_samplebits = 1784 flags & SND_SOC_TPLG_LNK_FLGBIT_SYMMETRIC_SAMPLEBITS ? 1785 1 : 0; 1786 1787 if (flag_mask & SND_SOC_TPLG_LNK_FLGBIT_VOICE_WAKEUP) 1788 link->ignore_suspend = 1789 flags & SND_SOC_TPLG_LNK_FLGBIT_VOICE_WAKEUP ? 1790 1 : 0; 1791 } 1792 1793 /* create the FE DAI link */ 1794 static int soc_tplg_fe_link_create(struct soc_tplg *tplg, 1795 struct snd_soc_tplg_pcm *pcm) 1796 { 1797 struct snd_soc_dai_link *link; 1798 int ret; 1799 1800 link = kzalloc(sizeof(struct snd_soc_dai_link), GFP_KERNEL); 1801 if (link == NULL) 1802 return -ENOMEM; 1803 1804 if (strlen(pcm->pcm_name)) { 1805 link->name = kstrdup(pcm->pcm_name, GFP_KERNEL); 1806 link->stream_name = kstrdup(pcm->pcm_name, GFP_KERNEL); 1807 } 1808 link->id = pcm->pcm_id; 1809 1810 if (strlen(pcm->dai_name)) 1811 link->cpu_dai_name = kstrdup(pcm->dai_name, GFP_KERNEL); 1812 1813 link->codec_name = "snd-soc-dummy"; 1814 link->codec_dai_name = "snd-soc-dummy-dai"; 1815 1816 /* enable DPCM */ 1817 link->dynamic = 1; 1818 link->dpcm_playback = pcm->playback; 1819 link->dpcm_capture = pcm->capture; 1820 if (pcm->flag_mask) 1821 set_link_flags(link, pcm->flag_mask, pcm->flags); 1822 1823 /* pass control to component driver for optional further init */ 1824 ret = soc_tplg_dai_link_load(tplg, link); 1825 if (ret < 0) { 1826 dev_err(tplg->comp->dev, "ASoC: FE link loading failed\n"); 1827 kfree(link); 1828 return ret; 1829 } 1830 1831 link->dobj.index = tplg->index; 1832 link->dobj.ops = tplg->ops; 1833 link->dobj.type = SND_SOC_DOBJ_DAI_LINK; 1834 list_add(&link->dobj.list, &tplg->comp->dobj_list); 1835 1836 snd_soc_add_dai_link(tplg->comp->card, link); 1837 return 0; 1838 } 1839 1840 /* create a FE DAI and DAI link from the PCM object */ 1841 static int soc_tplg_pcm_create(struct soc_tplg *tplg, 1842 struct snd_soc_tplg_pcm *pcm) 1843 { 1844 int ret; 1845 1846 ret = soc_tplg_dai_create(tplg, pcm); 1847 if (ret < 0) 1848 return ret; 1849 1850 return soc_tplg_fe_link_create(tplg, pcm); 1851 } 1852 1853 /* copy stream caps from the old version 4 of source */ 1854 static void stream_caps_new_ver(struct snd_soc_tplg_stream_caps *dest, 1855 struct snd_soc_tplg_stream_caps_v4 *src) 1856 { 1857 dest->size = sizeof(*dest); 1858 memcpy(dest->name, src->name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN); 1859 dest->formats = src->formats; 1860 dest->rates = src->rates; 1861 dest->rate_min = src->rate_min; 1862 dest->rate_max = src->rate_max; 1863 dest->channels_min = src->channels_min; 1864 dest->channels_max = src->channels_max; 1865 dest->periods_min = src->periods_min; 1866 dest->periods_max = src->periods_max; 1867 dest->period_size_min = src->period_size_min; 1868 dest->period_size_max = src->period_size_max; 1869 dest->buffer_size_min = src->buffer_size_min; 1870 dest->buffer_size_max = src->buffer_size_max; 1871 } 1872 1873 /** 1874 * pcm_new_ver - Create the new version of PCM from the old version. 1875 * @tplg: topology context 1876 * @src: older version of pcm as a source 1877 * @pcm: latest version of pcm created from the source 1878 * 1879 * Support from vesion 4. User should free the returned pcm manually. 1880 */ 1881 static int pcm_new_ver(struct soc_tplg *tplg, 1882 struct snd_soc_tplg_pcm *src, 1883 struct snd_soc_tplg_pcm **pcm) 1884 { 1885 struct snd_soc_tplg_pcm *dest; 1886 struct snd_soc_tplg_pcm_v4 *src_v4; 1887 int i; 1888 1889 *pcm = NULL; 1890 1891 if (src->size != sizeof(*src_v4)) { 1892 dev_err(tplg->dev, "ASoC: invalid PCM size\n"); 1893 return -EINVAL; 1894 } 1895 1896 dev_warn(tplg->dev, "ASoC: old version of PCM\n"); 1897 src_v4 = (struct snd_soc_tplg_pcm_v4 *)src; 1898 dest = kzalloc(sizeof(*dest), GFP_KERNEL); 1899 if (!dest) 1900 return -ENOMEM; 1901 1902 dest->size = sizeof(*dest); /* size of latest abi version */ 1903 memcpy(dest->pcm_name, src_v4->pcm_name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN); 1904 memcpy(dest->dai_name, src_v4->dai_name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN); 1905 dest->pcm_id = src_v4->pcm_id; 1906 dest->dai_id = src_v4->dai_id; 1907 dest->playback = src_v4->playback; 1908 dest->capture = src_v4->capture; 1909 dest->compress = src_v4->compress; 1910 dest->num_streams = src_v4->num_streams; 1911 for (i = 0; i < dest->num_streams; i++) 1912 memcpy(&dest->stream[i], &src_v4->stream[i], 1913 sizeof(struct snd_soc_tplg_stream)); 1914 1915 for (i = 0; i < 2; i++) 1916 stream_caps_new_ver(&dest->caps[i], &src_v4->caps[i]); 1917 1918 *pcm = dest; 1919 return 0; 1920 } 1921 1922 static int soc_tplg_pcm_elems_load(struct soc_tplg *tplg, 1923 struct snd_soc_tplg_hdr *hdr) 1924 { 1925 struct snd_soc_tplg_pcm *pcm, *_pcm; 1926 int count = hdr->count; 1927 int i; 1928 bool abi_match; 1929 1930 if (tplg->pass != SOC_TPLG_PASS_PCM_DAI) 1931 return 0; 1932 1933 /* check the element size and count */ 1934 pcm = (struct snd_soc_tplg_pcm *)tplg->pos; 1935 if (pcm->size > sizeof(struct snd_soc_tplg_pcm) 1936 || pcm->size < sizeof(struct snd_soc_tplg_pcm_v4)) { 1937 dev_err(tplg->dev, "ASoC: invalid size %d for PCM elems\n", 1938 pcm->size); 1939 return -EINVAL; 1940 } 1941 1942 if (soc_tplg_check_elem_count(tplg, 1943 pcm->size, count, 1944 hdr->payload_size, "PCM DAI")) { 1945 dev_err(tplg->dev, "ASoC: invalid count %d for PCM DAI elems\n", 1946 count); 1947 return -EINVAL; 1948 } 1949 1950 for (i = 0; i < count; i++) { 1951 pcm = (struct snd_soc_tplg_pcm *)tplg->pos; 1952 1953 /* check ABI version by size, create a new version of pcm 1954 * if abi not match. 1955 */ 1956 if (pcm->size == sizeof(*pcm)) { 1957 abi_match = true; 1958 _pcm = pcm; 1959 } else { 1960 abi_match = false; 1961 pcm_new_ver(tplg, pcm, &_pcm); 1962 } 1963 1964 /* create the FE DAIs and DAI links */ 1965 soc_tplg_pcm_create(tplg, _pcm); 1966 1967 /* offset by version-specific struct size and 1968 * real priv data size 1969 */ 1970 tplg->pos += pcm->size + _pcm->priv.size; 1971 1972 if (!abi_match) 1973 kfree(_pcm); /* free the duplicated one */ 1974 } 1975 1976 dev_dbg(tplg->dev, "ASoC: adding %d PCM DAIs\n", count); 1977 1978 return 0; 1979 } 1980 1981 /** 1982 * set_link_hw_format - Set the HW audio format of the physical DAI link. 1983 * @link: &snd_soc_dai_link which should be updated 1984 * @cfg: physical link configs. 1985 * 1986 * Topology context contains a list of supported HW formats (configs) and 1987 * a default format ID for the physical link. This function will use this 1988 * default ID to choose the HW format to set the link's DAI format for init. 1989 */ 1990 static void set_link_hw_format(struct snd_soc_dai_link *link, 1991 struct snd_soc_tplg_link_config *cfg) 1992 { 1993 struct snd_soc_tplg_hw_config *hw_config; 1994 unsigned char bclk_master, fsync_master; 1995 unsigned char invert_bclk, invert_fsync; 1996 int i; 1997 1998 for (i = 0; i < cfg->num_hw_configs; i++) { 1999 hw_config = &cfg->hw_config[i]; 2000 if (hw_config->id != cfg->default_hw_config_id) 2001 continue; 2002 2003 link->dai_fmt = hw_config->fmt & SND_SOC_DAIFMT_FORMAT_MASK; 2004 2005 /* clock signal polarity */ 2006 invert_bclk = hw_config->invert_bclk; 2007 invert_fsync = hw_config->invert_fsync; 2008 if (!invert_bclk && !invert_fsync) 2009 link->dai_fmt |= SND_SOC_DAIFMT_NB_NF; 2010 else if (!invert_bclk && invert_fsync) 2011 link->dai_fmt |= SND_SOC_DAIFMT_NB_IF; 2012 else if (invert_bclk && !invert_fsync) 2013 link->dai_fmt |= SND_SOC_DAIFMT_IB_NF; 2014 else 2015 link->dai_fmt |= SND_SOC_DAIFMT_IB_IF; 2016 2017 /* clock masters */ 2018 bclk_master = hw_config->bclk_master; 2019 fsync_master = hw_config->fsync_master; 2020 if (!bclk_master && !fsync_master) 2021 link->dai_fmt |= SND_SOC_DAIFMT_CBM_CFM; 2022 else if (bclk_master && !fsync_master) 2023 link->dai_fmt |= SND_SOC_DAIFMT_CBS_CFM; 2024 else if (!bclk_master && fsync_master) 2025 link->dai_fmt |= SND_SOC_DAIFMT_CBM_CFS; 2026 else 2027 link->dai_fmt |= SND_SOC_DAIFMT_CBS_CFS; 2028 } 2029 } 2030 2031 /** 2032 * link_new_ver - Create a new physical link config from the old 2033 * version of source. 2034 * @tplg: topology context 2035 * @src: old version of phyical link config as a source 2036 * @link: latest version of physical link config created from the source 2037 * 2038 * Support from vesion 4. User need free the returned link config manually. 2039 */ 2040 static int link_new_ver(struct soc_tplg *tplg, 2041 struct snd_soc_tplg_link_config *src, 2042 struct snd_soc_tplg_link_config **link) 2043 { 2044 struct snd_soc_tplg_link_config *dest; 2045 struct snd_soc_tplg_link_config_v4 *src_v4; 2046 int i; 2047 2048 *link = NULL; 2049 2050 if (src->size != sizeof(struct snd_soc_tplg_link_config_v4)) { 2051 dev_err(tplg->dev, "ASoC: invalid physical link config size\n"); 2052 return -EINVAL; 2053 } 2054 2055 dev_warn(tplg->dev, "ASoC: old version of physical link config\n"); 2056 2057 src_v4 = (struct snd_soc_tplg_link_config_v4 *)src; 2058 dest = kzalloc(sizeof(*dest), GFP_KERNEL); 2059 if (!dest) 2060 return -ENOMEM; 2061 2062 dest->size = sizeof(*dest); 2063 dest->id = src_v4->id; 2064 dest->num_streams = src_v4->num_streams; 2065 for (i = 0; i < dest->num_streams; i++) 2066 memcpy(&dest->stream[i], &src_v4->stream[i], 2067 sizeof(struct snd_soc_tplg_stream)); 2068 2069 *link = dest; 2070 return 0; 2071 } 2072 2073 /* Find and configure an existing physical DAI link */ 2074 static int soc_tplg_link_config(struct soc_tplg *tplg, 2075 struct snd_soc_tplg_link_config *cfg) 2076 { 2077 struct snd_soc_dai_link *link; 2078 const char *name, *stream_name; 2079 size_t len; 2080 int ret; 2081 2082 len = strnlen(cfg->name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN); 2083 if (len == SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 2084 return -EINVAL; 2085 else if (len) 2086 name = cfg->name; 2087 else 2088 name = NULL; 2089 2090 len = strnlen(cfg->stream_name, SNDRV_CTL_ELEM_ID_NAME_MAXLEN); 2091 if (len == SNDRV_CTL_ELEM_ID_NAME_MAXLEN) 2092 return -EINVAL; 2093 else if (len) 2094 stream_name = cfg->stream_name; 2095 else 2096 stream_name = NULL; 2097 2098 link = snd_soc_find_dai_link(tplg->comp->card, cfg->id, 2099 name, stream_name); 2100 if (!link) { 2101 dev_err(tplg->dev, "ASoC: physical link %s (id %d) not exist\n", 2102 name, cfg->id); 2103 return -EINVAL; 2104 } 2105 2106 /* hw format */ 2107 if (cfg->num_hw_configs) 2108 set_link_hw_format(link, cfg); 2109 2110 /* flags */ 2111 if (cfg->flag_mask) 2112 set_link_flags(link, cfg->flag_mask, cfg->flags); 2113 2114 /* pass control to component driver for optional further init */ 2115 ret = soc_tplg_dai_link_load(tplg, link); 2116 if (ret < 0) { 2117 dev_err(tplg->dev, "ASoC: physical link loading failed\n"); 2118 return ret; 2119 } 2120 2121 return 0; 2122 } 2123 2124 2125 /* Load physical link config elements from the topology context */ 2126 static int soc_tplg_link_elems_load(struct soc_tplg *tplg, 2127 struct snd_soc_tplg_hdr *hdr) 2128 { 2129 struct snd_soc_tplg_link_config *link, *_link; 2130 int count = hdr->count; 2131 int i, ret; 2132 bool abi_match; 2133 2134 if (tplg->pass != SOC_TPLG_PASS_LINK) { 2135 tplg->pos += hdr->size + hdr->payload_size; 2136 return 0; 2137 }; 2138 2139 /* check the element size and count */ 2140 link = (struct snd_soc_tplg_link_config *)tplg->pos; 2141 if (link->size > sizeof(struct snd_soc_tplg_link_config) 2142 || link->size < sizeof(struct snd_soc_tplg_link_config_v4)) { 2143 dev_err(tplg->dev, "ASoC: invalid size %d for physical link elems\n", 2144 link->size); 2145 return -EINVAL; 2146 } 2147 2148 if (soc_tplg_check_elem_count(tplg, 2149 link->size, count, 2150 hdr->payload_size, "physical link config")) { 2151 dev_err(tplg->dev, "ASoC: invalid count %d for physical link elems\n", 2152 count); 2153 return -EINVAL; 2154 } 2155 2156 /* config physical DAI links */ 2157 for (i = 0; i < count; i++) { 2158 link = (struct snd_soc_tplg_link_config *)tplg->pos; 2159 if (link->size == sizeof(*link)) { 2160 abi_match = true; 2161 _link = link; 2162 } else { 2163 abi_match = false; 2164 ret = link_new_ver(tplg, link, &_link); 2165 if (ret < 0) 2166 return ret; 2167 } 2168 2169 ret = soc_tplg_link_config(tplg, _link); 2170 if (ret < 0) 2171 return ret; 2172 2173 /* offset by version-specific struct size and 2174 * real priv data size 2175 */ 2176 tplg->pos += link->size + _link->priv.size; 2177 2178 if (!abi_match) 2179 kfree(_link); /* free the duplicated one */ 2180 } 2181 2182 return 0; 2183 } 2184 2185 /** 2186 * soc_tplg_dai_config - Find and configure an existing physical DAI. 2187 * @tplg: topology context 2188 * @d: physical DAI configs. 2189 * 2190 * The physical dai should already be registered by the platform driver. 2191 * The platform driver should specify the DAI name and ID for matching. 2192 */ 2193 static int soc_tplg_dai_config(struct soc_tplg *tplg, 2194 struct snd_soc_tplg_dai *d) 2195 { 2196 struct snd_soc_dai_link_component dai_component = {0}; 2197 struct snd_soc_dai *dai; 2198 struct snd_soc_dai_driver *dai_drv; 2199 struct snd_soc_pcm_stream *stream; 2200 struct snd_soc_tplg_stream_caps *caps; 2201 int ret; 2202 2203 dai_component.dai_name = d->dai_name; 2204 dai = snd_soc_find_dai(&dai_component); 2205 if (!dai) { 2206 dev_err(tplg->dev, "ASoC: physical DAI %s not registered\n", 2207 d->dai_name); 2208 return -EINVAL; 2209 } 2210 2211 if (d->dai_id != dai->id) { 2212 dev_err(tplg->dev, "ASoC: physical DAI %s id mismatch\n", 2213 d->dai_name); 2214 return -EINVAL; 2215 } 2216 2217 dai_drv = dai->driver; 2218 if (!dai_drv) 2219 return -EINVAL; 2220 2221 if (d->playback) { 2222 stream = &dai_drv->playback; 2223 caps = &d->caps[SND_SOC_TPLG_STREAM_PLAYBACK]; 2224 set_stream_info(stream, caps); 2225 } 2226 2227 if (d->capture) { 2228 stream = &dai_drv->capture; 2229 caps = &d->caps[SND_SOC_TPLG_STREAM_CAPTURE]; 2230 set_stream_info(stream, caps); 2231 } 2232 2233 if (d->flag_mask) 2234 set_dai_flags(dai_drv, d->flag_mask, d->flags); 2235 2236 /* pass control to component driver for optional further init */ 2237 ret = soc_tplg_dai_load(tplg, dai_drv); 2238 if (ret < 0) { 2239 dev_err(tplg->comp->dev, "ASoC: DAI loading failed\n"); 2240 return ret; 2241 } 2242 2243 return 0; 2244 } 2245 2246 /* load physical DAI elements */ 2247 static int soc_tplg_dai_elems_load(struct soc_tplg *tplg, 2248 struct snd_soc_tplg_hdr *hdr) 2249 { 2250 struct snd_soc_tplg_dai *dai; 2251 int count = hdr->count; 2252 int i; 2253 2254 if (tplg->pass != SOC_TPLG_PASS_BE_DAI) 2255 return 0; 2256 2257 /* config the existing BE DAIs */ 2258 for (i = 0; i < count; i++) { 2259 dai = (struct snd_soc_tplg_dai *)tplg->pos; 2260 if (dai->size != sizeof(*dai)) { 2261 dev_err(tplg->dev, "ASoC: invalid physical DAI size\n"); 2262 return -EINVAL; 2263 } 2264 2265 soc_tplg_dai_config(tplg, dai); 2266 tplg->pos += (sizeof(*dai) + dai->priv.size); 2267 } 2268 2269 dev_dbg(tplg->dev, "ASoC: Configure %d BE DAIs\n", count); 2270 return 0; 2271 } 2272 2273 /** 2274 * manifest_new_ver - Create a new version of manifest from the old version 2275 * of source. 2276 * @tplg: topology context 2277 * @src: old version of manifest as a source 2278 * @manifest: latest version of manifest created from the source 2279 * 2280 * Support from vesion 4. Users need free the returned manifest manually. 2281 */ 2282 static int manifest_new_ver(struct soc_tplg *tplg, 2283 struct snd_soc_tplg_manifest *src, 2284 struct snd_soc_tplg_manifest **manifest) 2285 { 2286 struct snd_soc_tplg_manifest *dest; 2287 struct snd_soc_tplg_manifest_v4 *src_v4; 2288 2289 *manifest = NULL; 2290 2291 if (src->size != sizeof(*src_v4)) { 2292 dev_err(tplg->dev, "ASoC: invalid manifest size\n"); 2293 return -EINVAL; 2294 } 2295 2296 dev_warn(tplg->dev, "ASoC: old version of manifest\n"); 2297 2298 src_v4 = (struct snd_soc_tplg_manifest_v4 *)src; 2299 dest = kzalloc(sizeof(*dest) + src_v4->priv.size, GFP_KERNEL); 2300 if (!dest) 2301 return -ENOMEM; 2302 2303 dest->size = sizeof(*dest); /* size of latest abi version */ 2304 dest->control_elems = src_v4->control_elems; 2305 dest->widget_elems = src_v4->widget_elems; 2306 dest->graph_elems = src_v4->graph_elems; 2307 dest->pcm_elems = src_v4->pcm_elems; 2308 dest->dai_link_elems = src_v4->dai_link_elems; 2309 dest->priv.size = src_v4->priv.size; 2310 if (dest->priv.size) 2311 memcpy(dest->priv.data, src_v4->priv.data, 2312 src_v4->priv.size); 2313 2314 *manifest = dest; 2315 return 0; 2316 } 2317 2318 static int soc_tplg_manifest_load(struct soc_tplg *tplg, 2319 struct snd_soc_tplg_hdr *hdr) 2320 { 2321 struct snd_soc_tplg_manifest *manifest, *_manifest; 2322 bool abi_match; 2323 int err; 2324 2325 if (tplg->pass != SOC_TPLG_PASS_MANIFEST) 2326 return 0; 2327 2328 manifest = (struct snd_soc_tplg_manifest *)tplg->pos; 2329 2330 /* check ABI version by size, create a new manifest if abi not match */ 2331 if (manifest->size == sizeof(*manifest)) { 2332 abi_match = true; 2333 _manifest = manifest; 2334 } else { 2335 abi_match = false; 2336 err = manifest_new_ver(tplg, manifest, &_manifest); 2337 if (err < 0) 2338 return err; 2339 } 2340 2341 /* pass control to component driver for optional further init */ 2342 if (tplg->comp && tplg->ops && tplg->ops->manifest) 2343 return tplg->ops->manifest(tplg->comp, _manifest); 2344 2345 if (!abi_match) /* free the duplicated one */ 2346 kfree(_manifest); 2347 2348 return 0; 2349 } 2350 2351 /* validate header magic, size and type */ 2352 static int soc_valid_header(struct soc_tplg *tplg, 2353 struct snd_soc_tplg_hdr *hdr) 2354 { 2355 if (soc_tplg_get_hdr_offset(tplg) >= tplg->fw->size) 2356 return 0; 2357 2358 if (hdr->size != sizeof(*hdr)) { 2359 dev_err(tplg->dev, 2360 "ASoC: invalid header size for type %d at offset 0x%lx size 0x%zx.\n", 2361 hdr->type, soc_tplg_get_hdr_offset(tplg), 2362 tplg->fw->size); 2363 return -EINVAL; 2364 } 2365 2366 /* big endian firmware objects not supported atm */ 2367 if (hdr->magic == cpu_to_be32(SND_SOC_TPLG_MAGIC)) { 2368 dev_err(tplg->dev, 2369 "ASoC: pass %d big endian not supported header got %x at offset 0x%lx size 0x%zx.\n", 2370 tplg->pass, hdr->magic, 2371 soc_tplg_get_hdr_offset(tplg), tplg->fw->size); 2372 return -EINVAL; 2373 } 2374 2375 if (hdr->magic != SND_SOC_TPLG_MAGIC) { 2376 dev_err(tplg->dev, 2377 "ASoC: pass %d does not have a valid header got %x at offset 0x%lx size 0x%zx.\n", 2378 tplg->pass, hdr->magic, 2379 soc_tplg_get_hdr_offset(tplg), tplg->fw->size); 2380 return -EINVAL; 2381 } 2382 2383 /* Support ABI from version 4 */ 2384 if (hdr->abi > SND_SOC_TPLG_ABI_VERSION 2385 || hdr->abi < SND_SOC_TPLG_ABI_VERSION_MIN) { 2386 dev_err(tplg->dev, 2387 "ASoC: pass %d invalid ABI version got 0x%x need 0x%x at offset 0x%lx size 0x%zx.\n", 2388 tplg->pass, hdr->abi, 2389 SND_SOC_TPLG_ABI_VERSION, soc_tplg_get_hdr_offset(tplg), 2390 tplg->fw->size); 2391 return -EINVAL; 2392 } 2393 2394 if (hdr->payload_size == 0) { 2395 dev_err(tplg->dev, "ASoC: header has 0 size at offset 0x%lx.\n", 2396 soc_tplg_get_hdr_offset(tplg)); 2397 return -EINVAL; 2398 } 2399 2400 if (tplg->pass == hdr->type) 2401 dev_dbg(tplg->dev, 2402 "ASoC: Got 0x%x bytes of type %d version %d vendor %d at pass %d\n", 2403 hdr->payload_size, hdr->type, hdr->version, 2404 hdr->vendor_type, tplg->pass); 2405 2406 return 1; 2407 } 2408 2409 /* check header type and call appropriate handler */ 2410 static int soc_tplg_load_header(struct soc_tplg *tplg, 2411 struct snd_soc_tplg_hdr *hdr) 2412 { 2413 tplg->pos = tplg->hdr_pos + sizeof(struct snd_soc_tplg_hdr); 2414 2415 /* check for matching ID */ 2416 if (hdr->index != tplg->req_index && 2417 tplg->req_index != SND_SOC_TPLG_INDEX_ALL) 2418 return 0; 2419 2420 tplg->index = hdr->index; 2421 2422 switch (hdr->type) { 2423 case SND_SOC_TPLG_TYPE_MIXER: 2424 case SND_SOC_TPLG_TYPE_ENUM: 2425 case SND_SOC_TPLG_TYPE_BYTES: 2426 return soc_tplg_kcontrol_elems_load(tplg, hdr); 2427 case SND_SOC_TPLG_TYPE_DAPM_GRAPH: 2428 return soc_tplg_dapm_graph_elems_load(tplg, hdr); 2429 case SND_SOC_TPLG_TYPE_DAPM_WIDGET: 2430 return soc_tplg_dapm_widget_elems_load(tplg, hdr); 2431 case SND_SOC_TPLG_TYPE_PCM: 2432 return soc_tplg_pcm_elems_load(tplg, hdr); 2433 case SND_SOC_TPLG_TYPE_DAI: 2434 return soc_tplg_dai_elems_load(tplg, hdr); 2435 case SND_SOC_TPLG_TYPE_DAI_LINK: 2436 case SND_SOC_TPLG_TYPE_BACKEND_LINK: 2437 /* physical link configurations */ 2438 return soc_tplg_link_elems_load(tplg, hdr); 2439 case SND_SOC_TPLG_TYPE_MANIFEST: 2440 return soc_tplg_manifest_load(tplg, hdr); 2441 default: 2442 /* bespoke vendor data object */ 2443 return soc_tplg_vendor_load(tplg, hdr); 2444 } 2445 2446 return 0; 2447 } 2448 2449 /* process the topology file headers */ 2450 static int soc_tplg_process_headers(struct soc_tplg *tplg) 2451 { 2452 struct snd_soc_tplg_hdr *hdr; 2453 int ret; 2454 2455 tplg->pass = SOC_TPLG_PASS_START; 2456 2457 /* process the header types from start to end */ 2458 while (tplg->pass <= SOC_TPLG_PASS_END) { 2459 2460 tplg->hdr_pos = tplg->fw->data; 2461 hdr = (struct snd_soc_tplg_hdr *)tplg->hdr_pos; 2462 2463 while (!soc_tplg_is_eof(tplg)) { 2464 2465 /* make sure header is valid before loading */ 2466 ret = soc_valid_header(tplg, hdr); 2467 if (ret < 0) 2468 return ret; 2469 else if (ret == 0) 2470 break; 2471 2472 /* load the header object */ 2473 ret = soc_tplg_load_header(tplg, hdr); 2474 if (ret < 0) 2475 return ret; 2476 2477 /* goto next header */ 2478 tplg->hdr_pos += hdr->payload_size + 2479 sizeof(struct snd_soc_tplg_hdr); 2480 hdr = (struct snd_soc_tplg_hdr *)tplg->hdr_pos; 2481 } 2482 2483 /* next data type pass */ 2484 tplg->pass++; 2485 } 2486 2487 /* signal DAPM we are complete */ 2488 ret = soc_tplg_dapm_complete(tplg); 2489 if (ret < 0) 2490 dev_err(tplg->dev, 2491 "ASoC: failed to initialise DAPM from Firmware\n"); 2492 2493 return ret; 2494 } 2495 2496 static int soc_tplg_load(struct soc_tplg *tplg) 2497 { 2498 int ret; 2499 2500 ret = soc_tplg_process_headers(tplg); 2501 if (ret == 0) 2502 soc_tplg_complete(tplg); 2503 2504 return ret; 2505 } 2506 2507 /* load audio component topology from "firmware" file */ 2508 int snd_soc_tplg_component_load(struct snd_soc_component *comp, 2509 struct snd_soc_tplg_ops *ops, const struct firmware *fw, u32 id) 2510 { 2511 struct soc_tplg tplg; 2512 2513 /* setup parsing context */ 2514 memset(&tplg, 0, sizeof(tplg)); 2515 tplg.fw = fw; 2516 tplg.dev = comp->dev; 2517 tplg.comp = comp; 2518 tplg.ops = ops; 2519 tplg.req_index = id; 2520 tplg.io_ops = ops->io_ops; 2521 tplg.io_ops_count = ops->io_ops_count; 2522 tplg.bytes_ext_ops = ops->bytes_ext_ops; 2523 tplg.bytes_ext_ops_count = ops->bytes_ext_ops_count; 2524 2525 return soc_tplg_load(&tplg); 2526 } 2527 EXPORT_SYMBOL_GPL(snd_soc_tplg_component_load); 2528 2529 /* remove this dynamic widget */ 2530 void snd_soc_tplg_widget_remove(struct snd_soc_dapm_widget *w) 2531 { 2532 /* make sure we are a widget */ 2533 if (w->dobj.type != SND_SOC_DOBJ_WIDGET) 2534 return; 2535 2536 remove_widget(w->dapm->component, &w->dobj, SOC_TPLG_PASS_WIDGET); 2537 } 2538 EXPORT_SYMBOL_GPL(snd_soc_tplg_widget_remove); 2539 2540 /* remove all dynamic widgets from this DAPM context */ 2541 void snd_soc_tplg_widget_remove_all(struct snd_soc_dapm_context *dapm, 2542 u32 index) 2543 { 2544 struct snd_soc_dapm_widget *w, *next_w; 2545 2546 list_for_each_entry_safe(w, next_w, &dapm->card->widgets, list) { 2547 2548 /* make sure we are a widget with correct context */ 2549 if (w->dobj.type != SND_SOC_DOBJ_WIDGET || w->dapm != dapm) 2550 continue; 2551 2552 /* match ID */ 2553 if (w->dobj.index != index && 2554 w->dobj.index != SND_SOC_TPLG_INDEX_ALL) 2555 continue; 2556 /* check and free and dynamic widget kcontrols */ 2557 snd_soc_tplg_widget_remove(w); 2558 snd_soc_dapm_free_widget(w); 2559 } 2560 snd_soc_dapm_reset_cache(dapm); 2561 } 2562 EXPORT_SYMBOL_GPL(snd_soc_tplg_widget_remove_all); 2563 2564 /* remove dynamic controls from the component driver */ 2565 int snd_soc_tplg_component_remove(struct snd_soc_component *comp, u32 index) 2566 { 2567 struct snd_soc_dobj *dobj, *next_dobj; 2568 int pass = SOC_TPLG_PASS_END; 2569 2570 /* process the header types from end to start */ 2571 while (pass >= SOC_TPLG_PASS_START) { 2572 2573 /* remove mixer controls */ 2574 list_for_each_entry_safe(dobj, next_dobj, &comp->dobj_list, 2575 list) { 2576 2577 /* match index */ 2578 if (dobj->index != index && 2579 dobj->index != SND_SOC_TPLG_INDEX_ALL) 2580 continue; 2581 2582 switch (dobj->type) { 2583 case SND_SOC_DOBJ_MIXER: 2584 remove_mixer(comp, dobj, pass); 2585 break; 2586 case SND_SOC_DOBJ_ENUM: 2587 remove_enum(comp, dobj, pass); 2588 break; 2589 case SND_SOC_DOBJ_BYTES: 2590 remove_bytes(comp, dobj, pass); 2591 break; 2592 case SND_SOC_DOBJ_WIDGET: 2593 remove_widget(comp, dobj, pass); 2594 break; 2595 case SND_SOC_DOBJ_PCM: 2596 remove_dai(comp, dobj, pass); 2597 break; 2598 case SND_SOC_DOBJ_DAI_LINK: 2599 remove_link(comp, dobj, pass); 2600 break; 2601 default: 2602 dev_err(comp->dev, "ASoC: invalid component type %d for removal\n", 2603 dobj->type); 2604 break; 2605 } 2606 } 2607 pass--; 2608 } 2609 2610 /* let caller know if FW can be freed when no objects are left */ 2611 return !list_empty(&comp->dobj_list); 2612 } 2613 EXPORT_SYMBOL_GPL(snd_soc_tplg_component_remove); 2614