| /linux/drivers/leds/ | 
| H A D | leds-el15203000.c | 1 // SPDX-License-Identifier: GPL-2.014  * +-----+---------+
 15  * | LED | COMMAND |
 16  * +-----+---------+
 18  * +-----+---------+
 22  * +----------+--------------+-------------------------------------------+
 24  * +----------+--------------+-------------------------------------------+
 26  * +----------+--------------+-------------------------------------------+
 28  * +----------+--------------+-------------------------------------------+
 30  * +----------+--------------+-------------------------------------------+
 [all …]
 
 | 
| H A D | leds-st1202.c | 1 // SPDX-License-Identifier: GPL-2.0-only3  * LED driver for STMicroelectronics LED1202 chip
 5  * Copyright (C) 2024 Remote-Tech Ltd. UK
 23 /* PATS: Pattern sequence feature enable */
 25 /* PATSR: Pattern sequence runs (self-clear when sequence is finished) */
 62 	struct device *dev = &chip->client->dev;  in st1202_read_reg()
 65 	ret = i2c_smbus_read_byte_data(chip->client, reg);  in st1202_read_reg()
 77 	struct device *dev = &chip->client->dev;  in st1202_write_reg()
 80 	ret = i2c_smbus_write_byte_data(chip->client, reg, val);  in st1202_write_reg()
 89 	return value / ST1202_MILLIS_PATTERN_DUR_MIN - 1;  in st1202_prescalar_to_miliseconds()
 [all …]
 
 | 
| H A D | leds-sc27xx-bltc.c | 1 // SPDX-License-Identifier: GPL-2.084 	return leds->priv->base + SC27XX_LEDS_OFFSET * leds->line;  in sc27xx_led_get_offset()
 90 	u32 ctrl_base = leds->priv->base + SC27XX_LEDS_CTRL;  in sc27xx_led_enable()
 91 	u8 ctrl_shift = SC27XX_CTRL_SHIFT * leds->line;  in sc27xx_led_enable()
 92 	struct regmap *regmap = leds->priv->regmap;  in sc27xx_led_enable()
 109 	struct regmap *regmap = leds->priv->regmap;  in sc27xx_led_disable()
 110 	u32 ctrl_base = leds->priv->base + SC27XX_LEDS_CTRL;  in sc27xx_led_disable()
 111 	u8 ctrl_shift = SC27XX_CTRL_SHIFT * leds->line;  in sc27xx_led_disable()
 122 	mutex_lock(&leds->priv->lock);  in sc27xx_led_set()
 129 	mutex_unlock(&leds->priv->lock);  in sc27xx_led_set()
 [all …]
 
 | 
| H A D | leds-spi-byte.c | 1 // SPDX-License-Identifier: GPL-2.02 // Copyright (c) 2019 Christian Mauderer <oss@c-mauderer.de>
 6  * - one LED is controlled by a single byte on MOSI
 7  * - the value of the byte gives the brightness between two values (lowest to
 9  * - no return value is necessary (no MISO signal)
 15  * - "ubnt,acb-spi-led": Microcontroller (SONiX 8F26E611LA) based device used
 19  *   * Mode: 00 -> set brightness between 0x00 (min) and 0x3F (max)
 20  *   * Mode: 01 -> pulsing pattern (min -> max -> min) with an interval. From
 22  *     slightly different pattern starting from 0x10 (longer gap between the
 24  *   * Mode: 10 -> same as 01 but with only a ramp from min to max. Again a
 [all …]
 
 | 
| H A D | leds-lm3533.c | 1 // SPDX-License-Identifier: GPL-2.0-or-later3  * leds-lm3533.c -- LM3533 LED driver
 5  * Copyright (C) 2011-2012 Texas Instruments
 59 static inline int lm3533_led_get_ctrlbank_id(struct lm3533_led *led)  in lm3533_led_get_ctrlbank_id()  argument
 61 	return led->id + 2;  in lm3533_led_get_ctrlbank_id()
 64 static inline u8 lm3533_led_get_lv_reg(struct lm3533_led *led, u8 base)  in lm3533_led_get_lv_reg()  argument
 66 	return base + led->id;  in lm3533_led_get_lv_reg()
 69 static inline u8 lm3533_led_get_pattern(struct lm3533_led *led)  in lm3533_led_get_pattern()  argument
 71 	return led->id;  in lm3533_led_get_pattern()
 74 static inline u8 lm3533_led_get_pattern_reg(struct lm3533_led *led,  in lm3533_led_get_pattern_reg()  argument
 [all …]
 
 | 
| H A D | led-core.c | 1 // SPDX-License-Identifier: GPL-2.0-only3  * LED Class Core
 5  * Copyright 2005-2006 Openedhand Ltd.
 11 #include <linux/led-class-multicolor.h>
 49 	if (!led_cdev->brightness_set)  in __led_set_brightness()
 50 		return -ENOTSUPP;  in __led_set_brightness()
 52 	led_cdev->brightness_set(led_cdev, value);  in __led_set_brightness()
 59 	if (!led_cdev->brightness_set_blocking)  in __led_set_brightness_blocking()
 60 		return -ENOTSUPP;  in __led_set_brightness_blocking()
 62 	return led_cdev->brightness_set_blocking(led_cdev, value);  in __led_set_brightness_blocking()
 [all …]
 
 | 
| H A D | leds-lp5569.c | 1 // SPDX-License-Identifier: GPL-2.0-only16 #include <linux/platform_data/leds-lp55xx.h>
 18 #include <dt-bindings/leds/leds-lp55xx.h>
 20 #include "leds-lp55xx-common.h"
 120 	/* Precompiled pattern per ENGINE setting LED MUX start and stop addresses */  in lp5569_init_program_engine()
 121 	static const u8 pattern[][LP55xx_BYTES_PER_PAGE] =  {  in lp5569_init_program_engine()  local
 140 	/* Write precompiled pattern for LED MUX address space for each ENGINE */  in lp5569_init_program_engine()
 142 		chip->engine_idx = i;  in lp5569_init_program_engine()
 147 					   pattern[i - 1][j]);  in lp5569_init_program_engine()
 161 		dev_err(&chip->cl->dev,  in lp5569_init_program_engine()
 [all …]
 
 | 
| H A D | leds-lp3944.c | 1 // SPDX-License-Identifier: GPL-2.0-only3  * leds-lp3944.c - driver for National Semiconductor LP3944 Funlight Chip
 14  * as a led controller.
 16  * The DIM modes are used to set _blink_ patterns for leds, the pattern is
 18  *   - period: from 0s to 1.6s
 19  *   - duty cycle: percentage of the period the led is on, from 0 to 100
 30 #include <linux/leds-lp3944.h>
 33 #define LP3944_REG_INPUT1     0x00 /* LEDs 0-7 InputRegister (Read Only) */
 40 #define LP3944_REG_LS0        0x06 /* LEDs 0-3 Selector (R/W) */
 41 #define LP3944_REG_LS1        0x07 /* LEDs 4-7 Selector (R/W) */
 [all …]
 
 | 
| /linux/Documentation/leds/ | 
| H A D | leds-mt6370-rgb.rst | 1 .. SPDX-License-Identifier: GPL-2.04 The device for Mediatek MT6370 RGB LED
 8 -----------
 10 The MT6370 integrates a four-channel RGB LED driver, designed to provide a
 11 variety of lighting effect for mobile device applications. The RGB LED devices
 12 includes a smart LED string controller and it can drive 3 channels of LEDs with
 13 a sink current up to 24mA and a CHG_VIN power good indicator LED with sink
 15 PWM Dimming mode, breath pattern mode, and constant current mode. The device
 16 can increase or decrease the brightness of the RGB LED via an I2C interface.
 18 The breath pattern for a channel can be programmed using the "pattern" trigger,
 [all …]
 
 | 
| H A D | leds-lp55xx.rst | 8 -----------13   Create LED class devices for multiple output channels
 14   Device attributes for user-space interface
 15   Program memory for running LED patterns
 28     control multi output LED channels such as led current, channel index.
 32 For example, LP5521 has maximum 3 LED channels.
 50   - Maximum number of channels
 51   - Reset command, chip enable command
 52   - Chip specific initialization
 53   - Brightness control register access
 [all …]
 
 | 
| H A D | leds-qcom-lpg.rst | 1 .. SPDX-License-Identifier: GPL-2.08 -----------
 11 number of PWM channels, a programmable pattern lookup table and a RGB LED
 23 deeper idle states the LPG provides pattern support. This consists of a shared
 25 range within the table to use, the rate and if the pattern should repeat.
 27 The pattern for a channel can be programmed using the "pattern" trigger, using
 30 /sys/class/leds/<led>/hw_pattern
 31 --------------------------------
 33 Specify a hardware pattern for a Qualcomm LPG LED.
 35 The pattern is a series of brightness and hold-time pairs, with the hold-time
 [all …]
 
 | 
| H A D | leds-sc27xx.rst | 1 .. SPDX-License-Identifier: GPL-2.07 /sys/class/leds/<led>/hw_pattern
 8 --------------------------------
 10 Specify a hardware pattern for the SC27XX LED. For the SC27XX
 11 LED controller, it only supports 4 stages to make a single
 12 hardware pattern, which is used to configure the rise time,
 15 For the breathing mode, the SC27XX LED only expects one brightness
 16 for the high stage. To be compatible with the hardware pattern
 20 - Min stage duration: 125 ms
 21 - Max stage duration: 31875 ms
 [all …]
 
 | 
| H A D | leds-lm3556.rst | 6   1.5 A Synchronous Boost LED Flash Driver w/ High-Side Current Source10       - Daniel Jeong
 12 	Contact:Daniel Jeong(daniel.jeong-at-ti.com, gshark.jeong-at-gmail.com)
 15 -----------
 21 In Flash Mode, the LED current source(LED) provides 16 target current levels
 50 In Torch Mode, the current source(LED) is programmed via the CURRENT CONTROL
 77 Indicator pattern can be set through /sys/class/leds/indicator/pattern file,
 78 and 4 patterns are pre-defined in indicator_pattern array.
 80 According to N-lank, Pulse time and N Period values, different pattern wiill
 84 Please refer datasheet for more detail about N-Blank, Pulse time and N Period.
 [all …]
 
 | 
| H A D | leds-cht-wcove.rst | 1 .. SPDX-License-Identifier: GPL-2.07 /sys/class/leds/<led>/hw_pattern
 8 --------------------------------
 10 Specify a hardware pattern for the Whiskey Cove PMIC LEDs.
 12 The only supported pattern is hardware breathing mode::
 18     Max-|     ---
 23     Min-|-           ---
 25 	0------2------4--> time (sec)
 31 The set pattern only controls the timing. For max brightness the last
 35 This is just like how blinking works in the LED subsystem,
 
 | 
| /linux/Documentation/devicetree/bindings/leds/ | 
| H A D | leds-el15203000.txt | 1 Crane Merchandising System - EL15203000 LED driver2 --------------------------------------------------
 4 This LED Board (aka RED LEDs board) is widely used in
 9 Vending area LED encoded with symbol 'V' (hex code 0x56).
 10 Doesn't have any hardware blinking pattern.
 12 Screen light tube LED which surrounds vending machine screen and
 13 encoded with symbol 'S' (hex code 0x53). Supports blinking breathing pattern.
 15 Water Pipe LED encoded with symbol 'P' (hex code 0x50) and
 16 actually consists of 5 LEDs that exposed by protocol like one LED.
 18 - cascade pattern
 [all …]
 
 | 
| H A D | leds-trigger-pattern.txt | 1 * Pattern format for LED pattern trigger3 The pattern is given by a series of tuples, of brightness and duration (ms).
 4 The LED is expected to traverse the series and each brightness value for the
 6 new value, and writing malformed pattern deactivates any active one.
 13 The gradual dimming format of the software pattern values should be:
 17 echo 0 1000 255 2000 > pattern
 19 It will make the LED go gradually from zero-intensity to max (255) intensity in
 22 LED brightness
 24 255-|       / \            / \            /
 28   0-|   /             \/             \/
 [all …]
 
 | 
| /linux/drivers/leds/rgb/ | 
| H A D | leds-mt6370-rgb.c | 1 // SPDX-License-Identifier: GPL-2.0-only14 #include <linux/led-class-multicolor.h>
 110 #define MT6370_CHEN_BIT(id)			BIT(MT6370_LED_ISNK4 - id)
 113 #define MT6370_PWM_DUTY				(BIT(5) - 1)
 114 #define MT6372_PWM_DUTY				(BIT(8) - 1)
 118 	 * If the color of the LED in DT is set to
 119 	 *   - 'LED_COLOR_ID_RGB'
 120 	 *   - 'LED_COLOR_ID_MULTI'
 123 	 * If so, this LED will choose 'struct led_classdev_mc mc' to use.
 125 	 * 'MT6370_LED_ISNK1' ~ 'MT6370_LED_ISNK4', then this LED will choose
 [all …]
 
 | 
| H A D | leds-ncp5623.c | 1 // SPDX-License-Identifier: GPL-2.0-only3  * NCP5623 Multi-LED Driver
 6  * Datasheet: https://www.onsemi.com/pdf/datasheet/ncp5623-d.pdf
 12 #include <linux/led-class-multicolor.h>
 49 	guard(mutex)(&ncp->lock);  in ncp5623_brightness_set()
 51 	if (ncp->delay && time_is_after_jiffies(ncp->delay))  in ncp5623_brightness_set()
 52 		return -EBUSY;  in ncp5623_brightness_set()
 54 	ncp->delay = 0;  in ncp5623_brightness_set()
 56 	for (int i = 0; i < mc_cdev->num_colors; i++) {  in ncp5623_brightness_set()
 57 		ret = ncp5623_write(ncp->client,  in ncp5623_brightness_set()
 [all …]
 
 | 
| H A D | Kconfig | 1 # SPDX-License-Identifier: GPL-2.06 	tristate "LEDs group multi-color support"
 11 	  different colors are physically grouped in a single multi-color LED
 12 	  and driven by a controller that doesn't have multi-color support.
 15 	  will be called leds-group-multicolor.
 18 	tristate "LED support for KTD202x Chips"
 23 	  RGB/White LED driver found in different BQ mobile phones.
 24 	  It is a 3 or 4 channel LED driver programmed via an I2C interface.
 27 	  will be called leds-ktd202x.
 30 	tristate "LED support for NCP5623"
 [all …]
 
 | 
| /linux/include/linux/ | 
| H A D | leds.h | 1 /* SPDX-License-Identifier: GPL-2.0-only */3  * Driver model for leds and led triggers
 11 #include <dt-bindings/leds/common.h>
 29  * LED Core
 47  * struct led_lookup_data - represents a single LED lookup entry
 49  * @list: internal list of all LED lookup entries
 50  * @provider: name of led_classdev providing the LED
 51  * @dev_id: name of the device associated with this LED
 52  * @con_id: name of the LED from the device's point of view
 66 	 * with in-driver hard-coded LED names used as a fallback when
 [all …]
 
 | 
| /linux/include/linux/mfd/ | 
| H A D | max8997.h | 1 /* SPDX-License-Identifier: GPL-2.0+ */3  * max8997.h - Driver for the Maxim 8997/8966
 5  *  Copyright (C) 2009-2010 Samsung Electronics
 120  * @internal_mode_pattern: internal mode pattern for internal mode
 121  *     [0 - 3]: valid pattern number
 123  *		   for the internal mode pattern
 124  *     [0 - 15]: available cycles
 125  * @pattern_signal_period: period of the waveform for the internal mode pattern
 126  *     [0 - 255]: available period
 150  *  The number of LED devices for MAX8997 is two
 [all …]
 
 | 
| /linux/drivers/leds/trigger/ | 
| H A D | Kconfig | 1 # SPDX-License-Identifier: GPL-2.0-only3 	bool "LED Trigger support"
 13 	tristate "LED Timer Trigger"
 16 	  via sysfs. Some LED hardware can be programmed to start
 17 	  blinking the LED without any further software interaction.
 18 	  For more details read Documentation/leds/leds-class.rst.
 23 	tristate "LED One-shot Trigger"
 25 	  This allows LEDs to blink in one-shot pulses with parameters
 28 	  or on dense events, where this blinks the LED at constant rate if
 36 	bool "LED Disk Trigger"
 [all …]
 
 | 
| H A D | ledtrig-timer.c | 1 // SPDX-License-Identifier: GPL-2.0-only3  * LED Kernel Timer Trigger
 5  * Copyright 2005-2006 Openedhand Ltd.
 23 	return sprintf(buf, "%lu\n", led_cdev->blink_delay_on);  in led_delay_on_show()
 37 	led_blink_set(led_cdev, &state, &led_cdev->blink_delay_off);  in led_delay_on_store()
 38 	led_cdev->blink_delay_on = state;  in led_delay_on_store()
 48 	return sprintf(buf, "%lu\n", led_cdev->blink_delay_off);  in led_delay_off_show()
 62 	led_blink_set(led_cdev, &led_cdev->blink_delay_on, &state);  in led_delay_off_store()
 63 	led_cdev->blink_delay_off = state;  in led_delay_off_store()
 80 	u32 *pattern;  in pattern_init()  local
 [all …]
 
 | 
| H A D | ledtrig-oneshot.c | 1 // SPDX-License-Identifier: GPL-2.0-only3  * One-shot LED Trigger
 7  * Based on ledtrig-timer.c by Richard Purdie <rpurdie@openedhand.com>
 32 			&led_cdev->blink_delay_on, &led_cdev->blink_delay_off,  in led_shot()
 33 			oneshot_data->invert);  in led_shot()
 43 	return sprintf(buf, "%u\n", oneshot_data->invert);  in led_invert_show()
 58 	oneshot_data->invert = !!state;  in led_invert_store()
 60 	if (oneshot_data->invert)  in led_invert_store()
 73 	return sprintf(buf, "%lu\n", led_cdev->blink_delay_on);  in led_delay_on_show()
 87 	led_cdev->blink_delay_on = state;  in led_delay_on_store()
 [all …]
 
 | 
| /linux/include/linux/platform_data/ | 
| H A D | leds-lp55xx.h | 1 /* SPDX-License-Identifier: GPL-2.0-only */9  * Derived from leds-lp5521.h, leds-lp5523.h
 16 #include <linux/led-class-multicolor.h>
 29 	u8 led_current; /* mA x10, 0 if led is not connected */
 55  * @led_config        : Configurable led class device
 56  * @num_channels      : Number of LED channels
 62  * @patterns          : Predefined pattern data for RGB channels
 68 	/* LED channel configuration */
 82 	/* Predefined pattern data */
 
 |