]> git.ipfire.org Git - thirdparty/u-boot.git/blame - drivers/video/am335x-fb.h
SPDX: Convert all of our single license tags to Linux Kernel style
[thirdparty/u-boot.git] / drivers / video / am335x-fb.h
CommitLineData
83d290c5 1/* SPDX-License-Identifier: GPL-2.0+ */
3c5fabd1 2/*
e880a5e2
HS
3 * Copyright (C) 2013-2018 Hannes Schmelzer <oe5hpm@oevsv.at> -
4 * B&R Industrial Automation GmbH - http://www.br-automation.com
3c5fabd1
HP
5 */
6
7#ifndef AM335X_FB_H
8#define AM335X_FB_H
9
10#define HSVS_CONTROL (0x01 << 25) /*
11 * 0 = lcd_lp and lcd_fp are driven on
12 * opposite edges of pixel clock than
13 * the lcd_pixel_o
14 * 1 = lcd_lp and lcd_fp are driven
15 * according to bit 24 Note that this
16 * bit MUST be set to '0' for Passive
17 * Matrix displays the edge timing is
18 * fixed
19 */
20#define HSVS_RISEFALL (0x01 << 24) /*
21 * 0 = lcd_lp and lcd_fp are driven on
22 * the rising edge of pixel clock (bit
23 * 25 must be set to 1)
24 * 1 = lcd_lp and lcd_fp are driven on
25 * the falling edge of pixel clock (bit
26 * 25 must be set to 1)
27 */
28#define DE_INVERT (0x01 << 23) /*
29 * 0 = DE is low-active
30 * 1 = DE is high-active
31 */
32#define PXCLK_INVERT (0x01 << 22) /*
33 * 0 = pix-clk is high-active
34 * 1 = pic-clk is low-active
35 */
36#define HSYNC_INVERT (0x01 << 21) /*
37 * 0 = HSYNC is active high
38 * 1 = HSYNC is avtive low
39 */
40#define VSYNC_INVERT (0x01 << 20) /*
41 * 0 = VSYNC is active high
42 * 1 = VSYNC is active low
43 */
44
45struct am335x_lcdpanel {
46 unsigned int hactive; /* Horizontal active area */
47 unsigned int vactive; /* Vertical active area */
48 unsigned int bpp; /* bits per pixel */
49 unsigned int hfp; /* Horizontal front porch */
50 unsigned int hbp; /* Horizontal back porch */
51 unsigned int hsw; /* Horizontal Sync Pulse Width */
52 unsigned int vfp; /* Vertical front porch */
53 unsigned int vbp; /* Vertical back porch */
54 unsigned int vsw; /* Vertical Sync Pulse Width */
8a094f50 55 unsigned int pxl_clk; /* Pixel clock */
3c5fabd1 56 unsigned int pol; /* polarity of sync, clock signals */
3b4e16eb
HP
57 unsigned int pup_delay; /*
58 * time in ms after power on to
59 * initialization of lcd-controller
60 * (VCC ramp up time)
61 */
3c5fabd1 62 unsigned int pon_delay; /*
3b4e16eb
HP
63 * time in ms after initialization of
64 * lcd-controller (pic stabilization)
3c5fabd1
HP
65 */
66 void (*panel_power_ctrl)(int); /* fp for power on/off display */
67};
68
69int am335xfb_init(struct am335x_lcdpanel *panel);
70
71#endif /* AM335X_FB_H */