hc
2023-11-22 f743a7adbd6e230d66a6206fa115b59fec2d88eb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/*
 * Copyright (C) 2017, STMicroelectronics - All Rights Reserved
 * Author: Patrick Delaunay <patrick.delaunay@st.com>
 *
 * SPDX-License-Identifier:    GPL-2.0+
 */
 
#include <common.h>
#include <dm.h>
#include <backlight.h>
#include <asm/gpio.h>
 
DECLARE_GLOBAL_DATA_PTR;
 
struct gpio_backlight_priv {
   struct gpio_desc gpio;
   bool def_value;
};
 
static int gpio_backlight_enable(struct udevice *dev)
{
   struct gpio_backlight_priv *priv = dev_get_priv(dev);
 
   dm_gpio_set_value(&priv->gpio, 1);
 
   return 0;
}
 
static int gpio_backlight_ofdata_to_platdata(struct udevice *dev)
{
   struct gpio_backlight_priv *priv = dev_get_priv(dev);
   int ret;
 
   ret = gpio_request_by_name(dev, "gpios", 0, &priv->gpio,
                  GPIOD_IS_OUT);
   if (ret) {
       debug("%s: Warning: cannot get GPIO: ret=%d\n",
             __func__, ret);
       return ret;
   }
 
   priv->def_value = dev_read_bool(dev, "default-on");
 
   return 0;
}
 
static int gpio_backlight_probe(struct udevice *dev)
{
   struct gpio_backlight_priv *priv = dev_get_priv(dev);
 
   if (priv->def_value)
       gpio_backlight_enable(dev);
 
   return 0;
}
 
static const struct backlight_ops gpio_backlight_ops = {
   .enable    = gpio_backlight_enable,
};
 
static const struct udevice_id gpio_backlight_ids[] = {
   { .compatible = "gpio-backlight" },
   { }
};
 
U_BOOT_DRIVER(gpio_backlight) = {
   .name    = "gpio_backlight",
   .id    = UCLASS_PANEL_BACKLIGHT,
   .of_match = gpio_backlight_ids,
   .ops    = &gpio_backlight_ops,
   .ofdata_to_platdata    = gpio_backlight_ofdata_to_platdata,
   .probe        = gpio_backlight_probe,
   .priv_auto_alloc_size    = sizeof(struct gpio_backlight_priv),
};