dorcr |= DORCR_PG1T | DORCR_DK1S | DORCR_PG1D_DS1;
        rcar_du_group_write(rgrp, DORCR, dorcr);
 
-       /* Apply planes to CRTCs association. */
-       mutex_lock(&rgrp->lock);
-       rcar_du_group_write(rgrp, DPTSR, (rgrp->dptsr_planes << 16) |
-                           rgrp->dptsr_planes);
-       mutex_unlock(&rgrp->lock);
+       /*
+        * DPTSR is used to select the source for the planes of a group. The
+        * first source is chosen by writing 0 to the respective bits, and this
+        * is always the default value of the register. In other words, writing
+        * DPTSR is only needed if the SoC supports choosing the second source.
+        *
+        * The SoCs documentations seems to confirm this, as the DPTSR register
+        * is not documented if only the first source exists on that SoC.
+        */
+       if (rgrp->channels_mask & BIT(1)) {
+               mutex_lock(&rgrp->lock);
+               rcar_du_group_write(rgrp, DPTSR, (rgrp->dptsr_planes << 16) |
+                                   rgrp->dptsr_planes);
+               mutex_unlock(&rgrp->lock);
+       }
 }
 
 /*