|
@@ -28,8 +28,9 @@ struct rcar_du_device;
|
|
|
struct rcar_du_lvdsenc;
|
|
|
|
|
|
#define RCAR_DU_FEATURE_CRTC_IRQ_CLOCK (1 << 0) /* Per-CRTC IRQ and clock */
|
|
|
-#define RCAR_DU_FEATURE_ALIGN_128B (1 << 1) /* Align pitches to 128 bytes */
|
|
|
-#define RCAR_DU_FEATURE_DEFR8 (1 << 2) /* Has DEFR8 register */
|
|
|
+#define RCAR_DU_FEATURE_DEFR8 (1 << 1) /* Has DEFR8 register */
|
|
|
+
|
|
|
+#define RCAR_DU_QUIRK_ALIGN_128B (1 << 0) /* Align pitches to 128 bytes */
|
|
|
|
|
|
/*
|
|
|
* struct rcar_du_output_routing - Output routing specification
|
|
@@ -48,12 +49,14 @@ struct rcar_du_output_routing {
|
|
|
/*
|
|
|
* struct rcar_du_device_info - DU model-specific information
|
|
|
* @features: device features (RCAR_DU_FEATURE_*)
|
|
|
+ * @quirks: device quirks (RCAR_DU_QUIRK_*)
|
|
|
* @num_crtcs: total number of CRTCs
|
|
|
* @routes: array of CRTC to output routes, indexed by output (RCAR_DU_OUTPUT_*)
|
|
|
* @num_lvds: number of internal LVDS encoders
|
|
|
*/
|
|
|
struct rcar_du_device_info {
|
|
|
unsigned int features;
|
|
|
+ unsigned int quirks;
|
|
|
unsigned int num_crtcs;
|
|
|
struct rcar_du_output_routing routes[RCAR_DU_OUTPUT_MAX];
|
|
|
unsigned int num_lvds;
|
|
@@ -84,6 +87,12 @@ static inline bool rcar_du_has(struct rcar_du_device *rcdu,
|
|
|
return rcdu->info->features & feature;
|
|
|
}
|
|
|
|
|
|
+static inline bool rcar_du_needs(struct rcar_du_device *rcdu,
|
|
|
+ unsigned int quirk)
|
|
|
+{
|
|
|
+ return rcdu->info->quirks & quirk;
|
|
|
+}
|
|
|
+
|
|
|
static inline u32 rcar_du_read(struct rcar_du_device *rcdu, u32 reg)
|
|
|
{
|
|
|
return ioread32(rcdu->mmio + reg);
|