summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/sna/sna_display_fake.c47
1 files changed, 15 insertions, 32 deletions
diff --git a/src/sna/sna_display_fake.c b/src/sna/sna_display_fake.c
index 08214788..97c463c1 100644
--- a/src/sna/sna_display_fake.c
+++ b/src/sna/sna_display_fake.c
@@ -239,9 +239,8 @@ static bool add_fake_output(struct sna *sna, bool late)
xf86CrtcPtr crtc;
RROutputPtr clones[32];
RRCrtcPtr crtcs[32];
- unsigned mask;
char buf[80];
- int i, j, len;
+ int i, len;
if (sna->mode.num_fake >= 32)
return false;
@@ -264,6 +263,9 @@ static bool add_fake_output(struct sna *sna, bool late)
output->interlaceAllowed = FALSE;
output->subpixel_order = SubPixelNone;
+ output->possible_crtcs = ~((1 << sna->mode.num_real_crtc) - 1);
+ output->possible_clones = ~((1 << sna->mode.num_real_output) - 1);
+
if (late) {
ScreenPtr screen = xf86ScrnToScreen(scrn);
@@ -277,46 +279,27 @@ static bool add_fake_output(struct sna *sna, bool late)
RRPostPendingProperties(output->randr_output);
- mask = (1 << ++sna->mode.num_fake) - 1;
- for (i = j = 0; i < xf86_config->num_output; i++) {
- output = xf86_config->output[i];
- if (output->driver_private)
- continue;
-
- output->possible_crtcs = mask << sna->mode.num_real_crtc;
- output->possible_clones = mask << sna->mode.num_real_output;
-
- clones[j++] = output->randr_output;
- }
- assert(j == sna->mode.num_fake);
-
- for (i = j = 0; i < xf86_config->num_crtc; i++) {
- crtc = xf86_config->crtc[i];
- if (crtc->driver_private)
- continue;
+ for (i = sna->mode.num_real_output; i < xf86_config->num_output; i++)
+ clones[i - sna->mode.num_real_output] = xf86_config->output[i]->randr_output;
+ assert(i - sna->mode.num_real_output == sna->mode.num_fake + 1);
- crtcs[j++] = crtc->randr_crtc;
- }
- assert(j == sna->mode.num_fake);
+ for (i = sna->mode.num_real_crtc; i < xf86_config->num_crtc; i++)
+ crtcs[i - sna->mode.num_real_crtc] = xf86_config->crtc[i]->randr_crtc;
+ assert(i - sna->mode.num_real_crtc == sna->mode.num_fake + 1);
- for (i = 0; i < xf86_config->num_output; i++) {
- output = xf86_config->output[i];
- if (output->driver_private)
- continue;
+ for (i = sna->mode.num_real_output; i < xf86_config->num_output; i++) {
+ RROutputPtr rr_output = xf86_config->output[i]->randr_output;
- if (!RROutputSetCrtcs(output->randr_output, crtcs, j) ||
- !RROutputSetClones(output->randr_output, clones, j))
+ if (!RROutputSetCrtcs(rr_output, crtcs, sna->mode.num_fake + 1) ||
+ !RROutputSetClones(rr_output, clones, sna->mode.num_fake + 1))
goto err;
}
RRCrtcSetRotations(crtc->randr_crtc,
RR_Rotate_All | RR_Reflect_All);
- } else {
- mask = (1 << ++sna->mode.num_fake) - 1;
- output->possible_crtcs = mask << sna->mode.num_real_crtc;
- output->possible_clones = mask << sna->mode.num_real_output;
}
+ sna->mode.num_fake++;
return true;
err: