blob: e4fbcbcaad359755a8a7e9bef7bd133cdbfc41f9 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Feng Li39e112d2016-11-03 14:15:17 +08002/*
3 * Copyright 2016 Freescale Semiconductor, Inc.
4 *
5 * FSL DCU Framebuffer driver
Feng Li39e112d2016-11-03 14:15:17 +08006 */
7
8#include <common.h>
9#include <fsl_dcu_fb.h>
Simon Glass3ba929a2020-10-30 21:38:53 -060010#include <asm/global_data.h>
Feng Li39e112d2016-11-03 14:15:17 +080011#include "div64.h"
12#include "../common/dcu_sii9022a.h"
13
14DECLARE_GLOBAL_DATA_PTR;
15
16unsigned int dcu_set_pixel_clock(unsigned int pixclock)
17{
18 unsigned long long div;
19
20 div = (unsigned long long)(gd->bus_clk / 1000);
21 div *= (unsigned long long)pixclock;
22 do_div(div, 1000000000);
23
24 return div;
25}
26
Igor Opaniuk9a0270f2019-06-10 14:47:49 +030027int platform_dcu_init(struct fb_info *fbinfo,
28 unsigned int xres, unsigned int yres,
29 const char *port,
30 struct fb_videomode *dcu_fb_videomode)
Feng Li39e112d2016-11-03 14:15:17 +080031{
32 const char *name;
33 unsigned int pixel_format;
34
35 if (strncmp(port, "twr_lcd", 4) == 0) {
36 name = "TWR_LCD_RGB card";
37 } else {
38 name = "HDMI";
39 dcu_set_dvi_encoder(dcu_fb_videomode);
40 }
41
42 printf("DCU: Switching to %s monitor @ %ux%u\n", name, xres, yres);
43
44 pixel_format = 32;
Igor Opaniuk9a0270f2019-06-10 14:47:49 +030045 fsl_dcu_init(fbinfo, xres, yres, pixel_format);
Feng Li39e112d2016-11-03 14:15:17 +080046
47 return 0;
48}