xref: /openbmc/linux/sound/soc/codecs/adau1372-spi.c (revision 6cd4c645)
1*6cd4c645SLars-Peter Clausen // SPDX-License-Identifier: GPL-2.0-only
2*6cd4c645SLars-Peter Clausen /*
3*6cd4c645SLars-Peter Clausen  * Driver for ADAU1372 codec
4*6cd4c645SLars-Peter Clausen  *
5*6cd4c645SLars-Peter Clausen  * Copyright 2016 Analog Devices Inc.
6*6cd4c645SLars-Peter Clausen  *  Author: Lars-Peter Clausen <lars@metafoo.de>
7*6cd4c645SLars-Peter Clausen  */
8*6cd4c645SLars-Peter Clausen 
9*6cd4c645SLars-Peter Clausen #include <linux/mod_devicetable.h>
10*6cd4c645SLars-Peter Clausen #include <linux/module.h>
11*6cd4c645SLars-Peter Clausen #include <linux/regmap.h>
12*6cd4c645SLars-Peter Clausen #include <linux/spi/spi.h>
13*6cd4c645SLars-Peter Clausen #include <sound/soc.h>
14*6cd4c645SLars-Peter Clausen 
15*6cd4c645SLars-Peter Clausen #include "adau1372.h"
16*6cd4c645SLars-Peter Clausen 
adau1372_spi_switch_mode(struct device * dev)17*6cd4c645SLars-Peter Clausen static void adau1372_spi_switch_mode(struct device *dev)
18*6cd4c645SLars-Peter Clausen {
19*6cd4c645SLars-Peter Clausen 	struct spi_device *spi = to_spi_device(dev);
20*6cd4c645SLars-Peter Clausen 
21*6cd4c645SLars-Peter Clausen 	/*
22*6cd4c645SLars-Peter Clausen 	 * To get the device into SPI mode CLATCH has to be pulled low three
23*6cd4c645SLars-Peter Clausen 	 * times.  Do this by issuing three dummy reads.
24*6cd4c645SLars-Peter Clausen 	 */
25*6cd4c645SLars-Peter Clausen 	spi_w8r8(spi, 0x00);
26*6cd4c645SLars-Peter Clausen 	spi_w8r8(spi, 0x00);
27*6cd4c645SLars-Peter Clausen 	spi_w8r8(spi, 0x00);
28*6cd4c645SLars-Peter Clausen }
29*6cd4c645SLars-Peter Clausen 
adau1372_spi_probe(struct spi_device * spi)30*6cd4c645SLars-Peter Clausen static int adau1372_spi_probe(struct spi_device *spi)
31*6cd4c645SLars-Peter Clausen {
32*6cd4c645SLars-Peter Clausen 	struct regmap_config config;
33*6cd4c645SLars-Peter Clausen 
34*6cd4c645SLars-Peter Clausen 	config = adau1372_regmap_config;
35*6cd4c645SLars-Peter Clausen 	config.read_flag_mask = 0x1;
36*6cd4c645SLars-Peter Clausen 
37*6cd4c645SLars-Peter Clausen 	return adau1372_probe(&spi->dev,
38*6cd4c645SLars-Peter Clausen 		devm_regmap_init_spi(spi, &config), adau1372_spi_switch_mode);
39*6cd4c645SLars-Peter Clausen }
40*6cd4c645SLars-Peter Clausen 
41*6cd4c645SLars-Peter Clausen static const struct spi_device_id adau1372_spi_id[] = {
42*6cd4c645SLars-Peter Clausen 	{ "adau1372", 0 },
43*6cd4c645SLars-Peter Clausen 	{ }
44*6cd4c645SLars-Peter Clausen };
45*6cd4c645SLars-Peter Clausen MODULE_DEVICE_TABLE(spi, adau1372_spi_id);
46*6cd4c645SLars-Peter Clausen 
47*6cd4c645SLars-Peter Clausen static struct spi_driver adau1372_spi_driver = {
48*6cd4c645SLars-Peter Clausen 	.driver = {
49*6cd4c645SLars-Peter Clausen 		.name = "adau1372",
50*6cd4c645SLars-Peter Clausen 	},
51*6cd4c645SLars-Peter Clausen 	.probe = adau1372_spi_probe,
52*6cd4c645SLars-Peter Clausen 	.id_table = adau1372_spi_id,
53*6cd4c645SLars-Peter Clausen };
54*6cd4c645SLars-Peter Clausen module_spi_driver(adau1372_spi_driver);
55*6cd4c645SLars-Peter Clausen 
56*6cd4c645SLars-Peter Clausen MODULE_DESCRIPTION("ASoC ADAU1372 CODEC SPI driver");
57*6cd4c645SLars-Peter Clausen MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");
58*6cd4c645SLars-Peter Clausen MODULE_LICENSE("GPL v2");
59