2 * Driver for ADAU1701 SigmaDSP processor
4 * Copyright 2011 Analog Devices Inc.
5 * Author: Lars-Peter Clausen <lars@metafoo.de>
6 * based on an inital version by Cliff Cai <cliff.cai@analog.com>
8 * Licensed under the GPL-2 or later.
11 #include <linux/module.h>
12 #include <linux/init.h>
13 #include <linux/i2c.h>
14 #include <linux/delay.h>
15 #include <linux/slab.h>
17 #include <linux/of_gpio.h>
18 #include <linux/of_device.h>
19 #include <linux/regmap.h>
20 #include <sound/core.h>
21 #include <sound/pcm.h>
22 #include <sound/pcm_params.h>
23 #include <sound/soc.h>
28 #define ADAU1701_DSPCTRL 0x081c
29 #define ADAU1701_SEROCTL 0x081e
30 #define ADAU1701_SERICTL 0x081f
32 #define ADAU1701_AUXNPOW 0x0822
33 #define ADAU1701_PINCONF_0 0x0820
34 #define ADAU1701_PINCONF_1 0x0821
35 #define ADAU1701_AUXNPOW 0x0822
37 #define ADAU1701_OSCIPOW 0x0826
38 #define ADAU1701_DACSET 0x0827
40 #define ADAU1701_MAX_REGISTER 0x0828
42 #define ADAU1701_DSPCTRL_CR (1 << 2)
43 #define ADAU1701_DSPCTRL_DAM (1 << 3)
44 #define ADAU1701_DSPCTRL_ADM (1 << 4)
45 #define ADAU1701_DSPCTRL_SR_48 0x00
46 #define ADAU1701_DSPCTRL_SR_96 0x01
47 #define ADAU1701_DSPCTRL_SR_192 0x02
48 #define ADAU1701_DSPCTRL_SR_MASK 0x03
50 #define ADAU1701_SEROCTL_INV_LRCLK 0x2000
51 #define ADAU1701_SEROCTL_INV_BCLK 0x1000
52 #define ADAU1701_SEROCTL_MASTER 0x0800
54 #define ADAU1701_SEROCTL_OBF16 0x0000
55 #define ADAU1701_SEROCTL_OBF8 0x0200
56 #define ADAU1701_SEROCTL_OBF4 0x0400
57 #define ADAU1701_SEROCTL_OBF2 0x0600
58 #define ADAU1701_SEROCTL_OBF_MASK 0x0600
60 #define ADAU1701_SEROCTL_OLF1024 0x0000
61 #define ADAU1701_SEROCTL_OLF512 0x0080
62 #define ADAU1701_SEROCTL_OLF256 0x0100
63 #define ADAU1701_SEROCTL_OLF_MASK 0x0180
65 #define ADAU1701_SEROCTL_MSB_DEALY1 0x0000
66 #define ADAU1701_SEROCTL_MSB_DEALY0 0x0004
67 #define ADAU1701_SEROCTL_MSB_DEALY8 0x0008
68 #define ADAU1701_SEROCTL_MSB_DEALY12 0x000c
69 #define ADAU1701_SEROCTL_MSB_DEALY16 0x0010
70 #define ADAU1701_SEROCTL_MSB_DEALY_MASK 0x001c
72 #define ADAU1701_SEROCTL_WORD_LEN_24 0x0000
73 #define ADAU1701_SEROCTL_WORD_LEN_20 0x0001
74 #define ADAU1701_SEROCTL_WORD_LEN_16 0x0002
75 #define ADAU1701_SEROCTL_WORD_LEN_MASK 0x0003
77 #define ADAU1701_AUXNPOW_VBPD 0x40
78 #define ADAU1701_AUXNPOW_VRPD 0x20
80 #define ADAU1701_SERICTL_I2S 0
81 #define ADAU1701_SERICTL_LEFTJ 1
82 #define ADAU1701_SERICTL_TDM 2
83 #define ADAU1701_SERICTL_RIGHTJ_24 3
84 #define ADAU1701_SERICTL_RIGHTJ_20 4
85 #define ADAU1701_SERICTL_RIGHTJ_18 5
86 #define ADAU1701_SERICTL_RIGHTJ_16 6
87 #define ADAU1701_SERICTL_MODE_MASK 7
88 #define ADAU1701_SERICTL_INV_BCLK BIT(3)
89 #define ADAU1701_SERICTL_INV_LRCLK BIT(4)
91 #define ADAU1701_OSCIPOW_OPD 0x04
92 #define ADAU1701_DACSET_DACINIT 1
94 #define ADAU1707_CLKDIV_UNSET (-1U)
96 #define ADAU1701_FIRMWARE "adau1701.bin"
100 int gpio_pll_mode
[2];
101 unsigned int dai_fmt
;
102 unsigned int pll_clkdiv
;
104 struct regmap
*regmap
;
108 static const struct snd_kcontrol_new adau1701_controls
[] = {
109 SOC_SINGLE("Master Capture Switch", ADAU1701_DSPCTRL
, 4, 1, 0),
112 static const struct snd_soc_dapm_widget adau1701_dapm_widgets
[] = {
113 SND_SOC_DAPM_DAC("DAC0", "Playback", ADAU1701_AUXNPOW
, 3, 1),
114 SND_SOC_DAPM_DAC("DAC1", "Playback", ADAU1701_AUXNPOW
, 2, 1),
115 SND_SOC_DAPM_DAC("DAC2", "Playback", ADAU1701_AUXNPOW
, 1, 1),
116 SND_SOC_DAPM_DAC("DAC3", "Playback", ADAU1701_AUXNPOW
, 0, 1),
117 SND_SOC_DAPM_ADC("ADC", "Capture", ADAU1701_AUXNPOW
, 7, 1),
119 SND_SOC_DAPM_OUTPUT("OUT0"),
120 SND_SOC_DAPM_OUTPUT("OUT1"),
121 SND_SOC_DAPM_OUTPUT("OUT2"),
122 SND_SOC_DAPM_OUTPUT("OUT3"),
123 SND_SOC_DAPM_INPUT("IN0"),
124 SND_SOC_DAPM_INPUT("IN1"),
127 static const struct snd_soc_dapm_route adau1701_dapm_routes
[] = {
128 { "OUT0", NULL
, "DAC0" },
129 { "OUT1", NULL
, "DAC1" },
130 { "OUT2", NULL
, "DAC2" },
131 { "OUT3", NULL
, "DAC3" },
133 { "ADC", NULL
, "IN0" },
134 { "ADC", NULL
, "IN1" },
137 static unsigned int adau1701_register_size(struct device
*dev
,
141 case ADAU1701_PINCONF_0
:
142 case ADAU1701_PINCONF_1
:
144 case ADAU1701_DSPCTRL
:
145 case ADAU1701_SEROCTL
:
146 case ADAU1701_AUXNPOW
:
147 case ADAU1701_OSCIPOW
:
148 case ADAU1701_DACSET
:
150 case ADAU1701_SERICTL
:
154 dev_err(dev
, "Unsupported register address: %d\n", reg
);
158 static bool adau1701_volatile_reg(struct device
*dev
, unsigned int reg
)
161 case ADAU1701_DACSET
:
168 static int adau1701_reg_write(void *context
, unsigned int reg
,
171 struct i2c_client
*client
= context
;
177 size
= adau1701_register_size(&client
->dev
, reg
);
184 for (i
= size
+ 1; i
>= 2; --i
) {
189 ret
= i2c_master_send(client
, buf
, size
+ 2);
198 static int adau1701_reg_read(void *context
, unsigned int reg
,
204 uint8_t send_buf
[2], recv_buf
[3];
205 struct i2c_client
*client
= context
;
206 struct i2c_msg msgs
[2];
208 size
= adau1701_register_size(&client
->dev
, reg
);
212 send_buf
[0] = reg
>> 8;
213 send_buf
[1] = reg
& 0xff;
215 msgs
[0].addr
= client
->addr
;
216 msgs
[0].len
= sizeof(send_buf
);
217 msgs
[0].buf
= send_buf
;
220 msgs
[1].addr
= client
->addr
;
222 msgs
[1].buf
= recv_buf
;
223 msgs
[1].flags
= I2C_M_RD
;
225 ret
= i2c_transfer(client
->adapter
, msgs
, ARRAY_SIZE(msgs
));
228 else if (ret
!= ARRAY_SIZE(msgs
))
233 for (i
= 0; i
< size
; i
++) {
235 *value
|= recv_buf
[i
];
241 static int adau1701_reset(struct snd_soc_codec
*codec
, unsigned int clkdiv
)
243 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
244 struct i2c_client
*client
= to_i2c_client(codec
->dev
);
247 if (clkdiv
!= ADAU1707_CLKDIV_UNSET
&&
248 gpio_is_valid(adau1701
->gpio_pll_mode
[0]) &&
249 gpio_is_valid(adau1701
->gpio_pll_mode
[1])) {
252 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[0], 0);
253 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[1], 0);
256 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[0], 0);
257 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[1], 1);
260 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[0], 1);
261 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[1], 0);
263 case 0: /* fallback */
265 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[0], 1);
266 gpio_set_value_cansleep(adau1701
->gpio_pll_mode
[1], 1);
271 adau1701
->pll_clkdiv
= clkdiv
;
273 if (gpio_is_valid(adau1701
->gpio_nreset
)) {
274 gpio_set_value_cansleep(adau1701
->gpio_nreset
, 0);
275 /* minimum reset time is 20ns */
277 gpio_set_value_cansleep(adau1701
->gpio_nreset
, 1);
278 /* power-up time may be as long as 85ms */
283 * Postpone the firmware download to a point in time when we
284 * know the correct PLL setup
286 if (clkdiv
!= ADAU1707_CLKDIV_UNSET
) {
287 ret
= process_sigma_firmware(client
, ADAU1701_FIRMWARE
);
289 dev_warn(codec
->dev
, "Failed to load firmware\n");
294 regmap_write(adau1701
->regmap
, ADAU1701_DACSET
, ADAU1701_DACSET_DACINIT
);
295 regmap_write(adau1701
->regmap
, ADAU1701_DSPCTRL
, ADAU1701_DSPCTRL_CR
);
297 regcache_mark_dirty(adau1701
->regmap
);
298 regcache_sync(adau1701
->regmap
);
303 static int adau1701_set_capture_pcm_format(struct snd_soc_codec
*codec
,
304 struct snd_pcm_hw_params
*params
)
306 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
307 unsigned int mask
= ADAU1701_SEROCTL_WORD_LEN_MASK
;
310 switch (params_width(params
)) {
312 val
= ADAU1701_SEROCTL_WORD_LEN_16
;
315 val
= ADAU1701_SEROCTL_WORD_LEN_20
;
318 val
= ADAU1701_SEROCTL_WORD_LEN_24
;
324 if (adau1701
->dai_fmt
== SND_SOC_DAIFMT_RIGHT_J
) {
325 switch (params_width(params
)) {
327 val
|= ADAU1701_SEROCTL_MSB_DEALY16
;
330 val
|= ADAU1701_SEROCTL_MSB_DEALY12
;
333 val
|= ADAU1701_SEROCTL_MSB_DEALY8
;
336 mask
|= ADAU1701_SEROCTL_MSB_DEALY_MASK
;
339 regmap_update_bits(adau1701
->regmap
, ADAU1701_SEROCTL
, mask
, val
);
344 static int adau1701_set_playback_pcm_format(struct snd_soc_codec
*codec
,
345 struct snd_pcm_hw_params
*params
)
347 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
350 if (adau1701
->dai_fmt
!= SND_SOC_DAIFMT_RIGHT_J
)
353 switch (params_width(params
)) {
355 val
= ADAU1701_SERICTL_RIGHTJ_16
;
358 val
= ADAU1701_SERICTL_RIGHTJ_20
;
361 val
= ADAU1701_SERICTL_RIGHTJ_24
;
367 regmap_update_bits(adau1701
->regmap
, ADAU1701_SERICTL
,
368 ADAU1701_SERICTL_MODE_MASK
, val
);
373 static int adau1701_hw_params(struct snd_pcm_substream
*substream
,
374 struct snd_pcm_hw_params
*params
, struct snd_soc_dai
*dai
)
376 struct snd_soc_codec
*codec
= dai
->codec
;
377 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
378 unsigned int clkdiv
= adau1701
->sysclk
/ params_rate(params
);
383 * If the mclk/lrclk ratio changes, the chip needs updated PLL
384 * mode GPIO settings, and a full reset cycle, including a new
387 if (clkdiv
!= adau1701
->pll_clkdiv
) {
388 ret
= adau1701_reset(codec
, clkdiv
);
393 switch (params_rate(params
)) {
395 val
= ADAU1701_DSPCTRL_SR_192
;
398 val
= ADAU1701_DSPCTRL_SR_96
;
401 val
= ADAU1701_DSPCTRL_SR_48
;
407 regmap_update_bits(adau1701
->regmap
, ADAU1701_DSPCTRL
,
408 ADAU1701_DSPCTRL_SR_MASK
, val
);
410 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
)
411 return adau1701_set_playback_pcm_format(codec
, params
);
413 return adau1701_set_capture_pcm_format(codec
, params
);
416 static int adau1701_set_dai_fmt(struct snd_soc_dai
*codec_dai
,
419 struct snd_soc_codec
*codec
= codec_dai
->codec
;
420 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
421 unsigned int serictl
= 0x00, seroctl
= 0x00;
424 switch (fmt
& SND_SOC_DAIFMT_MASTER_MASK
) {
425 case SND_SOC_DAIFMT_CBM_CFM
:
426 /* master, 64-bits per sample, 1 frame per sample */
427 seroctl
|= ADAU1701_SEROCTL_MASTER
| ADAU1701_SEROCTL_OBF16
428 | ADAU1701_SEROCTL_OLF1024
;
430 case SND_SOC_DAIFMT_CBS_CFS
:
436 /* clock inversion */
437 switch (fmt
& SND_SOC_DAIFMT_INV_MASK
) {
438 case SND_SOC_DAIFMT_NB_NF
:
439 invert_lrclk
= false;
441 case SND_SOC_DAIFMT_NB_IF
:
444 case SND_SOC_DAIFMT_IB_NF
:
445 invert_lrclk
= false;
446 serictl
|= ADAU1701_SERICTL_INV_BCLK
;
447 seroctl
|= ADAU1701_SEROCTL_INV_BCLK
;
449 case SND_SOC_DAIFMT_IB_IF
:
451 serictl
|= ADAU1701_SERICTL_INV_BCLK
;
452 seroctl
|= ADAU1701_SEROCTL_INV_BCLK
;
458 switch (fmt
& SND_SOC_DAIFMT_FORMAT_MASK
) {
459 case SND_SOC_DAIFMT_I2S
:
461 case SND_SOC_DAIFMT_LEFT_J
:
462 serictl
|= ADAU1701_SERICTL_LEFTJ
;
463 seroctl
|= ADAU1701_SEROCTL_MSB_DEALY0
;
464 invert_lrclk
= !invert_lrclk
;
466 case SND_SOC_DAIFMT_RIGHT_J
:
467 serictl
|= ADAU1701_SERICTL_RIGHTJ_24
;
468 seroctl
|= ADAU1701_SEROCTL_MSB_DEALY8
;
469 invert_lrclk
= !invert_lrclk
;
476 seroctl
|= ADAU1701_SEROCTL_INV_LRCLK
;
477 serictl
|= ADAU1701_SERICTL_INV_LRCLK
;
480 adau1701
->dai_fmt
= fmt
& SND_SOC_DAIFMT_FORMAT_MASK
;
482 regmap_write(adau1701
->regmap
, ADAU1701_SERICTL
, serictl
);
483 regmap_update_bits(adau1701
->regmap
, ADAU1701_SEROCTL
,
484 ~ADAU1701_SEROCTL_WORD_LEN_MASK
, seroctl
);
489 static int adau1701_set_bias_level(struct snd_soc_codec
*codec
,
490 enum snd_soc_bias_level level
)
492 unsigned int mask
= ADAU1701_AUXNPOW_VBPD
| ADAU1701_AUXNPOW_VRPD
;
493 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
496 case SND_SOC_BIAS_ON
:
498 case SND_SOC_BIAS_PREPARE
:
500 case SND_SOC_BIAS_STANDBY
:
501 /* Enable VREF and VREF buffer */
502 regmap_update_bits(adau1701
->regmap
,
503 ADAU1701_AUXNPOW
, mask
, 0x00);
505 case SND_SOC_BIAS_OFF
:
506 /* Disable VREF and VREF buffer */
507 regmap_update_bits(adau1701
->regmap
,
508 ADAU1701_AUXNPOW
, mask
, mask
);
512 codec
->dapm
.bias_level
= level
;
516 static int adau1701_digital_mute(struct snd_soc_dai
*dai
, int mute
)
518 struct snd_soc_codec
*codec
= dai
->codec
;
519 unsigned int mask
= ADAU1701_DSPCTRL_DAM
;
520 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
528 regmap_update_bits(adau1701
->regmap
, ADAU1701_DSPCTRL
, mask
, val
);
533 static int adau1701_set_sysclk(struct snd_soc_codec
*codec
, int clk_id
,
534 int source
, unsigned int freq
, int dir
)
537 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
540 case ADAU1701_CLK_SRC_OSC
:
543 case ADAU1701_CLK_SRC_MCLK
:
544 val
= ADAU1701_OSCIPOW_OPD
;
550 regmap_update_bits(adau1701
->regmap
, ADAU1701_OSCIPOW
,
551 ADAU1701_OSCIPOW_OPD
, val
);
552 adau1701
->sysclk
= freq
;
557 #define ADAU1701_RATES (SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_96000 | \
558 SNDRV_PCM_RATE_192000)
560 #define ADAU1701_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S20_3LE |\
561 SNDRV_PCM_FMTBIT_S24_LE)
563 static const struct snd_soc_dai_ops adau1701_dai_ops
= {
564 .set_fmt
= adau1701_set_dai_fmt
,
565 .hw_params
= adau1701_hw_params
,
566 .digital_mute
= adau1701_digital_mute
,
569 static struct snd_soc_dai_driver adau1701_dai
= {
572 .stream_name
= "Playback",
575 .rates
= ADAU1701_RATES
,
576 .formats
= ADAU1701_FORMATS
,
579 .stream_name
= "Capture",
582 .rates
= ADAU1701_RATES
,
583 .formats
= ADAU1701_FORMATS
,
585 .ops
= &adau1701_dai_ops
,
586 .symmetric_rates
= 1,
590 static const struct of_device_id adau1701_dt_ids
[] = {
591 { .compatible
= "adi,adau1701", },
594 MODULE_DEVICE_TABLE(of
, adau1701_dt_ids
);
597 static int adau1701_probe(struct snd_soc_codec
*codec
)
601 struct adau1701
*adau1701
= snd_soc_codec_get_drvdata(codec
);
604 * Let the pll_clkdiv variable default to something that won't happen
605 * at runtime. That way, we can postpone the firmware download from
606 * adau1701_reset() to a point in time when we know the correct PLL
609 adau1701
->pll_clkdiv
= ADAU1707_CLKDIV_UNSET
;
611 /* initalize with pre-configured pll mode settings */
612 ret
= adau1701_reset(codec
, adau1701
->pll_clkdiv
);
616 /* set up pin config */
618 for (i
= 0; i
< 6; i
++)
619 val
|= adau1701
->pin_config
[i
] << (i
* 4);
621 regmap_write(adau1701
->regmap
, ADAU1701_PINCONF_0
, val
);
624 for (i
= 0; i
< 6; i
++)
625 val
|= adau1701
->pin_config
[i
+ 6] << (i
* 4);
627 regmap_write(adau1701
->regmap
, ADAU1701_PINCONF_1
, val
);
632 static struct snd_soc_codec_driver adau1701_codec_drv
= {
633 .probe
= adau1701_probe
,
634 .set_bias_level
= adau1701_set_bias_level
,
635 .idle_bias_off
= true,
637 .controls
= adau1701_controls
,
638 .num_controls
= ARRAY_SIZE(adau1701_controls
),
639 .dapm_widgets
= adau1701_dapm_widgets
,
640 .num_dapm_widgets
= ARRAY_SIZE(adau1701_dapm_widgets
),
641 .dapm_routes
= adau1701_dapm_routes
,
642 .num_dapm_routes
= ARRAY_SIZE(adau1701_dapm_routes
),
644 .set_sysclk
= adau1701_set_sysclk
,
647 static const struct regmap_config adau1701_regmap
= {
650 .max_register
= ADAU1701_MAX_REGISTER
,
651 .cache_type
= REGCACHE_RBTREE
,
652 .volatile_reg
= adau1701_volatile_reg
,
653 .reg_write
= adau1701_reg_write
,
654 .reg_read
= adau1701_reg_read
,
657 static int adau1701_i2c_probe(struct i2c_client
*client
,
658 const struct i2c_device_id
*id
)
660 struct adau1701
*adau1701
;
661 struct device
*dev
= &client
->dev
;
662 int gpio_nreset
= -EINVAL
;
663 int gpio_pll_mode
[2] = { -EINVAL
, -EINVAL
};
666 adau1701
= devm_kzalloc(dev
, sizeof(*adau1701
), GFP_KERNEL
);
670 adau1701
->regmap
= devm_regmap_init(dev
, NULL
, client
,
672 if (IS_ERR(adau1701
->regmap
))
673 return PTR_ERR(adau1701
->regmap
);
676 gpio_nreset
= of_get_named_gpio(dev
->of_node
, "reset-gpio", 0);
677 if (gpio_nreset
< 0 && gpio_nreset
!= -ENOENT
)
680 gpio_pll_mode
[0] = of_get_named_gpio(dev
->of_node
,
681 "adi,pll-mode-gpios", 0);
682 if (gpio_pll_mode
[0] < 0 && gpio_pll_mode
[0] != -ENOENT
)
683 return gpio_pll_mode
[0];
685 gpio_pll_mode
[1] = of_get_named_gpio(dev
->of_node
,
686 "adi,pll-mode-gpios", 1);
687 if (gpio_pll_mode
[1] < 0 && gpio_pll_mode
[1] != -ENOENT
)
688 return gpio_pll_mode
[1];
690 of_property_read_u32(dev
->of_node
, "adi,pll-clkdiv",
691 &adau1701
->pll_clkdiv
);
693 of_property_read_u8_array(dev
->of_node
, "adi,pin-config",
694 adau1701
->pin_config
,
695 ARRAY_SIZE(adau1701
->pin_config
));
698 if (gpio_is_valid(gpio_nreset
)) {
699 ret
= devm_gpio_request_one(dev
, gpio_nreset
, GPIOF_OUT_INIT_LOW
,
705 if (gpio_is_valid(gpio_pll_mode
[0]) &&
706 gpio_is_valid(gpio_pll_mode
[1])) {
707 ret
= devm_gpio_request_one(dev
, gpio_pll_mode
[0],
709 "ADAU1701 PLL mode 0");
713 ret
= devm_gpio_request_one(dev
, gpio_pll_mode
[1],
715 "ADAU1701 PLL mode 1");
720 adau1701
->gpio_nreset
= gpio_nreset
;
721 adau1701
->gpio_pll_mode
[0] = gpio_pll_mode
[0];
722 adau1701
->gpio_pll_mode
[1] = gpio_pll_mode
[1];
724 i2c_set_clientdata(client
, adau1701
);
725 ret
= snd_soc_register_codec(&client
->dev
, &adau1701_codec_drv
,
730 static int adau1701_i2c_remove(struct i2c_client
*client
)
732 snd_soc_unregister_codec(&client
->dev
);
736 static const struct i2c_device_id adau1701_i2c_id
[] = {
743 MODULE_DEVICE_TABLE(i2c
, adau1701_i2c_id
);
745 static struct i2c_driver adau1701_i2c_driver
= {
748 .owner
= THIS_MODULE
,
749 .of_match_table
= of_match_ptr(adau1701_dt_ids
),
751 .probe
= adau1701_i2c_probe
,
752 .remove
= adau1701_i2c_remove
,
753 .id_table
= adau1701_i2c_id
,
756 module_i2c_driver(adau1701_i2c_driver
);
758 MODULE_DESCRIPTION("ASoC ADAU1701 SigmaDSP driver");
759 MODULE_AUTHOR("Cliff Cai <cliff.cai@analog.com>");
760 MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");
761 MODULE_LICENSE("GPL");