1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright 2014 Google Inc.
12 int display_read_edid(struct udevice *dev, u8 *buf, int buf_size)
14 struct dm_display_ops *ops = display_get_ops(dev);
16 if (!ops || !ops->read_edid)
18 return ops->read_edid(dev, buf, buf_size);
21 int display_enable(struct udevice *dev, int panel_bpp,
22 const struct display_timing *timing)
24 struct dm_display_ops *ops = display_get_ops(dev);
25 struct display_plat *disp_uc_plat;
28 if (!ops || !ops->enable)
30 ret = ops->enable(dev, panel_bpp, timing);
34 disp_uc_plat = dev_get_uclass_platdata(dev);
35 disp_uc_plat->in_use = true;
40 static bool display_mode_valid(void *priv, const struct display_timing *timing)
42 struct udevice *dev = priv;
43 struct dm_display_ops *ops = display_get_ops(dev);
45 if (ops && ops->mode_valid)
46 return ops->mode_valid(dev, timing);
51 int display_read_timing(struct udevice *dev, struct display_timing *timing)
53 struct dm_display_ops *ops = display_get_ops(dev);
54 int panel_bits_per_colour;
55 u8 buf[EDID_EXT_SIZE];
58 if (ops && ops->read_timing)
59 return ops->read_timing(dev, timing);
61 if (!ops || !ops->read_edid)
63 ret = ops->read_edid(dev, buf, sizeof(buf));
67 return edid_get_timing_validate(buf, ret, timing,
68 &panel_bits_per_colour,
69 display_mode_valid, dev);
72 bool display_in_use(struct udevice *dev)
74 struct display_plat *disp_uc_plat = dev_get_uclass_platdata(dev);
76 return disp_uc_plat->in_use;
79 UCLASS_DRIVER(display) = {
82 .per_device_platdata_auto_alloc_size = sizeof(struct display_plat),