提交 06a33079 编写于 作者: T Tomi Valkeinen

videomode: combine videomode dmt_flags and data_flags

Both videomode and display_timing contain flags describing the modes.
These are stored in dmt_flags and data_flags. There's no need to
separate these flags, and having separate fields just makes the flags
more difficult to use.

This patch combines the fields and renames VESA_DMT_* flags to
DISPLAY_FLAGS_*.
Signed-off-by: NTomi Valkeinen <tomi.valkeinen@ti.com>
Cc: Steffen Trumtrar <s.trumtrar@pengutronix.de>
上级 a38884f6
...@@ -523,17 +523,17 @@ int drm_display_mode_from_videomode(const struct videomode *vm, ...@@ -523,17 +523,17 @@ int drm_display_mode_from_videomode(const struct videomode *vm,
dmode->clock = vm->pixelclock / 1000; dmode->clock = vm->pixelclock / 1000;
dmode->flags = 0; dmode->flags = 0;
if (vm->dmt_flags & VESA_DMT_HSYNC_HIGH) if (vm->flags & DISPLAY_FLAGS_HSYNC_HIGH)
dmode->flags |= DRM_MODE_FLAG_PHSYNC; dmode->flags |= DRM_MODE_FLAG_PHSYNC;
else if (vm->dmt_flags & VESA_DMT_HSYNC_LOW) else if (vm->flags & DISPLAY_FLAGS_HSYNC_LOW)
dmode->flags |= DRM_MODE_FLAG_NHSYNC; dmode->flags |= DRM_MODE_FLAG_NHSYNC;
if (vm->dmt_flags & VESA_DMT_VSYNC_HIGH) if (vm->flags & DISPLAY_FLAGS_VSYNC_HIGH)
dmode->flags |= DRM_MODE_FLAG_PVSYNC; dmode->flags |= DRM_MODE_FLAG_PVSYNC;
else if (vm->dmt_flags & VESA_DMT_VSYNC_LOW) else if (vm->flags & DISPLAY_FLAGS_VSYNC_LOW)
dmode->flags |= DRM_MODE_FLAG_NVSYNC; dmode->flags |= DRM_MODE_FLAG_NVSYNC;
if (vm->data_flags & DISPLAY_FLAGS_INTERLACED) if (vm->flags & DISPLAY_FLAGS_INTERLACED)
dmode->flags |= DRM_MODE_FLAG_INTERLACE; dmode->flags |= DRM_MODE_FLAG_INTERLACE;
if (vm->data_flags & DISPLAY_FLAGS_DOUBLESCAN) if (vm->flags & DISPLAY_FLAGS_DOUBLESCAN)
dmode->flags |= DRM_MODE_FLAG_DBLSCAN; dmode->flags |= DRM_MODE_FLAG_DBLSCAN;
drm_mode_set_name(dmode); drm_mode_set_name(dmode);
......
...@@ -1398,13 +1398,13 @@ int fb_videomode_from_videomode(const struct videomode *vm, ...@@ -1398,13 +1398,13 @@ int fb_videomode_from_videomode(const struct videomode *vm,
fbmode->sync = 0; fbmode->sync = 0;
fbmode->vmode = 0; fbmode->vmode = 0;
if (vm->dmt_flags & VESA_DMT_HSYNC_HIGH) if (vm->flags & DISPLAY_FLAGS_HSYNC_HIGH)
fbmode->sync |= FB_SYNC_HOR_HIGH_ACT; fbmode->sync |= FB_SYNC_HOR_HIGH_ACT;
if (vm->dmt_flags & VESA_DMT_HSYNC_HIGH) if (vm->flags & DISPLAY_FLAGS_HSYNC_HIGH)
fbmode->sync |= FB_SYNC_VERT_HIGH_ACT; fbmode->sync |= FB_SYNC_VERT_HIGH_ACT;
if (vm->data_flags & DISPLAY_FLAGS_INTERLACED) if (vm->flags & DISPLAY_FLAGS_INTERLACED)
fbmode->vmode |= FB_VMODE_INTERLACED; fbmode->vmode |= FB_VMODE_INTERLACED;
if (vm->data_flags & DISPLAY_FLAGS_DOUBLESCAN) if (vm->flags & DISPLAY_FLAGS_DOUBLESCAN)
fbmode->vmode |= FB_VMODE_DOUBLE; fbmode->vmode |= FB_VMODE_DOUBLE;
fbmode->flag = 0; fbmode->flag = 0;
......
...@@ -79,25 +79,24 @@ static struct display_timing *of_get_display_timing(struct device_node *np) ...@@ -79,25 +79,24 @@ static struct display_timing *of_get_display_timing(struct device_node *np)
ret |= parse_timing_property(np, "vsync-len", &dt->vsync_len); ret |= parse_timing_property(np, "vsync-len", &dt->vsync_len);
ret |= parse_timing_property(np, "clock-frequency", &dt->pixelclock); ret |= parse_timing_property(np, "clock-frequency", &dt->pixelclock);
dt->dmt_flags = 0; dt->flags = 0;
dt->data_flags = 0;
if (!of_property_read_u32(np, "vsync-active", &val)) if (!of_property_read_u32(np, "vsync-active", &val))
dt->dmt_flags |= val ? VESA_DMT_VSYNC_HIGH : dt->flags |= val ? DISPLAY_FLAGS_VSYNC_HIGH :
VESA_DMT_VSYNC_LOW; DISPLAY_FLAGS_VSYNC_LOW;
if (!of_property_read_u32(np, "hsync-active", &val)) if (!of_property_read_u32(np, "hsync-active", &val))
dt->dmt_flags |= val ? VESA_DMT_HSYNC_HIGH : dt->flags |= val ? DISPLAY_FLAGS_HSYNC_HIGH :
VESA_DMT_HSYNC_LOW; DISPLAY_FLAGS_HSYNC_LOW;
if (!of_property_read_u32(np, "de-active", &val)) if (!of_property_read_u32(np, "de-active", &val))
dt->data_flags |= val ? DISPLAY_FLAGS_DE_HIGH : dt->flags |= val ? DISPLAY_FLAGS_DE_HIGH :
DISPLAY_FLAGS_DE_LOW; DISPLAY_FLAGS_DE_LOW;
if (!of_property_read_u32(np, "pixelclk-active", &val)) if (!of_property_read_u32(np, "pixelclk-active", &val))
dt->data_flags |= val ? DISPLAY_FLAGS_PIXDATA_POSEDGE : dt->flags |= val ? DISPLAY_FLAGS_PIXDATA_POSEDGE :
DISPLAY_FLAGS_PIXDATA_NEGEDGE; DISPLAY_FLAGS_PIXDATA_NEGEDGE;
if (of_property_read_bool(np, "interlaced")) if (of_property_read_bool(np, "interlaced"))
dt->data_flags |= DISPLAY_FLAGS_INTERLACED; dt->flags |= DISPLAY_FLAGS_INTERLACED;
if (of_property_read_bool(np, "doublescan")) if (of_property_read_bool(np, "doublescan"))
dt->data_flags |= DISPLAY_FLAGS_DOUBLESCAN; dt->flags |= DISPLAY_FLAGS_DOUBLESCAN;
if (ret) { if (ret) {
pr_err("%s: error reading timing properties\n", pr_err("%s: error reading timing properties\n",
......
...@@ -31,8 +31,7 @@ int videomode_from_timing(const struct display_timings *disp, ...@@ -31,8 +31,7 @@ int videomode_from_timing(const struct display_timings *disp,
vm->vback_porch = display_timing_get_value(&dt->vback_porch, TE_TYP); vm->vback_porch = display_timing_get_value(&dt->vback_porch, TE_TYP);
vm->vsync_len = display_timing_get_value(&dt->vsync_len, TE_TYP); vm->vsync_len = display_timing_get_value(&dt->vsync_len, TE_TYP);
vm->dmt_flags = dt->dmt_flags; vm->flags = dt->flags;
vm->data_flags = dt->data_flags;
return 0; return 0;
} }
......
...@@ -12,19 +12,16 @@ ...@@ -12,19 +12,16 @@
#include <linux/bitops.h> #include <linux/bitops.h>
#include <linux/types.h> #include <linux/types.h>
/* VESA display monitor timing parameters */ #define DISPLAY_FLAGS_HSYNC_LOW BIT(0)
#define VESA_DMT_HSYNC_LOW BIT(0) #define DISPLAY_FLAGS_HSYNC_HIGH BIT(1)
#define VESA_DMT_HSYNC_HIGH BIT(1) #define DISPLAY_FLAGS_VSYNC_LOW BIT(2)
#define VESA_DMT_VSYNC_LOW BIT(2) #define DISPLAY_FLAGS_VSYNC_HIGH BIT(3)
#define VESA_DMT_VSYNC_HIGH BIT(3) #define DISPLAY_FLAGS_DE_LOW BIT(4) /* data enable flag */
#define DISPLAY_FLAGS_DE_HIGH BIT(5)
/* display specific flags */ #define DISPLAY_FLAGS_PIXDATA_POSEDGE BIT(6) /* drive data on pos. edge */
#define DISPLAY_FLAGS_DE_LOW BIT(0) /* data enable flag */ #define DISPLAY_FLAGS_PIXDATA_NEGEDGE BIT(7) /* drive data on neg. edge */
#define DISPLAY_FLAGS_DE_HIGH BIT(1) #define DISPLAY_FLAGS_INTERLACED BIT(8)
#define DISPLAY_FLAGS_PIXDATA_POSEDGE BIT(2) /* drive data on pos. edge */ #define DISPLAY_FLAGS_DOUBLESCAN BIT(9)
#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 * A single signal can be specified via a range of minimal and maximal values
...@@ -72,8 +69,7 @@ struct display_timing { ...@@ -72,8 +69,7 @@ struct display_timing {
struct timing_entry vback_porch; /* ver. back porch */ struct timing_entry vback_porch; /* ver. back porch */
struct timing_entry vsync_len; /* ver. sync len */ struct timing_entry vsync_len; /* ver. sync len */
unsigned int dmt_flags; /* VESA DMT flags */ unsigned int flags; /* display flags */
unsigned int data_flags; /* video data flags */
}; };
/* /*
......
...@@ -29,8 +29,7 @@ struct videomode { ...@@ -29,8 +29,7 @@ struct videomode {
u32 vback_porch; u32 vback_porch;
u32 vsync_len; u32 vsync_len;
unsigned int dmt_flags; /* VESA DMT flags */ unsigned int flags; /* display flags */
unsigned int data_flags; /* video data flags */
}; };
/** /**
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册