blob: 4dc923a91b16d2754008b9cca390f20e9f09056f [file] [log] [blame]
Googler25e92cf2023-12-13 10:05:01 +00001/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * Copyright (c) 2015 Google, Inc
4 * Written by Simon Glass <sjg@chromium.org>
5 */
6
7#ifndef __LED_H
8#define __LED_H
9
10/**
11 * struct led_uc_plat - Platform data the uclass stores about each device
12 *
13 * @label: LED label
14 */
15struct led_uc_plat {
16 const char *label;
17};
18
19/**
20 * struct led_uc_priv - Private data the uclass stores about each device
21 *
22 * @period_ms: Flash period in milliseconds
23 */
24struct led_uc_priv {
25 int period_ms;
26};
27
28enum led_state_t {
29 LEDST_OFF = 0,
30 LEDST_ON = 1,
31 LEDST_TOGGLE,
32#ifdef CONFIG_LED_BLINK
33 LEDST_BLINK,
34#endif
35#ifdef CONFIG_AML_LED_PWM
36 LEDST_SET_BRIGHTNESS,
37 LEDST_GET_BRIGHTNESS,
38#endif
39
40 LEDST_COUNT,
41};
42
43struct led_ops {
44 /**
45 * set_state() - set the state of an LED
46 *
47 * @dev: LED device to change
48 * @state: LED state to set
49 * @return 0 if OK, -ve on error
50 */
51 int (*set_state)(struct udevice *dev, enum led_state_t state);
52
53 /**
54 * led_get_state() - get the state of an LED
55 *
56 * @dev: LED device to change
57 * @return LED state led_state_t, or -ve on error
58 */
59 enum led_state_t (*get_state)(struct udevice *dev);
60
61#ifdef CONFIG_LED_BLINK
62 /**
63 * led_set_period() - set the blink period of an LED
64 *
65 * Thie records the period if supported, or returns -ENOSYS if not.
66 * To start the LED blinking, use set_state().
67 *
68 * @dev: LED device to change
69 * @period_ms: LED blink period in milliseconds
70 * @return 0 if OK, -ve on error
71 */
72 int (*set_period)(struct udevice *dev, int period_ms);
73#endif
74#ifdef CONFIG_AML_LED_PWM
75 /**
76 * set_brightness() - set the brightness of an LED
77 *
78 *
79 * @dev: LED device to change
80 * @brightness: LED brightness
81 * @return 0 if OK, -ve on error
82 */
83 int (*set_brightness)(struct udevice *dev, int brightness);
84 /**
85 * get_brightness() - get the brightness of an LED
86 *
87 * Thie records the period if supported, or returns -ENOSYS if not.
88 * To start the LED blinking, use set_state().
89 *
90 * @dev: LED device to change
91 * @return brightness
92 */
93 int (*get_brightness)(struct udevice *dev);
94#endif
95};
96
97#define led_get_ops(dev) ((struct led_ops *)(dev)->driver->ops)
98
99/**
100 * led_get_by_label() - Find an LED device by label
101 *
102 * @label: LED label to look up
103 * @devp: Returns the associated device, if found
104 * @return 0 if found, -ENODEV if not found, other -ve on error
105 */
106int led_get_by_label(const char *label, struct udevice **devp);
107
108/**
109 * led_set_state() - set the state of an LED
110 *
111 * @dev: LED device to change
112 * @state: LED state to set
113 * @return 0 if OK, -ve on error
114 */
115int led_set_state(struct udevice *dev, enum led_state_t state);
116
117/**
118 * led_get_state() - get the state of an LED
119 *
120 * @dev: LED device to change
121 * @return LED state led_state_t, or -ve on error
122 */
123enum led_state_t led_get_state(struct udevice *dev);
124
125/**
126 * led_set_period() - set the blink period of an LED
127 *
128 * @dev: LED device to change
129 * @period_ms: LED blink period in milliseconds
130 * @return 0 if OK, -ve on error
131 */
132int led_set_period(struct udevice *dev, int period_ms);
133
134/**
135 * led_default_state() - set the default state for all the LED
136 *
137 * This enables all leds which have default state.
138 * see Documentation/devicetree/bindings/leds/common.txt
139 *
140 */
141int led_default_state(void);
142
143#ifdef CONFIG_AML_LED_PWM
144/**
145 * set_brightness() - set the brightness of an LED
146 *
147 * Thie records the period if supported, or returns -ENOSYS if not.
148 * To start the LED blinking, use set_state().
149 *
150 * @dev: LED device to change
151 * @period_ms: LED blink period in milliseconds
152 * @return 0 if OK, -ve on error
153 */
154int led_set_brightness(struct udevice *dev, int brightness);
155/**
156 * get_brightness() - get the brightness of an LED
157 *
158 * Thie records the period if supported, or returns -ENOSYS if not.
159 * To start the LED blinking, use set_state().
160 *
161 * @dev: LED device to change
162 * @period_ms: LED blink period in milliseconds
163 * @return 0 if OK, -ve on error
164 */
165int led_get_brightness(struct udevice *dev);
166#endif
167#endif