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