7d7aa2fd92
This change makes the names of Broadcom targets consistent by using the common notation based on SoC/CPU ID (which is used internally anyway), bcmXXXX instead of brcmXXXX. This is even used for target TITLE in make menuconfig already, only the short target name used brcm so far. Despite, since subtargets range from bcm2708 to bcm2711, it seems appropriate to use bcm27xx instead of bcm2708 (again, as already done for BOARDNAME). This also renames the packages brcm2708-userland and brcm2708-gpu-fw. Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de> Acked-by: Álvaro Fernández Rojas <noltari@gmail.com>
63 lines
2.2 KiB
Diff
63 lines
2.2 KiB
Diff
From 82ef7a95f5ae86df811253d58d93ca4fb2cbd45a Mon Sep 17 00:00:00 2001
|
|
From: Dave Stevenson <dave.stevenson@raspberrypi.org>
|
|
Date: Fri, 24 May 2019 17:59:01 +0100
|
|
Subject: [PATCH] drm/vc4: Support the VEC in FKMS
|
|
|
|
Extends the DPI/DSI support to also report the VEC output
|
|
which supports interlacing too.
|
|
|
|
Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.org>
|
|
---
|
|
drivers/gpu/drm/vc4/vc4_firmware_kms.c | 16 +++++++++++++++-
|
|
1 file changed, 15 insertions(+), 1 deletion(-)
|
|
|
|
--- a/drivers/gpu/drm/vc4/vc4_firmware_kms.c
|
|
+++ b/drivers/gpu/drm/vc4/vc4_firmware_kms.c
|
|
@@ -125,6 +125,7 @@ struct set_timings {
|
|
#define TIMINGS_FLAGS_H_SYNC_NEG 0
|
|
#define TIMINGS_FLAGS_V_SYNC_POS BIT(1)
|
|
#define TIMINGS_FLAGS_V_SYNC_NEG 0
|
|
+#define TIMINGS_FLAGS_INTERLACE BIT(2)
|
|
|
|
#define TIMINGS_FLAGS_ASPECT_MASK GENMASK(7, 4)
|
|
#define TIMINGS_FLAGS_ASPECT_NONE (0 << 4)
|
|
@@ -1047,6 +1048,12 @@ static int vc4_fkms_lcd_connector_get_mo
|
|
fw_mode.flags |= DRM_MODE_FLAG_PVSYNC;
|
|
else
|
|
fw_mode.flags |= DRM_MODE_FLAG_NVSYNC;
|
|
+ if (mb.timings.flags & TIMINGS_FLAGS_V_SYNC_POS)
|
|
+ fw_mode.flags |= DRM_MODE_FLAG_PVSYNC;
|
|
+ else
|
|
+ fw_mode.flags |= DRM_MODE_FLAG_NVSYNC;
|
|
+ if (mb.timings.flags & TIMINGS_FLAGS_INTERLACE)
|
|
+ fw_mode.flags |= DRM_MODE_FLAG_INTERLACE;
|
|
|
|
fw_mode.base.type = DRM_MODE_OBJECT_MODE;
|
|
|
|
@@ -1133,17 +1140,24 @@ vc4_fkms_connector_init(struct drm_devic
|
|
DRM_MODE_CONNECTOR_DSI);
|
|
drm_connector_helper_add(connector,
|
|
&vc4_fkms_lcd_conn_helper_funcs);
|
|
+ connector->interlace_allowed = 0;
|
|
+ } else if (fkms_connector->display_type == DRM_MODE_ENCODER_TVDAC) {
|
|
+ drm_connector_init(dev, connector, &vc4_fkms_connector_funcs,
|
|
+ DRM_MODE_CONNECTOR_Composite);
|
|
+ drm_connector_helper_add(connector,
|
|
+ &vc4_fkms_lcd_conn_helper_funcs);
|
|
+ connector->interlace_allowed = 1;
|
|
} else {
|
|
drm_connector_init(dev, connector, &vc4_fkms_connector_funcs,
|
|
DRM_MODE_CONNECTOR_HDMIA);
|
|
drm_connector_helper_add(connector,
|
|
&vc4_fkms_connector_helper_funcs);
|
|
+ connector->interlace_allowed = 0;
|
|
}
|
|
|
|
connector->polled = (DRM_CONNECTOR_POLL_CONNECT |
|
|
DRM_CONNECTOR_POLL_DISCONNECT);
|
|
|
|
- connector->interlace_allowed = 0;
|
|
connector->doublescan_allowed = 0;
|
|
|
|
drm_connector_attach_encoder(connector, encoder);
|