diff options
Diffstat (limited to 'osl19x.patch')
-rw-r--r-- | osl19x.patch | 399 |
1 files changed, 399 insertions, 0 deletions
diff --git a/osl19x.patch b/osl19x.patch new file mode 100644 index 000000000000..63697938b19e --- /dev/null +++ b/osl19x.patch @@ -0,0 +1,399 @@ +From 56aa72bc1922652dba8539f5a305a175619d68aa Mon Sep 17 00:00:00 2001 +From: Brecht Van Lommel <brechtvanlommel@gmail.com> +Date: Fri, 26 Oct 2018 19:26:06 +0200 +Subject: [PATCH 1/4] Fix T57393: Cycles OSL bevel and AO not working after OSL + upgrade. + +--- + intern/cycles/kernel/osl/osl_services.cpp | 28 +++++++++++++++++++++-- + intern/cycles/kernel/osl/osl_services.h | 7 +++++- + 2 files changed, 32 insertions(+), 3 deletions(-) + +diff --git a/intern/cycles/kernel/osl/osl_services.cpp b/intern/cycles/kernel/osl/osl_services.cpp +index 1535496c73d..f54d18d5e38 100644 +--- a/intern/cycles/kernel/osl/osl_services.cpp ++++ b/intern/cycles/kernel/osl/osl_services.cpp +@@ -900,6 +900,23 @@ bool OSLRenderServices::has_userdata(ustring name, TypeDesc type, OSL::ShaderGlo + return false; /* never called by OSL */ + } + ++TextureSystem::TextureHandle *OSLRenderServices::get_texture_handle(ustring filename) ++{ ++ if (filename.length() && filename[0] == '@') { ++ /* Dummy, we don't use texture handles for builtin textures but need ++ * to tell the OSL runtime optimizer that this is a valid texture. */ ++ return NULL; ++ } ++ else { ++ return texturesys()->get_texture_handle(filename); ++ } ++} ++ ++bool OSLRenderServices::good(TextureSystem::TextureHandle *texture_handle) ++{ ++ return texturesys()->good(texture_handle); ++} ++ + bool OSLRenderServices::texture(ustring filename, + TextureHandle *texture_handle, + TexturePerthread *texture_thread_info, +@@ -910,7 +927,8 @@ bool OSLRenderServices::texture(ustring filename, + int nchannels, + float *result, + float *dresultds, +- float *dresultdt) ++ float *dresultdt, ++ ustring *errormessage) + { + OSL::TextureSystem *ts = osl_ts; + ShaderData *sd = (ShaderData *)(sg->renderstate); +@@ -1131,7 +1149,13 @@ bool OSLRenderServices::get_texture_info(OSL::ShaderGlobals *sg, ustring filenam + TypeDesc datatype, void *data) + { + OSL::TextureSystem *ts = osl_ts; +- return ts->get_texture_info(filename, subimage, dataname, datatype, data); ++ if (filename.length() && filename[0] == '@') { ++ /* Special builtin textures. */ ++ return false; ++ } ++ else { ++ return ts->get_texture_info(filename, subimage, dataname, datatype, data); ++ } + } + + int OSLRenderServices::pointcloud_search(OSL::ShaderGlobals *sg, ustring filename, const OSL::Vec3 ¢er, +diff --git a/intern/cycles/kernel/osl/osl_services.h b/intern/cycles/kernel/osl/osl_services.h +index ec34ca77115..8b47342c9d3 100644 +--- a/intern/cycles/kernel/osl/osl_services.h ++++ b/intern/cycles/kernel/osl/osl_services.h +@@ -93,6 +93,10 @@ public: + bool getmessage(OSL::ShaderGlobals *sg, ustring source, ustring name, + TypeDesc type, void *val, bool derivatives); + ++ TextureSystem::TextureHandle *get_texture_handle(ustring filename); ++ ++ bool good(TextureSystem::TextureHandle *texture_handle); ++ + bool texture(ustring filename, + TextureSystem::TextureHandle *texture_handle, + TexturePerthread *texture_thread_info, +@@ -103,7 +107,8 @@ public: + int nchannels, + float *result, + float *dresultds, +- float *dresultdt); ++ float *dresultdt, ++ ustring *errormessage); + + bool texture3d(ustring filename, + TextureHandle *texture_handle, +-- +2.32.0 + + +From 4f6171e877777306f9394e239c1e6edea72af93d Mon Sep 17 00:00:00 2001 +From: Sergey Sharybin <sergey.vfx@gmail.com> +Date: Fri, 9 Nov 2018 12:08:51 +0100 +Subject: [PATCH 2/4] Cycles: Cleanup, space after (void) + +It was used in like 95% of places. +--- + intern/cycles/kernel/osl/osl_services.cpp | 4 ++-- + 1 file changed, 2 insertions(+), 2 deletions(-) + +diff --git a/intern/cycles/kernel/osl/osl_services.cpp b/intern/cycles/kernel/osl/osl_services.cpp +index f54d18d5e38..a1aa6c6b978 100644 +--- a/intern/cycles/kernel/osl/osl_services.cpp ++++ b/intern/cycles/kernel/osl/osl_services.cpp +@@ -1028,7 +1028,7 @@ bool OSLRenderServices::texture(ustring filename, + * other nasty stuff happening. + */ + string err = ts->geterror(); +- (void)err; ++ (void) err; + } + + return status; +@@ -1107,7 +1107,7 @@ bool OSLRenderServices::texture3d(ustring filename, + * other nasty stuff happening. + */ + string err = ts->geterror(); +- (void)err; ++ (void) err; + } + + return status; +-- +2.32.0 + + +From cbcfbd8bb23f5ef6636dc94668ee6cfa5b3f11cb Mon Sep 17 00:00:00 2001 +From: Sergey Sharybin <sergey.vfx@gmail.com> +Date: Thu, 15 Nov 2018 17:16:40 +0100 +Subject: [PATCH 3/4] Cycles: Cleanup, code style + +--- + intern/cycles/kernel/osl/osl_services.cpp | 4 ++-- + 1 file changed, 2 insertions(+), 2 deletions(-) + +diff --git a/intern/cycles/kernel/osl/osl_services.cpp b/intern/cycles/kernel/osl/osl_services.cpp +index a1aa6c6b978..c35f240837f 100644 +--- a/intern/cycles/kernel/osl/osl_services.cpp ++++ b/intern/cycles/kernel/osl/osl_services.cpp +@@ -902,7 +902,7 @@ bool OSLRenderServices::has_userdata(ustring name, TypeDesc type, OSL::ShaderGlo + + TextureSystem::TextureHandle *OSLRenderServices::get_texture_handle(ustring filename) + { +- if (filename.length() && filename[0] == '@') { ++ if(filename.length() && filename[0] == '@') { + /* Dummy, we don't use texture handles for builtin textures but need + * to tell the OSL runtime optimizer that this is a valid texture. */ + return NULL; +@@ -1149,7 +1149,7 @@ bool OSLRenderServices::get_texture_info(OSL::ShaderGlobals *sg, ustring filenam + TypeDesc datatype, void *data) + { + OSL::TextureSystem *ts = osl_ts; +- if (filename.length() && filename[0] == '@') { ++ if(filename.length() && filename[0] == '@') { + /* Special builtin textures. */ + return false; + } +-- +2.32.0 + + +From ba0ff934b30a9f89a2827fcfb60e5f2eca5f7f72 Mon Sep 17 00:00:00 2001 +From: Brecht Van Lommel <brechtvanlommel@gmail.com> +Date: Wed, 2 Jan 2019 19:55:26 +0100 +Subject: [PATCH 4/4] Fix T60061: Cycles OSL point density not working. + +Add override keywords so we can detect when the function definitions change. +--- + intern/cycles/kernel/osl/osl_services.cpp | 50 +++++++++------ + intern/cycles/kernel/osl/osl_services.h | 77 ++++++++++++++--------- + 2 files changed, 78 insertions(+), 49 deletions(-) + +diff --git a/intern/cycles/kernel/osl/osl_services.cpp b/intern/cycles/kernel/osl/osl_services.cpp +index c35f240837f..51938d330d5 100644 +--- a/intern/cycles/kernel/osl/osl_services.cpp ++++ b/intern/cycles/kernel/osl/osl_services.cpp +@@ -895,11 +895,6 @@ bool OSLRenderServices::get_userdata(bool derivatives, ustring name, TypeDesc ty + return false; /* disabled by lockgeom */ + } + +-bool OSLRenderServices::has_userdata(ustring name, TypeDesc type, OSL::ShaderGlobals *sg) +-{ +- return false; /* never called by OSL */ +-} +- + TextureSystem::TextureHandle *OSLRenderServices::get_texture_handle(ustring filename) + { + if(filename.length() && filename[0] == '@') { +@@ -1047,7 +1042,8 @@ bool OSLRenderServices::texture3d(ustring filename, + float *result, + float *dresultds, + float *dresultdt, +- float *dresultdr) ++ float *dresultdr, ++ ustring *errormessage) + { + OSL::TextureSystem *ts = osl_ts; + ShaderData *sd = (ShaderData *)(sg->renderstate); +@@ -1113,22 +1109,36 @@ bool OSLRenderServices::texture3d(ustring filename, + return status; + } + +-bool OSLRenderServices::environment(ustring filename, TextureOpt &options, +- OSL::ShaderGlobals *sg, const OSL::Vec3 &R, +- const OSL::Vec3 &dRdx, const OSL::Vec3 &dRdy, +- int nchannels, float *result) ++bool OSLRenderServices::environment(ustring filename, ++ TextureHandle *th, ++ TexturePerthread *thread_info, ++ TextureOpt &options, ++ OSL::ShaderGlobals *sg, ++ const OSL::Vec3 &R, ++ const OSL::Vec3 &dRdx, ++ const OSL::Vec3 &dRdy, ++ int nchannels, ++ float *result, ++ float *dresultds, ++ float *dresultdt, ++ ustring *errormessage) + { + OSL::TextureSystem *ts = osl_ts; +- ShaderData *sd = (ShaderData *)(sg->renderstate); +- KernelGlobals *kg = sd->osl_globals; +- OSLThreadData *tdata = kg->osl_tdata; +- OIIO::TextureSystem::Perthread *thread_info = tdata->oiio_thread_info; + +- OIIO::TextureSystem::TextureHandle *th = ts->get_texture_handle(filename, thread_info); ++ if (thread_info == NULL) { ++ ShaderData *sd = (ShaderData *)(sg->renderstate); ++ KernelGlobals *kg = sd->osl_globals; ++ OSLThreadData *tdata = kg->osl_tdata; ++ thread_info = tdata->oiio_thread_info; ++ } ++ ++ if (th == NULL) { ++ th = ts->get_texture_handle(filename, thread_info); ++ } + + bool status = ts->environment(th, thread_info, + options, R, dRdx, dRdy, +- nchannels, result); ++ nchannels, result, dresultds, dresultdt); + + if(!status) { + if(nchannels == 3 || nchannels == 4) { +@@ -1144,9 +1154,13 @@ bool OSLRenderServices::environment(ustring filename, TextureOpt &options, + return status; + } + +-bool OSLRenderServices::get_texture_info(OSL::ShaderGlobals *sg, ustring filename, int subimage, ++bool OSLRenderServices::get_texture_info(OSL::ShaderGlobals *sg, ++ ustring filename, ++ TextureHandle *th, ++ int subimage, + ustring dataname, +- TypeDesc datatype, void *data) ++ TypeDesc datatype, ++ void *data) + { + OSL::TextureSystem *ts = osl_ts; + if(filename.length() && filename[0] == '@') { +diff --git a/intern/cycles/kernel/osl/osl_services.h b/intern/cycles/kernel/osl/osl_services.h +index 8b47342c9d3..9e58a1c5c45 100644 +--- a/intern/cycles/kernel/osl/osl_services.h ++++ b/intern/cycles/kernel/osl/osl_services.h +@@ -45,57 +45,57 @@ class OSLRenderServices : public OSL::RendererServices + public: + OSLRenderServices(); + ~OSLRenderServices(); +- ++ + void thread_init(KernelGlobals *kernel_globals, OSL::TextureSystem *ts); + +- bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform, float time); +- bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform, float time); +- +- bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring from, float time); +- bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring to, float time); +- +- bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform); +- bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform); +- +- bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring from); +- bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring from); ++ bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform, float time) override; ++ bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform, float time) override; ++ ++ bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring from, float time) override; ++ bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring to, float time) override; ++ ++ bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform) override; ++ bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, OSL::TransformationPtr xform) override; ++ ++ bool get_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring from) override; ++ bool get_inverse_matrix(OSL::ShaderGlobals *sg, OSL::Matrix44 &result, ustring from) override; + + bool get_array_attribute(OSL::ShaderGlobals *sg, bool derivatives, + ustring object, TypeDesc type, ustring name, +- int index, void *val); ++ int index, void *val) override; + bool get_attribute(OSL::ShaderGlobals *sg, bool derivatives, ustring object, +- TypeDesc type, ustring name, void *val); ++ TypeDesc type, ustring name, void *val) override; + bool get_attribute(ShaderData *sd, bool derivatives, ustring object_name, + TypeDesc type, ustring name, void *val); + + bool get_userdata(bool derivatives, ustring name, TypeDesc type, +- OSL::ShaderGlobals *sg, void *val); ++ OSL::ShaderGlobals *sg, void *val) override; + bool has_userdata(ustring name, TypeDesc type, OSL::ShaderGlobals *sg); + + int pointcloud_search(OSL::ShaderGlobals *sg, ustring filename, const OSL::Vec3 ¢er, + float radius, int max_points, bool sort, size_t *out_indices, +- float *out_distances, int derivs_offset); ++ float *out_distances, int derivs_offset) override; + + int pointcloud_get(OSL::ShaderGlobals *sg, ustring filename, size_t *indices, int count, +- ustring attr_name, TypeDesc attr_type, void *out_data); ++ ustring attr_name, TypeDesc attr_type, void *out_data) override; + + bool pointcloud_write(OSL::ShaderGlobals *sg, + ustring filename, const OSL::Vec3 &pos, + int nattribs, const ustring *names, + const TypeDesc *types, +- const void **data); ++ const void **data) override; + + bool trace(TraceOpt &options, OSL::ShaderGlobals *sg, + const OSL::Vec3 &P, const OSL::Vec3 &dPdx, + const OSL::Vec3 &dPdy, const OSL::Vec3 &R, +- const OSL::Vec3 &dRdx, const OSL::Vec3 &dRdy); ++ const OSL::Vec3 &dRdx, const OSL::Vec3 &dRdy) override; + + bool getmessage(OSL::ShaderGlobals *sg, ustring source, ustring name, +- TypeDesc type, void *val, bool derivatives); ++ TypeDesc type, void *val, bool derivatives) override; + + TextureSystem::TextureHandle *get_texture_handle(ustring filename); + +- bool good(TextureSystem::TextureHandle *texture_handle); ++ bool good(TextureSystem::TextureHandle *texture_handle) override; + + bool texture(ustring filename, + TextureSystem::TextureHandle *texture_handle, +@@ -108,7 +108,7 @@ public: + float *result, + float *dresultds, + float *dresultdt, +- ustring *errormessage); ++ ustring *errormessage) override; + + bool texture3d(ustring filename, + TextureHandle *texture_handle, +@@ -123,15 +123,30 @@ public: + float *result, + float *dresultds, + float *dresultdt, +- float *dresultdr); +- +- bool environment(ustring filename, TextureOpt &options, +- OSL::ShaderGlobals *sg, const OSL::Vec3 &R, +- const OSL::Vec3 &dRdx, const OSL::Vec3 &dRdy, +- int nchannels, float *result); +- +- bool get_texture_info(OSL::ShaderGlobals *sg, ustring filename, int subimage, +- ustring dataname, TypeDesc datatype, void *data); ++ float *dresultdr, ++ ustring *errormessage) override; ++ ++ bool environment(ustring filename, ++ TextureHandle *texture_handle, ++ TexturePerthread *texture_thread_info, ++ TextureOpt &options, ++ OSL::ShaderGlobals *sg, ++ const OSL::Vec3 &R, ++ const OSL::Vec3 &dRdx, ++ const OSL::Vec3 &dRdy, ++ int nchannels, ++ float *result, ++ float *dresultds, ++ float *dresultdt, ++ ustring *errormessage) override; ++ ++ bool get_texture_info(OSL::ShaderGlobals *sg, ++ ustring filename, ++ TextureHandle *texture_handle, ++ int subimage, ++ ustring dataname, ++ TypeDesc datatype, ++ void *data); + + static bool get_background_attribute(KernelGlobals *kg, ShaderData *sd, ustring name, + TypeDesc type, bool derivatives, void *val); +-- +2.32.0 + |