forked from pool/glslang
Accepting request 394017 from X11:Wayland
- Update to 2.3.g401 OBS-URL: https://build.opensuse.org/request/show/394017 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/glslang?expand=0&rev=2
This commit is contained in:
commit
2e8fba92bd
108
badcode.diff
108
badcode.diff
@ -1,108 +0,0 @@
|
|||||||
|
|
||||||
wtf, code with undefined behavior.
|
|
||||||
|
|
||||||
SPIRV/SpvBuilder.cpp:701:39: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing]
|
|
||||||
unsigned value = *(unsigned int*)&f;
|
|
||||||
SPIRV/SpvBuilder.cpp:724:55: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing]
|
|
||||||
unsigned long long value = *(unsigned long long*)&d;
|
|
||||||
glslang/MachineIndependent/Constant.cpp:51:31: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing]
|
|
||||||
int bitPatternL = *(int*)&x;
|
|
||||||
glslang/MachineIndependent/Constant.cpp:60:31: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing]
|
|
||||||
int bitPatternL = *(int*)&x;
|
|
||||||
|
|
||||||
And pointless compile timestamps.
|
|
||||||
glslang-devel.x86_64: W: file-contains-date-and-time /usr/bin/spirv-remap
|
|
||||||
Your file uses __DATE and __TIME__ this causes the package to rebuild when
|
|
||||||
---
|
|
||||||
SPIRV/SpvBuilder.cpp | 9 +++++++--
|
|
||||||
StandAlone/spirv-remap.cpp | 2 +-
|
|
||||||
glslang/MachineIndependent/Constant.cpp | 15 +++++++++++----
|
|
||||||
3 files changed, 19 insertions(+), 7 deletions(-)
|
|
||||||
|
|
||||||
Index: glslang-2.3.g244/SPIRV/SpvBuilder.cpp
|
|
||||||
===================================================================
|
|
||||||
--- glslang-2.3.g244.orig/SPIRV/SpvBuilder.cpp
|
|
||||||
+++ glslang-2.3.g244/SPIRV/SpvBuilder.cpp
|
|
||||||
@@ -53,6 +53,7 @@
|
|
||||||
#ifndef _WIN32
|
|
||||||
#include <cstdio>
|
|
||||||
#endif
|
|
||||||
+#include <cstring>
|
|
||||||
|
|
||||||
namespace spv {
|
|
||||||
|
|
||||||
@@ -698,7 +699,9 @@ Id Builder::makeFloatConstant(float f, b
|
|
||||||
{
|
|
||||||
Op opcode = specConstant ? OpSpecConstant : OpConstant;
|
|
||||||
Id typeId = makeFloatType(32);
|
|
||||||
- unsigned value = *(unsigned int*)&f;
|
|
||||||
+ unsigned value;
|
|
||||||
+ static_assert(sizeof(value) <= sizeof(float), "horrible code");
|
|
||||||
+ memcpy(&value, &f, sizeof(value));
|
|
||||||
|
|
||||||
// See if we already made it. Applies only to regular constants, because specialization constants
|
|
||||||
// must remain distinct for the purpose of applying a SpecId decoration.
|
|
||||||
@@ -721,7 +724,9 @@ Id Builder::makeDoubleConstant(double d,
|
|
||||||
{
|
|
||||||
Op opcode = specConstant ? OpSpecConstant : OpConstant;
|
|
||||||
Id typeId = makeFloatType(64);
|
|
||||||
- unsigned long long value = *(unsigned long long*)&d;
|
|
||||||
+ unsigned long long value;
|
|
||||||
+ static_assert(sizeof(value) <= sizeof(d), "horrible code");
|
|
||||||
+ memcpy(&value, &d, sizeof(value));
|
|
||||||
unsigned op1 = value & 0xFFFFFFFF;
|
|
||||||
unsigned op2 = value >> 32;
|
|
||||||
|
|
||||||
Index: glslang-2.3.g244/StandAlone/spirv-remap.cpp
|
|
||||||
===================================================================
|
|
||||||
--- glslang-2.3.g244.orig/StandAlone/spirv-remap.cpp
|
|
||||||
+++ glslang-2.3.g244/StandAlone/spirv-remap.cpp
|
|
||||||
@@ -225,7 +225,7 @@ namespace {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (arg == "--version" || arg == "-V") {
|
|
||||||
- std::cout << basename(argv[0]) << " version 0.97 " << __DATE__ << " " << __TIME__ << std::endl;
|
|
||||||
+ std::cout << basename(argv[0]) << " version 0.97 " << "__DATE__" << " " << "__TIME__" << std::endl;
|
|
||||||
exit(0);
|
|
||||||
} else if (arg == "--input" || arg == "-i") {
|
|
||||||
// Collect input files
|
|
||||||
Index: glslang-2.3.g244/glslang/MachineIndependent/Constant.cpp
|
|
||||||
===================================================================
|
|
||||||
--- glslang-2.3.g244.orig/glslang/MachineIndependent/Constant.cpp
|
|
||||||
+++ glslang-2.3.g244/glslang/MachineIndependent/Constant.cpp
|
|
||||||
@@ -38,6 +38,7 @@
|
|
||||||
#include <cmath>
|
|
||||||
#include <cfloat>
|
|
||||||
#include <cstdlib>
|
|
||||||
+#include <cstring>
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
@@ -48,8 +49,11 @@ using namespace glslang;
|
|
||||||
bool isNan(double x)
|
|
||||||
{
|
|
||||||
// tough to find a platform independent library function, do it directly
|
|
||||||
- int bitPatternL = *(int*)&x;
|
|
||||||
- int bitPatternH = *((int*)&x + 1);
|
|
||||||
+ int bitPatternL;
|
|
||||||
+ static_assert(sizeof(int[2]) <= sizeof(x), "horrible code");
|
|
||||||
+ memcpy(&bitPatternL, &x, sizeof(bitPatternL));
|
|
||||||
+ int bitPatternH;
|
|
||||||
+ memcpy(&bitPatternH, reinterpret_cast<int *>(&x) + 1, sizeof(bitPatternH));
|
|
||||||
return (bitPatternH & 0x7ff80000) == 0x7ff80000 &&
|
|
||||||
((bitPatternH & 0xFFFFF) != 0 || bitPatternL != 0);
|
|
||||||
}
|
|
||||||
@@ -57,8 +61,11 @@ bool isNan(double x)
|
|
||||||
bool isInf(double x)
|
|
||||||
{
|
|
||||||
// tough to find a platform independent library function, do it directly
|
|
||||||
- int bitPatternL = *(int*)&x;
|
|
||||||
- int bitPatternH = *((int*)&x + 1);
|
|
||||||
+ int bitPatternL;
|
|
||||||
+ static_assert(sizeof(int[2]) <= sizeof(x), "horrible code");
|
|
||||||
+ memcpy(&bitPatternL, &x, sizeof(bitPatternL));
|
|
||||||
+ int bitPatternH;
|
|
||||||
+ memcpy(&bitPatternH, reinterpret_cast<int *>(&x) + 1, sizeof(bitPatternH));
|
|
||||||
return (bitPatternH & 0x7ff00000) == 0x7ff00000 &&
|
|
||||||
(bitPatternH & 0xFFFFF) == 0 && bitPatternL == 0;
|
|
||||||
}
|
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:bb0c46a44eb12e909f608446b167c3c0663e363ff3488b99becc57671297d45d
|
|
||||||
size 836320
|
|
3
glslang-2.3.g401.tar.xz
Normal file
3
glslang-2.3.g401.tar.xz
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:dd311b86ecf0655e06e9946cd5295e9465910da9695c583ddcc9dd153ee5b967
|
||||||
|
size 586956
|
@ -1,3 +1,10 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Apr 26 18:35:34 UTC 2016 - jengelh@inai.de
|
||||||
|
|
||||||
|
- Update to 2.3.g401
|
||||||
|
* Fix compile error involving std::isinf
|
||||||
|
- Drop badcode.diff (merged upstream)
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Wed Feb 17 11:06:24 UTC 2016 - jengelh@inai.de
|
Wed Feb 17 11:06:24 UTC 2016 - jengelh@inai.de
|
||||||
|
|
||||||
|
@ -16,8 +16,10 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
|
|
||||||
|
%define version_unconverted 2.3.g401
|
||||||
|
|
||||||
Name: glslang
|
Name: glslang
|
||||||
Version: 2.3.g244
|
Version: 2.3.g401
|
||||||
Release: 0
|
Release: 0
|
||||||
Summary: OpenGL and OpenGL ES shader front end and validator
|
Summary: OpenGL and OpenGL ES shader front end and validator
|
||||||
License: BSD-3-Clause
|
License: BSD-3-Clause
|
||||||
@ -25,7 +27,6 @@ Group: Development/Libraries/C and C++
|
|||||||
Url: https://www.khronos.org/opengles/sdk/tools/Reference-Compiler/
|
Url: https://www.khronos.org/opengles/sdk/tools/Reference-Compiler/
|
||||||
|
|
||||||
Source: %name-%version.tar.xz
|
Source: %name-%version.tar.xz
|
||||||
Patch1: badcode.diff
|
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
BuildRequires: bison
|
BuildRequires: bison
|
||||||
BuildRequires: cmake >= 2.8
|
BuildRequires: cmake >= 2.8
|
||||||
@ -55,7 +56,6 @@ compressor's dictionary can find better cross module commonality.
|
|||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q
|
%setup -q
|
||||||
%patch -P 1 -p1
|
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%cmake
|
%cmake
|
||||||
@ -74,12 +74,14 @@ cp -a SPIRV glslang "$b/%_includedir/"
|
|||||||
find "$b/%_includedir/" -type f ! -iname "*.h" -a ! -iname "*.hpp" -print -delete
|
find "$b/%_includedir/" -type f ! -iname "*.h" -a ! -iname "*.hpp" -print -delete
|
||||||
ln -s SPIRV/spirv.hpp "$b/%_includedir/"
|
ln -s SPIRV/spirv.hpp "$b/%_includedir/"
|
||||||
find "$b/%_includedir/" -type f -exec chmod a-x "{}" "+"
|
find "$b/%_includedir/" -type f -exec chmod a-x "{}" "+"
|
||||||
|
cp build/StandAlone/libglslang-default-resource-limits.so "$b/%_libdir/"
|
||||||
|
|
||||||
%files devel
|
%files devel
|
||||||
%defattr(-,root,root)
|
%defattr(-,root,root)
|
||||||
%_bindir/gls*
|
%_bindir/gls*
|
||||||
%_bindir/spirv*
|
%_bindir/spirv*
|
||||||
%_libdir/*.a
|
%_libdir/*.a
|
||||||
|
%_libdir/*resource*.so
|
||||||
%_includedir/*
|
%_includedir/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
Loading…
Reference in New Issue
Block a user