/* * Driver for ADAU1381/ADAU1781 CODEC * * Copyright 2014 Analog Devices Inc. * Author: Lars-Peter Clausen * * Licensed under the GPL-2. */ #include #include #include #include #include #include "adau1781.h" static void adau1781_spi_switch_mode(struct device *dev) { struct spi_device *spi = to_spi_device(dev); /* * To get the device into SPI mode CLATCH has to be pulled low three * times. Do this by issuing three dummy reads. */ spi_w8r8(spi, 0x00); spi_w8r8(spi, 0x00); spi_w8r8(spi, 0x00); } static int adau1781_spi_probe(struct spi_device *spi) { const struct spi_device_id *id = spi_get_device_id(spi); struct regmap_config config; if (!id) return -EINVAL; config = adau1781_regmap_config; config.val_bits = 8; config.reg_bits = 24; config.read_flag_mask = 0x1; return adau1781_probe(&spi->dev, devm_regmap_init_spi(spi, &config), id->driver_data, adau1781_spi_switch_mode); } static int adau1781_spi_remove(struct spi_device *spi) { adau17x1_remove(&spi->dev); return 0; } static const struct spi_device_id adau1781_spi_id[] = { { "adau1381", ADAU1381 }, { "adau1781", ADAU1781 }, { } }; MODULE_DEVICE_TABLE(spi, adau1781_spi_id); #if defined(CONFIG_OF) static const struct of_device_id adau1781_spi_dt_ids[] = { { .compatible = "adi,adau1381", }, { .compatible = "adi,adau1781", }, { }, }; MODULE_DEVICE_TABLE(of, adau1781_spi_dt_ids); #endif static struct spi_driver adau1781_spi_driver = { .driver = { .name = "adau1781", .of_match_table = of_match_ptr(adau1781_spi_dt_ids), }, .probe = adau1781_spi_probe, .remove = adau1781_spi_remove, .id_table = adau1781_spi_id, }; module_spi_driver(adau1781_spi_driver); MODULE_DESCRIPTION("ASoC ADAU1381/ADAU1781 CODEC SPI driver"); MODULE_AUTHOR("Lars-Peter Clausen "); MODULE_LICENSE("GPL"); 3365135d43f861003555c963b309672d053a2228'>commitdiff
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-01-27 12:44:32 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-01-27 12:44:32 -0800
commit3365135d43f861003555c963b309672d053a2228 (patch)
treebfef4adec5da118bf1b3df7e5cff74f45af9e02d /include/soc/fsl
parent5906374446386fd16fe562b042429d905d231ec3 (diff)
parente0d76fa4475ef2cf4b52d18588b8ce95153d021b (diff)
Merge tag 'xfs-for-linus-4.10-rc6-5' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux
Pull xfs uodates from Darrick Wong: "I have some more fixes this week: better input validation, corruption avoidance, build fixes, memory leak fixes, and a couple from Christoph to avoid an ENOSPC failure. Summary: - Fix race conditions in the CoW code - Fix some incorrect input validation checks - Avoid crashing fs by running out of space when freeing inodes - Fix toctou race wrt whether or not an inode has an attr - Fix build error on arm - Fix page refcount corruption when readahead fails - Don't corrupt userspace in the bmap ioctl" * tag 'xfs-for-linus-4.10-rc6-5' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux: xfs: prevent quotacheck from overloading inode lru xfs: fix bmv_count confusion w/ shared extents xfs: clear _XBF_PAGES from buffers when readahead page xfs: extsize hints are not unlikely in xfs_bmap_btalloc xfs: remove racy hasattr check from attr ops xfs: use per-AG reservations for the finobt xfs: only update mount/resv fields on success in __xfs_ag_resv_init xfs: verify dirblocklog correctly xfs: fix COW writeback race
Diffstat (limited to 'include/soc/fsl')