xref: /openbmc/u-boot/board/freescale/ls1021atwr/dcu.c (revision 83d290c56fab2d38cd1ab4c4cc7099559c1d5046)
1*83d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
2b4ecc8c6SWang Huan /*
3b4ecc8c6SWang Huan  * Copyright 2014 Freescale Semiconductor, Inc.
4b4ecc8c6SWang Huan  *
5b4ecc8c6SWang Huan  * FSL DCU Framebuffer driver
6b4ecc8c6SWang Huan  */
7b4ecc8c6SWang Huan 
8b4ecc8c6SWang Huan #include <common.h>
9b4ecc8c6SWang Huan #include <fsl_dcu_fb.h>
10b4ecc8c6SWang Huan #include "div64.h"
11b4ecc8c6SWang Huan #include "../common/dcu_sii9022a.h"
12b4ecc8c6SWang Huan 
13b4ecc8c6SWang Huan DECLARE_GLOBAL_DATA_PTR;
14b4ecc8c6SWang Huan 
dcu_set_pixel_clock(unsigned int pixclock)15b4ecc8c6SWang Huan unsigned int dcu_set_pixel_clock(unsigned int pixclock)
16b4ecc8c6SWang Huan {
17b4ecc8c6SWang Huan 	unsigned long long div;
18b4ecc8c6SWang Huan 
19b4ecc8c6SWang Huan 	div = (unsigned long long)(gd->bus_clk / 1000);
20b4ecc8c6SWang Huan 	div *= (unsigned long long)pixclock;
21b4ecc8c6SWang Huan 	do_div(div, 1000000000);
22b4ecc8c6SWang Huan 
23b4ecc8c6SWang Huan 	return div;
24b4ecc8c6SWang Huan }
25b4ecc8c6SWang Huan 
platform_dcu_init(unsigned int xres,unsigned int yres,const char * port,struct fb_videomode * dcu_fb_videomode)26b4ecc8c6SWang Huan int platform_dcu_init(unsigned int xres, unsigned int yres,
27b4ecc8c6SWang Huan 		      const char *port,
28b4ecc8c6SWang Huan 		      struct fb_videomode *dcu_fb_videomode)
29b4ecc8c6SWang Huan {
30b4ecc8c6SWang Huan 	const char *name;
31b4ecc8c6SWang Huan 	unsigned int pixel_format;
32b4ecc8c6SWang Huan 
33b4ecc8c6SWang Huan 	if (strncmp(port, "twr_lcd", 4) == 0) {
34b4ecc8c6SWang Huan 		name = "TWR_LCD_RGB card";
35b4ecc8c6SWang Huan 	} else {
36b4ecc8c6SWang Huan 		name = "HDMI";
37b4ecc8c6SWang Huan 		dcu_set_dvi_encoder(dcu_fb_videomode);
38b4ecc8c6SWang Huan 	}
39b4ecc8c6SWang Huan 
40b4ecc8c6SWang Huan 	printf("DCU: Switching to %s monitor @ %ux%u\n", name, xres, yres);
41b4ecc8c6SWang Huan 
42b4ecc8c6SWang Huan 	pixel_format = 32;
43b4ecc8c6SWang Huan 	fsl_dcu_init(xres, yres, pixel_format);
44b4ecc8c6SWang Huan 
45b4ecc8c6SWang Huan 	return 0;
46b4ecc8c6SWang Huan }
47