Zephyr Project API 4.3.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
led_strip.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2017 Linaro Limited
3 * Copyright (c) 2024 Jamie McCrae
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
16
17#ifndef ZEPHYR_INCLUDE_DRIVERS_LED_STRIP_H_
18#define ZEPHYR_INCLUDE_DRIVERS_LED_STRIP_H_
19
31
32#include <errno.h>
33#include <zephyr/types.h>
34#include <zephyr/device.h>
35
36#ifdef __cplusplus
37extern "C" {
38#endif
39
46struct led_rgb {
47#ifdef CONFIG_LED_STRIP_RGB_SCRATCH
48 /*
49 * Pad/scratch space needed by some drivers. Users should
50 * ignore.
51 */
52 uint8_t scratch;
53#endif
60};
61
68typedef int (*led_api_update_rgb)(const struct device *dev,
69 struct led_rgb *pixels,
70 size_t num_pixels);
71
78typedef int (*led_api_update_channels)(const struct device *dev,
79 uint8_t *channels,
80 size_t num_channels);
81
88typedef size_t (*led_api_length)(const struct device *dev);
89
100
113static inline int led_strip_update_rgb(const struct device *dev,
114 struct led_rgb *pixels,
115 size_t num_pixels)
116{
117 const struct led_strip_driver_api *api =
118 (const struct led_strip_driver_api *)dev->api;
119
120 /* Allow for out-of-tree drivers that do not have this function for 2 Zephyr releases
121 * until making it mandatory, function added after Zephyr 3.6
122 */
123 if (api->length != NULL) {
124 /* Ensure supplied pixel size is valid for this device */
125 if (api->length(dev) < num_pixels) {
126 return -ERANGE;
127 }
128 }
129
130 return api->update_rgb(dev, pixels, num_pixels);
131}
132
148static inline int led_strip_update_channels(const struct device *dev,
149 uint8_t *channels,
150 size_t num_channels)
151{
152 const struct led_strip_driver_api *api =
153 (const struct led_strip_driver_api *)dev->api;
154
155 if (api->update_channels == NULL) {
156 return -ENOSYS;
157 }
158
159 return api->update_channels(dev, channels, num_channels);
160}
161
169static inline size_t led_strip_length(const struct device *dev)
170{
171 const struct led_strip_driver_api *api =
172 (const struct led_strip_driver_api *)dev->api;
173
174 return api->length(dev);
175}
176
177#ifdef __cplusplus
178}
179#endif
180
184
185#endif /* ZEPHYR_INCLUDE_DRIVERS_LED_STRIP_H_ */
System error numbers.
size_t(* led_api_length)(const struct device *dev)
Callback API for getting length of an LED strip.
Definition led_strip.h:88
static int led_strip_update_rgb(const struct device *dev, struct led_rgb *pixels, size_t num_pixels)
Mandatory function to update an LED strip with the given RGB array.
Definition led_strip.h:113
static size_t led_strip_length(const struct device *dev)
Mandatory function to get chain length (in pixels) of an LED strip device.
Definition led_strip.h:169
static int led_strip_update_channels(const struct device *dev, uint8_t *channels, size_t num_channels)
Optional function to update an LED strip with the given channel array (each channel byte correspondin...
Definition led_strip.h:148
int(* led_api_update_rgb)(const struct device *dev, struct led_rgb *pixels, size_t num_pixels)
Callback API for updating an RGB LED strip.
Definition led_strip.h:68
int(* led_api_update_channels)(const struct device *dev, uint8_t *channels, size_t num_channels)
Callback API for updating channels without an RGB interpretation.
Definition led_strip.h:78
#define ENOSYS
Function not implemented.
Definition errno.h:82
#define ERANGE
Result too large.
Definition errno.h:72
#define NULL
Definition iar_missing_defs.h:20
Size of off_t must be equal or less than size of size_t
Definition retained_mem.h:29
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:519
Color value for a single RGB LED.
Definition led_strip.h:46
uint8_t r
Red channel.
Definition led_strip.h:55
uint8_t g
Green channel.
Definition led_strip.h:57
uint8_t b
Blue channel.
Definition led_strip.h:59
LED strip driver API.
Definition led_strip.h:95
led_api_length length
Definition led_strip.h:98
led_api_update_channels update_channels
Definition led_strip.h:97
led_api_update_rgb update_rgb
Definition led_strip.h:96