/* * 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"); nclude/net/irda/af_irda.h?id=e6e7b48b295afa5a5ab440de0a94d9ad8b3ce2d0'>commitdiff
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2017-01-12 17:15:56 +0100
committerDaniel Vetter <daniel.vetter@ffwll.ch>2017-01-30 10:17:32 +0100
commite6e7b48b295afa5a5ab440de0a94d9ad8b3ce2d0 (patch)
tree77cadb6d8aad1b52c34e4afa8c9deef603bbe2ed /include/net/irda/af_irda.h
parent4e5b54f127426c82dc2816340c26d951a5bb3429 (diff)
drm: Don't race connector registration
I was under the misconception that the sysfs dev stuff can be fully set up, and then registered all in one step with device_add. That's true for properties and property groups, but not for parents and child devices. Those must be fully registered before you can register a child. Add a bit of tracking to make sure that asynchronous mst connector hotplugging gets this right. For consistency we rely upon the implicit barriers of the connector->mutex, which is taken anyway, to ensure that at least either the connector or device registration call will work out. Mildly tested since I can't reliably reproduce this on my mst box here. Reported-by: Dave Hansen <dave.hansen@intel.com> Cc: Dave Hansen <dave.hansen@intel.com> Acked-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/1484237756-2720-1-git-send-email-daniel.vetter@ffwll.ch
Diffstat (limited to 'include/net/irda/af_irda.h')