{
        struct dpu_encoder_phys *phys_enc = NULL;
        struct dpu_encoder_irq *irq;
-       int i, ret = 0;
+       int i;
 
        if (!p) {
-               ret = -EINVAL;
-               goto fail;
+               DPU_ERROR("failed to create encoder due to invalid parameter\n");
+               return ERR_PTR(-EINVAL);
        }
 
        phys_enc = kzalloc(sizeof(*phys_enc), GFP_KERNEL);
        if (!phys_enc) {
-               ret = -ENOMEM;
-               goto fail;
+               DPU_ERROR("failed to create encoder due to memory allocation error\n");
+               return ERR_PTR(-ENOMEM);
        }
 
        phys_enc->hw_mdptop = p->dpu_kms->hw_mdp;
        DPU_DEBUG_VIDENC(phys_enc, "created intf idx:%d\n", p->intf_idx);
 
        return phys_enc;
-
-fail:
-       DPU_ERROR("failed to create encoder\n");
-       if (phys_enc)
-               dpu_encoder_phys_vid_destroy(phys_enc);
-
-       return ERR_PTR(ret);
 }