[arch-commits] Commit in blender/trunk (4 files)

Sven-Hendrik Haase svenstaro at archlinux.org
Sat Jun 9 12:45:07 UTC 2018


    Date: Saturday, June 9, 2018 @ 12:45:05
  Author: svenstaro
Revision: 342169

upgpkg: blender 17:2.79.b.git3.32432d91-1

Rebuild actual release version with a ton of patches

Added:
  blender/trunk/openvdb3-abi.patch
  blender/trunk/tree_hpp.patch
  blender/trunk/util_sseb.patch
Modified:
  blender/trunk/PKGBUILD

--------------------+
 PKGBUILD           |   25 ++++--
 openvdb3-abi.patch |   28 +++++++
 tree_hpp.patch     |  183 +++++++++++++++++++++++++++++++++++++++++++++++++++
 util_sseb.patch    |   13 +++
 4 files changed, 241 insertions(+), 8 deletions(-)

Modified: PKGBUILD
===================================================================
--- PKGBUILD	2018-06-09 11:27:21 UTC (rev 342168)
+++ PKGBUILD	2018-06-09 12:45:05 UTC (rev 342169)
@@ -12,12 +12,12 @@
 # unreasonable.
 
 # _gittag=v2.79b
-_gitcommit=0385b33f0b3e389ea2a82c4b6bb181c684f0511a
+_gitcommit=32432d91bbec558cbd88e54aece61b0d641c1761
 
 pkgname=blender
 pkgver=2.79.b
-[[ -n $_gitcommit ]] && pkgver=${pkgver}.git2.${_gitcommit:0:8}
-pkgrel=16
+[[ -n $_gitcommit ]] && pkgver=${pkgver}.git3.${_gitcommit:0:8}
+pkgrel=1
 epoch=17
 pkgdesc="A fully integrated 3D graphics creation suite"
 arch=('x86_64')
@@ -35,7 +35,11 @@
         "git://git.blender.org/blender-addons-contrib.git"
         "git://git.blender.org/blender-translations.git"
         "git://git.blender.org/blender-dev-tools.git"
-        "git://git.blender.org/scons.git")
+        "git://git.blender.org/scons.git"
+        ffmpeg4.0.patch
+        tree_hpp.patch
+        util_sseb.patch
+        openvdb3-abi.patch)
 if [[ -n $_gittag ]]; then
     source+=("${pkgname}-${pkgver}::git://git.blender.org/blender.git#tag=${_gittag}")
 elif [[ -n $_gitcommit ]]; then
@@ -46,6 +50,10 @@
          'SKIP'
          'SKIP'
          'SKIP'
+         'da14d7cbdea1ab5499659a066658cdd2'
+         'feea89510de171946c41c6208461f453'
+         '53da216adbc2a9d555a59c15b8f0ef08'
+         '3f9613fcb7ea61214982272e9c20a294'
          'SKIP')
 
 prepare() {
@@ -59,8 +67,10 @@
   git config submodule."scons".url ${srcdir}/scons
   git submodule update
 
-  # Fix installation of modules
-  sed -i "144i\ \ \ \ pass" release/scripts/addons_contrib/np_station/np_point_dimension.py
+  patch -Np1 -i "$srcdir"/ffmpeg4.0.patch
+  patch -Np1 -i "$srcdir"/tree_hpp.patch
+  patch -Np1 -i "$srcdir"/util_sseb.patch
+  patch -Np1 -i "$srcdir"/openvdb3-abi.patch
 }
 
 build() {
@@ -69,8 +79,6 @@
   [[ -d build ]] && rm -rf build
   mkdir build && cd build
 
-  export CFLAGS="${CFLAGS} -DOPENVDB_3_ABI_COMPATIBLE"
-  export CXXFLAGS="${CXXFLAGS} -DOPENVDB_3_ABI_COMPATIBLE"
   cmake -C../build_files/cmake/config/blender_release.cmake .. \
     -DCMAKE_INSTALL_PREFIX=/usr \
     -DCMAKE_BUILD_TYPE=Release \
@@ -83,6 +91,7 @@
     -DWITH_LLVM=ON \
     -DWITH_CYCLES_CUDA_BINARIES=ON \
     -DWITH_CYCLES_PTEX=OFF \
+    -DCYCLES_CUDA_BINARIES_ARCH="sm_30;sm_35;sm_37;sm_50;sm_52;sm_60;sm_61;sm_62;sm_70" \
     -DPYTHON_VERSION=3.6 \
     -DPYTHON_LIBPATH=/usr/lib \
     -DPYTHON_LIBRARY=python3.6m \

Added: openvdb3-abi.patch
===================================================================
--- openvdb3-abi.patch	                        (rev 0)
+++ openvdb3-abi.patch	2018-06-09 12:45:05 UTC (rev 342169)
@@ -0,0 +1,28 @@
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index bfea2dd1a97..c59aff4c62c 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -252,6 +252,10 @@ option(WITH_OPENSUBDIV    "Enable OpenSubdiv for surface subdivision" _init_OPEN
+ option(WITH_OPENVDB       "Enable features relying on OpenVDB" OFF)
+ option(WITH_OPENVDB_BLOSC "Enable blosc compression for OpenVDB, only enable if OpenVDB was built with blosc support" OFF)
+ 
++if(WITH_OPENVDB)
++    add_definitions(-DOPENVDB_3_ABI_COMPATIBLE=TRUE)
++endif()
++
+ # GHOST Windowing Library Options
+ option(WITH_GHOST_DEBUG   "Enable debugging output for the GHOST library" OFF)
+ mark_as_advanced(WITH_GHOST_DEBUG)
+diff --git a/intern/openvdb/intern/openvdb_writer.cc b/intern/openvdb/intern/openvdb_writer.cc
+index e886c5a76a8..bedcfe65552 100644
+--- a/intern/openvdb/intern/openvdb_writer.cc
++++ b/intern/openvdb/intern/openvdb_writer.cc
+@@ -45,7 +45,7 @@ void OpenVDBWriter::insert(const openvdb::GridBase::Ptr &grid)
+ 
+ void OpenVDBWriter::insert(const openvdb::GridBase &grid)
+ {
+-#if (OPENVDB_LIBRARY_MAJOR_VERSION_NUMBER == 3)
++#if (OPENVDB_LIBRARY_MAJOR_VERSION_NUMBER <= 3) || defined(OPENVDB_3_ABI_COMPATIBLE)
+ 	m_grids->push_back(grid.copyGrid());
+ #else
+ 	m_grids->push_back(grid.copyGridWithNewTree());

Added: tree_hpp.patch
===================================================================
--- tree_hpp.patch	                        (rev 0)
+++ tree_hpp.patch	2018-06-09 12:45:05 UTC (rev 342169)
@@ -0,0 +1,183 @@
+diff --git a/intern/itasc/kdl/tree.hpp b/intern/itasc/kdl/tree.hpp
+index c8a253fc901..bd35f82d185 100644
+--- a/intern/itasc/kdl/tree.hpp
++++ b/intern/itasc/kdl/tree.hpp
+@@ -1,177 +1,177 @@
+ // Copyright  (C)  2007  Ruben Smits <ruben dot smits at mech dot kuleuven dot be>
+ 
+ // Version: 1.0
+ // Author: Ruben Smits <ruben dot smits at mech dot kuleuven dot be>
+ // Maintainer: Ruben Smits <ruben dot smits at mech dot kuleuven dot be>
+ // URL: http://www.orocos.org/kdl
+ 
+ // This library is free software; you can redistribute it and/or
+ // modify it under the terms of the GNU Lesser General Public
+ // License as published by the Free Software Foundation; either
+ // version 2.1 of the License, or (at your option) any later version.
+ 
+ // This library is distributed in the hope that it will be useful,
+ // but WITHOUT ANY WARRANTY; without even the implied warranty of
+ // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ // Lesser General Public License for more details.
+ 
+ // You should have received a copy of the GNU Lesser General Public
+ // License along with this library; if not, write to the Free Software
+ // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ 
+ #ifndef KDL_TREE_HPP
+ #define KDL_TREE_HPP
+ 
+ #include "segment.hpp"
+ #include "chain.hpp"
+ 
+ #include <string>
+ #include <map>
+ #include <Eigen/Core>
+ 
+ namespace KDL
+ {
+     //Forward declaration
+     class TreeElement;
+     // Eigen allocator is needed for alignment of Eigen data types
+-    typedef std::map<std::string,TreeElement, std::less<std::string>, Eigen::aligned_allocator<std::pair<std::string, TreeElement> > > SegmentMap;
++    typedef std::map<std::string,TreeElement, std::less<std::string>, Eigen::aligned_allocator<std::pair<const std::string, TreeElement> > > SegmentMap;
+ 
+     class TreeElement
+     {
+     public:
+         TreeElement():q_nr(0),parent(0)
+         {};
+     public:
+         Segment segment;
+         unsigned int q_nr;
+         SegmentMap::value_type const *parent;
+         std::vector<SegmentMap::const_iterator > children;
+         TreeElement(const Segment& segment_in,const SegmentMap::value_type& parent_in,unsigned int q_nr_in)
+         {
+ 			q_nr=q_nr_in;
+             segment=segment_in;
+             parent=&parent_in;
+         };
+         static TreeElement Root()
+         {
+             return TreeElement();
+         };
+     };
+ 
+     /**
+      * \brief  This class encapsulates a <strong>tree</strong>
+      * kinematic interconnection structure. It is build out of segments.
+      *
+      * @ingroup KinematicFamily
+      */
+     class Tree
+     {
+     private:
+         SegmentMap segments;
+         unsigned int nrOfJoints;
+         unsigned int nrOfSegments;
+ 
+         bool addTreeRecursive(SegmentMap::const_iterator root, const std::string& tree_name, const std::string& hook_name);
+ 
+     public:
+         /**
+          * The constructor of a tree, a new tree is always empty
+          */
+         Tree();
+         Tree(const Tree& in);
+         Tree& operator= (const Tree& arg);
+ 
+         /**
+          * Adds a new segment to the end of the segment with
+          * hook_name as segment_name
+          *
+          * @param segment new segment to add
+          * @param segment_name name of the new segment
+          * @param hook_name name of the segment to connect this
+          * segment with.
+          *
+          * @return false if hook_name could not be found.
+          */
+         bool addSegment(const Segment& segment, const std::string& segment_name, const std::string& hook_name);
+ 
+         /**
+          * Adds a complete chain to the end of the segment with
+          * hook_name as segment_name. Segment i of
+          * the chain will get chain_name+".Segment"+i as segment_name.
+          *
+          * @param chain Chain to add
+          * @param chain_name name of the chain
+          * @param hook_name name of the segment to connect the chain with.
+          *
+          * @return false if hook_name could not be found.
+          */
+         bool addChain(const Chain& chain, const std::string& chain_name, const std::string& hook_name);
+ 
+         /**
+          * Adds a complete tree to the end of the segment with
+          * hookname as segment_name. The segments of the tree will get
+          * tree_name+segment_name as segment_name.
+          *
+          * @param tree Tree to add
+          * @param tree_name name of the tree
+          * @param hook_name name of the segment to connect the tree with
+          *
+          * @return false if hook_name could not be found
+          */
+         bool addTree(const Tree& tree, const std::string& tree_name,const std::string& hook_name);
+ 
+         /**
+          * Request the total number of joints in the tree.\n
+          * <strong> Important:</strong> It is not the same as the
+          * total number of segments since a segment does not need to have
+          * a joint.
+          *
+          * @return total nr of joints
+          */
+         unsigned int getNrOfJoints()const
+         {
+             return nrOfJoints;
+         };
+ 
+         /**
+          * Request the total number of segments in the tree.
+          * @return total number of segments
+          */
+         unsigned int getNrOfSegments()const {return nrOfSegments;};
+ 
+         /**
+          * Request the segment of the tree with name segment_name.
+          *
+          * @param segment_name the name of the requested segment
+          *
+          * @return constant iterator pointing to the requested segment
+          */
+         SegmentMap::const_iterator getSegment(const std::string& segment_name)const
+         {
+             return segments.find(segment_name);
+         };
+ 
+         SegmentMap::value_type const* getSegmentPtr(const std::string& segment_name)const
+         {
+             SegmentMap::const_iterator it = segments.find(segment_name);
+             
+             if (it == segments.end())
+                 return 0;
+ 
+             return &*it;
+         };
+ 
+         const SegmentMap& getSegments()const
+         {
+             return segments;
+         }
+ 
+         virtual ~Tree(){};
+     };
+ }
+ #endif
+ 
+ 
+ 
+ 
+ 

Added: util_sseb.patch
===================================================================
--- util_sseb.patch	                        (rev 0)
+++ util_sseb.patch	2018-06-09 12:45:05 UTC (rev 342169)
@@ -0,0 +1,13 @@
+diff --git a/intern/cycles/util/util_sseb.h b/intern/cycles/util/util_sseb.h
+index 6e669701f3b..9ffe391666a 100644
+--- a/intern/cycles/util/util_sseb.h
++++ b/intern/cycles/util/util_sseb.h
+@@ -116,7 +116,7 @@ __forceinline const sseb unpacklo( const sseb& a, const sseb& b ) { return _mm_u
+ __forceinline const sseb unpackhi( const sseb& a, const sseb& b ) { return _mm_unpackhi_ps(a, b); }
+ 
+ template<size_t i0, size_t i1, size_t i2, size_t i3> __forceinline const sseb shuffle( const sseb& a ) {
+-	return _mm_shuffle_epi32(a, _MM_SHUFFLE(i3, i2, i1, i0));
++	return _mm_castsi128_ps(_mm_shuffle_epi32(a, _MM_SHUFFLE(i3, i2, i1, i0)));
+ }
+ 
+ template<> __forceinline const sseb shuffle<0, 1, 0, 1>( const sseb& a ) {



More information about the arch-commits mailing list