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:
Diffstat (limited to 'intern/cycles/kernel/svm/svm_closure.h')
-rw-r--r--intern/cycles/kernel/svm/svm_closure.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/intern/cycles/kernel/svm/svm_closure.h b/intern/cycles/kernel/svm/svm_closure.h
index 9a9aefa5b29..6d9c4e215e6 100644
--- a/intern/cycles/kernel/svm/svm_closure.h
+++ b/intern/cycles/kernel/svm/svm_closure.h
@@ -337,6 +337,46 @@ __device void svm_node_closure_bsdf(KernelGlobals *kg, ShaderData *sd, float *st
}
break;
}
+#ifdef __HAIR__
+ case CLOSURE_BSDF_HAIR_REFLECTION_ID:
+ case CLOSURE_BSDF_HAIR_TRANSMISSION_ID: {
+
+ if(sd->flag & SD_BACKFACING && sd->segment != ~0) {
+ ShaderClosure *sc = svm_node_closure_get_bsdf(sd, mix_weight);
+ if(sc) {
+ sc->weight = make_float3(1.0f,1.0f,1.0f);
+ sc->N = N;
+ sd->flag |= bsdf_transparent_setup(sc);
+ }
+ }
+ else {
+ ShaderClosure *sc = &sd->closure[sd->num_closure];
+ sc = svm_node_closure_get_bsdf(sd, mix_weight);
+
+ if(sc) {
+ sc->N = N;
+ sc->data0 = param1;
+ sc->data1 = param2;
+ sc->offset = -stack_load_float(stack, data_node.z);
+ if(sd->segment == ~0) {
+ sc->T = normalize(sd->dPdv);
+ sc->offset = 0.0f;
+ }
+ else
+ sc->T = sd->dPdu;
+ if(type == CLOSURE_BSDF_HAIR_REFLECTION_ID) {
+ sd->flag |= bsdf_hair_reflection_setup(sc);
+ }
+ else {
+ sd->flag |= bsdf_hair_transmission_setup(sc);
+ }
+ }
+ }
+
+ break;
+ }
+#endif
+
#ifdef __SUBSURFACE__
case CLOSURE_BSSRDF_COMPATIBLE_ID:
case CLOSURE_BSSRDF_CUBIC_ID: