2 * TAS5086 ASoC codec driver
4 * Copyright (c) 2013 Daniel Mack <zonque@gmail.com>
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
17 * - implement DAPM and input muxing
18 * - implement modulation limit
19 * - implement non-default PWM start
21 * Note that this chip has a very unusual register layout, specifically
22 * because the registers are of unequal size, and multi-byte registers
23 * require bulk writes to take effect. Regmap does not support that kind
26 * Currently, the driver does not touch any of the registers >= 0x20, so
27 * it doesn't matter because the entire map can be accessed as 8-bit
28 * array. In case more features will be added in the future
29 * that require access to higher registers, the entire regmap H/W I/O
30 * routines have to be open-coded.
33 #include <linux/module.h>
34 #include <linux/slab.h>
35 #include <linux/delay.h>
36 #include <linux/gpio.h>
37 #include <linux/i2c.h>
38 #include <linux/regmap.h>
39 #include <linux/regulator/consumer.h>
40 #include <linux/spi/spi.h>
42 #include <linux/of_device.h>
43 #include <linux/of_gpio.h>
44 #include <sound/pcm.h>
45 #include <sound/pcm_params.h>
46 #include <sound/soc.h>
47 #include <sound/tlv.h>
48 #include <sound/tas5086.h>
50 #define TAS5086_PCM_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | \
51 SNDRV_PCM_FMTBIT_S20_3LE | \
52 SNDRV_PCM_FMTBIT_S24_3LE)
54 #define TAS5086_PCM_RATES (SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_44100 | \
55 SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_88200 | \
56 SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_176400 | \
57 SNDRV_PCM_RATE_192000)
62 #define TAS5086_CLOCK_CONTROL 0x00 /* Clock control register */
63 #define TAS5086_CLOCK_RATE(val) (val << 5)
64 #define TAS5086_CLOCK_RATE_MASK (0x7 << 5)
65 #define TAS5086_CLOCK_RATIO(val) (val << 2)
66 #define TAS5086_CLOCK_RATIO_MASK (0x7 << 2)
67 #define TAS5086_CLOCK_SCLK_RATIO_48 (1 << 1)
68 #define TAS5086_CLOCK_VALID (1 << 0)
70 #define TAS5086_DEEMPH_MASK 0x03
71 #define TAS5086_SOFT_MUTE_ALL 0x3f
73 #define TAS5086_DEV_ID 0x01 /* Device ID register */
74 #define TAS5086_ERROR_STATUS 0x02 /* Error status register */
75 #define TAS5086_SYS_CONTROL_1 0x03 /* System control register 1 */
76 #define TAS5086_SERIAL_DATA_IF 0x04 /* Serial data interface register */
77 #define TAS5086_SYS_CONTROL_2 0x05 /* System control register 2 */
78 #define TAS5086_SOFT_MUTE 0x06 /* Soft mute register */
79 #define TAS5086_MASTER_VOL 0x07 /* Master volume */
80 #define TAS5086_CHANNEL_VOL(X) (0x08 + (X)) /* Channel 1-6 volume */
81 #define TAS5086_VOLUME_CONTROL 0x09 /* Volume control register */
82 #define TAS5086_MOD_LIMIT 0x10 /* Modulation limit register */
83 #define TAS5086_PWM_START 0x18 /* PWM start register */
84 #define TAS5086_SURROUND 0x19 /* Surround register */
85 #define TAS5086_SPLIT_CAP_CHARGE 0x1a /* Split cap charge period register */
86 #define TAS5086_OSC_TRIM 0x1b /* Oscillator trim register */
87 #define TAS5086_BKNDERR 0x1c
88 #define TAS5086_INPUT_MUX 0x20
89 #define TAS5086_PWM_OUTPUT_MUX 0x25
91 #define TAS5086_MAX_REGISTER TAS5086_PWM_OUTPUT_MUX
93 #define TAS5086_PWM_START_MIDZ_FOR_START_1 (1 << 7)
94 #define TAS5086_PWM_START_MIDZ_FOR_START_2 (1 << 6)
95 #define TAS5086_PWM_START_CHANNEL_MASK (0x3f)
98 * Default TAS5086 power-up configuration
100 static const struct reg_default tas5086_reg_defaults
[] = {
132 static int tas5086_register_size(struct device
*dev
, unsigned int reg
)
135 case TAS5086_CLOCK_CONTROL
... TAS5086_BKNDERR
:
137 case TAS5086_INPUT_MUX
:
138 case TAS5086_PWM_OUTPUT_MUX
:
142 dev_err(dev
, "Unsupported register address: %d\n", reg
);
146 static bool tas5086_accessible_reg(struct device
*dev
, unsigned int reg
)
158 static bool tas5086_volatile_reg(struct device
*dev
, unsigned int reg
)
162 case TAS5086_ERROR_STATUS
:
169 static bool tas5086_writeable_reg(struct device
*dev
, unsigned int reg
)
171 return tas5086_accessible_reg(dev
, reg
) && (reg
!= TAS5086_DEV_ID
);
174 static int tas5086_reg_write(void *context
, unsigned int reg
,
177 struct i2c_client
*client
= context
;
178 unsigned int i
, size
;
182 size
= tas5086_register_size(&client
->dev
, reg
);
188 for (i
= size
; i
>= 1; --i
) {
193 ret
= i2c_master_send(client
, buf
, size
+ 1);
202 static int tas5086_reg_read(void *context
, unsigned int reg
,
205 struct i2c_client
*client
= context
;
206 uint8_t send_buf
, recv_buf
[4];
207 struct i2c_msg msgs
[2];
212 size
= tas5086_register_size(&client
->dev
, reg
);
218 msgs
[0].addr
= client
->addr
;
219 msgs
[0].len
= sizeof(send_buf
);
220 msgs
[0].buf
= &send_buf
;
223 msgs
[1].addr
= client
->addr
;
225 msgs
[1].buf
= recv_buf
;
226 msgs
[1].flags
= I2C_M_RD
;
228 ret
= i2c_transfer(client
->adapter
, msgs
, ARRAY_SIZE(msgs
));
231 else if (ret
!= ARRAY_SIZE(msgs
))
236 for (i
= 0; i
< size
; i
++) {
238 *value
|= recv_buf
[i
];
244 static const char * const supply_names
[] = {
248 struct tas5086_private
{
249 struct regmap
*regmap
;
250 unsigned int mclk
, sclk
;
253 unsigned int charge_period
;
254 unsigned int pwm_start_mid_z
;
255 /* Current sample rate for de-emphasis control */
257 /* GPIO driving Reset pin, if any */
259 struct regulator_bulk_data supplies
[ARRAY_SIZE(supply_names
)];
262 static int tas5086_deemph
[] = { 0, 32000, 44100, 48000 };
264 static int tas5086_set_deemph(struct snd_soc_codec
*codec
)
266 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
270 for (i
= 0; i
< ARRAY_SIZE(tas5086_deemph
); i
++) {
271 if (tas5086_deemph
[i
] == priv
->rate
) {
278 return regmap_update_bits(priv
->regmap
, TAS5086_SYS_CONTROL_1
,
279 TAS5086_DEEMPH_MASK
, val
);
282 static int tas5086_get_deemph(struct snd_kcontrol
*kcontrol
,
283 struct snd_ctl_elem_value
*ucontrol
)
285 struct snd_soc_codec
*codec
= snd_soc_kcontrol_codec(kcontrol
);
286 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
288 ucontrol
->value
.integer
.value
[0] = priv
->deemph
;
293 static int tas5086_put_deemph(struct snd_kcontrol
*kcontrol
,
294 struct snd_ctl_elem_value
*ucontrol
)
296 struct snd_soc_codec
*codec
= snd_soc_kcontrol_codec(kcontrol
);
297 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
299 priv
->deemph
= ucontrol
->value
.integer
.value
[0];
301 return tas5086_set_deemph(codec
);
305 static int tas5086_set_dai_sysclk(struct snd_soc_dai
*codec_dai
,
306 int clk_id
, unsigned int freq
, int dir
)
308 struct snd_soc_codec
*codec
= codec_dai
->codec
;
309 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
312 case TAS5086_CLK_IDX_MCLK
:
315 case TAS5086_CLK_IDX_SCLK
:
323 static int tas5086_set_dai_fmt(struct snd_soc_dai
*codec_dai
,
326 struct snd_soc_codec
*codec
= codec_dai
->codec
;
327 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
329 /* The TAS5086 can only be slave to all clocks */
330 if ((format
& SND_SOC_DAIFMT_MASTER_MASK
) != SND_SOC_DAIFMT_CBS_CFS
) {
331 dev_err(codec
->dev
, "Invalid clocking mode\n");
335 /* we need to refer to the data format from hw_params() */
336 priv
->format
= format
;
341 static const int tas5086_sample_rates
[] = {
342 32000, 38000, 44100, 48000, 88200, 96000, 176400, 192000
345 static const int tas5086_ratios
[] = {
346 64, 128, 192, 256, 384, 512
349 static int index_in_array(const int *array
, int len
, int needle
)
353 for (i
= 0; i
< len
; i
++)
354 if (array
[i
] == needle
)
360 static int tas5086_hw_params(struct snd_pcm_substream
*substream
,
361 struct snd_pcm_hw_params
*params
,
362 struct snd_soc_dai
*dai
)
364 struct snd_soc_codec
*codec
= dai
->codec
;
365 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
369 priv
->rate
= params_rate(params
);
371 /* Look up the sample rate and refer to the offset in the list */
372 val
= index_in_array(tas5086_sample_rates
,
373 ARRAY_SIZE(tas5086_sample_rates
), priv
->rate
);
376 dev_err(codec
->dev
, "Invalid sample rate\n");
380 ret
= regmap_update_bits(priv
->regmap
, TAS5086_CLOCK_CONTROL
,
381 TAS5086_CLOCK_RATE_MASK
,
382 TAS5086_CLOCK_RATE(val
));
386 /* MCLK / Fs ratio */
387 val
= index_in_array(tas5086_ratios
, ARRAY_SIZE(tas5086_ratios
),
388 priv
->mclk
/ priv
->rate
);
390 dev_err(codec
->dev
, "Inavlid MCLK / Fs ratio\n");
394 ret
= regmap_update_bits(priv
->regmap
, TAS5086_CLOCK_CONTROL
,
395 TAS5086_CLOCK_RATIO_MASK
,
396 TAS5086_CLOCK_RATIO(val
));
401 ret
= regmap_update_bits(priv
->regmap
, TAS5086_CLOCK_CONTROL
,
402 TAS5086_CLOCK_SCLK_RATIO_48
,
403 (priv
->sclk
== 48 * priv
->rate
) ?
404 TAS5086_CLOCK_SCLK_RATIO_48
: 0);
409 * The chip has a very unituitive register mapping and muxes information
410 * about data format and sample depth into the same register, but not on
411 * a logical bit-boundary. Hence, we have to refer to the format passed
412 * in the set_dai_fmt() callback and set up everything from here.
414 * First, determine the 'base' value, using the format ...
416 switch (priv
->format
& SND_SOC_DAIFMT_FORMAT_MASK
) {
417 case SND_SOC_DAIFMT_RIGHT_J
:
420 case SND_SOC_DAIFMT_I2S
:
423 case SND_SOC_DAIFMT_LEFT_J
:
427 dev_err(codec
->dev
, "Invalid DAI format\n");
431 /* ... then add the offset for the sample bit depth. */
432 switch (params_width(params
)) {
443 dev_err(codec
->dev
, "Invalid bit width\n");
447 ret
= regmap_write(priv
->regmap
, TAS5086_SERIAL_DATA_IF
, val
);
451 /* clock is considered valid now */
452 ret
= regmap_update_bits(priv
->regmap
, TAS5086_CLOCK_CONTROL
,
453 TAS5086_CLOCK_VALID
, TAS5086_CLOCK_VALID
);
457 return tas5086_set_deemph(codec
);
460 static int tas5086_mute_stream(struct snd_soc_dai
*dai
, int mute
, int stream
)
462 struct snd_soc_codec
*codec
= dai
->codec
;
463 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
464 unsigned int val
= 0;
467 val
= TAS5086_SOFT_MUTE_ALL
;
469 return regmap_write(priv
->regmap
, TAS5086_SOFT_MUTE
, val
);
472 static void tas5086_reset(struct tas5086_private
*priv
)
474 if (gpio_is_valid(priv
->gpio_nreset
)) {
475 /* Reset codec - minimum assertion time is 400ns */
476 gpio_direction_output(priv
->gpio_nreset
, 0);
478 gpio_set_value(priv
->gpio_nreset
, 1);
480 /* Codec needs ~15ms to wake up */
485 /* charge period values in microseconds */
486 static const int tas5086_charge_period
[] = {
487 13000, 16900, 23400, 31200, 41600, 54600, 72800, 96200,
488 130000, 156000, 234000, 312000, 416000, 546000, 728000, 962000,
489 1300000, 169000, 2340000, 3120000, 4160000, 5460000, 7280000, 9620000,
492 static int tas5086_init(struct device
*dev
, struct tas5086_private
*priv
)
497 * If any of the channels is configured to start in Mid-Z mode,
498 * configure 'part 1' of the PWM starts to use Mid-Z, and tell
499 * all configured mid-z channels to start start under 'part 1'.
501 if (priv
->pwm_start_mid_z
)
502 regmap_write(priv
->regmap
, TAS5086_PWM_START
,
503 TAS5086_PWM_START_MIDZ_FOR_START_1
|
504 priv
->pwm_start_mid_z
);
506 /* lookup and set split-capacitor charge period */
507 if (priv
->charge_period
== 0) {
508 regmap_write(priv
->regmap
, TAS5086_SPLIT_CAP_CHARGE
, 0);
510 i
= index_in_array(tas5086_charge_period
,
511 ARRAY_SIZE(tas5086_charge_period
),
512 priv
->charge_period
);
514 regmap_write(priv
->regmap
, TAS5086_SPLIT_CAP_CHARGE
,
518 "Invalid split-cap charge period of %d ns.\n",
519 priv
->charge_period
);
522 /* enable factory trim */
523 ret
= regmap_write(priv
->regmap
, TAS5086_OSC_TRIM
, 0x00);
527 /* start all channels */
528 ret
= regmap_write(priv
->regmap
, TAS5086_SYS_CONTROL_2
, 0x20);
532 /* mute all channels for now */
533 ret
= regmap_write(priv
->regmap
, TAS5086_SOFT_MUTE
,
534 TAS5086_SOFT_MUTE_ALL
);
541 /* TAS5086 controls */
542 static const DECLARE_TLV_DB_SCALE(tas5086_dac_tlv
, -10350, 50, 1);
544 static const struct snd_kcontrol_new tas5086_controls
[] = {
545 SOC_SINGLE_TLV("Master Playback Volume", TAS5086_MASTER_VOL
,
546 0, 0xff, 1, tas5086_dac_tlv
),
547 SOC_DOUBLE_R_TLV("Channel 1/2 Playback Volume",
548 TAS5086_CHANNEL_VOL(0), TAS5086_CHANNEL_VOL(1),
549 0, 0xff, 1, tas5086_dac_tlv
),
550 SOC_DOUBLE_R_TLV("Channel 3/4 Playback Volume",
551 TAS5086_CHANNEL_VOL(2), TAS5086_CHANNEL_VOL(3),
552 0, 0xff, 1, tas5086_dac_tlv
),
553 SOC_DOUBLE_R_TLV("Channel 5/6 Playback Volume",
554 TAS5086_CHANNEL_VOL(4), TAS5086_CHANNEL_VOL(5),
555 0, 0xff, 1, tas5086_dac_tlv
),
556 SOC_SINGLE_BOOL_EXT("De-emphasis Switch", 0,
557 tas5086_get_deemph
, tas5086_put_deemph
),
560 /* Input mux controls */
561 static const char *tas5086_dapm_sdin_texts
[] =
563 "SDIN1-L", "SDIN1-R", "SDIN2-L", "SDIN2-R",
564 "SDIN3-L", "SDIN3-R", "Ground (0)", "nc"
567 static const struct soc_enum tas5086_dapm_input_mux_enum
[] = {
568 SOC_ENUM_SINGLE(TAS5086_INPUT_MUX
, 20, 8, tas5086_dapm_sdin_texts
),
569 SOC_ENUM_SINGLE(TAS5086_INPUT_MUX
, 16, 8, tas5086_dapm_sdin_texts
),
570 SOC_ENUM_SINGLE(TAS5086_INPUT_MUX
, 12, 8, tas5086_dapm_sdin_texts
),
571 SOC_ENUM_SINGLE(TAS5086_INPUT_MUX
, 8, 8, tas5086_dapm_sdin_texts
),
572 SOC_ENUM_SINGLE(TAS5086_INPUT_MUX
, 4, 8, tas5086_dapm_sdin_texts
),
573 SOC_ENUM_SINGLE(TAS5086_INPUT_MUX
, 0, 8, tas5086_dapm_sdin_texts
),
576 static const struct snd_kcontrol_new tas5086_dapm_input_mux_controls
[] = {
577 SOC_DAPM_ENUM("Channel 1 input", tas5086_dapm_input_mux_enum
[0]),
578 SOC_DAPM_ENUM("Channel 2 input", tas5086_dapm_input_mux_enum
[1]),
579 SOC_DAPM_ENUM("Channel 3 input", tas5086_dapm_input_mux_enum
[2]),
580 SOC_DAPM_ENUM("Channel 4 input", tas5086_dapm_input_mux_enum
[3]),
581 SOC_DAPM_ENUM("Channel 5 input", tas5086_dapm_input_mux_enum
[4]),
582 SOC_DAPM_ENUM("Channel 6 input", tas5086_dapm_input_mux_enum
[5]),
585 /* Output mux controls */
586 static const char *tas5086_dapm_channel_texts
[] =
587 { "Channel 1 Mux", "Channel 2 Mux", "Channel 3 Mux",
588 "Channel 4 Mux", "Channel 5 Mux", "Channel 6 Mux" };
590 static const struct soc_enum tas5086_dapm_output_mux_enum
[] = {
591 SOC_ENUM_SINGLE(TAS5086_PWM_OUTPUT_MUX
, 20, 6, tas5086_dapm_channel_texts
),
592 SOC_ENUM_SINGLE(TAS5086_PWM_OUTPUT_MUX
, 16, 6, tas5086_dapm_channel_texts
),
593 SOC_ENUM_SINGLE(TAS5086_PWM_OUTPUT_MUX
, 12, 6, tas5086_dapm_channel_texts
),
594 SOC_ENUM_SINGLE(TAS5086_PWM_OUTPUT_MUX
, 8, 6, tas5086_dapm_channel_texts
),
595 SOC_ENUM_SINGLE(TAS5086_PWM_OUTPUT_MUX
, 4, 6, tas5086_dapm_channel_texts
),
596 SOC_ENUM_SINGLE(TAS5086_PWM_OUTPUT_MUX
, 0, 6, tas5086_dapm_channel_texts
),
599 static const struct snd_kcontrol_new tas5086_dapm_output_mux_controls
[] = {
600 SOC_DAPM_ENUM("PWM1 Output", tas5086_dapm_output_mux_enum
[0]),
601 SOC_DAPM_ENUM("PWM2 Output", tas5086_dapm_output_mux_enum
[1]),
602 SOC_DAPM_ENUM("PWM3 Output", tas5086_dapm_output_mux_enum
[2]),
603 SOC_DAPM_ENUM("PWM4 Output", tas5086_dapm_output_mux_enum
[3]),
604 SOC_DAPM_ENUM("PWM5 Output", tas5086_dapm_output_mux_enum
[4]),
605 SOC_DAPM_ENUM("PWM6 Output", tas5086_dapm_output_mux_enum
[5]),
608 static const struct snd_soc_dapm_widget tas5086_dapm_widgets
[] = {
609 SND_SOC_DAPM_INPUT("SDIN1-L"),
610 SND_SOC_DAPM_INPUT("SDIN1-R"),
611 SND_SOC_DAPM_INPUT("SDIN2-L"),
612 SND_SOC_DAPM_INPUT("SDIN2-R"),
613 SND_SOC_DAPM_INPUT("SDIN3-L"),
614 SND_SOC_DAPM_INPUT("SDIN3-R"),
615 SND_SOC_DAPM_INPUT("SDIN4-L"),
616 SND_SOC_DAPM_INPUT("SDIN4-R"),
618 SND_SOC_DAPM_OUTPUT("PWM1"),
619 SND_SOC_DAPM_OUTPUT("PWM2"),
620 SND_SOC_DAPM_OUTPUT("PWM3"),
621 SND_SOC_DAPM_OUTPUT("PWM4"),
622 SND_SOC_DAPM_OUTPUT("PWM5"),
623 SND_SOC_DAPM_OUTPUT("PWM6"),
625 SND_SOC_DAPM_MUX("Channel 1 Mux", SND_SOC_NOPM
, 0, 0,
626 &tas5086_dapm_input_mux_controls
[0]),
627 SND_SOC_DAPM_MUX("Channel 2 Mux", SND_SOC_NOPM
, 0, 0,
628 &tas5086_dapm_input_mux_controls
[1]),
629 SND_SOC_DAPM_MUX("Channel 3 Mux", SND_SOC_NOPM
, 0, 0,
630 &tas5086_dapm_input_mux_controls
[2]),
631 SND_SOC_DAPM_MUX("Channel 4 Mux", SND_SOC_NOPM
, 0, 0,
632 &tas5086_dapm_input_mux_controls
[3]),
633 SND_SOC_DAPM_MUX("Channel 5 Mux", SND_SOC_NOPM
, 0, 0,
634 &tas5086_dapm_input_mux_controls
[4]),
635 SND_SOC_DAPM_MUX("Channel 6 Mux", SND_SOC_NOPM
, 0, 0,
636 &tas5086_dapm_input_mux_controls
[5]),
638 SND_SOC_DAPM_MUX("PWM1 Mux", SND_SOC_NOPM
, 0, 0,
639 &tas5086_dapm_output_mux_controls
[0]),
640 SND_SOC_DAPM_MUX("PWM2 Mux", SND_SOC_NOPM
, 0, 0,
641 &tas5086_dapm_output_mux_controls
[1]),
642 SND_SOC_DAPM_MUX("PWM3 Mux", SND_SOC_NOPM
, 0, 0,
643 &tas5086_dapm_output_mux_controls
[2]),
644 SND_SOC_DAPM_MUX("PWM4 Mux", SND_SOC_NOPM
, 0, 0,
645 &tas5086_dapm_output_mux_controls
[3]),
646 SND_SOC_DAPM_MUX("PWM5 Mux", SND_SOC_NOPM
, 0, 0,
647 &tas5086_dapm_output_mux_controls
[4]),
648 SND_SOC_DAPM_MUX("PWM6 Mux", SND_SOC_NOPM
, 0, 0,
649 &tas5086_dapm_output_mux_controls
[5]),
652 static const struct snd_soc_dapm_route tas5086_dapm_routes
[] = {
653 /* SDIN inputs -> channel muxes */
654 { "Channel 1 Mux", "SDIN1-L", "SDIN1-L" },
655 { "Channel 1 Mux", "SDIN1-R", "SDIN1-R" },
656 { "Channel 1 Mux", "SDIN2-L", "SDIN2-L" },
657 { "Channel 1 Mux", "SDIN2-R", "SDIN2-R" },
658 { "Channel 1 Mux", "SDIN3-L", "SDIN3-L" },
659 { "Channel 1 Mux", "SDIN3-R", "SDIN3-R" },
661 { "Channel 2 Mux", "SDIN1-L", "SDIN1-L" },
662 { "Channel 2 Mux", "SDIN1-R", "SDIN1-R" },
663 { "Channel 2 Mux", "SDIN2-L", "SDIN2-L" },
664 { "Channel 2 Mux", "SDIN2-R", "SDIN2-R" },
665 { "Channel 2 Mux", "SDIN3-L", "SDIN3-L" },
666 { "Channel 2 Mux", "SDIN3-R", "SDIN3-R" },
668 { "Channel 2 Mux", "SDIN1-L", "SDIN1-L" },
669 { "Channel 2 Mux", "SDIN1-R", "SDIN1-R" },
670 { "Channel 2 Mux", "SDIN2-L", "SDIN2-L" },
671 { "Channel 2 Mux", "SDIN2-R", "SDIN2-R" },
672 { "Channel 2 Mux", "SDIN3-L", "SDIN3-L" },
673 { "Channel 2 Mux", "SDIN3-R", "SDIN3-R" },
675 { "Channel 3 Mux", "SDIN1-L", "SDIN1-L" },
676 { "Channel 3 Mux", "SDIN1-R", "SDIN1-R" },
677 { "Channel 3 Mux", "SDIN2-L", "SDIN2-L" },
678 { "Channel 3 Mux", "SDIN2-R", "SDIN2-R" },
679 { "Channel 3 Mux", "SDIN3-L", "SDIN3-L" },
680 { "Channel 3 Mux", "SDIN3-R", "SDIN3-R" },
682 { "Channel 4 Mux", "SDIN1-L", "SDIN1-L" },
683 { "Channel 4 Mux", "SDIN1-R", "SDIN1-R" },
684 { "Channel 4 Mux", "SDIN2-L", "SDIN2-L" },
685 { "Channel 4 Mux", "SDIN2-R", "SDIN2-R" },
686 { "Channel 4 Mux", "SDIN3-L", "SDIN3-L" },
687 { "Channel 4 Mux", "SDIN3-R", "SDIN3-R" },
689 { "Channel 5 Mux", "SDIN1-L", "SDIN1-L" },
690 { "Channel 5 Mux", "SDIN1-R", "SDIN1-R" },
691 { "Channel 5 Mux", "SDIN2-L", "SDIN2-L" },
692 { "Channel 5 Mux", "SDIN2-R", "SDIN2-R" },
693 { "Channel 5 Mux", "SDIN3-L", "SDIN3-L" },
694 { "Channel 5 Mux", "SDIN3-R", "SDIN3-R" },
696 { "Channel 6 Mux", "SDIN1-L", "SDIN1-L" },
697 { "Channel 6 Mux", "SDIN1-R", "SDIN1-R" },
698 { "Channel 6 Mux", "SDIN2-L", "SDIN2-L" },
699 { "Channel 6 Mux", "SDIN2-R", "SDIN2-R" },
700 { "Channel 6 Mux", "SDIN3-L", "SDIN3-L" },
701 { "Channel 6 Mux", "SDIN3-R", "SDIN3-R" },
703 /* Channel muxes -> PWM muxes */
704 { "PWM1 Mux", "Channel 1 Mux", "Channel 1 Mux" },
705 { "PWM2 Mux", "Channel 1 Mux", "Channel 1 Mux" },
706 { "PWM3 Mux", "Channel 1 Mux", "Channel 1 Mux" },
707 { "PWM4 Mux", "Channel 1 Mux", "Channel 1 Mux" },
708 { "PWM5 Mux", "Channel 1 Mux", "Channel 1 Mux" },
709 { "PWM6 Mux", "Channel 1 Mux", "Channel 1 Mux" },
711 { "PWM1 Mux", "Channel 2 Mux", "Channel 2 Mux" },
712 { "PWM2 Mux", "Channel 2 Mux", "Channel 2 Mux" },
713 { "PWM3 Mux", "Channel 2 Mux", "Channel 2 Mux" },
714 { "PWM4 Mux", "Channel 2 Mux", "Channel 2 Mux" },
715 { "PWM5 Mux", "Channel 2 Mux", "Channel 2 Mux" },
716 { "PWM6 Mux", "Channel 2 Mux", "Channel 2 Mux" },
718 { "PWM1 Mux", "Channel 3 Mux", "Channel 3 Mux" },
719 { "PWM2 Mux", "Channel 3 Mux", "Channel 3 Mux" },
720 { "PWM3 Mux", "Channel 3 Mux", "Channel 3 Mux" },
721 { "PWM4 Mux", "Channel 3 Mux", "Channel 3 Mux" },
722 { "PWM5 Mux", "Channel 3 Mux", "Channel 3 Mux" },
723 { "PWM6 Mux", "Channel 3 Mux", "Channel 3 Mux" },
725 { "PWM1 Mux", "Channel 4 Mux", "Channel 4 Mux" },
726 { "PWM2 Mux", "Channel 4 Mux", "Channel 4 Mux" },
727 { "PWM3 Mux", "Channel 4 Mux", "Channel 4 Mux" },
728 { "PWM4 Mux", "Channel 4 Mux", "Channel 4 Mux" },
729 { "PWM5 Mux", "Channel 4 Mux", "Channel 4 Mux" },
730 { "PWM6 Mux", "Channel 4 Mux", "Channel 4 Mux" },
732 { "PWM1 Mux", "Channel 5 Mux", "Channel 5 Mux" },
733 { "PWM2 Mux", "Channel 5 Mux", "Channel 5 Mux" },
734 { "PWM3 Mux", "Channel 5 Mux", "Channel 5 Mux" },
735 { "PWM4 Mux", "Channel 5 Mux", "Channel 5 Mux" },
736 { "PWM5 Mux", "Channel 5 Mux", "Channel 5 Mux" },
737 { "PWM6 Mux", "Channel 5 Mux", "Channel 5 Mux" },
739 { "PWM1 Mux", "Channel 6 Mux", "Channel 6 Mux" },
740 { "PWM2 Mux", "Channel 6 Mux", "Channel 6 Mux" },
741 { "PWM3 Mux", "Channel 6 Mux", "Channel 6 Mux" },
742 { "PWM4 Mux", "Channel 6 Mux", "Channel 6 Mux" },
743 { "PWM5 Mux", "Channel 6 Mux", "Channel 6 Mux" },
744 { "PWM6 Mux", "Channel 6 Mux", "Channel 6 Mux" },
746 /* The PWM muxes are directly connected to the PWM outputs */
747 { "PWM1", NULL
, "PWM1 Mux" },
748 { "PWM2", NULL
, "PWM2 Mux" },
749 { "PWM3", NULL
, "PWM3 Mux" },
750 { "PWM4", NULL
, "PWM4 Mux" },
751 { "PWM5", NULL
, "PWM5 Mux" },
752 { "PWM6", NULL
, "PWM6 Mux" },
756 static const struct snd_soc_dai_ops tas5086_dai_ops
= {
757 .hw_params
= tas5086_hw_params
,
758 .set_sysclk
= tas5086_set_dai_sysclk
,
759 .set_fmt
= tas5086_set_dai_fmt
,
760 .mute_stream
= tas5086_mute_stream
,
763 static struct snd_soc_dai_driver tas5086_dai
= {
764 .name
= "tas5086-hifi",
766 .stream_name
= "Playback",
769 .rates
= TAS5086_PCM_RATES
,
770 .formats
= TAS5086_PCM_FORMATS
,
772 .ops
= &tas5086_dai_ops
,
776 static int tas5086_soc_suspend(struct snd_soc_codec
*codec
)
778 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
781 /* Shut down all channels */
782 ret
= regmap_write(priv
->regmap
, TAS5086_SYS_CONTROL_2
, 0x60);
786 regulator_bulk_disable(ARRAY_SIZE(priv
->supplies
), priv
->supplies
);
791 static int tas5086_soc_resume(struct snd_soc_codec
*codec
)
793 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
796 ret
= regulator_bulk_enable(ARRAY_SIZE(priv
->supplies
), priv
->supplies
);
801 regcache_mark_dirty(priv
->regmap
);
803 ret
= tas5086_init(codec
->dev
, priv
);
807 ret
= regcache_sync(priv
->regmap
);
814 #define tas5086_soc_suspend NULL
815 #define tas5086_soc_resume NULL
816 #endif /* CONFIG_PM */
819 static const struct of_device_id tas5086_dt_ids
[] = {
820 { .compatible
= "ti,tas5086", },
823 MODULE_DEVICE_TABLE(of
, tas5086_dt_ids
);
826 static int tas5086_probe(struct snd_soc_codec
*codec
)
828 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
831 ret
= regulator_bulk_enable(ARRAY_SIZE(priv
->supplies
), priv
->supplies
);
833 dev_err(codec
->dev
, "Failed to enable regulators: %d\n", ret
);
837 priv
->pwm_start_mid_z
= 0;
838 priv
->charge_period
= 1300000; /* hardware default is 1300 ms */
840 if (of_match_device(of_match_ptr(tas5086_dt_ids
), codec
->dev
)) {
841 struct device_node
*of_node
= codec
->dev
->of_node
;
843 of_property_read_u32(of_node
, "ti,charge-period",
844 &priv
->charge_period
);
846 for (i
= 0; i
< 6; i
++) {
849 snprintf(name
, sizeof(name
),
850 "ti,mid-z-channel-%d", i
+ 1);
852 if (of_get_property(of_node
, name
, NULL
) != NULL
)
853 priv
->pwm_start_mid_z
|= 1 << i
;
858 ret
= tas5086_init(codec
->dev
, priv
);
860 goto exit_disable_regulators
;
862 /* set master volume to 0 dB */
863 ret
= regmap_write(priv
->regmap
, TAS5086_MASTER_VOL
, 0x30);
865 goto exit_disable_regulators
;
869 exit_disable_regulators
:
870 regulator_bulk_disable(ARRAY_SIZE(priv
->supplies
), priv
->supplies
);
875 static int tas5086_remove(struct snd_soc_codec
*codec
)
877 struct tas5086_private
*priv
= snd_soc_codec_get_drvdata(codec
);
879 if (gpio_is_valid(priv
->gpio_nreset
))
880 /* Set codec to the reset state */
881 gpio_set_value(priv
->gpio_nreset
, 0);
883 regulator_bulk_disable(ARRAY_SIZE(priv
->supplies
), priv
->supplies
);
888 static struct snd_soc_codec_driver soc_codec_dev_tas5086
= {
889 .probe
= tas5086_probe
,
890 .remove
= tas5086_remove
,
891 .suspend
= tas5086_soc_suspend
,
892 .resume
= tas5086_soc_resume
,
893 .controls
= tas5086_controls
,
894 .num_controls
= ARRAY_SIZE(tas5086_controls
),
895 .dapm_widgets
= tas5086_dapm_widgets
,
896 .num_dapm_widgets
= ARRAY_SIZE(tas5086_dapm_widgets
),
897 .dapm_routes
= tas5086_dapm_routes
,
898 .num_dapm_routes
= ARRAY_SIZE(tas5086_dapm_routes
),
901 static const struct i2c_device_id tas5086_i2c_id
[] = {
905 MODULE_DEVICE_TABLE(i2c
, tas5086_i2c_id
);
907 static const struct regmap_config tas5086_regmap
= {
910 .max_register
= TAS5086_MAX_REGISTER
,
911 .reg_defaults
= tas5086_reg_defaults
,
912 .num_reg_defaults
= ARRAY_SIZE(tas5086_reg_defaults
),
913 .cache_type
= REGCACHE_RBTREE
,
914 .volatile_reg
= tas5086_volatile_reg
,
915 .writeable_reg
= tas5086_writeable_reg
,
916 .readable_reg
= tas5086_accessible_reg
,
917 .reg_read
= tas5086_reg_read
,
918 .reg_write
= tas5086_reg_write
,
921 static int tas5086_i2c_probe(struct i2c_client
*i2c
,
922 const struct i2c_device_id
*id
)
924 struct tas5086_private
*priv
;
925 struct device
*dev
= &i2c
->dev
;
926 int gpio_nreset
= -EINVAL
;
929 priv
= devm_kzalloc(dev
, sizeof(*priv
), GFP_KERNEL
);
933 for (i
= 0; i
< ARRAY_SIZE(supply_names
); i
++)
934 priv
->supplies
[i
].supply
= supply_names
[i
];
936 ret
= devm_regulator_bulk_get(dev
, ARRAY_SIZE(priv
->supplies
),
939 dev_err(dev
, "Failed to get regulators: %d\n", ret
);
943 priv
->regmap
= devm_regmap_init(dev
, NULL
, i2c
, &tas5086_regmap
);
944 if (IS_ERR(priv
->regmap
)) {
945 ret
= PTR_ERR(priv
->regmap
);
946 dev_err(&i2c
->dev
, "Failed to create regmap: %d\n", ret
);
950 i2c_set_clientdata(i2c
, priv
);
952 if (of_match_device(of_match_ptr(tas5086_dt_ids
), dev
)) {
953 struct device_node
*of_node
= dev
->of_node
;
954 gpio_nreset
= of_get_named_gpio(of_node
, "reset-gpio", 0);
957 if (gpio_is_valid(gpio_nreset
))
958 if (devm_gpio_request(dev
, gpio_nreset
, "TAS5086 Reset"))
959 gpio_nreset
= -EINVAL
;
961 priv
->gpio_nreset
= gpio_nreset
;
963 ret
= regulator_bulk_enable(ARRAY_SIZE(priv
->supplies
), priv
->supplies
);
965 dev_err(dev
, "Failed to enable regulators: %d\n", ret
);
971 /* The TAS5086 always returns 0x03 in its TAS5086_DEV_ID register */
972 ret
= regmap_read(priv
->regmap
, TAS5086_DEV_ID
, &i
);
973 if (ret
== 0 && i
!= 0x3) {
975 "Failed to identify TAS5086 codec (got %02x)\n", i
);
980 * The chip has been identified, so we can turn off the power
981 * again until the dai link is set up.
983 regulator_bulk_disable(ARRAY_SIZE(priv
->supplies
), priv
->supplies
);
986 ret
= snd_soc_register_codec(&i2c
->dev
, &soc_codec_dev_tas5086
,
992 static int tas5086_i2c_remove(struct i2c_client
*i2c
)
994 snd_soc_unregister_codec(&i2c
->dev
);
998 static struct i2c_driver tas5086_i2c_driver
= {
1001 .of_match_table
= of_match_ptr(tas5086_dt_ids
),
1003 .id_table
= tas5086_i2c_id
,
1004 .probe
= tas5086_i2c_probe
,
1005 .remove
= tas5086_i2c_remove
,
1008 module_i2c_driver(tas5086_i2c_driver
);
1010 MODULE_AUTHOR("Daniel Mack <zonque@gmail.com>");
1011 MODULE_DESCRIPTION("Texas Instruments TAS5086 ALSA SoC Codec Driver");
1012 MODULE_LICENSE("GPL");