/* * Copyright (c) 2013 Google, Inc * * SPDX-License-Identifier: GPL-2.0+ */ #include <common.h> #include <fdtdec.h> #include <lcd.h> #include <malloc.h> #include <asm/sdl.h> #include <asm/u-boot-sandbox.h> DECLARE_GLOBAL_DATA_PTR; enum { /* Maximum LCD size we support */ LCD_MAX_WIDTH = 1366, LCD_MAX_HEIGHT = 768, LCD_MAX_LOG2_BPP = 4, /* 2^4 = 16 bpp */ }; vidinfo_t panel_info; void lcd_setcolreg(ushort regno, ushort red, ushort green, ushort blue) { } void lcd_ctrl_init(void *lcdbase) { /* * Allocate memory to keep BMP color conversion map. This is required * for 8 bit BMPs only (hence 256 colors). If malloc fails - keep * going, it is not even clear if displyaing the bitmap will be * required on the way up. */ panel_info.cmap = malloc(256 * NBITS(panel_info.vl_bpix) / 8); } void lcd_enable(void) { if (sandbox_sdl_init_display(panel_info.vl_col, panel_info.vl_row, panel_info.vl_bpix)) puts("LCD init failed\n"); } int sandbox_lcd_sdl_early_init(void) { const void *blob = gd->fdt_blob; int xres = LCD_MAX_WIDTH, yres = LCD_MAX_HEIGHT; int node; int ret = 0; /* * The code in common/lcd.c does not cope with not being able to * set up a frame buffer. It will just happily keep writing to * invalid memory. So here we make sure that at least some buffer * is available even if it actually won't be displayed. */ node = fdtdec_next_compatible(blob, 0, COMPAT_SANDBOX_LCD_SDL); if (node >= 0) { xres = fdtdec_get_int(blob, node, "xres", LCD_MAX_WIDTH); yres = fdtdec_get_int(blob, node, "yres", LCD_MAX_HEIGHT); if (xres < 0 || xres > LCD_MAX_WIDTH) { xres = LCD_MAX_WIDTH; ret = -EINVAL; } if (yres < 0 || yres > LCD_MAX_HEIGHT) { yres = LCD_MAX_HEIGHT; ret = -EINVAL; } } panel_info.vl_col = xres; panel_info.vl_row = yres; panel_info.vl_bpix = LCD_COLOR16; return ret; }