Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f36e7f71 authored by qctecmdr's avatar qctecmdr Committed by Gerrit - the friendly Code Review server
Browse files

Merge "drm: sde: Remove feature support for IGC/3D LUT for virtual planes"

parents f32cb6cf 47ecefa4
Loading
Loading
Loading
Loading
+21 −5
Original line number Diff line number Diff line
@@ -1023,10 +1023,16 @@ static void sde_hw_sspp_setup_uidle(struct sde_hw_pipe *ctx,
}

static void _setup_layer_ops_colorproc(struct sde_hw_pipe *c,
		unsigned long features)
		unsigned long features, bool is_virtual_pipe)
{
	int ret = 0;

	if (is_virtual_pipe) {
		features &=
			~(BIT(SDE_SSPP_VIG_IGC) | BIT(SDE_SSPP_VIG_GAMUT));
		c->cap->features = features;
	}

	if (test_bit(SDE_SSPP_HSIC, &features)) {
		if (c->cap->sblk->hsic_blk.version ==
			(SDE_COLOR_PROCESS_VER(0x1, 0x7))) {
@@ -1181,7 +1187,8 @@ static void sde_hw_sspp_setup_dgm_csc(struct sde_hw_pipe *ctx,
}

static void _setup_layer_ops(struct sde_hw_pipe *c,
		unsigned long features, unsigned long perf_features)
		unsigned long features, unsigned long perf_features,
		bool is_virtual_pipe)
{
	int ret;

@@ -1247,7 +1254,7 @@ static void _setup_layer_ops(struct sde_hw_pipe *c,
	if (test_bit(SDE_PERF_SSPP_UIDLE, &perf_features))
		c->ops.setup_uidle = sde_hw_sspp_setup_uidle;

	_setup_layer_ops_colorproc(c, features);
	_setup_layer_ops_colorproc(c, features, is_virtual_pipe);

	if (test_bit(SDE_SSPP_DGM_INVERSE_PMA, &features))
		c->ops.setup_inverse_pma = sde_hw_sspp_setup_dgm_inverse_pma;
@@ -1264,6 +1271,7 @@ static struct sde_sspp_cfg *_sspp_offset(enum sde_sspp sspp,
		struct sde_hw_blk_reg_map *b)
{
	int i;
	struct sde_sspp_cfg *cfg;

	if ((sspp < SSPP_MAX) && catalog && addr && b) {
		for (i = 0; i < catalog->sspp_count; i++) {
@@ -1273,7 +1281,14 @@ static struct sde_sspp_cfg *_sspp_offset(enum sde_sspp sspp,
				b->length = catalog->sspp[i].len;
				b->hwversion = catalog->hwversion;
				b->log_mask = SDE_DBG_MASK_SSPP;
				return &catalog->sspp[i];

				/* Only shallow copy is needed */
				cfg =  kmemdup(&catalog->sspp[i], sizeof(*cfg),
					GFP_KERNEL);
				if (!cfg)
					return ERR_PTR(-ENOMEM);

				return cfg;
			}
		}
	}
@@ -1313,7 +1328,7 @@ struct sde_hw_pipe *sde_hw_sspp_init(enum sde_sspp idx,
	hw_pipe->idx = idx;
	hw_pipe->cap = cfg;
	_setup_layer_ops(hw_pipe, hw_pipe->cap->features,
		hw_pipe->cap->perf_features);
		hw_pipe->cap->perf_features, is_virtual_pipe);

	if (hw_pipe->ops.get_scaler_ver) {
		sde_init_scaler_blk(&hw_pipe->cap->sblk->scaler_blk,
@@ -1353,6 +1368,7 @@ void sde_hw_sspp_destroy(struct sde_hw_pipe *ctx)
	if (ctx) {
		sde_hw_blk_destroy(&ctx->base);
		reg_dmav1_deinit_sspp_ops(ctx->idx);
		kfree(ctx->cap);
	}
	kfree(ctx);
}