summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVito Caputo <vcaputo@pengaru.com>2019-11-24 13:26:23 -0800
committerVito Caputo <vcaputo@pengaru.com>2019-11-24 13:28:29 -0800
commitb0675254fbc1a134e1fbb9af23c71a8c3e032ed7 (patch)
tree2a38979db6cebd36470d1ab6cefefefcce76c31b
parentcc1dea6ec94aad181c05c157ca679c5dc1c1004d (diff)
montage: skip pixbounce
Segfaults were observed when montage came up in rtv, since pixbounce doesn't seem to be rendering properly at all just skip it for now. I suspect what's happening is rtv ran pixbounce before running montage, and pixbounce caches fragment knowledge @ initialization. So when montage ran pixbounce in a tile, that stale fragment knowledge was used and caused scribbling. Stars probably has similar problems actually.
-rw-r--r--src/modules/montage/montage.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/modules/montage/montage.c b/src/modules/montage/montage.c
index 068c6e0..5502bae 100644
--- a/src/modules/montage/montage.c
+++ b/src/modules/montage/montage.c
@@ -12,6 +12,7 @@
typedef struct montage_context_t {
const rototiller_module_t **modules;
const rototiller_module_t *rtv_module;
+ const rototiller_module_t *pixbounce_module;
void **contexts;
size_t n_modules;
unsigned n_cpus;
@@ -46,6 +47,10 @@ static int skip_module(montage_context_t *ctxt, const rototiller_module_t *modul
if (module == ctxt->rtv_module)
return 1;
+ /* pixbounce is broken */
+ if (module == ctxt->pixbounce_module)
+ return 1;
+
return 0;
}
@@ -65,6 +70,7 @@ static void * montage_create_context(unsigned num_cpus)
}
ctxt->rtv_module = rototiller_lookup_module("rtv");
+ ctxt->pixbounce_module = rototiller_lookup_module("pixbounce");
for (int i = 0; i < ctxt->n_modules; i++) {
const rototiller_module_t *module = ctxt->modules[i];
© All Rights Reserved