Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrecht Van Lommel <brechtvanlommel@gmail.com>2017-12-26 01:43:55 +0300
committerBrecht Van Lommel <brechtvanlommel@gmail.com>2017-12-26 01:59:20 +0300
commit948515c21a6ee6253eebb2359a95182e21696a84 (patch)
treed9cb0b2a8c4d80570c9116b00afc544fe68f0286 /intern/cycles/kernel/svm/svm.h
parente8e92dffed05f86ffea2f378e115285a105d6fd4 (diff)
Fix T53600: Cycles shader mixing issue with principled BSDF and zero weights.
SVM nodes need to read all data to get the right offset for the following node. This is quite weak, a more generic solution would be good in the future.
Diffstat (limited to 'intern/cycles/kernel/svm/svm.h')
-rw-r--r--intern/cycles/kernel/svm/svm.h8
1 files changed, 2 insertions, 6 deletions
diff --git a/intern/cycles/kernel/svm/svm.h b/intern/cycles/kernel/svm/svm.h
index 9ff02c1586b..d3dac5706d0 100644
--- a/intern/cycles/kernel/svm/svm.h
+++ b/intern/cycles/kernel/svm/svm.h
@@ -211,9 +211,7 @@ ccl_device_noinline void svm_eval_nodes(KernelGlobals *kg, ShaderData *sd, ccl_a
break;
}
case NODE_CLOSURE_BSDF:
- if(type == SHADER_TYPE_SURFACE) {
- svm_node_closure_bsdf(kg, sd, stack, node, path_flag, &offset);
- }
+ svm_node_closure_bsdf(kg, sd, stack, node, type, path_flag, &offset);
break;
case NODE_CLOSURE_EMISSION:
svm_node_closure_emission(sd, stack, node);
@@ -331,9 +329,7 @@ ccl_device_noinline void svm_eval_nodes(KernelGlobals *kg, ShaderData *sd, ccl_a
break;
# if NODES_FEATURE(NODE_FEATURE_VOLUME)
case NODE_CLOSURE_VOLUME:
- if(type == SHADER_TYPE_VOLUME) {
- svm_node_closure_volume(kg, sd, stack, node, path_flag);
- }
+ svm_node_closure_volume(kg, sd, stack, node, type, path_flag);
break;
# endif /* NODES_FEATURE(NODE_FEATURE_VOLUME) */
# ifdef __EXTRA_NODES__