blob: 8b12e60b61736b62cfa5dc1b2dd989b26efec5f1 [file] [log] [blame]
Steffen Trumtrar8714c0c2012-12-17 14:20:17 +01001/*
2 * Copyright 2012 Steffen Trumtrar <s.trumtrar@pengutronix.de>
3 *
4 * generic videomode description
5 *
6 * This file is released under the GPLv2
7 */
8
9#ifndef __LINUX_VIDEOMODE_H
10#define __LINUX_VIDEOMODE_H
11
12#include <linux/types.h>
13#include <video/display_timing.h>
14
15/*
16 * Subsystem independent description of a videomode.
17 * Can be generated from struct display_timing.
18 */
19struct videomode {
20 unsigned long pixelclock; /* pixelclock in Hz */
21
22 u32 hactive;
23 u32 hfront_porch;
24 u32 hback_porch;
25 u32 hsync_len;
26
27 u32 vactive;
28 u32 vfront_porch;
29 u32 vback_porch;
30 u32 vsync_len;
31
Tomi Valkeinen32ed6ef2013-03-12 10:31:29 +020032 enum display_flags flags; /* display flags */
Steffen Trumtrar8714c0c2012-12-17 14:20:17 +010033};
34
35/**
36 * videomode_from_timing - convert display timing to videomode
37 * @disp: structure with all possible timing entries
38 * @vm: return value
39 * @index: index into the list of display timings in devicetree
40 *
41 * DESCRIPTION:
42 * This function converts a struct display_timing to a struct videomode.
43 */
44int videomode_from_timing(const struct display_timings *disp,
45 struct videomode *vm, unsigned int index);
46
47#endif