1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2016, Bin Meng <bmeng.cn@gmail.com>
10 #include <asm/arch/sysinfo.h>
12 static int save_vesa_mode(struct cb_framebuffer *fb,
13 struct vesa_mode_info *vesa)
16 * If there is no framebuffer structure, bail out and keep
17 * running on the serial console.
22 vesa->x_resolution = fb->x_resolution;
23 vesa->y_resolution = fb->y_resolution;
24 vesa->bits_per_pixel = fb->bits_per_pixel;
25 vesa->bytes_per_scanline = fb->bytes_per_line;
26 vesa->phys_base_ptr = fb->physical_address;
27 vesa->red_mask_size = fb->red_mask_size;
28 vesa->red_mask_pos = fb->red_mask_pos;
29 vesa->green_mask_size = fb->green_mask_size;
30 vesa->green_mask_pos = fb->green_mask_pos;
31 vesa->blue_mask_size = fb->blue_mask_size;
32 vesa->blue_mask_pos = fb->blue_mask_pos;
33 vesa->reserved_mask_size = fb->reserved_mask_size;
34 vesa->reserved_mask_pos = fb->reserved_mask_pos;
39 static int coreboot_video_probe(struct udevice *dev)
41 struct video_uc_platdata *plat = dev_get_uclass_platdata(dev);
42 struct video_priv *uc_priv = dev_get_uclass_priv(dev);
43 struct cb_framebuffer *fb = lib_sysinfo.framebuffer;
44 struct vesa_mode_info *vesa = &mode_info.vesa;
49 /* Initialize vesa_mode_info structure */
50 ret = save_vesa_mode(fb, vesa);
54 ret = vbe_setup_video_priv(vesa, uc_priv, plat);
58 printf("%dx%dx%d\n", uc_priv->xsize, uc_priv->ysize,
59 vesa->bits_per_pixel);
64 printf("No video mode configured in coreboot!\n");
68 static const struct udevice_id coreboot_video_ids[] = {
69 { .compatible = "coreboot-fb" },
73 U_BOOT_DRIVER(coreboot_video) = {
74 .name = "coreboot_video",
76 .of_match = coreboot_video_ids,
77 .probe = coreboot_video_probe,