llviewerjointmesh_sse.cpp
上传用户:king477883
上传日期:2021-03-01
资源大小:9553k
文件大小:4k
源码类别:

游戏引擎

开发平台:

C++ Builder

  1. /** 
  2.  * @file llviewerjointmesh_sse.cpp
  3.  * @brief SSE vectorized joint skinning code, only used when video card does
  4.  * not support avatar vertex programs.
  5.  *
  6.  * *NOTE: Disabled on Windows builds. See llv4math.h for details.
  7.  *
  8.  * $LicenseInfo:firstyear=2007&license=viewergpl$
  9.  * 
  10.  * Copyright (c) 2007-2010, Linden Research, Inc.
  11.  * 
  12.  * Second Life Viewer Source Code
  13.  * The source code in this file ("Source Code") is provided by Linden Lab
  14.  * to you under the terms of the GNU General Public License, version 2.0
  15.  * ("GPL"), unless you have obtained a separate licensing agreement
  16.  * ("Other License"), formally executed by you and Linden Lab.  Terms of
  17.  * the GPL can be found in doc/GPL-license.txt in this distribution, or
  18.  * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
  19.  * 
  20.  * There are special exceptions to the terms and conditions of the GPL as
  21.  * it is applied to this Source Code. View the full text of the exception
  22.  * in the file doc/FLOSS-exception.txt in this software distribution, or
  23.  * online at
  24.  * http://secondlifegrid.net/programs/open_source/licensing/flossexception
  25.  * 
  26.  * By copying, modifying or distributing this software, you acknowledge
  27.  * that you have read and understood your obligations described above,
  28.  * and agree to abide by those obligations.
  29.  * 
  30.  * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
  31.  * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
  32.  * COMPLETENESS OR PERFORMANCE.
  33.  * $/LicenseInfo$
  34.  */
  35. //-----------------------------------------------------------------------------
  36. // Header Files
  37. //-----------------------------------------------------------------------------
  38. #include "llviewerprecompiledheaders.h"
  39. #include "llviewerjointmesh.h"
  40. // project includes
  41. #include "llface.h"
  42. #include "llpolymesh.h"
  43. // library includes
  44. #include "lldarray.h"
  45. #include "llv4math.h" // for LL_VECTORIZE
  46. #include "llv4matrix3.h"
  47. #include "llv4matrix4.h"
  48. #include "v3math.h"
  49. #if LL_VECTORIZE
  50. inline void matrix_translate(LLV4Matrix4& m, const LLMatrix4* w, const LLVector3& j)
  51. {
  52. m.mV[VX] = _mm_loadu_ps(w->mMatrix[VX]);
  53. m.mV[VY] = _mm_loadu_ps(w->mMatrix[VY]);
  54. m.mV[VZ] = _mm_loadu_ps(w->mMatrix[VZ]);
  55. m.mV[VW] = _mm_loadu_ps(w->mMatrix[VW]);
  56. m.mV[VW] = _mm_add_ps(m.mV[VW], _mm_mul_ps(_mm_set1_ps(j.mV[VX]), m.mV[VX])); // ( ax * vx ) + vw
  57. m.mV[VW] = _mm_add_ps(m.mV[VW], _mm_mul_ps(_mm_set1_ps(j.mV[VY]), m.mV[VY]));
  58. m.mV[VW] = _mm_add_ps(m.mV[VW], _mm_mul_ps(_mm_set1_ps(j.mV[VZ]), m.mV[VZ]));
  59. }
  60. // static
  61. void LLViewerJointMesh::updateGeometrySSE(LLFace *face, LLPolyMesh *mesh)
  62. {
  63. // This cannot be a file-level static because it will be initialized
  64. // before main() using SSE code, which will crash on non-SSE processors.
  65. static LLV4Matrix4 sJointMat[32];
  66. LLDynamicArray<LLJointRenderData*>& joint_data = mesh->getReferenceMesh()->mJointRenderData;
  67. //upload joint pivots/matrices
  68. for(S32 j = 0, jend = joint_data.count(); j < jend ; ++j )
  69. {
  70. matrix_translate(sJointMat[j], joint_data[j]->mWorldMatrix,
  71. joint_data[j]->mSkinJoint ?
  72. joint_data[j]->mSkinJoint->mRootToJointSkinOffset
  73. : joint_data[j+1]->mSkinJoint->mRootToParentJointSkinOffset);
  74. }
  75. F32 weight = F32_MAX;
  76. LLV4Matrix4 blend_mat;
  77. LLStrider<LLVector3> o_vertices;
  78. LLStrider<LLVector3> o_normals;
  79. LLVertexBuffer *buffer = face->mVertexBuffer;
  80. buffer->getVertexStrider(o_vertices,  mesh->mFaceVertexOffset);
  81. buffer->getNormalStrider(o_normals,   mesh->mFaceVertexOffset);
  82. const F32* weights = mesh->getWeights();
  83. const LLVector3* coords = mesh->getCoords();
  84. const LLVector3* normals = mesh->getNormals();
  85. for (U32 index = 0, index_end = mesh->getNumVertices(); index < index_end; ++index)
  86. {
  87. if( weight != weights[index])
  88. {
  89. S32 joint = llfloor(weight = weights[index]);
  90. blend_mat.lerp(sJointMat[joint], sJointMat[joint+1], weight - joint);
  91. }
  92. blend_mat.multiply(coords[index], o_vertices[index]);
  93. ((LLV4Matrix3)blend_mat).multiply(normals[index], o_normals[index]);
  94. }
  95. buffer->setBuffer(0);
  96. }
  97. #else
  98. void LLViewerJointMesh::updateGeometrySSE(LLFace *face, LLPolyMesh *mesh)
  99. {
  100. LLViewerJointMesh::updateGeometryVectorized(face, mesh);
  101. }
  102. #endif