/Linux-v6.1/Documentation/devicetree/bindings/iio/adc/ |
D | atmel,sama9260-adc.yaml | 1 # SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) 3 --- 4 $id: http://devicetree.org/schemas/iio/adc/atmel,sama9260-adc.yaml# 5 $schema: http://devicetree.org/meta-schemas/core.yaml# 7 title: AT91 sama9260 and similar Analog to Digital Converter (ADC) 10 - Alexandre Belloni <alexandre.belloni@bootlin.com> 15 - atmel,at91sam9260-adc 16 - atmel,at91sam9rl-adc 17 - atmel,at91sam9g45-adc 18 - atmel,at91sam9x5-adc [all …]
|
/Linux-v6.1/drivers/iio/adc/ |
D | stm32-dfsdm-adc.c | 1 // SPDX-License-Identifier: GPL-2.0 3 * This file is the ADC part of the STM32 DFSDM driver 5 * Copyright (C) 2017, STMicroelectronics - All Rights Reserved 10 #include <linux/dma-mapping.h> 11 #include <linux/iio/adc/stm32-dfsdm-adc.h> 13 #include <linux/iio/hw-consumer.h> 15 #include <linux/iio/timer/stm32-lptim-trigger.h> 16 #include <linux/iio/timer/stm32-timer-trigger.h> 27 #include "stm32-dfsdm.h" 42 /* Limit filter output resolution to 31 bits. (i.e. sample range is +/-2^30) */ [all …]
|
D | ab8500-gpadc.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * Copyright (C) ST-Ericsson SA 2010 11 * AB8500 General Purpose ADC driver. The AB8500 uses reference voltages: 19 * battery temperature or "ADC aux" 1 and 2. Other voltages are internal rails 22 * parts of the system are required to obtain handles to the ADC to do work 52 /* 0 = use rising edge, 1 = use falling edge */ 54 /* 0 = use VTVOUT, 1 = use VRTC as pull-up supply for battery temp NTC */ 63 * the bit layout is the same for SW and HW conversion set-up 163 #define AB8500_ADC_CH_IBAT_MIN (-6000) /* mA range measured by ADC for ibat */ 165 #define AB8500_ADC_CH_IBAT_MIN_V (-60) /* mV range measured by ADC for ibat */ [all …]
|
D | stm32-adc.c | 1 // SPDX-License-Identifier: GPL-2.0 3 * This file is part of STM32 ADC driver 5 * Copyright (C) 2016, STMicroelectronics - All Rights Reserved 11 #include <linux/dma-mapping.h> 15 #include <linux/iio/timer/stm32-lptim-trigger.h> 16 #include <linux/iio/timer/stm32-timer-trigger.h> 25 #include <linux/nvmem-consumer.h> 30 #include "stm32-adc-core.h" 35 /* BOOST bit must be set on STM32H7 when ADC clock is above 20MHz */ 57 /* extsel - trigger mux selection value */ [all …]
|
D | stm32-adc-core.c | 1 // SPDX-License-Identifier: GPL-2.0 3 * This file is part of STM32 ADC driver 5 * Copyright (C) 2016, STMicroelectronics - All Rights Reserved 8 * Inspired from: fsl-imx25-tsadc 26 #include "stm32-adc-core.h" 42 * struct stm32_adc_common_regs - stm32 common registers 47 * @ier: interrupt enable register offset for each adc 62 * struct stm32_adc_priv_cfg - stm32 core compatible configuration data 66 * @ipid: adc identification number 69 * @num_adcs: maximum number of ADC instances in the common registers [all …]
|
D | at91_adc.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later 3 * Driver for the ADC present in the Atmel AT91 evaluation boards. 38 #define AT91_ADC_TSAMOD (3 << 0) /* ADC mode */ 39 #define AT91_ADC_TSAMOD_ADC_ONLY_MODE (0 << 0) /* ADC Mode */ 103 #define AT91_ADC_ACR_PENDETSENS (0x3 << 0) /* pull-up resistor */ 137 (st->registers->channel_base + (ch * 4)) 139 (readl_relaxed(st->reg_base + reg)) 141 (writel_relaxed(val, st->reg_base + reg)) 161 * struct at91_adc_trigger - description of triggers 163 * @value: value to set in the ADC's trigger setup register [all …]
|
D | ti-adc108s102.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * TI ADC108S102 SPI ADC driver 5 * Copyright (c) 2013-2015 Intel Corporation. 12 * The communication with ADC chip is via the SPI bus (mode 3). 29 * In case of ACPI, we use the hard-wired 5000 mV of the Galileo and IOT2000 31 * via the vref-supply regulator. 36 * Defining the ADC resolution being 12 bits, we can use the same driver for 38 * chips. The ADC108S102 effectively returns a 12-bit result with the 2 39 * least-significant bits unset. 45 * 16-bit SPI command format: [all …]
|
D | ti-ads1015.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * ADS1015 - Texas Instruments Analog-to-Digital Converter 7 * IIO driver for ADS1015 ADC 7-bit I2C slave address: 8 * * 0x48 - ADDR connected to Ground 9 * * 0x49 - ADDR connected to Vdd 10 * * 0x4A - ADDR connected to SDA 11 * * 0x4B - ADDR connected to SCL 111 * Translation from PGA bits to full-scale positive and negative input voltage 118 static const int ads1015_scale[] = { /* 12bit ADC */ 127 static const int ads1115_scale[] = { /* 16bit ADC */ [all …]
|
/Linux-v6.1/arch/arm/include/asm/ |
D | div64.h | 1 /* SPDX-License-Identifier: GPL-2.0 */ 18 * In other words, a 64-bit dividend with a 32-bit divisor producing 19 * a 64-bit result and a 32-bit remainder. To accomplish this optimally 48 * we can force the use of the out-of-line version for 57 unsigned long long res; in __arch_xprod_64() local 63 : "=&r" (res) in __arch_xprod_64() 67 res = m; in __arch_xprod_64() 70 : "+&r" (res) in __arch_xprod_64() 77 "adc %Q0, %1, #0" in __arch_xprod_64() 78 : "=&r" (res), "+&r" (tmp) in __arch_xprod_64() [all …]
|
D | atomic.h | 1 /* SPDX-License-Identifier: GPL-2.0-only */ 22 * strex/ldrex monitor on some implementations. The reason we can use it for 25 #define arch_atomic_read(v) READ_ONCE((v)->counter) 26 #define arch_atomic_set(v,i) WRITE_ONCE(((v)->counter), (i)) 31 * ARMv6 UP and SMP safe atomic ops. We use load exclusive and 42 prefetchw(&v->counter); \ 49 : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter) \ 50 : "r" (&v->counter), "Ir" (i) \ 60 prefetchw(&v->counter); \ 68 : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter) \ [all …]
|
/Linux-v6.1/drivers/thermal/qcom/ |
D | qcom-spmi-temp-alarm.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * Copyright (c) 2011-2015, 2017, 2020, The Linux Foundation. All rights reserved. 46 /* Over-temperature trip point values in mC */ 68 /* Temperature in Milli Celsius reported during stage 0 if no ADC is present */ 85 struct iio_channel *adc; member 97 ret = regmap_read(chip->map, chip->base + addr, &val); in qpnp_tm_read() 107 return regmap_write(chip->map, chip->base + addr, data); in qpnp_tm_write() 111 * qpnp_tm_decode_temp() - return temperature in mC corresponding to the 112 * specified over-temperature stage 114 * @stage: Over-temperature stage [all …]
|
/Linux-v6.1/drivers/power/supply/ |
D | ab8500_btemp.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * Copyright (C) ST-Ericsson SA 2012 31 #include <linux/fixp-arith.h> 33 #include "ab8500-bm.h" 35 #define BTEMP_THERMAL_LOW_LIMIT -10 51 * struct ab8500_btemp_interrupts - ab8500 interrupts 77 * struct ab8500_btemp - ab8500 BTEMP device information 80 * @curr_source: What current source we use, in uA 85 * @adc_bat_ctrl: ADC channel for the battery control 125 * ab8500_btemp_batctrl_volt_to_res() - convert batctrl voltage to resistance [all …]
|
D | ug3105_battery.c | 1 // SPDX-License-Identifier: GPL-2.0+ 5 * Note the uG3105 is not a full-featured autonomous fuel-gauge. Instead it is 6 * expected to be use in combination with some always on microcontroller reading 7 * its coulomb-counter before it can wrap (must be read every 400 seconds!). 9 * Since Linux does not monitor coulomb-counter changes while the device 19 * 4. Add some mechanism (needs userspace help, or maybe use efivar?) to remember 23 * and then use total_coulomb_count to report energy_now over time, resetting 25 * readings, esp. in the 30-70% range and allow userspace to estimate time 28 * capacity during run-time ? 32 * in a total_coulomb_count increase of 3277 units with a 5 milli-ohm sense R. [all …]
|
/Linux-v6.1/drivers/iio/light/ |
D | gp2ap002.c | 1 // SPDX-License-Identifier: GPL-2.0-only 14 * https://lore.kernel.org/lkml/1315556546-7445-1-git-send-email-dg77.kim@samsung.com/ 17 * https://lore.kernel.org/linux-input/20190125175045.22576-1-pawel.mikolaj.chmiel@gmail.com/ 18 * Based partly on code from the Samsung GT-S7710 by <mjchen@sta.samsung.com> 28 #include <linux/iio/consumer.h> /* To get our ADC channel */ 29 #include <linux/iio/types.h> /* To deal with our ADC channel */ 42 /* ------------------------------------------------------------------------ */ 45 /* ------------------------------------------------------------------------ */ 52 /* ------------------------------------------------------------------------ */ 54 /* LED0 :Select switch for LED driver's On-registence(0:2x higher, 1:normal)*/ [all …]
|
/Linux-v6.1/sound/soc/sunxi/ |
D | sun4i-codec.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later 5 * Copyright 2015 Maxime Ripard <maxime.ripard@free-electrons.com> 7 * Copyright 2016 Chen-Yu Tsai <wens@csie.org> 79 /* Codec ADC digital controls and FIFO registers */ 92 /* Codec ADC side analog signal controls */ 187 /* ADC mixer controls */ 253 regmap_set_bits(scodec->regmap, SUN4I_CODEC_DAC_FIFOC, in sun4i_codec_start_playback() 257 regmap_set_bits(scodec->regmap, SUN4I_CODEC_DAC_FIFOC, in sun4i_codec_start_playback() 264 regmap_clear_bits(scodec->regmap, SUN4I_CODEC_DAC_FIFOC, in sun4i_codec_stop_playback() 270 /* Enable ADC DRQ */ in sun4i_codec_start_capture() [all …]
|
/Linux-v6.1/drivers/thermal/broadcom/ |
D | bcm2835_thermal.c | 1 // SPDX-License-Identifier: GPL-2.0+ 37 BCM2835_TS_TSENSCTL_CTRL_SHIFT - 1, \ 47 BCM2835_TS_TSENSCTL_THOLD_SHIFT - 1, \ 61 BCM2835_TS_TSENSSTAT_DATA_SHIFT - 1, \ 73 static int bcm2835_thermal_adc2temp(u32 adc, int offset, int slope) in bcm2835_thermal_adc2temp() argument 75 return offset + slope * adc; in bcm2835_thermal_adc2temp() 80 temp -= offset; in bcm2835_thermal_temp2adc() 86 temp = BIT(BCM2835_TS_TSENSSTAT_DATA_BITS) - 1; in bcm2835_thermal_temp2adc() 93 struct bcm2835_thermal_data *data = tz->devdata; in bcm2835_thermal_get_temp() 94 u32 val = readl(data->regs + BCM2835_TS_TSENSSTAT); in bcm2835_thermal_get_temp() [all …]
|
/Linux-v6.1/drivers/input/keyboard/ |
D | Kconfig | 1 # SPDX-License-Identifier: GPL-2.0-only 17 tristate "ADC Ladder Buttons" 21 to an ADC using a resistor ladder. 23 Say Y here if your device has such buttons connected to an ADC. Your 24 board-specific setup logic must also provide a configuration data 38 be called adp5520-keys. 47 Say Y here if you want to use a ADP5588/87 attached to your 51 module will be called adp5588-keys. 57 Say Y here if you want to use a ADP5585/ADP5589 attached to your 61 module will be called adp5589-keys. [all …]
|
D | sun4i-lradc-keys.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later 3 * Allwinner sun4i low res adc attached tablet keys driver 14 * there are no boards known to use channel 1. 62 /* struct lradc_variant - Describe sun4i-a10-lradc-keys hardware variant 113 ints = readl(lradc->base + LRADC_INTS); in sun4i_lradc_irq() 121 input_report_key(lradc->input, lradc->chan0_keycode, 0); in sun4i_lradc_irq() 122 lradc->chan0_keycode = 0; in sun4i_lradc_irq() 125 if ((ints & CHAN0_KEYDOWN_IRQ) && lradc->chan0_keycode == 0) { in sun4i_lradc_irq() 126 val = readl(lradc->base + LRADC_DATA0) & 0x3f; in sun4i_lradc_irq() 127 voltage = val * lradc->vref / 63; in sun4i_lradc_irq() [all …]
|
/Linux-v6.1/drivers/thermal/ti-soc-thermal/ |
D | ti-bandgap.c | 1 // SPDX-License-Identifier: GPL-2.0-only 5 * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ 6 * Author: J Keerthy <j-keerthy@ti.com> 7 * Author: Moiz Sonasath <m-sonasath@ti.com> 36 #include "ti-bandgap.h" 47 * ti_bandgap_readl() - simple read helper function 56 return readl(bgp->base + reg); in ti_bandgap_readl() 60 * ti_bandgap_writel() - simple write helper function 69 writel(val, bgp->base + reg); in ti_bandgap_writel() 75 * RMW_BITS() - used to read, modify and update bandgap bitfields. [all …]
|
/Linux-v6.1/sound/soc/codecs/ |
D | 88pm860x-codec.c | 1 // SPDX-License-Identifier: GPL-2.0-only 3 * 88pm860x-codec.c -- 88PM860x ALSA SoC Audio Driver 26 #include "88pm860x-codec.h" 75 /* ADC Analog Register 1 (0xd0) */ 117 * This widget should be just after DAC & PGA in DAPM power-on sequence and 118 * before DAC & PGA in DAPM power-off sequence. 149 /* -9450dB to 0dB in 150dB steps ( mute instead of -9450dB) */ 150 static const DECLARE_TLV_DB_SCALE(dpga_tlv, -9450, 150, 1); 152 /* -9dB to 0db in 3dB steps */ 153 static const DECLARE_TLV_DB_SCALE(adc_tlv, -900, 300, 0); [all …]
|
/Linux-v6.1/sound/soc/sprd/ |
D | sprd-mcdt.c | 1 // SPDX-License-Identifier: GPL-2.0 14 #include "sprd-mcdt.h" 121 u32 orig = readl_relaxed(mcdt->base + reg); in sprd_mcdt_update() 125 writel_relaxed(tmp, mcdt->base + reg); in sprd_mcdt_update() 187 writel_relaxed(val, mcdt->base + reg); in sprd_mcdt_dac_write_fifo() 195 *val = readl_relaxed(mcdt->base + reg); in sprd_mcdt_adc_read_fifo() 385 return !!(readl_relaxed(mcdt->base + reg) & BIT(shift)); in sprd_mcdt_chan_fifo_sts() 403 u32 r_addr = (readl_relaxed(mcdt->base + reg) >> in sprd_mcdt_dac_fifo_avail() 405 u32 w_addr = readl_relaxed(mcdt->base + reg) & MCDT_CH_FIFO_ADDR_MASK; in sprd_mcdt_dac_fifo_avail() 408 return 4 * (MCDT_FIFO_LENGTH - w_addr + r_addr); in sprd_mcdt_dac_fifo_avail() [all …]
|
/Linux-v6.1/arch/arm/mach-s3c/ |
D | mach-gta02.c | 1 // SPDX-License-Identifier: GPL-2.0+ 5 // Copyright (C) 2006-2009 by Openmoko, Inc. 31 #include <linux/mfd/pcf50633/adc.h> 40 #include <linux/mtd/nand-ecc-sw-hamming.h> 50 #include <asm/mach-types.h> 55 #include <linux/platform_data/i2c-s3c2410.h> 56 #include <linux/platform_data/mtd-nand-s3c2410.h> 57 #include <linux/platform_data/touchscreen-s3c2410.h> 58 #include <linux/platform_data/usb-ohci-s3c2410.h> 59 #include <linux/platform_data/usb-s3c2410_udc.h> [all …]
|
/Linux-v6.1/arch/arm64/boot/dts/qcom/ |
D | sdm845-mtp.dts | 1 // SPDX-License-Identifier: GPL-2.0 8 /dts-v1/; 10 #include <dt-bindings/regulator/qcom,rpmh-regulator.h> 17 compatible = "qcom,sdm845-mtp", "qcom,sdm845"; 24 stdout-path = "serial0:115200n8"; 27 vph_pwr: vph-pwr-regulator { 28 compatible = "regulator-fixed"; 29 regulator-name = "vph_pwr"; 30 regulator-min-microvolt = <3700000>; 31 regulator-max-microvolt = <3700000>; [all …]
|
/Linux-v6.1/drivers/mfd/ |
D | stmpe.c | 1 // SPDX-License-Identifier: GPL-2.0-only 5 * Copyright (C) ST-Ericsson SA 2010 7 * Author: Rabin Vincent <rabin.vincent@stericsson.com> for ST-Ericsson 26 * struct stmpe_platform_data - STMPE platform data 28 * @blocks: bitmask of blocks to enable (use STMPE_BLOCK_*) 29 * @irq_trigger: IRQ trigger to use for the interrupt to the host 43 return stmpe->variant->enable(stmpe, blocks, true); in __stmpe_enable() 48 return stmpe->variant->enable(stmpe, blocks, false); in __stmpe_disable() 55 ret = stmpe->ci->read_byte(stmpe, reg); in __stmpe_reg_read() 57 dev_err(stmpe->dev, "failed to read reg %#x: %d\n", reg, ret); in __stmpe_reg_read() [all …]
|
/Linux-v6.1/drivers/media/usb/gspca/stv06xx/ |
D | stv06xx_pb0100.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later 3 * Copyright (c) 2001 Jean-Fredric Clere, Nikolas Zimmermann, Georg Acher 4 * Mark Cave-Ayland, Carlo E Prelz, Dick Streefland 9 * P/N 861050-0010: Sensor HDCS1000 ASIC STV0600 10 * P/N 861050-0020: Sensor Photobit PB100 ASIC STV0600-1 - QuickCam Express 11 * P/N 861055: Sensor ST VV6410 ASIC STV0610 - LEGO cam 12 * P/N 861075-0040: Sensor HDCS1000 ASIC 13 * P/N 961179-0700: Sensor ST VV6410 ASIC STV0602 - Dexxa WebCam USB 14 * P/N 861040-0000: Sensor ST VV6410 ASIC STV0610 - QuickCam Web 18 * The spec file for the PB-0100 suggests the following for best quality [all …]
|