1 /* 2 * Codec driver for ST STA32x 2.1-channel high-efficiency digital audio system 3 * 4 * Copyright: 2011 Raumfeld GmbH 5 * Author: Johannes Stezenbach <js@sig21.net> 6 * 7 * based on code from: 8 * Wolfson Microelectronics PLC. 9 * Mark Brown <broonie@opensource.wolfsonmicro.com> 10 * Freescale Semiconductor, Inc. 11 * Timur Tabi <timur@freescale.com> 12 * 13 * This program is free software; you can redistribute it and/or modify it 14 * under the terms of the GNU General Public License as published by the 15 * Free Software Foundation; either version 2 of the License, or (at your 16 * option) any later version. 17 */ 18 19 #define pr_fmt(fmt) KBUILD_MODNAME ":%s:%d: " fmt, __func__, __LINE__ 20 21 #include <linux/module.h> 22 #include <linux/moduleparam.h> 23 #include <linux/init.h> 24 #include <linux/delay.h> 25 #include <linux/pm.h> 26 #include <linux/i2c.h> 27 #include <linux/of_device.h> 28 #include <linux/of_gpio.h> 29 #include <linux/regmap.h> 30 #include <linux/regulator/consumer.h> 31 #include <linux/gpio/consumer.h> 32 #include <linux/slab.h> 33 #include <linux/workqueue.h> 34 #include <sound/core.h> 35 #include <sound/pcm.h> 36 #include <sound/pcm_params.h> 37 #include <sound/soc.h> 38 #include <sound/soc-dapm.h> 39 #include <sound/initval.h> 40 #include <sound/tlv.h> 41 42 #include <sound/sta32x.h> 43 #include "sta32x.h" 44 45 #define STA32X_RATES (SNDRV_PCM_RATE_32000 | \ 46 SNDRV_PCM_RATE_44100 | \ 47 SNDRV_PCM_RATE_48000 | \ 48 SNDRV_PCM_RATE_88200 | \ 49 SNDRV_PCM_RATE_96000 | \ 50 SNDRV_PCM_RATE_176400 | \ 51 SNDRV_PCM_RATE_192000) 52 53 #define STA32X_FORMATS \ 54 (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S16_BE | \ 55 SNDRV_PCM_FMTBIT_S18_3LE | SNDRV_PCM_FMTBIT_S18_3BE | \ 56 SNDRV_PCM_FMTBIT_S20_3LE | SNDRV_PCM_FMTBIT_S20_3BE | \ 57 SNDRV_PCM_FMTBIT_S24_3LE | SNDRV_PCM_FMTBIT_S24_3BE | \ 58 SNDRV_PCM_FMTBIT_S24_LE | SNDRV_PCM_FMTBIT_S24_BE | \ 59 SNDRV_PCM_FMTBIT_S32_LE | SNDRV_PCM_FMTBIT_S32_BE) 60 61 /* Power-up register defaults */ 62 static const struct reg_default sta32x_regs[] = { 63 { 0x0, 0x63 }, 64 { 0x1, 0x80 }, 65 { 0x2, 0xc2 }, 66 { 0x3, 0x40 }, 67 { 0x4, 0xc2 }, 68 { 0x5, 0x5c }, 69 { 0x6, 0x10 }, 70 { 0x7, 0xff }, 71 { 0x8, 0x60 }, 72 { 0x9, 0x60 }, 73 { 0xa, 0x60 }, 74 { 0xb, 0x80 }, 75 { 0xc, 0x00 }, 76 { 0xd, 0x00 }, 77 { 0xe, 0x00 }, 78 { 0xf, 0x40 }, 79 { 0x10, 0x80 }, 80 { 0x11, 0x77 }, 81 { 0x12, 0x6a }, 82 { 0x13, 0x69 }, 83 { 0x14, 0x6a }, 84 { 0x15, 0x69 }, 85 { 0x16, 0x00 }, 86 { 0x17, 0x00 }, 87 { 0x18, 0x00 }, 88 { 0x19, 0x00 }, 89 { 0x1a, 0x00 }, 90 { 0x1b, 0x00 }, 91 { 0x1c, 0x00 }, 92 { 0x1d, 0x00 }, 93 { 0x1e, 0x00 }, 94 { 0x1f, 0x00 }, 95 { 0x20, 0x00 }, 96 { 0x21, 0x00 }, 97 { 0x22, 0x00 }, 98 { 0x23, 0x00 }, 99 { 0x24, 0x00 }, 100 { 0x25, 0x00 }, 101 { 0x26, 0x00 }, 102 { 0x27, 0x2d }, 103 { 0x28, 0xc0 }, 104 { 0x2b, 0x00 }, 105 { 0x2c, 0x0c }, 106 }; 107 108 static const struct regmap_range sta32x_write_regs_range[] = { 109 regmap_reg_range(STA32X_CONFA, STA32X_FDRC2), 110 }; 111 112 static const struct regmap_range sta32x_read_regs_range[] = { 113 regmap_reg_range(STA32X_CONFA, STA32X_FDRC2), 114 }; 115 116 static const struct regmap_range sta32x_volatile_regs_range[] = { 117 regmap_reg_range(STA32X_CFADDR2, STA32X_CFUD), 118 }; 119 120 static const struct regmap_access_table sta32x_write_regs = { 121 .yes_ranges = sta32x_write_regs_range, 122 .n_yes_ranges = ARRAY_SIZE(sta32x_write_regs_range), 123 }; 124 125 static const struct regmap_access_table sta32x_read_regs = { 126 .yes_ranges = sta32x_read_regs_range, 127 .n_yes_ranges = ARRAY_SIZE(sta32x_read_regs_range), 128 }; 129 130 static const struct regmap_access_table sta32x_volatile_regs = { 131 .yes_ranges = sta32x_volatile_regs_range, 132 .n_yes_ranges = ARRAY_SIZE(sta32x_volatile_regs_range), 133 }; 134 135 /* regulator power supply names */ 136 static const char *sta32x_supply_names[] = { 137 "Vdda", /* analog supply, 3.3VV */ 138 "Vdd3", /* digital supply, 3.3V */ 139 "Vcc" /* power amp spply, 10V - 36V */ 140 }; 141 142 /* codec private data */ 143 struct sta32x_priv { 144 struct regmap *regmap; 145 struct regulator_bulk_data supplies[ARRAY_SIZE(sta32x_supply_names)]; 146 struct snd_soc_codec *codec; 147 struct sta32x_platform_data *pdata; 148 149 unsigned int mclk; 150 unsigned int format; 151 152 u32 coef_shadow[STA32X_COEF_COUNT]; 153 struct delayed_work watchdog_work; 154 int shutdown; 155 struct gpio_desc *gpiod_nreset; 156 struct mutex coeff_lock; 157 }; 158 159 static const DECLARE_TLV_DB_SCALE(mvol_tlv, -12700, 50, 1); 160 static const DECLARE_TLV_DB_SCALE(chvol_tlv, -7950, 50, 1); 161 static const DECLARE_TLV_DB_SCALE(tone_tlv, -120, 200, 0); 162 163 static const char *sta32x_drc_ac[] = { 164 "Anti-Clipping", "Dynamic Range Compression" }; 165 static const char *sta32x_auto_eq_mode[] = { 166 "User", "Preset", "Loudness" }; 167 static const char *sta32x_auto_gc_mode[] = { 168 "User", "AC no clipping", "AC limited clipping (10%)", 169 "DRC nighttime listening mode" }; 170 static const char *sta32x_auto_xo_mode[] = { 171 "User", "80Hz", "100Hz", "120Hz", "140Hz", "160Hz", "180Hz", "200Hz", 172 "220Hz", "240Hz", "260Hz", "280Hz", "300Hz", "320Hz", "340Hz", "360Hz" }; 173 static const char *sta32x_preset_eq_mode[] = { 174 "Flat", "Rock", "Soft Rock", "Jazz", "Classical", "Dance", "Pop", "Soft", 175 "Hard", "Party", "Vocal", "Hip-Hop", "Dialog", "Bass-boost #1", 176 "Bass-boost #2", "Bass-boost #3", "Loudness 1", "Loudness 2", 177 "Loudness 3", "Loudness 4", "Loudness 5", "Loudness 6", "Loudness 7", 178 "Loudness 8", "Loudness 9", "Loudness 10", "Loudness 11", "Loudness 12", 179 "Loudness 13", "Loudness 14", "Loudness 15", "Loudness 16" }; 180 static const char *sta32x_limiter_select[] = { 181 "Limiter Disabled", "Limiter #1", "Limiter #2" }; 182 static const char *sta32x_limiter_attack_rate[] = { 183 "3.1584", "2.7072", "2.2560", "1.8048", "1.3536", "0.9024", 184 "0.4512", "0.2256", "0.1504", "0.1123", "0.0902", "0.0752", 185 "0.0645", "0.0564", "0.0501", "0.0451" }; 186 static const char *sta32x_limiter_release_rate[] = { 187 "0.5116", "0.1370", "0.0744", "0.0499", "0.0360", "0.0299", 188 "0.0264", "0.0208", "0.0198", "0.0172", "0.0147", "0.0137", 189 "0.0134", "0.0117", "0.0110", "0.0104" }; 190 static DECLARE_TLV_DB_RANGE(sta32x_limiter_ac_attack_tlv, 191 0, 7, TLV_DB_SCALE_ITEM(-1200, 200, 0), 192 8, 16, TLV_DB_SCALE_ITEM(300, 100, 0), 193 ); 194 195 static DECLARE_TLV_DB_RANGE(sta32x_limiter_ac_release_tlv, 196 0, 0, TLV_DB_SCALE_ITEM(TLV_DB_GAIN_MUTE, 0, 0), 197 1, 1, TLV_DB_SCALE_ITEM(-2900, 0, 0), 198 2, 2, TLV_DB_SCALE_ITEM(-2000, 0, 0), 199 3, 8, TLV_DB_SCALE_ITEM(-1400, 200, 0), 200 8, 16, TLV_DB_SCALE_ITEM(-700, 100, 0), 201 ); 202 203 static DECLARE_TLV_DB_RANGE(sta32x_limiter_drc_attack_tlv, 204 0, 7, TLV_DB_SCALE_ITEM(-3100, 200, 0), 205 8, 13, TLV_DB_SCALE_ITEM(-1600, 100, 0), 206 14, 16, TLV_DB_SCALE_ITEM(-1000, 300, 0), 207 ); 208 209 static DECLARE_TLV_DB_RANGE(sta32x_limiter_drc_release_tlv, 210 0, 0, TLV_DB_SCALE_ITEM(TLV_DB_GAIN_MUTE, 0, 0), 211 1, 2, TLV_DB_SCALE_ITEM(-3800, 200, 0), 212 3, 4, TLV_DB_SCALE_ITEM(-3300, 200, 0), 213 5, 12, TLV_DB_SCALE_ITEM(-3000, 200, 0), 214 13, 16, TLV_DB_SCALE_ITEM(-1500, 300, 0), 215 ); 216 217 static SOC_ENUM_SINGLE_DECL(sta32x_drc_ac_enum, 218 STA32X_CONFD, STA32X_CONFD_DRC_SHIFT, 219 sta32x_drc_ac); 220 static SOC_ENUM_SINGLE_DECL(sta32x_auto_eq_enum, 221 STA32X_AUTO1, STA32X_AUTO1_AMEQ_SHIFT, 222 sta32x_auto_eq_mode); 223 static SOC_ENUM_SINGLE_DECL(sta32x_auto_gc_enum, 224 STA32X_AUTO1, STA32X_AUTO1_AMGC_SHIFT, 225 sta32x_auto_gc_mode); 226 static SOC_ENUM_SINGLE_DECL(sta32x_auto_xo_enum, 227 STA32X_AUTO2, STA32X_AUTO2_XO_SHIFT, 228 sta32x_auto_xo_mode); 229 static SOC_ENUM_SINGLE_DECL(sta32x_preset_eq_enum, 230 STA32X_AUTO3, STA32X_AUTO3_PEQ_SHIFT, 231 sta32x_preset_eq_mode); 232 static SOC_ENUM_SINGLE_DECL(sta32x_limiter_ch1_enum, 233 STA32X_C1CFG, STA32X_CxCFG_LS_SHIFT, 234 sta32x_limiter_select); 235 static SOC_ENUM_SINGLE_DECL(sta32x_limiter_ch2_enum, 236 STA32X_C2CFG, STA32X_CxCFG_LS_SHIFT, 237 sta32x_limiter_select); 238 static SOC_ENUM_SINGLE_DECL(sta32x_limiter_ch3_enum, 239 STA32X_C3CFG, STA32X_CxCFG_LS_SHIFT, 240 sta32x_limiter_select); 241 static SOC_ENUM_SINGLE_DECL(sta32x_limiter1_attack_rate_enum, 242 STA32X_L1AR, STA32X_LxA_SHIFT, 243 sta32x_limiter_attack_rate); 244 static SOC_ENUM_SINGLE_DECL(sta32x_limiter2_attack_rate_enum, 245 STA32X_L2AR, STA32X_LxA_SHIFT, 246 sta32x_limiter_attack_rate); 247 static SOC_ENUM_SINGLE_DECL(sta32x_limiter1_release_rate_enum, 248 STA32X_L1AR, STA32X_LxR_SHIFT, 249 sta32x_limiter_release_rate); 250 static SOC_ENUM_SINGLE_DECL(sta32x_limiter2_release_rate_enum, 251 STA32X_L2AR, STA32X_LxR_SHIFT, 252 sta32x_limiter_release_rate); 253 254 /* byte array controls for setting biquad, mixer, scaling coefficients; 255 * for biquads all five coefficients need to be set in one go, 256 * mixer and pre/postscale coefs can be set individually; 257 * each coef is 24bit, the bytes are ordered in the same way 258 * as given in the STA32x data sheet (big endian; b1, b2, a1, a2, b0) 259 */ 260 261 static int sta32x_coefficient_info(struct snd_kcontrol *kcontrol, 262 struct snd_ctl_elem_info *uinfo) 263 { 264 int numcoef = kcontrol->private_value >> 16; 265 uinfo->type = SNDRV_CTL_ELEM_TYPE_BYTES; 266 uinfo->count = 3 * numcoef; 267 return 0; 268 } 269 270 static int sta32x_coefficient_get(struct snd_kcontrol *kcontrol, 271 struct snd_ctl_elem_value *ucontrol) 272 { 273 struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); 274 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 275 int numcoef = kcontrol->private_value >> 16; 276 int index = kcontrol->private_value & 0xffff; 277 unsigned int cfud, val; 278 int i, ret = 0; 279 280 mutex_lock(&sta32x->coeff_lock); 281 282 /* preserve reserved bits in STA32X_CFUD */ 283 regmap_read(sta32x->regmap, STA32X_CFUD, &cfud); 284 cfud &= 0xf0; 285 /* 286 * chip documentation does not say if the bits are self clearing, 287 * so do it explicitly 288 */ 289 regmap_write(sta32x->regmap, STA32X_CFUD, cfud); 290 291 regmap_write(sta32x->regmap, STA32X_CFADDR2, index); 292 if (numcoef == 1) { 293 regmap_write(sta32x->regmap, STA32X_CFUD, cfud | 0x04); 294 } else if (numcoef == 5) { 295 regmap_write(sta32x->regmap, STA32X_CFUD, cfud | 0x08); 296 } else { 297 ret = -EINVAL; 298 goto exit_unlock; 299 } 300 301 for (i = 0; i < 3 * numcoef; i++) { 302 regmap_read(sta32x->regmap, STA32X_B1CF1 + i, &val); 303 ucontrol->value.bytes.data[i] = val; 304 } 305 306 exit_unlock: 307 mutex_unlock(&sta32x->coeff_lock); 308 309 return ret; 310 } 311 312 static int sta32x_coefficient_put(struct snd_kcontrol *kcontrol, 313 struct snd_ctl_elem_value *ucontrol) 314 { 315 struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); 316 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 317 int numcoef = kcontrol->private_value >> 16; 318 int index = kcontrol->private_value & 0xffff; 319 unsigned int cfud; 320 int i; 321 322 /* preserve reserved bits in STA32X_CFUD */ 323 regmap_read(sta32x->regmap, STA32X_CFUD, &cfud); 324 cfud &= 0xf0; 325 /* 326 * chip documentation does not say if the bits are self clearing, 327 * so do it explicitly 328 */ 329 regmap_write(sta32x->regmap, STA32X_CFUD, cfud); 330 331 regmap_write(sta32x->regmap, STA32X_CFADDR2, index); 332 for (i = 0; i < numcoef && (index + i < STA32X_COEF_COUNT); i++) 333 sta32x->coef_shadow[index + i] = 334 (ucontrol->value.bytes.data[3 * i] << 16) 335 | (ucontrol->value.bytes.data[3 * i + 1] << 8) 336 | (ucontrol->value.bytes.data[3 * i + 2]); 337 for (i = 0; i < 3 * numcoef; i++) 338 regmap_write(sta32x->regmap, STA32X_B1CF1 + i, 339 ucontrol->value.bytes.data[i]); 340 if (numcoef == 1) 341 regmap_write(sta32x->regmap, STA32X_CFUD, cfud | 0x01); 342 else if (numcoef == 5) 343 regmap_write(sta32x->regmap, STA32X_CFUD, cfud | 0x02); 344 else 345 return -EINVAL; 346 347 return 0; 348 } 349 350 static int sta32x_sync_coef_shadow(struct snd_soc_codec *codec) 351 { 352 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 353 unsigned int cfud; 354 int i; 355 356 /* preserve reserved bits in STA32X_CFUD */ 357 regmap_read(sta32x->regmap, STA32X_CFUD, &cfud); 358 cfud &= 0xf0; 359 360 for (i = 0; i < STA32X_COEF_COUNT; i++) { 361 regmap_write(sta32x->regmap, STA32X_CFADDR2, i); 362 regmap_write(sta32x->regmap, STA32X_B1CF1, 363 (sta32x->coef_shadow[i] >> 16) & 0xff); 364 regmap_write(sta32x->regmap, STA32X_B1CF2, 365 (sta32x->coef_shadow[i] >> 8) & 0xff); 366 regmap_write(sta32x->regmap, STA32X_B1CF3, 367 (sta32x->coef_shadow[i]) & 0xff); 368 /* 369 * chip documentation does not say if the bits are 370 * self-clearing, so do it explicitly 371 */ 372 regmap_write(sta32x->regmap, STA32X_CFUD, cfud); 373 regmap_write(sta32x->regmap, STA32X_CFUD, cfud | 0x01); 374 } 375 return 0; 376 } 377 378 static int sta32x_cache_sync(struct snd_soc_codec *codec) 379 { 380 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 381 unsigned int mute; 382 int rc; 383 384 /* mute during register sync */ 385 regmap_read(sta32x->regmap, STA32X_MMUTE, &mute); 386 regmap_write(sta32x->regmap, STA32X_MMUTE, mute | STA32X_MMUTE_MMUTE); 387 sta32x_sync_coef_shadow(codec); 388 rc = regcache_sync(sta32x->regmap); 389 regmap_write(sta32x->regmap, STA32X_MMUTE, mute); 390 return rc; 391 } 392 393 /* work around ESD issue where sta32x resets and loses all configuration */ 394 static void sta32x_watchdog(struct work_struct *work) 395 { 396 struct sta32x_priv *sta32x = container_of(work, struct sta32x_priv, 397 watchdog_work.work); 398 struct snd_soc_codec *codec = sta32x->codec; 399 unsigned int confa, confa_cached; 400 401 /* check if sta32x has reset itself */ 402 confa_cached = snd_soc_read(codec, STA32X_CONFA); 403 regcache_cache_bypass(sta32x->regmap, true); 404 confa = snd_soc_read(codec, STA32X_CONFA); 405 regcache_cache_bypass(sta32x->regmap, false); 406 if (confa != confa_cached) { 407 regcache_mark_dirty(sta32x->regmap); 408 sta32x_cache_sync(codec); 409 } 410 411 if (!sta32x->shutdown) 412 queue_delayed_work(system_power_efficient_wq, 413 &sta32x->watchdog_work, 414 round_jiffies_relative(HZ)); 415 } 416 417 static void sta32x_watchdog_start(struct sta32x_priv *sta32x) 418 { 419 if (sta32x->pdata->needs_esd_watchdog) { 420 sta32x->shutdown = 0; 421 queue_delayed_work(system_power_efficient_wq, 422 &sta32x->watchdog_work, 423 round_jiffies_relative(HZ)); 424 } 425 } 426 427 static void sta32x_watchdog_stop(struct sta32x_priv *sta32x) 428 { 429 if (sta32x->pdata->needs_esd_watchdog) { 430 sta32x->shutdown = 1; 431 cancel_delayed_work_sync(&sta32x->watchdog_work); 432 } 433 } 434 435 #define SINGLE_COEF(xname, index) \ 436 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ 437 .info = sta32x_coefficient_info, \ 438 .get = sta32x_coefficient_get,\ 439 .put = sta32x_coefficient_put, \ 440 .private_value = index | (1 << 16) } 441 442 #define BIQUAD_COEFS(xname, index) \ 443 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ 444 .info = sta32x_coefficient_info, \ 445 .get = sta32x_coefficient_get,\ 446 .put = sta32x_coefficient_put, \ 447 .private_value = index | (5 << 16) } 448 449 static const struct snd_kcontrol_new sta32x_snd_controls[] = { 450 SOC_SINGLE_TLV("Master Volume", STA32X_MVOL, 0, 0xff, 1, mvol_tlv), 451 SOC_SINGLE("Master Switch", STA32X_MMUTE, 0, 1, 1), 452 SOC_SINGLE("Ch1 Switch", STA32X_MMUTE, 1, 1, 1), 453 SOC_SINGLE("Ch2 Switch", STA32X_MMUTE, 2, 1, 1), 454 SOC_SINGLE("Ch3 Switch", STA32X_MMUTE, 3, 1, 1), 455 SOC_SINGLE_TLV("Ch1 Volume", STA32X_C1VOL, 0, 0xff, 1, chvol_tlv), 456 SOC_SINGLE_TLV("Ch2 Volume", STA32X_C2VOL, 0, 0xff, 1, chvol_tlv), 457 SOC_SINGLE_TLV("Ch3 Volume", STA32X_C3VOL, 0, 0xff, 1, chvol_tlv), 458 SOC_SINGLE("De-emphasis Filter Switch", STA32X_CONFD, STA32X_CONFD_DEMP_SHIFT, 1, 0), 459 SOC_ENUM("Compressor/Limiter Switch", sta32x_drc_ac_enum), 460 SOC_SINGLE("Miami Mode Switch", STA32X_CONFD, STA32X_CONFD_MME_SHIFT, 1, 0), 461 SOC_SINGLE("Zero Cross Switch", STA32X_CONFE, STA32X_CONFE_ZCE_SHIFT, 1, 0), 462 SOC_SINGLE("Soft Ramp Switch", STA32X_CONFE, STA32X_CONFE_SVE_SHIFT, 1, 0), 463 SOC_SINGLE("Auto-Mute Switch", STA32X_CONFF, STA32X_CONFF_IDE_SHIFT, 1, 0), 464 SOC_ENUM("Automode EQ", sta32x_auto_eq_enum), 465 SOC_ENUM("Automode GC", sta32x_auto_gc_enum), 466 SOC_ENUM("Automode XO", sta32x_auto_xo_enum), 467 SOC_ENUM("Preset EQ", sta32x_preset_eq_enum), 468 SOC_SINGLE("Ch1 Tone Control Bypass Switch", STA32X_C1CFG, STA32X_CxCFG_TCB_SHIFT, 1, 0), 469 SOC_SINGLE("Ch2 Tone Control Bypass Switch", STA32X_C2CFG, STA32X_CxCFG_TCB_SHIFT, 1, 0), 470 SOC_SINGLE("Ch1 EQ Bypass Switch", STA32X_C1CFG, STA32X_CxCFG_EQBP_SHIFT, 1, 0), 471 SOC_SINGLE("Ch2 EQ Bypass Switch", STA32X_C2CFG, STA32X_CxCFG_EQBP_SHIFT, 1, 0), 472 SOC_SINGLE("Ch1 Master Volume Bypass Switch", STA32X_C1CFG, STA32X_CxCFG_VBP_SHIFT, 1, 0), 473 SOC_SINGLE("Ch2 Master Volume Bypass Switch", STA32X_C1CFG, STA32X_CxCFG_VBP_SHIFT, 1, 0), 474 SOC_SINGLE("Ch3 Master Volume Bypass Switch", STA32X_C1CFG, STA32X_CxCFG_VBP_SHIFT, 1, 0), 475 SOC_ENUM("Ch1 Limiter Select", sta32x_limiter_ch1_enum), 476 SOC_ENUM("Ch2 Limiter Select", sta32x_limiter_ch2_enum), 477 SOC_ENUM("Ch3 Limiter Select", sta32x_limiter_ch3_enum), 478 SOC_SINGLE_TLV("Bass Tone Control", STA32X_TONE, STA32X_TONE_BTC_SHIFT, 15, 0, tone_tlv), 479 SOC_SINGLE_TLV("Treble Tone Control", STA32X_TONE, STA32X_TONE_TTC_SHIFT, 15, 0, tone_tlv), 480 SOC_ENUM("Limiter1 Attack Rate (dB/ms)", sta32x_limiter1_attack_rate_enum), 481 SOC_ENUM("Limiter2 Attack Rate (dB/ms)", sta32x_limiter2_attack_rate_enum), 482 SOC_ENUM("Limiter1 Release Rate (dB/ms)", sta32x_limiter1_release_rate_enum), 483 SOC_ENUM("Limiter2 Release Rate (dB/ms)", sta32x_limiter2_release_rate_enum), 484 485 /* depending on mode, the attack/release thresholds have 486 * two different enum definitions; provide both 487 */ 488 SOC_SINGLE_TLV("Limiter1 Attack Threshold (AC Mode)", STA32X_L1ATRT, STA32X_LxA_SHIFT, 489 16, 0, sta32x_limiter_ac_attack_tlv), 490 SOC_SINGLE_TLV("Limiter2 Attack Threshold (AC Mode)", STA32X_L2ATRT, STA32X_LxA_SHIFT, 491 16, 0, sta32x_limiter_ac_attack_tlv), 492 SOC_SINGLE_TLV("Limiter1 Release Threshold (AC Mode)", STA32X_L1ATRT, STA32X_LxR_SHIFT, 493 16, 0, sta32x_limiter_ac_release_tlv), 494 SOC_SINGLE_TLV("Limiter2 Release Threshold (AC Mode)", STA32X_L2ATRT, STA32X_LxR_SHIFT, 495 16, 0, sta32x_limiter_ac_release_tlv), 496 SOC_SINGLE_TLV("Limiter1 Attack Threshold (DRC Mode)", STA32X_L1ATRT, STA32X_LxA_SHIFT, 497 16, 0, sta32x_limiter_drc_attack_tlv), 498 SOC_SINGLE_TLV("Limiter2 Attack Threshold (DRC Mode)", STA32X_L2ATRT, STA32X_LxA_SHIFT, 499 16, 0, sta32x_limiter_drc_attack_tlv), 500 SOC_SINGLE_TLV("Limiter1 Release Threshold (DRC Mode)", STA32X_L1ATRT, STA32X_LxR_SHIFT, 501 16, 0, sta32x_limiter_drc_release_tlv), 502 SOC_SINGLE_TLV("Limiter2 Release Threshold (DRC Mode)", STA32X_L2ATRT, STA32X_LxR_SHIFT, 503 16, 0, sta32x_limiter_drc_release_tlv), 504 505 BIQUAD_COEFS("Ch1 - Biquad 1", 0), 506 BIQUAD_COEFS("Ch1 - Biquad 2", 5), 507 BIQUAD_COEFS("Ch1 - Biquad 3", 10), 508 BIQUAD_COEFS("Ch1 - Biquad 4", 15), 509 BIQUAD_COEFS("Ch2 - Biquad 1", 20), 510 BIQUAD_COEFS("Ch2 - Biquad 2", 25), 511 BIQUAD_COEFS("Ch2 - Biquad 3", 30), 512 BIQUAD_COEFS("Ch2 - Biquad 4", 35), 513 BIQUAD_COEFS("High-pass", 40), 514 BIQUAD_COEFS("Low-pass", 45), 515 SINGLE_COEF("Ch1 - Prescale", 50), 516 SINGLE_COEF("Ch2 - Prescale", 51), 517 SINGLE_COEF("Ch1 - Postscale", 52), 518 SINGLE_COEF("Ch2 - Postscale", 53), 519 SINGLE_COEF("Ch3 - Postscale", 54), 520 SINGLE_COEF("Thermal warning - Postscale", 55), 521 SINGLE_COEF("Ch1 - Mix 1", 56), 522 SINGLE_COEF("Ch1 - Mix 2", 57), 523 SINGLE_COEF("Ch2 - Mix 1", 58), 524 SINGLE_COEF("Ch2 - Mix 2", 59), 525 SINGLE_COEF("Ch3 - Mix 1", 60), 526 SINGLE_COEF("Ch3 - Mix 2", 61), 527 }; 528 529 static const struct snd_soc_dapm_widget sta32x_dapm_widgets[] = { 530 SND_SOC_DAPM_DAC("DAC", "Playback", SND_SOC_NOPM, 0, 0), 531 SND_SOC_DAPM_OUTPUT("LEFT"), 532 SND_SOC_DAPM_OUTPUT("RIGHT"), 533 SND_SOC_DAPM_OUTPUT("SUB"), 534 }; 535 536 static const struct snd_soc_dapm_route sta32x_dapm_routes[] = { 537 { "LEFT", NULL, "DAC" }, 538 { "RIGHT", NULL, "DAC" }, 539 { "SUB", NULL, "DAC" }, 540 }; 541 542 /* MCLK interpolation ratio per fs */ 543 static struct { 544 int fs; 545 int ir; 546 } interpolation_ratios[] = { 547 { 32000, 0 }, 548 { 44100, 0 }, 549 { 48000, 0 }, 550 { 88200, 1 }, 551 { 96000, 1 }, 552 { 176400, 2 }, 553 { 192000, 2 }, 554 }; 555 556 /* MCLK to fs clock ratios */ 557 static int mcs_ratio_table[3][7] = { 558 { 768, 512, 384, 256, 128, 576, 0 }, 559 { 384, 256, 192, 128, 64, 0 }, 560 { 384, 256, 192, 128, 64, 0 }, 561 }; 562 563 /** 564 * sta32x_set_dai_sysclk - configure MCLK 565 * @codec_dai: the codec DAI 566 * @clk_id: the clock ID (ignored) 567 * @freq: the MCLK input frequency 568 * @dir: the clock direction (ignored) 569 * 570 * The value of MCLK is used to determine which sample rates are supported 571 * by the STA32X, based on the mclk_ratios table. 572 * 573 * This function must be called by the machine driver's 'startup' function, 574 * otherwise the list of supported sample rates will not be available in 575 * time for ALSA. 576 * 577 * For setups with variable MCLKs, pass 0 as 'freq' argument. This will cause 578 * theoretically possible sample rates to be enabled. Call it again with a 579 * proper value set one the external clock is set (most probably you would do 580 * that from a machine's driver 'hw_param' hook. 581 */ 582 static int sta32x_set_dai_sysclk(struct snd_soc_dai *codec_dai, 583 int clk_id, unsigned int freq, int dir) 584 { 585 struct snd_soc_codec *codec = codec_dai->codec; 586 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 587 588 dev_dbg(codec->dev, "mclk=%u\n", freq); 589 sta32x->mclk = freq; 590 591 return 0; 592 } 593 594 /** 595 * sta32x_set_dai_fmt - configure the codec for the selected audio format 596 * @codec_dai: the codec DAI 597 * @fmt: a SND_SOC_DAIFMT_x value indicating the data format 598 * 599 * This function takes a bitmask of SND_SOC_DAIFMT_x bits and programs the 600 * codec accordingly. 601 */ 602 static int sta32x_set_dai_fmt(struct snd_soc_dai *codec_dai, 603 unsigned int fmt) 604 { 605 struct snd_soc_codec *codec = codec_dai->codec; 606 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 607 u8 confb = 0; 608 609 switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) { 610 case SND_SOC_DAIFMT_CBS_CFS: 611 break; 612 default: 613 return -EINVAL; 614 } 615 616 switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) { 617 case SND_SOC_DAIFMT_I2S: 618 case SND_SOC_DAIFMT_RIGHT_J: 619 case SND_SOC_DAIFMT_LEFT_J: 620 sta32x->format = fmt & SND_SOC_DAIFMT_FORMAT_MASK; 621 break; 622 default: 623 return -EINVAL; 624 } 625 626 switch (fmt & SND_SOC_DAIFMT_INV_MASK) { 627 case SND_SOC_DAIFMT_NB_NF: 628 confb |= STA32X_CONFB_C2IM; 629 break; 630 case SND_SOC_DAIFMT_NB_IF: 631 confb |= STA32X_CONFB_C1IM; 632 break; 633 default: 634 return -EINVAL; 635 } 636 637 return regmap_update_bits(sta32x->regmap, STA32X_CONFB, 638 STA32X_CONFB_C1IM | STA32X_CONFB_C2IM, confb); 639 } 640 641 /** 642 * sta32x_hw_params - program the STA32X with the given hardware parameters. 643 * @substream: the audio stream 644 * @params: the hardware parameters to set 645 * @dai: the SOC DAI (ignored) 646 * 647 * This function programs the hardware with the values provided. 648 * Specifically, the sample rate and the data format. 649 */ 650 static int sta32x_hw_params(struct snd_pcm_substream *substream, 651 struct snd_pcm_hw_params *params, 652 struct snd_soc_dai *dai) 653 { 654 struct snd_soc_codec *codec = dai->codec; 655 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 656 int i, mcs = -EINVAL, ir = -EINVAL; 657 unsigned int confa, confb; 658 unsigned int rate, ratio; 659 int ret; 660 661 if (!sta32x->mclk) { 662 dev_err(codec->dev, 663 "sta32x->mclk is unset. Unable to determine ratio\n"); 664 return -EIO; 665 } 666 667 rate = params_rate(params); 668 ratio = sta32x->mclk / rate; 669 dev_dbg(codec->dev, "rate: %u, ratio: %u\n", rate, ratio); 670 671 for (i = 0; i < ARRAY_SIZE(interpolation_ratios); i++) { 672 if (interpolation_ratios[i].fs == rate) { 673 ir = interpolation_ratios[i].ir; 674 break; 675 } 676 } 677 678 if (ir < 0) { 679 dev_err(codec->dev, "Unsupported samplerate: %u\n", rate); 680 return -EINVAL; 681 } 682 683 for (i = 0; i < 6; i++) { 684 if (mcs_ratio_table[ir][i] == ratio) { 685 mcs = i; 686 break; 687 } 688 } 689 690 if (mcs < 0) { 691 dev_err(codec->dev, "Unresolvable ratio: %u\n", ratio); 692 return -EINVAL; 693 } 694 695 confa = (ir << STA32X_CONFA_IR_SHIFT) | 696 (mcs << STA32X_CONFA_MCS_SHIFT); 697 confb = 0; 698 699 switch (params_width(params)) { 700 case 24: 701 dev_dbg(codec->dev, "24bit\n"); 702 /* fall through */ 703 case 32: 704 dev_dbg(codec->dev, "24bit or 32bit\n"); 705 switch (sta32x->format) { 706 case SND_SOC_DAIFMT_I2S: 707 confb |= 0x0; 708 break; 709 case SND_SOC_DAIFMT_LEFT_J: 710 confb |= 0x1; 711 break; 712 case SND_SOC_DAIFMT_RIGHT_J: 713 confb |= 0x2; 714 break; 715 } 716 717 break; 718 case 20: 719 dev_dbg(codec->dev, "20bit\n"); 720 switch (sta32x->format) { 721 case SND_SOC_DAIFMT_I2S: 722 confb |= 0x4; 723 break; 724 case SND_SOC_DAIFMT_LEFT_J: 725 confb |= 0x5; 726 break; 727 case SND_SOC_DAIFMT_RIGHT_J: 728 confb |= 0x6; 729 break; 730 } 731 732 break; 733 case 18: 734 dev_dbg(codec->dev, "18bit\n"); 735 switch (sta32x->format) { 736 case SND_SOC_DAIFMT_I2S: 737 confb |= 0x8; 738 break; 739 case SND_SOC_DAIFMT_LEFT_J: 740 confb |= 0x9; 741 break; 742 case SND_SOC_DAIFMT_RIGHT_J: 743 confb |= 0xa; 744 break; 745 } 746 747 break; 748 case 16: 749 dev_dbg(codec->dev, "16bit\n"); 750 switch (sta32x->format) { 751 case SND_SOC_DAIFMT_I2S: 752 confb |= 0x0; 753 break; 754 case SND_SOC_DAIFMT_LEFT_J: 755 confb |= 0xd; 756 break; 757 case SND_SOC_DAIFMT_RIGHT_J: 758 confb |= 0xe; 759 break; 760 } 761 762 break; 763 default: 764 return -EINVAL; 765 } 766 767 ret = regmap_update_bits(sta32x->regmap, STA32X_CONFA, 768 STA32X_CONFA_MCS_MASK | STA32X_CONFA_IR_MASK, 769 confa); 770 if (ret < 0) 771 return ret; 772 773 ret = regmap_update_bits(sta32x->regmap, STA32X_CONFB, 774 STA32X_CONFB_SAI_MASK | STA32X_CONFB_SAIFB, 775 confb); 776 if (ret < 0) 777 return ret; 778 779 return 0; 780 } 781 782 static int sta32x_startup_sequence(struct sta32x_priv *sta32x) 783 { 784 if (sta32x->gpiod_nreset) { 785 gpiod_set_value(sta32x->gpiod_nreset, 0); 786 mdelay(1); 787 gpiod_set_value(sta32x->gpiod_nreset, 1); 788 mdelay(1); 789 } 790 791 return 0; 792 } 793 794 /** 795 * sta32x_set_bias_level - DAPM callback 796 * @codec: the codec device 797 * @level: DAPM power level 798 * 799 * This is called by ALSA to put the codec into low power mode 800 * or to wake it up. If the codec is powered off completely 801 * all registers must be restored after power on. 802 */ 803 static int sta32x_set_bias_level(struct snd_soc_codec *codec, 804 enum snd_soc_bias_level level) 805 { 806 int ret; 807 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 808 809 dev_dbg(codec->dev, "level = %d\n", level); 810 switch (level) { 811 case SND_SOC_BIAS_ON: 812 break; 813 814 case SND_SOC_BIAS_PREPARE: 815 /* Full power on */ 816 regmap_update_bits(sta32x->regmap, STA32X_CONFF, 817 STA32X_CONFF_PWDN | STA32X_CONFF_EAPD, 818 STA32X_CONFF_PWDN | STA32X_CONFF_EAPD); 819 break; 820 821 case SND_SOC_BIAS_STANDBY: 822 if (codec->dapm.bias_level == SND_SOC_BIAS_OFF) { 823 ret = regulator_bulk_enable(ARRAY_SIZE(sta32x->supplies), 824 sta32x->supplies); 825 if (ret != 0) { 826 dev_err(codec->dev, 827 "Failed to enable supplies: %d\n", ret); 828 return ret; 829 } 830 831 sta32x_startup_sequence(sta32x); 832 sta32x_cache_sync(codec); 833 sta32x_watchdog_start(sta32x); 834 } 835 836 /* Power down */ 837 regmap_update_bits(sta32x->regmap, STA32X_CONFF, 838 STA32X_CONFF_PWDN | STA32X_CONFF_EAPD, 839 0); 840 841 break; 842 843 case SND_SOC_BIAS_OFF: 844 /* The chip runs through the power down sequence for us. */ 845 regmap_update_bits(sta32x->regmap, STA32X_CONFF, 846 STA32X_CONFF_PWDN | STA32X_CONFF_EAPD, 0); 847 msleep(300); 848 sta32x_watchdog_stop(sta32x); 849 850 if (sta32x->gpiod_nreset) 851 gpiod_set_value(sta32x->gpiod_nreset, 0); 852 853 regulator_bulk_disable(ARRAY_SIZE(sta32x->supplies), 854 sta32x->supplies); 855 break; 856 } 857 codec->dapm.bias_level = level; 858 return 0; 859 } 860 861 static const struct snd_soc_dai_ops sta32x_dai_ops = { 862 .hw_params = sta32x_hw_params, 863 .set_sysclk = sta32x_set_dai_sysclk, 864 .set_fmt = sta32x_set_dai_fmt, 865 }; 866 867 static struct snd_soc_dai_driver sta32x_dai = { 868 .name = "sta32x-hifi", 869 .playback = { 870 .stream_name = "Playback", 871 .channels_min = 2, 872 .channels_max = 2, 873 .rates = STA32X_RATES, 874 .formats = STA32X_FORMATS, 875 }, 876 .ops = &sta32x_dai_ops, 877 }; 878 879 static int sta32x_probe(struct snd_soc_codec *codec) 880 { 881 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 882 struct sta32x_platform_data *pdata = sta32x->pdata; 883 int i, ret = 0, thermal = 0; 884 ret = regulator_bulk_enable(ARRAY_SIZE(sta32x->supplies), 885 sta32x->supplies); 886 if (ret != 0) { 887 dev_err(codec->dev, "Failed to enable supplies: %d\n", ret); 888 return ret; 889 } 890 891 ret = sta32x_startup_sequence(sta32x); 892 if (ret < 0) { 893 dev_err(codec->dev, "Failed to startup device\n"); 894 return ret; 895 } 896 897 /* CONFA */ 898 if (!pdata->thermal_warning_recovery) 899 thermal |= STA32X_CONFA_TWAB; 900 if (!pdata->thermal_warning_adjustment) 901 thermal |= STA32X_CONFA_TWRB; 902 if (!pdata->fault_detect_recovery) 903 thermal |= STA32X_CONFA_FDRB; 904 regmap_update_bits(sta32x->regmap, STA32X_CONFA, 905 STA32X_CONFA_TWAB | STA32X_CONFA_TWRB | 906 STA32X_CONFA_FDRB, 907 thermal); 908 909 /* CONFC */ 910 regmap_update_bits(sta32x->regmap, STA32X_CONFC, 911 STA32X_CONFC_CSZ_MASK, 912 pdata->drop_compensation_ns 913 << STA32X_CONFC_CSZ_SHIFT); 914 915 /* CONFE */ 916 regmap_update_bits(sta32x->regmap, STA32X_CONFE, 917 STA32X_CONFE_MPCV, 918 pdata->max_power_use_mpcc ? 919 STA32X_CONFE_MPCV : 0); 920 regmap_update_bits(sta32x->regmap, STA32X_CONFE, 921 STA32X_CONFE_MPC, 922 pdata->max_power_correction ? 923 STA32X_CONFE_MPC : 0); 924 regmap_update_bits(sta32x->regmap, STA32X_CONFE, 925 STA32X_CONFE_AME, 926 pdata->am_reduction_mode ? 927 STA32X_CONFE_AME : 0); 928 regmap_update_bits(sta32x->regmap, STA32X_CONFE, 929 STA32X_CONFE_PWMS, 930 pdata->odd_pwm_speed_mode ? 931 STA32X_CONFE_PWMS : 0); 932 933 /* CONFF */ 934 regmap_update_bits(sta32x->regmap, STA32X_CONFF, 935 STA32X_CONFF_IDE, 936 pdata->invalid_input_detect_mute ? 937 STA32X_CONFF_IDE : 0); 938 939 /* select output configuration */ 940 regmap_update_bits(sta32x->regmap, STA32X_CONFF, 941 STA32X_CONFF_OCFG_MASK, 942 pdata->output_conf 943 << STA32X_CONFF_OCFG_SHIFT); 944 945 /* channel to output mapping */ 946 regmap_update_bits(sta32x->regmap, STA32X_C1CFG, 947 STA32X_CxCFG_OM_MASK, 948 pdata->ch1_output_mapping 949 << STA32X_CxCFG_OM_SHIFT); 950 regmap_update_bits(sta32x->regmap, STA32X_C2CFG, 951 STA32X_CxCFG_OM_MASK, 952 pdata->ch2_output_mapping 953 << STA32X_CxCFG_OM_SHIFT); 954 regmap_update_bits(sta32x->regmap, STA32X_C3CFG, 955 STA32X_CxCFG_OM_MASK, 956 pdata->ch3_output_mapping 957 << STA32X_CxCFG_OM_SHIFT); 958 959 /* initialize coefficient shadow RAM with reset values */ 960 for (i = 4; i <= 49; i += 5) 961 sta32x->coef_shadow[i] = 0x400000; 962 for (i = 50; i <= 54; i++) 963 sta32x->coef_shadow[i] = 0x7fffff; 964 sta32x->coef_shadow[55] = 0x5a9df7; 965 sta32x->coef_shadow[56] = 0x7fffff; 966 sta32x->coef_shadow[59] = 0x7fffff; 967 sta32x->coef_shadow[60] = 0x400000; 968 sta32x->coef_shadow[61] = 0x400000; 969 970 if (sta32x->pdata->needs_esd_watchdog) 971 INIT_DELAYED_WORK(&sta32x->watchdog_work, sta32x_watchdog); 972 973 sta32x_set_bias_level(codec, SND_SOC_BIAS_STANDBY); 974 /* Bias level configuration will have done an extra enable */ 975 regulator_bulk_disable(ARRAY_SIZE(sta32x->supplies), sta32x->supplies); 976 977 return 0; 978 } 979 980 static int sta32x_remove(struct snd_soc_codec *codec) 981 { 982 struct sta32x_priv *sta32x = snd_soc_codec_get_drvdata(codec); 983 984 sta32x_watchdog_stop(sta32x); 985 regulator_bulk_disable(ARRAY_SIZE(sta32x->supplies), sta32x->supplies); 986 987 return 0; 988 } 989 990 static const struct snd_soc_codec_driver sta32x_codec = { 991 .probe = sta32x_probe, 992 .remove = sta32x_remove, 993 .set_bias_level = sta32x_set_bias_level, 994 .suspend_bias_off = true, 995 .controls = sta32x_snd_controls, 996 .num_controls = ARRAY_SIZE(sta32x_snd_controls), 997 .dapm_widgets = sta32x_dapm_widgets, 998 .num_dapm_widgets = ARRAY_SIZE(sta32x_dapm_widgets), 999 .dapm_routes = sta32x_dapm_routes, 1000 .num_dapm_routes = ARRAY_SIZE(sta32x_dapm_routes), 1001 }; 1002 1003 static const struct regmap_config sta32x_regmap = { 1004 .reg_bits = 8, 1005 .val_bits = 8, 1006 .max_register = STA32X_FDRC2, 1007 .reg_defaults = sta32x_regs, 1008 .num_reg_defaults = ARRAY_SIZE(sta32x_regs), 1009 .cache_type = REGCACHE_RBTREE, 1010 .wr_table = &sta32x_write_regs, 1011 .rd_table = &sta32x_read_regs, 1012 .volatile_table = &sta32x_volatile_regs, 1013 }; 1014 1015 #ifdef CONFIG_OF 1016 static const struct of_device_id st32x_dt_ids[] = { 1017 { .compatible = "st,sta32x", }, 1018 { } 1019 }; 1020 MODULE_DEVICE_TABLE(of, st32x_dt_ids); 1021 1022 static int sta32x_probe_dt(struct device *dev, struct sta32x_priv *sta32x) 1023 { 1024 struct device_node *np = dev->of_node; 1025 struct sta32x_platform_data *pdata; 1026 u16 tmp; 1027 1028 pdata = devm_kzalloc(dev, sizeof(*pdata), GFP_KERNEL); 1029 if (!pdata) 1030 return -ENOMEM; 1031 1032 of_property_read_u8(np, "st,output-conf", 1033 &pdata->output_conf); 1034 of_property_read_u8(np, "st,ch1-output-mapping", 1035 &pdata->ch1_output_mapping); 1036 of_property_read_u8(np, "st,ch2-output-mapping", 1037 &pdata->ch2_output_mapping); 1038 of_property_read_u8(np, "st,ch3-output-mapping", 1039 &pdata->ch3_output_mapping); 1040 1041 if (of_get_property(np, "st,thermal-warning-recovery", NULL)) 1042 pdata->thermal_warning_recovery = 1; 1043 if (of_get_property(np, "st,thermal-warning-adjustment", NULL)) 1044 pdata->thermal_warning_adjustment = 1; 1045 if (of_get_property(np, "st,needs_esd_watchdog", NULL)) 1046 pdata->needs_esd_watchdog = 1; 1047 1048 tmp = 140; 1049 of_property_read_u16(np, "st,drop-compensation-ns", &tmp); 1050 pdata->drop_compensation_ns = clamp_t(u16, tmp, 0, 300) / 20; 1051 1052 /* CONFE */ 1053 if (of_get_property(np, "st,max-power-use-mpcc", NULL)) 1054 pdata->max_power_use_mpcc = 1; 1055 1056 if (of_get_property(np, "st,max-power-correction", NULL)) 1057 pdata->max_power_correction = 1; 1058 1059 if (of_get_property(np, "st,am-reduction-mode", NULL)) 1060 pdata->am_reduction_mode = 1; 1061 1062 if (of_get_property(np, "st,odd-pwm-speed-mode", NULL)) 1063 pdata->odd_pwm_speed_mode = 1; 1064 1065 /* CONFF */ 1066 if (of_get_property(np, "st,invalid-input-detect-mute", NULL)) 1067 pdata->invalid_input_detect_mute = 1; 1068 1069 sta32x->pdata = pdata; 1070 1071 return 0; 1072 } 1073 #endif 1074 1075 static int sta32x_i2c_probe(struct i2c_client *i2c, 1076 const struct i2c_device_id *id) 1077 { 1078 struct device *dev = &i2c->dev; 1079 struct sta32x_priv *sta32x; 1080 int ret, i; 1081 1082 sta32x = devm_kzalloc(&i2c->dev, sizeof(struct sta32x_priv), 1083 GFP_KERNEL); 1084 if (!sta32x) 1085 return -ENOMEM; 1086 1087 mutex_init(&sta32x->coeff_lock); 1088 sta32x->pdata = dev_get_platdata(dev); 1089 1090 #ifdef CONFIG_OF 1091 if (dev->of_node) { 1092 ret = sta32x_probe_dt(dev, sta32x); 1093 if (ret < 0) 1094 return ret; 1095 } 1096 #endif 1097 1098 /* GPIOs */ 1099 sta32x->gpiod_nreset = devm_gpiod_get(dev, "reset"); 1100 if (IS_ERR(sta32x->gpiod_nreset)) { 1101 ret = PTR_ERR(sta32x->gpiod_nreset); 1102 if (ret != -ENOENT && ret != -ENOSYS) 1103 return ret; 1104 1105 sta32x->gpiod_nreset = NULL; 1106 } else { 1107 gpiod_direction_output(sta32x->gpiod_nreset, 0); 1108 } 1109 1110 /* regulators */ 1111 for (i = 0; i < ARRAY_SIZE(sta32x->supplies); i++) 1112 sta32x->supplies[i].supply = sta32x_supply_names[i]; 1113 1114 ret = devm_regulator_bulk_get(&i2c->dev, ARRAY_SIZE(sta32x->supplies), 1115 sta32x->supplies); 1116 if (ret != 0) { 1117 dev_err(&i2c->dev, "Failed to request supplies: %d\n", ret); 1118 return ret; 1119 } 1120 1121 sta32x->regmap = devm_regmap_init_i2c(i2c, &sta32x_regmap); 1122 if (IS_ERR(sta32x->regmap)) { 1123 ret = PTR_ERR(sta32x->regmap); 1124 dev_err(dev, "Failed to init regmap: %d\n", ret); 1125 return ret; 1126 } 1127 1128 i2c_set_clientdata(i2c, sta32x); 1129 1130 ret = snd_soc_register_codec(dev, &sta32x_codec, &sta32x_dai, 1); 1131 if (ret < 0) 1132 dev_err(dev, "Failed to register codec (%d)\n", ret); 1133 1134 return ret; 1135 } 1136 1137 static int sta32x_i2c_remove(struct i2c_client *client) 1138 { 1139 snd_soc_unregister_codec(&client->dev); 1140 return 0; 1141 } 1142 1143 static const struct i2c_device_id sta32x_i2c_id[] = { 1144 { "sta326", 0 }, 1145 { "sta328", 0 }, 1146 { "sta329", 0 }, 1147 { } 1148 }; 1149 MODULE_DEVICE_TABLE(i2c, sta32x_i2c_id); 1150 1151 static struct i2c_driver sta32x_i2c_driver = { 1152 .driver = { 1153 .name = "sta32x", 1154 .owner = THIS_MODULE, 1155 .of_match_table = of_match_ptr(st32x_dt_ids), 1156 }, 1157 .probe = sta32x_i2c_probe, 1158 .remove = sta32x_i2c_remove, 1159 .id_table = sta32x_i2c_id, 1160 }; 1161 1162 module_i2c_driver(sta32x_i2c_driver); 1163 1164 MODULE_DESCRIPTION("ASoC STA32X driver"); 1165 MODULE_AUTHOR("Johannes Stezenbach <js@sig21.net>"); 1166 MODULE_LICENSE("GPL"); 1167