123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- /*
- * Copyright 2012 Steffen Trumtrar <s.trumtrar@pengutronix.de>
- *
- * description of display timings
- *
- * This file is released under the GPLv2
- */
- #ifndef __LINUX_DISPLAY_TIMING_H
- #define __LINUX_DISPLAY_TIMING_H
- #include <linux/bitops.h>
- #include <linux/types.h>
- /* VESA display monitor timing parameters */
- #define VESA_DMT_HSYNC_LOW BIT(0)
- #define VESA_DMT_HSYNC_HIGH BIT(1)
- #define VESA_DMT_VSYNC_LOW BIT(2)
- #define VESA_DMT_VSYNC_HIGH BIT(3)
- /* display specific flags */
- #define DISPLAY_FLAGS_DE_LOW BIT(0) /* data enable flag */
- #define DISPLAY_FLAGS_DE_HIGH BIT(1)
- #define DISPLAY_FLAGS_PIXDATA_POSEDGE BIT(2) /* drive data on pos. edge */
- #define DISPLAY_FLAGS_PIXDATA_NEGEDGE BIT(3) /* drive data on neg. edge */
- #define DISPLAY_FLAGS_INTERLACED BIT(4)
- #define DISPLAY_FLAGS_DOUBLESCAN BIT(5)
- /*
- * A single signal can be specified via a range of minimal and maximal values
- * with a typical value, that lies somewhere inbetween.
- */
- struct timing_entry {
- u32 min;
- u32 typ;
- u32 max;
- };
- enum timing_entry_index {
- TE_MIN = 0,
- TE_TYP = 1,
- TE_MAX = 2,
- };
- /*
- * Single "mode" entry. This describes one set of signal timings a display can
- * have in one setting. This struct can later be converted to struct videomode
- * (see include/video/videomode.h). As each timing_entry can be defined as a
- * range, one struct display_timing may become multiple struct videomodes.
- *
- * Example: hsync active high, vsync active low
- *
- * Active Video
- * Video ______________________XXXXXXXXXXXXXXXXXXXXXX_____________________
- * |<- sync ->|<- back ->|<----- active ----->|<- front ->|<- sync..
- * | | porch | | porch |
- *
- * HSync _|¯¯¯¯¯¯¯¯¯¯|___________________________________________|¯¯¯¯¯¯¯¯¯
- *
- * VSync ¯|__________|¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯|_________
- */
- struct display_timing {
- struct timing_entry pixelclock;
- struct timing_entry hactive; /* hor. active video */
- struct timing_entry hfront_porch; /* hor. front porch */
- struct timing_entry hback_porch; /* hor. back porch */
- struct timing_entry hsync_len; /* hor. sync len */
- struct timing_entry vactive; /* ver. active video */
- struct timing_entry vfront_porch; /* ver. front porch */
- struct timing_entry vback_porch; /* ver. back porch */
- struct timing_entry vsync_len; /* ver. sync len */
- unsigned int dmt_flags; /* VESA DMT flags */
- unsigned int data_flags; /* video data flags */
- };
- /*
- * This describes all timing settings a display provides.
- * The native_mode is the default setting for this display.
- * Drivers that can handle multiple videomodes should work with this struct and
- * convert each entry to the desired end result.
- */
- struct display_timings {
- unsigned int num_timings;
- unsigned int native_mode;
- struct display_timing **timings;
- };
- /* get value specified by index from struct timing_entry */
- static inline u32 display_timing_get_value(const struct timing_entry *te,
- enum timing_entry_index index)
- {
- switch (index) {
- case TE_MIN:
- return te->min;
- break;
- case TE_TYP:
- return te->typ;
- break;
- case TE_MAX:
- return te->max;
- break;
- default:
- return te->typ;
- }
- }
- /* get one entry from struct display_timings */
- static inline struct display_timing *display_timings_get(const struct
- display_timings *disp,
- unsigned int index)
- {
- if (disp->num_timings > index)
- return disp->timings[index];
- else
- return NULL;
- }
- void display_timings_release(struct display_timings *disp);
- #endif
|