import llvm-9.0.1-4.module+el8.2.0+5887+847e8a86
This commit is contained in:
parent
5ca104e76f
commit
4fc9fff5c4
2
.gitignore
vendored
2
.gitignore
vendored
@ -1 +1 @@
|
|||||||
SOURCES/llvm-8.0.1.src.tar.xz
|
SOURCES/llvm-9.0.1.src.tar.xz
|
||||||
|
@ -1 +1 @@
|
|||||||
09964f9eabc364f221a3caefbdaea28557273b4a SOURCES/llvm-8.0.1.src.tar.xz
|
f7fcf3bd92d130784513c06efe6910f135372ce3 SOURCES/llvm-9.0.1.src.tar.xz
|
||||||
|
2510
SOURCES/0001-BPF-Handling-type-conversions-correctly-for-CO-RE.patch
Normal file
2510
SOURCES/0001-BPF-Handling-type-conversions-correctly-for-CO-RE.patch
Normal file
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,138 @@
|
|||||||
|
From f2ccdd2700174c717dc55a0f4c3f5a91ae73ff42 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Yonghong Song <yhs@fb.com>
|
||||||
|
Date: Fri, 2 Aug 2019 21:28:28 +0000
|
||||||
|
Subject: [PATCH] [BPF] annotate DIType metadata for builtin
|
||||||
|
preseve_array_access_index()
|
||||||
|
|
||||||
|
Previously, debuginfo types are annotated to
|
||||||
|
IR builtin preserve_struct_access_index() and
|
||||||
|
preserve_union_access_index(), but not
|
||||||
|
preserve_array_access_index(). The debug info
|
||||||
|
is useful to identify the root type name which
|
||||||
|
later will be used for type comparison.
|
||||||
|
|
||||||
|
For user access without explicit type conversions,
|
||||||
|
the previous scheme works as we can ignore intermediate
|
||||||
|
compiler generated type conversions (e.g., from union types to
|
||||||
|
union members) and still generate correct access index string.
|
||||||
|
|
||||||
|
The issue comes with user explicit type conversions, e.g.,
|
||||||
|
converting an array to a structure like below:
|
||||||
|
struct t { int a; char b[40]; };
|
||||||
|
struct p { int c; int d; };
|
||||||
|
struct t *var = ...;
|
||||||
|
... __builtin_preserve_access_index(&(((struct p *)&(var->b[0]))->d)) ...
|
||||||
|
Although BPF backend can derive the type of &(var->b[0]),
|
||||||
|
explicit type annotation make checking more consistent
|
||||||
|
and less error prone.
|
||||||
|
|
||||||
|
Another benefit is for multiple dimension array handling.
|
||||||
|
For example,
|
||||||
|
struct p { int c; int d; } g[8][9][10];
|
||||||
|
... __builtin_preserve_access_index(&g[2][3][4].d) ...
|
||||||
|
It would be possible to calculate the number of "struct p"'s
|
||||||
|
before accessing its member "d" if array debug info is
|
||||||
|
available as it contains each dimension range.
|
||||||
|
|
||||||
|
This patch enables to annotate IR builtin preserve_array_access_index()
|
||||||
|
with proper debuginfo type. The unit test case and language reference
|
||||||
|
is updated as well.
|
||||||
|
|
||||||
|
Signed-off-by: Yonghong Song <yhs@fb.com>
|
||||||
|
|
||||||
|
Differential Revision: https://reviews.llvm.org/D65664
|
||||||
|
|
||||||
|
llvm-svn: 367724
|
||||||
|
(cherry picked from commit d0ea05d5eff475a27a5d3bbe4d9fd389935f9cb2)
|
||||||
|
|
||||||
|
Also added back
|
||||||
|
Value *CreatePreserveArrayAccessIndex(Value *Base, unsigned Dimension,
|
||||||
|
unsigned LastIndex);
|
||||||
|
|
||||||
|
To avoid breaking the ABI.
|
||||||
|
---
|
||||||
|
clang/lib/CodeGen/CGExpr.cpp | 12 ++++++++---
|
||||||
|
.../CodeGen/builtin-preserve-access-index-array.c | 18 +++++++++++++++++
|
||||||
|
clang/test/CodeGen/builtin-preserve-access-index.c | 23 +++++++++++-----------
|
||||||
|
llvm/docs/LangRef.rst | 4 ++++
|
||||||
|
llvm/include/llvm/IR/IRBuilder.h | 13 ++++++++++--
|
||||||
|
llvm/test/CodeGen/BPF/CORE/intrinsic-array.ll | 2 +-
|
||||||
|
6 files changed, 55 insertions(+), 17 deletions(-)
|
||||||
|
create mode 100644 clang/test/CodeGen/builtin-preserve-access-index-array.c
|
||||||
|
|
||||||
|
diff --git a/llvm/docs/LangRef.rst b/llvm/docs/LangRef.rst
|
||||||
|
index 87e8a55..b63e3af 100644
|
||||||
|
--- a/llvm/docs/LangRef.rst
|
||||||
|
+++ b/llvm/docs/LangRef.rst
|
||||||
|
@@ -17349,6 +17349,10 @@ based on array base ``base``, array dimension ``dim`` and the last access index
|
||||||
|
into the array. The return type ``ret_type`` is a pointer type to the array element.
|
||||||
|
The array ``dim`` and ``index`` are preserved which is more robust than
|
||||||
|
getelementptr instruction which may be subject to compiler transformation.
|
||||||
|
+The ``llvm.preserve.access.index`` type of metadata is attached to this call instruction
|
||||||
|
+to provide array or pointer debuginfo type.
|
||||||
|
+The metadata is a ``DICompositeType`` or ``DIDerivedType`` representing the
|
||||||
|
+debuginfo version of ``type``.
|
||||||
|
|
||||||
|
Arguments:
|
||||||
|
""""""""""
|
||||||
|
diff --git a/llvm/include/llvm/IR/IRBuilder.h b/llvm/include/llvm/IR/IRBuilder.h
|
||||||
|
index a74364d..c2fa9a3 100644
|
||||||
|
--- a/llvm/include/llvm/IR/IRBuilder.h
|
||||||
|
+++ b/llvm/include/llvm/IR/IRBuilder.h
|
||||||
|
@@ -2455,6 +2455,11 @@ public:
|
||||||
|
|
||||||
|
Value *CreatePreserveArrayAccessIndex(Value *Base, unsigned Dimension,
|
||||||
|
unsigned LastIndex) {
|
||||||
|
+ return CreatePreserveArrayAccessIndex(Base, Dimension, LastIndex, nullptr);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ Value *CreatePreserveArrayAccessIndex(Value *Base, unsigned Dimension,
|
||||||
|
+ unsigned LastIndex, MDNode *DbgInfo) {
|
||||||
|
assert(isa<PointerType>(Base->getType()) &&
|
||||||
|
"Invalid Base ptr type for preserve.array.access.index.");
|
||||||
|
auto *BaseType = Base->getType();
|
||||||
|
@@ -2476,6 +2481,8 @@ public:
|
||||||
|
Value *DimV = getInt32(Dimension);
|
||||||
|
CallInst *Fn =
|
||||||
|
CreateCall(FnPreserveArrayAccessIndex, {Base, DimV, LastIndexV});
|
||||||
|
+ if (DbgInfo)
|
||||||
|
+ Fn->setMetadata(LLVMContext::MD_preserve_access_index, DbgInfo);
|
||||||
|
|
||||||
|
return Fn;
|
||||||
|
}
|
||||||
|
@@ -2493,7 +2500,8 @@ public:
|
||||||
|
Value *DIIndex = getInt32(FieldIndex);
|
||||||
|
CallInst *Fn =
|
||||||
|
CreateCall(FnPreserveUnionAccessIndex, {Base, DIIndex});
|
||||||
|
- Fn->setMetadata(LLVMContext::MD_preserve_access_index, DbgInfo);
|
||||||
|
+ if (DbgInfo)
|
||||||
|
+ Fn->setMetadata(LLVMContext::MD_preserve_access_index, DbgInfo);
|
||||||
|
|
||||||
|
return Fn;
|
||||||
|
}
|
||||||
|
@@ -2516,7 +2524,8 @@ public:
|
||||||
|
Value *DIIndex = getInt32(FieldIndex);
|
||||||
|
CallInst *Fn = CreateCall(FnPreserveStructAccessIndex,
|
||||||
|
{Base, GEPIndex, DIIndex});
|
||||||
|
- Fn->setMetadata(LLVMContext::MD_preserve_access_index, DbgInfo);
|
||||||
|
+ if (DbgInfo)
|
||||||
|
+ Fn->setMetadata(LLVMContext::MD_preserve_access_index, DbgInfo);
|
||||||
|
|
||||||
|
return Fn;
|
||||||
|
}
|
||||||
|
diff --git a/llvm/test/CodeGen/BPF/CORE/intrinsic-array.ll b/llvm/test/CodeGen/BPF/CORE/intrinsic-array.ll
|
||||||
|
index adbcb9f..fe2c196 100644
|
||||||
|
--- a/llvm/test/CodeGen/BPF/CORE/intrinsic-array.ll
|
||||||
|
+++ b/llvm/test/CodeGen/BPF/CORE/intrinsic-array.ll
|
||||||
|
@@ -14,7 +14,7 @@
|
||||||
|
define dso_local i32 @test(%struct.s* %arg) local_unnamed_addr #0 !dbg !7 {
|
||||||
|
entry:
|
||||||
|
call void @llvm.dbg.value(metadata %struct.s* %arg, metadata !17, metadata !DIExpression()), !dbg !18
|
||||||
|
- %0 = tail call %struct.s* @llvm.preserve.array.access.index.p0s_struct.ss.p0s_struct.ss(%struct.s* %arg, i32 0, i32 2), !dbg !19
|
||||||
|
+ %0 = tail call %struct.s* @llvm.preserve.array.access.index.p0s_struct.ss.p0s_struct.ss(%struct.s* %arg, i32 0, i32 2), !dbg !19, !llvm.preserve.access.index !11
|
||||||
|
%1 = tail call i32* @llvm.preserve.struct.access.index.p0i32.p0s_struct.ss(%struct.s* %0, i32 1, i32 1), !dbg !19, !llvm.preserve.access.index !12
|
||||||
|
%2 = bitcast i32* %1 to i8*, !dbg !19
|
||||||
|
%call = tail call i32 @get_value(i8* %2) #4, !dbg !20
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
@ -0,0 +1,66 @@
|
|||||||
|
From 8f6917ea11bd1bfbfe07f3577756d1c4abfdb916 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tom Stellard <tstellar@redhat.com>
|
||||||
|
Date: Fri, 6 Sep 2019 11:03:18 -0700
|
||||||
|
Subject: [PATCH] CMake: Split static library exports into their own export
|
||||||
|
file
|
||||||
|
|
||||||
|
---
|
||||||
|
llvm/cmake/modules/AddLLVM.cmake | 6 +++++-
|
||||||
|
llvm/cmake/modules/CMakeLists.txt | 3 +++
|
||||||
|
llvm/cmake/modules/LLVMConfig.cmake.in | 2 ++
|
||||||
|
3 files changed, 10 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/llvm/cmake/modules/AddLLVM.cmake b/llvm/cmake/modules/AddLLVM.cmake
|
||||||
|
index 619e986..200fc45 100644
|
||||||
|
--- a/llvm/cmake/modules/AddLLVM.cmake
|
||||||
|
+++ b/llvm/cmake/modules/AddLLVM.cmake
|
||||||
|
@@ -691,7 +691,11 @@ macro(add_llvm_library name)
|
||||||
|
if(${name} IN_LIST LLVM_DISTRIBUTION_COMPONENTS OR
|
||||||
|
(in_llvm_libs AND "llvm-libraries" IN_LIST LLVM_DISTRIBUTION_COMPONENTS) OR
|
||||||
|
NOT LLVM_DISTRIBUTION_COMPONENTS)
|
||||||
|
- set(export_to_llvmexports EXPORT LLVMExports)
|
||||||
|
+ if (ARG_SHARED)
|
||||||
|
+ set(export_to_llvmexports EXPORT LLVMExports)
|
||||||
|
+ else()
|
||||||
|
+ set(export_to_llvmexports EXPORT LLVMStaticExports)
|
||||||
|
+ endif()
|
||||||
|
set_property(GLOBAL PROPERTY LLVM_HAS_EXPORTS True)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
diff --git a/llvm/cmake/modules/CMakeLists.txt b/llvm/cmake/modules/CMakeLists.txt
|
||||||
|
index 9cf22b4..dc982d2 100644
|
||||||
|
--- a/llvm/cmake/modules/CMakeLists.txt
|
||||||
|
+++ b/llvm/cmake/modules/CMakeLists.txt
|
||||||
|
@@ -105,6 +105,7 @@ set(LLVM_CONFIG_BINARY_DIR "\${LLVM_INSTALL_PREFIX}")
|
||||||
|
set(LLVM_CONFIG_TOOLS_BINARY_DIR "\${LLVM_INSTALL_PREFIX}/bin")
|
||||||
|
set(LLVM_CONFIG_EXPORTS_FILE "\${LLVM_CMAKE_DIR}/LLVMExports.cmake")
|
||||||
|
set(LLVM_CONFIG_EXPORTS "${LLVM_EXPORTS}")
|
||||||
|
+set(LLVM_CONFIG_STATIC_EXPORTS_FILE "\${LLVM_CMAKE_DIR}/LLVMStaticExports.cmake")
|
||||||
|
configure_file(
|
||||||
|
LLVMConfig.cmake.in
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/LLVMConfig.cmake
|
||||||
|
@@ -121,6 +122,8 @@ if (NOT LLVM_INSTALL_TOOLCHAIN_ONLY)
|
||||||
|
if(llvm_has_exports)
|
||||||
|
install(EXPORT LLVMExports DESTINATION ${LLVM_INSTALL_PACKAGE_DIR}
|
||||||
|
COMPONENT cmake-exports)
|
||||||
|
+ install(EXPORT LLVMStaticExports DESTINATION ${LLVM_INSTALL_PACKAGE_DIR}
|
||||||
|
+ COMPONENT cmake-exports)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
install(FILES
|
||||||
|
diff --git a/llvm/cmake/modules/LLVMConfig.cmake.in b/llvm/cmake/modules/LLVMConfig.cmake.in
|
||||||
|
index 536031f..6ef54a0 100644
|
||||||
|
--- a/llvm/cmake/modules/LLVMConfig.cmake.in
|
||||||
|
+++ b/llvm/cmake/modules/LLVMConfig.cmake.in
|
||||||
|
@@ -89,6 +89,8 @@ if(NOT TARGET LLVMSupport)
|
||||||
|
set(LLVM_EXPORTED_TARGETS "@LLVM_CONFIG_EXPORTS@")
|
||||||
|
include("@LLVM_CONFIG_EXPORTS_FILE@")
|
||||||
|
@llvm_config_include_buildtree_only_exports@
|
||||||
|
+
|
||||||
|
+ include("@LLVM_CONFIG_STATIC_EXPORTS_FILE@" OPTIONAL)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# By creating intrinsics_gen here, subprojects that depend on LLVM's
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
@ -0,0 +1,65 @@
|
|||||||
|
From 9d496e978f59e153bb76e92229d5a524d92dee04 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tom Stellard <tstellar@redhat.com>
|
||||||
|
Date: Tue, 10 Sep 2019 13:33:48 -0700
|
||||||
|
Subject: [PATCH] CMake: Split test binary exports into their own export file
|
||||||
|
|
||||||
|
---
|
||||||
|
llvm/cmake/modules/AddLLVM.cmake | 7 ++++++-
|
||||||
|
llvm/cmake/modules/CMakeLists.txt | 3 +++
|
||||||
|
llvm/cmake/modules/LLVMConfig.cmake.in | 1 +
|
||||||
|
3 files changed, 10 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/llvm/cmake/modules/AddLLVM.cmake b/llvm/cmake/modules/AddLLVM.cmake
|
||||||
|
index 200fc45..9eec7a7 100644
|
||||||
|
--- a/llvm/cmake/modules/AddLLVM.cmake
|
||||||
|
+++ b/llvm/cmake/modules/AddLLVM.cmake
|
||||||
|
@@ -953,7 +953,12 @@ macro(add_llvm_utility name)
|
||||||
|
set(export_to_llvmexports)
|
||||||
|
if (${name} IN_LIST LLVM_DISTRIBUTION_COMPONENTS OR
|
||||||
|
NOT LLVM_DISTRIBUTION_COMPONENTS)
|
||||||
|
- set(export_to_llvmexports EXPORT LLVMExports)
|
||||||
|
+ if (${name} STREQUAL "not" OR ${name} STREQUAL "count" OR
|
||||||
|
+ ${name} STREQUAL "yaml-bench" OR ${name} STREQUAL "lli-child-target")
|
||||||
|
+ set(export_to_llvmexports EXPORT LLVMTestExports)
|
||||||
|
+ else()
|
||||||
|
+ set(export_to_llvmexports EXPORT LLVMExports)
|
||||||
|
+ endif()
|
||||||
|
set_property(GLOBAL PROPERTY LLVM_HAS_EXPORTS True)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
diff --git a/llvm/cmake/modules/CMakeLists.txt b/llvm/cmake/modules/CMakeLists.txt
|
||||||
|
index dc982d2..c861f45 100644
|
||||||
|
--- a/llvm/cmake/modules/CMakeLists.txt
|
||||||
|
+++ b/llvm/cmake/modules/CMakeLists.txt
|
||||||
|
@@ -106,6 +106,7 @@ set(LLVM_CONFIG_TOOLS_BINARY_DIR "\${LLVM_INSTALL_PREFIX}/bin")
|
||||||
|
set(LLVM_CONFIG_EXPORTS_FILE "\${LLVM_CMAKE_DIR}/LLVMExports.cmake")
|
||||||
|
set(LLVM_CONFIG_EXPORTS "${LLVM_EXPORTS}")
|
||||||
|
set(LLVM_CONFIG_STATIC_EXPORTS_FILE "\${LLVM_CMAKE_DIR}/LLVMStaticExports.cmake")
|
||||||
|
+set(LLVM_CONFIG_TEST_EXPORTS_FILE "\${LLVM_CMAKE_DIR}/LLVMTestExports.cmake")
|
||||||
|
configure_file(
|
||||||
|
LLVMConfig.cmake.in
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/LLVMConfig.cmake
|
||||||
|
@@ -124,6 +125,8 @@ if (NOT LLVM_INSTALL_TOOLCHAIN_ONLY)
|
||||||
|
COMPONENT cmake-exports)
|
||||||
|
install(EXPORT LLVMStaticExports DESTINATION ${LLVM_INSTALL_PACKAGE_DIR}
|
||||||
|
COMPONENT cmake-exports)
|
||||||
|
+ install(EXPORT LLVMTestExports DESTINATION ${LLVM_INSTALL_PACKAGE_DIR}
|
||||||
|
+ COMPONENT cmake-exports)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
install(FILES
|
||||||
|
diff --git a/llvm/cmake/modules/LLVMConfig.cmake.in b/llvm/cmake/modules/LLVMConfig.cmake.in
|
||||||
|
index 6ef54a0..d81b09a 100644
|
||||||
|
--- a/llvm/cmake/modules/LLVMConfig.cmake.in
|
||||||
|
+++ b/llvm/cmake/modules/LLVMConfig.cmake.in
|
||||||
|
@@ -91,6 +91,7 @@ if(NOT TARGET LLVMSupport)
|
||||||
|
@llvm_config_include_buildtree_only_exports@
|
||||||
|
|
||||||
|
include("@LLVM_CONFIG_STATIC_EXPORTS_FILE@" OPTIONAL)
|
||||||
|
+ include("@LLVM_CONFIG_TEST_EXPORTS_FILE@" OPTIONAL)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# By creating intrinsics_gen here, subprojects that depend on LLVM's
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
@ -1,14 +1,14 @@
|
|||||||
From eeb9da2ece9a58448c213b900090b32e6d303bff Mon Sep 17 00:00:00 2001
|
From e7bc515182199764b17ab3f5e22047342f9c7514 Mon Sep 17 00:00:00 2001
|
||||||
From: serge-sans-paille <sguelton@redhat.com>
|
From: serge-sans-paille <sguelton@redhat.com>
|
||||||
Date: Thu, 13 Jun 2019 07:58:59 +0000
|
Date: Thu, 13 Jun 2019 07:58:59 +0000
|
||||||
Subject: [PATCH 4/4] Deactivate markdown doc
|
Subject: [PATCH] Deactivate markdown doc
|
||||||
|
|
||||||
---
|
---
|
||||||
llvm/docs/conf.py | 4 ++--
|
llvm/docs/conf.py | 4 ++--
|
||||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/llvm/docs/conf.py b/llvm/docs/conf.py
|
diff --git a/llvm/docs/conf.py b/llvm/docs/conf.py
|
||||||
index 7fdcb3d2f52..501b48b540d 100644
|
index 4a52df8..340cd07 100644
|
||||||
--- a/llvm/docs/conf.py
|
--- a/llvm/docs/conf.py
|
||||||
+++ b/llvm/docs/conf.py
|
+++ b/llvm/docs/conf.py
|
||||||
@@ -32,9 +32,9 @@ extensions = ['sphinx.ext.intersphinx', 'sphinx.ext.todo']
|
@@ -32,9 +32,9 @@ extensions = ['sphinx.ext.intersphinx', 'sphinx.ext.todo']
|
||||||
@ -24,5 +24,5 @@ index 7fdcb3d2f52..501b48b540d 100644
|
|||||||
# The encoding of source files.
|
# The encoding of source files.
|
||||||
#source_encoding = 'utf-8-sig'
|
#source_encoding = 'utf-8-sig'
|
||||||
--
|
--
|
||||||
2.20.1
|
1.8.3.1
|
||||||
|
|
||||||
|
@ -0,0 +1,223 @@
|
|||||||
|
From 8987da9a2cac6c5bd39ba100ffd1aaede94dc6a0 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Michael Pozulp <pozulp.llvm@gmail.com>
|
||||||
|
Date: Fri, 9 Aug 2019 19:10:55 +0000
|
||||||
|
Subject: [PATCH] [Docs][llvm-strip] Add help text to llvm-strip rst doc
|
||||||
|
|
||||||
|
Summary: Addresses https://bugs.llvm.org/show_bug.cgi?id=42383
|
||||||
|
|
||||||
|
Reviewers: jhenderson, alexshap, rupprecht
|
||||||
|
|
||||||
|
Reviewed By: jhenderson
|
||||||
|
|
||||||
|
Subscribers: wolfgangp, jakehehrlich, llvm-commits
|
||||||
|
|
||||||
|
Tags: #llvm
|
||||||
|
|
||||||
|
Differential Revision: https://reviews.llvm.org/D65384
|
||||||
|
|
||||||
|
llvm-svn: 368464
|
||||||
|
---
|
||||||
|
llvm/docs/CommandGuide/llvm-strip.md | 16 ----
|
||||||
|
llvm/docs/CommandGuide/llvm-strip.rst | 167 ++++++++++++++++++++++++++++++++++
|
||||||
|
2 files changed, 167 insertions(+), 16 deletions(-)
|
||||||
|
delete mode 100644 llvm/docs/CommandGuide/llvm-strip.md
|
||||||
|
create mode 100644 llvm/docs/CommandGuide/llvm-strip.rst
|
||||||
|
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-strip.md b/llvm/docs/CommandGuide/llvm-strip.md
|
||||||
|
deleted file mode 100644
|
||||||
|
index dd6e859..0000000
|
||||||
|
--- a/llvm/docs/CommandGuide/llvm-strip.md
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,16 +0,0 @@
|
||||||
|
-# llvm-strip - object stripping tool
|
||||||
|
-
|
||||||
|
-## SYNOPSIS
|
||||||
|
-
|
||||||
|
-**llvm-strip** [*options*]
|
||||||
|
-
|
||||||
|
-## DESCRIPTION
|
||||||
|
-
|
||||||
|
-**llvm-strip** is a tool to strip sections and symbols from object files.
|
||||||
|
-
|
||||||
|
-The tool is still in active development, but in most scenarios it works as a
|
||||||
|
-drop-in replacement for GNU's **strip**.
|
||||||
|
-
|
||||||
|
-## SEE ALSO
|
||||||
|
-
|
||||||
|
-[llvm-objcopy](llvm-objcopy.html)
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-strip.rst b/llvm/docs/CommandGuide/llvm-strip.rst
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..6e02482
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/llvm/docs/CommandGuide/llvm-strip.rst
|
||||||
|
@@ -0,0 +1,167 @@
|
||||||
|
+llvm-strip - object stripping tool
|
||||||
|
+==================================
|
||||||
|
+
|
||||||
|
+.. program:: llvm-strip
|
||||||
|
+
|
||||||
|
+SYNOPSIS
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:program:`llvm-strip` [*options*] *inputs...*
|
||||||
|
+
|
||||||
|
+DESCRIPTION
|
||||||
|
+-----------
|
||||||
|
+
|
||||||
|
+:program:`llvm-strip` is a tool to strip sections and symbols from object files.
|
||||||
|
+If no other stripping or remove options are specified, :option:`--strip-all`
|
||||||
|
+will be enabled by default.
|
||||||
|
+
|
||||||
|
+The input files are modified in-place. If "-" is specified for the input file,
|
||||||
|
+the input is read from the program's standard input stream.
|
||||||
|
+
|
||||||
|
+If the input is an archive, any requested operations will be applied to each
|
||||||
|
+archive member individually.
|
||||||
|
+
|
||||||
|
+The tool is still in active development, but in most scenarios it works as a
|
||||||
|
+drop-in replacement for GNU's :program:`strip`.
|
||||||
|
+
|
||||||
|
+GENERIC AND CROSS-PLATFORM OPTIONS
|
||||||
|
+----------------------------------
|
||||||
|
+
|
||||||
|
+The following options are either agnostic of the file format, or apply to
|
||||||
|
+multiple file formats.
|
||||||
|
+
|
||||||
|
+.. option:: --disable-deterministic-archives, -U
|
||||||
|
+
|
||||||
|
+ Use real values for UIDs, GIDs and timestamps when updating archive member
|
||||||
|
+ headers.
|
||||||
|
+
|
||||||
|
+.. option:: --discard-all, -x
|
||||||
|
+
|
||||||
|
+ Remove most local symbols from the output. Different file formats may limit
|
||||||
|
+ this to a subset of the local symbols. For example, file and section symbols in
|
||||||
|
+ ELF objects will not be discarded.
|
||||||
|
+
|
||||||
|
+.. option:: --enable-deterministic-archives, -D
|
||||||
|
+
|
||||||
|
+ Enable deterministic mode when stripping archives, i.e. use 0 for archive member
|
||||||
|
+ header UIDs, GIDs and timestamp fields. On by default.
|
||||||
|
+
|
||||||
|
+.. option:: --help, -h
|
||||||
|
+
|
||||||
|
+ Print a summary of command line options.
|
||||||
|
+
|
||||||
|
+.. option:: --no-strip-all
|
||||||
|
+
|
||||||
|
+ Disable --strip-all.
|
||||||
|
+
|
||||||
|
+.. option:: -o <file>
|
||||||
|
+
|
||||||
|
+ Write output to <file>. Multiple input files cannot be used in combination
|
||||||
|
+ with -o.
|
||||||
|
+
|
||||||
|
+.. option:: --regex
|
||||||
|
+
|
||||||
|
+ If specified, symbol and section names specified by other switches are treated
|
||||||
|
+ as extended POSIX regular expression patterns.
|
||||||
|
+
|
||||||
|
+.. option:: --remove-section <section>, -R
|
||||||
|
+
|
||||||
|
+ Remove the specified section from the output. Can be specified multiple times
|
||||||
|
+ to remove multiple sections simultaneously.
|
||||||
|
+
|
||||||
|
+.. option:: --strip-all-gnu
|
||||||
|
+
|
||||||
|
+ Remove all symbols, debug sections and relocations from the output. This option
|
||||||
|
+ is equivalent to GNU :program:`strip`'s ``--strip-all`` switch.
|
||||||
|
+
|
||||||
|
+.. option:: --strip-all, -S
|
||||||
|
+
|
||||||
|
+ For ELF objects, remove from the output all symbols and non-alloc sections not
|
||||||
|
+ within segments, except for .gnu.warning sections and the section name table.
|
||||||
|
+
|
||||||
|
+ For COFF objects, remove all symbols, debug sections, and relocations from the
|
||||||
|
+ output.
|
||||||
|
+
|
||||||
|
+.. option:: --strip-debug, -g
|
||||||
|
+
|
||||||
|
+ Remove all debug sections.
|
||||||
|
+
|
||||||
|
+.. option:: --strip-sections
|
||||||
|
+
|
||||||
|
+ Remove all section headers and all sections not in segments.
|
||||||
|
+
|
||||||
|
+.. option:: --strip-symbol <symbol>, -N
|
||||||
|
+
|
||||||
|
+ Remove all symbols named ``<symbol>`` from the output. Can be specified
|
||||||
|
+ multiple times to remove multiple symbols.
|
||||||
|
+
|
||||||
|
+.. option:: --strip-unneeded
|
||||||
|
+
|
||||||
|
+ Remove all local or undefined symbols that are not required by relocations.
|
||||||
|
+
|
||||||
|
+.. option:: --version, -V
|
||||||
|
+
|
||||||
|
+ Display the version of this program.
|
||||||
|
+
|
||||||
|
+COFF-SPECIFIC OPTIONS
|
||||||
|
+---------------------
|
||||||
|
+
|
||||||
|
+The following options are implemented only for COFF objects. If used with other
|
||||||
|
+objects, :program:`llvm-strip` will either emit an error or silently ignore
|
||||||
|
+them.
|
||||||
|
+
|
||||||
|
+.. option:: --only-keep-debug
|
||||||
|
+
|
||||||
|
+ Remove the contents of non-debug sections from the output, but keep the section
|
||||||
|
+ headers.
|
||||||
|
+
|
||||||
|
+ELF-SPECIFIC OPTIONS
|
||||||
|
+--------------------
|
||||||
|
+
|
||||||
|
+The following options are implemented only for ELF objects. If used with other
|
||||||
|
+objects, :program:`llvm-strip` will either emit an error or silently ignore
|
||||||
|
+them.
|
||||||
|
+
|
||||||
|
+.. option:: --allow-broken-links
|
||||||
|
+
|
||||||
|
+ Allow llvm-strip to remove sections even if it would leave invalid section
|
||||||
|
+ references. Any invalid sh_link fields will be set to zero.
|
||||||
|
+
|
||||||
|
+.. option:: --discard-locals, -X
|
||||||
|
+
|
||||||
|
+ Remove local symbols starting with ".L" from the output.
|
||||||
|
+
|
||||||
|
+.. option:: --keep-file-symbols
|
||||||
|
+
|
||||||
|
+ Keep symbols of type `STT_FILE`, even if they would otherwise be stripped.
|
||||||
|
+
|
||||||
|
+ .. option:: --keep-section <section>
|
||||||
|
+
|
||||||
|
+ When removing sections from the output, do not remove sections named
|
||||||
|
+ ``<section>``. Can be specified multiple times to keep multiple sections.
|
||||||
|
+
|
||||||
|
+.. option:: --keep-symbol <symbol>, -K
|
||||||
|
+
|
||||||
|
+ Do not remove symbols named ``<symbol>``. Can be specified multiple times to
|
||||||
|
+ keep multiple symbols.
|
||||||
|
+
|
||||||
|
+.. option:: --preserve-dates, -p
|
||||||
|
+
|
||||||
|
+ Preserve access and modification timestamps.
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+EXIT STATUS
|
||||||
|
+-----------
|
||||||
|
+
|
||||||
|
+:program:`llvm-strip` exits with a non-zero exit code if there is an error.
|
||||||
|
+Otherwise, it exits with code 0.
|
||||||
|
+
|
||||||
|
+BUGS
|
||||||
|
+----
|
||||||
|
+
|
||||||
|
+To report bugs, please visit <http://llvm.org/bugs/>.
|
||||||
|
+
|
||||||
|
+SEE ALSO
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:manpage:`llvm-objcopy(1)`
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
@ -1,82 +1,28 @@
|
|||||||
From e491bb836e530585e4d278b82725e4cefdd14abc Mon Sep 17 00:00:00 2001
|
From d15c835028bcc72a8695d047f0acaa530aa54716 Mon Sep 17 00:00:00 2001
|
||||||
From: serge-sans-paille <sguelton@redhat.com>
|
From: Tom Stellard <tstellar@redhat.com>
|
||||||
Date: Thu, 13 Jun 2019 07:55:37 +0000
|
Date: Wed, 31 Jul 2019 20:43:42 -0700
|
||||||
Subject: [PATCH 3/4] Filter-out-cxxflags-not-supported-by-clang
|
Subject: [PATCH] Filter out cxxflags not supported by clang
|
||||||
|
|
||||||
---
|
---
|
||||||
llvm/cmake/modules/AddLLVM.cmake | 6 +++++-
|
llvm/tools/llvm-config/CMakeLists.txt | 4 ++++
|
||||||
llvm/cmake/modules/CMakeLists.txt | 3 +++
|
1 file changed, 4 insertions(+)
|
||||||
llvm/cmake/modules/LLVMConfig.cmake.in | 2 ++
|
|
||||||
llvm/tools/llvm-config/CMakeLists.txt | 4 ++++
|
|
||||||
4 files changed, 14 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/llvm/cmake/modules/AddLLVM.cmake b/llvm/cmake/modules/AddLLVM.cmake
|
|
||||||
index 1a417447278..bb10f20cdd6 100644
|
|
||||||
--- a/llvm/cmake/modules/AddLLVM.cmake
|
|
||||||
+++ b/llvm/cmake/modules/AddLLVM.cmake
|
|
||||||
@@ -664,7 +664,11 @@ macro(add_llvm_library name)
|
|
||||||
|
|
||||||
if(${name} IN_LIST LLVM_DISTRIBUTION_COMPONENTS OR
|
|
||||||
NOT LLVM_DISTRIBUTION_COMPONENTS)
|
|
||||||
- set(export_to_llvmexports EXPORT LLVMExports)
|
|
||||||
+ if (ARG_SHARED)
|
|
||||||
+ set(export_to_llvmexports EXPORT LLVMExports)
|
|
||||||
+ else()
|
|
||||||
+ set(export_to_llvmexports EXPORT LLVMStaticExports)
|
|
||||||
+ endif()
|
|
||||||
set_property(GLOBAL PROPERTY LLVM_HAS_EXPORTS True)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
diff --git a/llvm/cmake/modules/CMakeLists.txt b/llvm/cmake/modules/CMakeLists.txt
|
|
||||||
index f5cc0006fa0..6605dc729c2 100644
|
|
||||||
--- a/llvm/cmake/modules/CMakeLists.txt
|
|
||||||
+++ b/llvm/cmake/modules/CMakeLists.txt
|
|
||||||
@@ -97,6 +97,7 @@ set(LLVM_CONFIG_BINARY_DIR "\${LLVM_INSTALL_PREFIX}")
|
|
||||||
set(LLVM_CONFIG_TOOLS_BINARY_DIR "\${LLVM_INSTALL_PREFIX}/bin")
|
|
||||||
set(LLVM_CONFIG_EXPORTS_FILE "\${LLVM_CMAKE_DIR}/LLVMExports.cmake")
|
|
||||||
set(LLVM_CONFIG_EXPORTS "${LLVM_EXPORTS}")
|
|
||||||
+set(LLVM_CONFIG_STATIC_EXPORTS_FILE "\${LLVM_CMAKE_DIR}/LLVMStaticExports.cmake")
|
|
||||||
configure_file(
|
|
||||||
LLVMConfig.cmake.in
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/LLVMConfig.cmake
|
|
||||||
@@ -113,6 +114,8 @@ if (NOT LLVM_INSTALL_TOOLCHAIN_ONLY)
|
|
||||||
if(llvm_has_exports)
|
|
||||||
install(EXPORT LLVMExports DESTINATION ${LLVM_INSTALL_PACKAGE_DIR}
|
|
||||||
COMPONENT cmake-exports)
|
|
||||||
+ install(EXPORT LLVMStaticExports DESTINATION ${LLVM_INSTALL_PACKAGE_DIR}
|
|
||||||
+ COMPONENT cmake-exports)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
install(FILES
|
|
||||||
diff --git a/llvm/cmake/modules/LLVMConfig.cmake.in b/llvm/cmake/modules/LLVMConfig.cmake.in
|
|
||||||
index 7ca06381d90..44d042c9b11 100644
|
|
||||||
--- a/llvm/cmake/modules/LLVMConfig.cmake.in
|
|
||||||
+++ b/llvm/cmake/modules/LLVMConfig.cmake.in
|
|
||||||
@@ -84,6 +84,8 @@ if(NOT TARGET LLVMSupport)
|
|
||||||
set(LLVM_EXPORTED_TARGETS "@LLVM_CONFIG_EXPORTS@")
|
|
||||||
include("@LLVM_CONFIG_EXPORTS_FILE@")
|
|
||||||
@llvm_config_include_buildtree_only_exports@
|
|
||||||
+
|
|
||||||
+ include("@LLVM_CONFIG_STATIC_EXPORTS_FILE@" OPTIONAL)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# By creating intrinsics_gen here, subprojects that depend on LLVM's
|
|
||||||
diff --git a/llvm/tools/llvm-config/CMakeLists.txt b/llvm/tools/llvm-config/CMakeLists.txt
|
diff --git a/llvm/tools/llvm-config/CMakeLists.txt b/llvm/tools/llvm-config/CMakeLists.txt
|
||||||
index a7db17386fb..8a796d03b5a 100644
|
index 8e97a10..9b9b7d1 100644
|
||||||
--- a/llvm/tools/llvm-config/CMakeLists.txt
|
--- a/llvm/tools/llvm-config/CMakeLists.txt
|
||||||
+++ b/llvm/tools/llvm-config/CMakeLists.txt
|
+++ b/llvm/tools/llvm-config/CMakeLists.txt
|
||||||
@@ -42,7 +42,11 @@ set(LLVM_SRC_ROOT ${LLVM_MAIN_SRC_DIR})
|
@@ -43,7 +43,11 @@ set(LLVM_SRC_ROOT ${LLVM_MAIN_SRC_DIR})
|
||||||
set(LLVM_OBJ_ROOT ${LLVM_BINARY_DIR})
|
set(LLVM_OBJ_ROOT ${LLVM_BINARY_DIR})
|
||||||
set(LLVM_CPPFLAGS "${LLVM_DEFINITIONS}")
|
set(LLVM_CPPFLAGS "${LLVM_DEFINITIONS}")
|
||||||
set(LLVM_CFLAGS "${LLVM_C_STD_FLAG} ${LLVM_DEFINITIONS}")
|
set(LLVM_CFLAGS "${LLVM_C_STD_FLAG} ${LLVM_DEFINITIONS}")
|
||||||
+STRING(REGEX REPLACE "-mcet" "" LLVM_CFLAGS ${LLVM_CFLAGS})
|
+STRING(REGEX REPLACE "-mcet" "" LLVM_CFLAGS ${LLVM_CFLAGS})
|
||||||
+STRING(REGEX REPLACE "-fcf-protection" "" LLVM_CFLAGS ${LLVM_CFLAGS})
|
+STRING(REGEX REPLACE "-fcf-protection" "" LLVM_CFLAGS ${LLVM_CFLAGS})
|
||||||
set(LLVM_CXXFLAGS "${LLVM_CXX_STD_FLAG} ${COMPILE_FLAGS} ${LLVM_DEFINITIONS}")
|
set(LLVM_CXXFLAGS "${LLVM_CXX_STD_FLAG} ${LLVM_CXX_STDLIB_FLAG} ${COMPILE_FLAGS} ${LLVM_DEFINITIONS}")
|
||||||
+STRING(REGEX REPLACE "-mcet" "" LLVM_CXXFLAGS ${LLVM_CXXFLAGS})
|
+STRING(REGEX REPLACE "-mcet" "" LLVM_CXXFLAGS ${LLVM_CXXFLAGS})
|
||||||
+STRING(REGEX REPLACE "-fcf-protection" "" LLVM_CXXFLAGS ${LLVM_CXXFLAGS})
|
+STRING(REGEX REPLACE "-fcf-protection" "" LLVM_CXXFLAGS ${LLVM_CXXFLAGS})
|
||||||
set(LLVM_BUILD_SYSTEM cmake)
|
set(LLVM_BUILD_SYSTEM cmake)
|
||||||
set(LLVM_HAS_RTTI ${LLVM_CONFIG_HAS_RTTI})
|
set(LLVM_HAS_RTTI ${LLVM_CONFIG_HAS_RTTI})
|
||||||
set(LLVM_DYLIB_VERSION "${LLVM_VERSION_MAJOR}${LLVM_VERSION_SUFFIX}")
|
set(LLVM_DYLIB_VERSION "${LLVM_VERSION_MAJOR}${LLVM_VERSION_SUFFIX}")
|
||||||
--
|
--
|
||||||
2.20.1
|
1.8.3.1
|
||||||
|
|
||||||
|
@ -0,0 +1,34 @@
|
|||||||
|
From f0762684457a883b6813b48c98a1e94e377bc06b Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tom Stellard <tstellar@redhat.com>
|
||||||
|
Date: Wed, 28 Aug 2019 19:31:21 -0700
|
||||||
|
Subject: [PATCH] Pass target to gold linker to avoid faliures on i686
|
||||||
|
|
||||||
|
---
|
||||||
|
llvm/test/tools/gold/X86/linkonce_odr_unnamed_addr.ll | 4 ++--
|
||||||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/llvm/test/tools/gold/X86/linkonce_odr_unnamed_addr.ll b/llvm/test/tools/gold/X86/linkonce_odr_unnamed_addr.ll
|
||||||
|
index 525bf2d..01291bd 100644
|
||||||
|
--- a/llvm/test/tools/gold/X86/linkonce_odr_unnamed_addr.ll
|
||||||
|
+++ b/llvm/test/tools/gold/X86/linkonce_odr_unnamed_addr.ll
|
||||||
|
@@ -3,7 +3,7 @@
|
||||||
|
|
||||||
|
; RUN: opt -module-summary %s -o %t.o
|
||||||
|
; RUN: opt -module-summary %p/Inputs/linkonce_odr_unnamed_addr.ll -o %t2.o
|
||||||
|
-; RUN: %gold -plugin %llvmshlibdir/LLVMgold%shlibext \
|
||||||
|
+; RUN: %gold -m elf_x86_64 -plugin %llvmshlibdir/LLVMgold%shlibext \
|
||||||
|
; RUN: --plugin-opt=save-temps \
|
||||||
|
; RUN: %t.o %t2.o -o %t3.o
|
||||||
|
; RUN: llvm-dis %t.o.1.promote.bc -o - | FileCheck %s
|
||||||
|
@@ -11,7 +11,7 @@
|
||||||
|
; Now test when one module is a native object. In that case we must be
|
||||||
|
; conservative and not auto hide.
|
||||||
|
; RUN: llc %p/Inputs/linkonce_odr_unnamed_addr.ll -o %t2native.o -filetype=obj
|
||||||
|
-; RUN: %gold -plugin %llvmshlibdir/LLVMgold%shlibext \
|
||||||
|
+; RUN: %gold -m elf_x86_64 -plugin %llvmshlibdir/LLVMgold%shlibext \
|
||||||
|
; RUN: --plugin-opt=save-temps \
|
||||||
|
; RUN: %t.o %t2native.o -o %t3.o
|
||||||
|
; RUN: llvm-dis %t.o.1.promote.bc -o - | FileCheck %s --check-prefix=NOSUMMARY
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
113
SOURCES/0001-Revert-SCEV-add-no-wrap-flag-for-SCEVAddExpr.patch
Normal file
113
SOURCES/0001-Revert-SCEV-add-no-wrap-flag-for-SCEVAddExpr.patch
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
From 58e8c793d0e43150a6452e971a32d7407a8a7401 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tim Northover <tnorthover@apple.com>
|
||||||
|
Date: Mon, 30 Sep 2019 07:46:52 +0000
|
||||||
|
Subject: [PATCH] Revert "[SCEV] add no wrap flag for SCEVAddExpr."
|
||||||
|
|
||||||
|
This reverts r366419 because the analysis performed is within the context of
|
||||||
|
the loop and it's only valid to add wrapping flags to "global" expressions if
|
||||||
|
they're always correct.
|
||||||
|
|
||||||
|
llvm-svn: 373184
|
||||||
|
---
|
||||||
|
llvm/lib/Analysis/ScalarEvolution.cpp | 2 +-
|
||||||
|
llvm/test/Analysis/ScalarEvolution/limit-depth.ll | 2 +-
|
||||||
|
llvm/test/Analysis/ScalarEvolution/nsw.ll | 2 +-
|
||||||
|
llvm/test/Analysis/ScalarEvolution/trip-count12.ll | 2 +-
|
||||||
|
llvm/test/Analysis/ScalarEvolution/trip-count9.ll | 8 ++++----
|
||||||
|
5 files changed, 8 insertions(+), 8 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/llvm/lib/Analysis/ScalarEvolution.cpp b/llvm/lib/Analysis/ScalarEvolution.cpp
|
||||||
|
index 354ae05bb841..c29fc5dbccfb 100644
|
||||||
|
--- a/llvm/lib/Analysis/ScalarEvolution.cpp
|
||||||
|
+++ b/llvm/lib/Analysis/ScalarEvolution.cpp
|
||||||
|
@@ -4992,7 +4992,7 @@ const SCEV *ScalarEvolution::createSimpleAffineAddRec(PHINode *PN,
|
||||||
|
// overflow.
|
||||||
|
if (auto *BEInst = dyn_cast<Instruction>(BEValueV))
|
||||||
|
if (isLoopInvariant(Accum, L) && isAddRecNeverPoison(BEInst, L))
|
||||||
|
- (void)getAddRecExpr(getAddExpr(StartVal, Accum, Flags), Accum, L, Flags);
|
||||||
|
+ (void)getAddRecExpr(getAddExpr(StartVal, Accum), Accum, L, Flags);
|
||||||
|
|
||||||
|
return PHISCEV;
|
||||||
|
}
|
||||||
|
diff --git a/llvm/test/Analysis/ScalarEvolution/limit-depth.ll b/llvm/test/Analysis/ScalarEvolution/limit-depth.ll
|
||||||
|
index db68a4f84c91..6fdf8c5df974 100644
|
||||||
|
--- a/llvm/test/Analysis/ScalarEvolution/limit-depth.ll
|
||||||
|
+++ b/llvm/test/Analysis/ScalarEvolution/limit-depth.ll
|
||||||
|
@@ -46,7 +46,7 @@ define void @test_mul(i32 %a, i32 %b, i32 %c, i32 %d, i32 %e, i32 %f) {
|
||||||
|
define void @test_sext(i32 %a, i32 %b, i32 %c, i32 %d, i32 %e, i32 %f) {
|
||||||
|
; CHECK-LABEL: @test_sext
|
||||||
|
; CHECK: %se2 = sext i64 %iv2.inc to i128
|
||||||
|
-; CHECK-NEXT: --> {(1 + (sext i64 {(sext i32 (1 + %a)<nsw> to i64),+,1}<nsw><%loop> to i128))<nsw>,+,1}<nsw><%loop2>
|
||||||
|
+; CHECK-NEXT: --> {(1 + (sext i64 {(sext i32 (1 + %a) to i64),+,1}<nsw><%loop> to i128))<nsw>,+,1}<nsw><%loop2>
|
||||||
|
entry:
|
||||||
|
br label %loop
|
||||||
|
|
||||||
|
diff --git a/llvm/test/Analysis/ScalarEvolution/nsw.ll b/llvm/test/Analysis/ScalarEvolution/nsw.ll
|
||||||
|
index 69427368625d..ca24f9d4a04b 100644
|
||||||
|
--- a/llvm/test/Analysis/ScalarEvolution/nsw.ll
|
||||||
|
+++ b/llvm/test/Analysis/ScalarEvolution/nsw.ll
|
||||||
|
@@ -163,7 +163,7 @@ bb5: ; preds = %bb2
|
||||||
|
declare void @f(i32)
|
||||||
|
|
||||||
|
; CHECK-LABEL: nswnowrap
|
||||||
|
-; CHECK: --> {(1 + %v)<nsw>,+,1}<nsw><%for.body>{{ U: [^ ]+ S: [^ ]+}}{{ *}}Exits: (2 + %v)
|
||||||
|
+; CHECK: --> {(1 + %v)<nsw>,+,1}<nsw><%for.body>{{ U: [^ ]+ S: [^ ]+}}{{ *}}Exits: (1 + ((1 + %v)<nsw> smax %v))
|
||||||
|
define void @nswnowrap(i32 %v, i32* %buf) {
|
||||||
|
entry:
|
||||||
|
%add = add nsw i32 %v, 1
|
||||||
|
diff --git a/llvm/test/Analysis/ScalarEvolution/trip-count12.ll b/llvm/test/Analysis/ScalarEvolution/trip-count12.ll
|
||||||
|
index 5e7d72d5e4f3..d0086ee2e6ac 100644
|
||||||
|
--- a/llvm/test/Analysis/ScalarEvolution/trip-count12.ll
|
||||||
|
+++ b/llvm/test/Analysis/ScalarEvolution/trip-count12.ll
|
||||||
|
@@ -1,7 +1,7 @@
|
||||||
|
; RUN: opt < %s -analyze -scalar-evolution | FileCheck %s
|
||||||
|
|
||||||
|
; CHECK: Determining loop execution counts for: @test
|
||||||
|
-; CHECK: Loop %for.body: backedge-taken count is ((-2 + %len)<nsw> /u 2)
|
||||||
|
+; CHECK: Loop %for.body: backedge-taken count is ((-2 + %len) /u 2)
|
||||||
|
; CHECK: Loop %for.body: max backedge-taken count is 1073741823
|
||||||
|
|
||||||
|
define zeroext i16 @test(i16* nocapture %p, i32 %len) nounwind readonly {
|
||||||
|
diff --git a/llvm/test/Analysis/ScalarEvolution/trip-count9.ll b/llvm/test/Analysis/ScalarEvolution/trip-count9.ll
|
||||||
|
index c0a1d12fa00e..9a080b34743f 100644
|
||||||
|
--- a/llvm/test/Analysis/ScalarEvolution/trip-count9.ll
|
||||||
|
+++ b/llvm/test/Analysis/ScalarEvolution/trip-count9.ll
|
||||||
|
@@ -179,7 +179,7 @@ exit:
|
||||||
|
}
|
||||||
|
|
||||||
|
; CHECK: Determining loop execution counts for: @nsw_startx
|
||||||
|
-; CHECK: Loop %loop: backedge-taken count is (-1 + (-1 * %x) + ((1 + %x)<nsw> smax %n))
|
||||||
|
+; CHECK: Loop %loop: backedge-taken count is (-1 + (-1 * %x) + ((1 + %x) smax %n))
|
||||||
|
; CHECK: Loop %loop: max backedge-taken count is -1
|
||||||
|
define void @nsw_startx(i4 %n, i4 %x) {
|
||||||
|
entry:
|
||||||
|
@@ -195,7 +195,7 @@ exit:
|
||||||
|
}
|
||||||
|
|
||||||
|
; CHECK: Determining loop execution counts for: @nsw_startx_step2
|
||||||
|
-; CHECK: Loop %loop: backedge-taken count is ((-1 + (-1 * %x) + ((2 + %x)<nsw> smax %n)) /u 2)
|
||||||
|
+; CHECK: Loop %loop: backedge-taken count is ((-1 + (-1 * %x) + ((2 + %x) smax %n)) /u 2)
|
||||||
|
; CHECK: Loop %loop: max backedge-taken count is 7
|
||||||
|
define void @nsw_startx_step2(i4 %n, i4 %x) {
|
||||||
|
entry:
|
||||||
|
@@ -381,7 +381,7 @@ exit:
|
||||||
|
}
|
||||||
|
|
||||||
|
; CHECK: Determining loop execution counts for: @even_nsw_startx
|
||||||
|
-; CHECK: Loop %loop: backedge-taken count is (-1 + (-1 * %x) + ((1 + %x)<nsw> smax (2 * %n)))
|
||||||
|
+; CHECK: Loop %loop: backedge-taken count is (-1 + (-1 * %x) + ((1 + %x) smax (2 * %n)))
|
||||||
|
; CHECK: Loop %loop: max backedge-taken count is -2
|
||||||
|
define void @even_nsw_startx(i4 %n, i4 %x) {
|
||||||
|
entry:
|
||||||
|
@@ -398,7 +398,7 @@ exit:
|
||||||
|
}
|
||||||
|
|
||||||
|
; CHECK: Determining loop execution counts for: @even_nsw_startx_step2
|
||||||
|
-; CHECK: Loop %loop: backedge-taken count is ((-1 + (-1 * %x) + ((2 + %x)<nsw> smax (2 * %n))) /u 2)
|
||||||
|
+; CHECK: Loop %loop: backedge-taken count is ((-1 + (-1 * %x) + ((2 + %x) smax (2 * %n))) /u 2)
|
||||||
|
; CHECK: Loop %loop: max backedge-taken count is 7
|
||||||
|
define void @even_nsw_startx_step2(i4 %n, i4 %x) {
|
||||||
|
entry:
|
||||||
|
--
|
||||||
|
2.24.1
|
||||||
|
|
@ -1,381 +0,0 @@
|
|||||||
From 5fd2c900e90445c6efb7b97f8c663e588bcab81b Mon Sep 17 00:00:00 2001
|
|
||||||
From: serge-sans-paille <sguelton@redhat.com>
|
|
||||||
Date: Tue, 2 Jul 2019 09:25:52 +0000
|
|
||||||
Subject: [PATCH] Selectively disable threading from gold
|
|
||||||
|
|
||||||
Related: rhbz#1636479
|
|
||||||
---
|
|
||||||
llvm/include/llvm/LTO/LTO.h | 3 +
|
|
||||||
llvm/include/llvm/LTO/LTOBackend.h | 3 +
|
|
||||||
llvm/include/llvm/Support/ThreadPool.h | 7 ++
|
|
||||||
llvm/lib/LTO/LTO.cpp | 134 ++++++++++++++++++++++++-
|
|
||||||
llvm/lib/LTO/LTOBackend.cpp | 48 ++++++++-
|
|
||||||
llvm/lib/Support/ThreadPool.cpp | 6 +-
|
|
||||||
llvm/tools/gold/gold-plugin.cpp | 7 +-
|
|
||||||
7 files changed, 197 insertions(+), 11 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/llvm/include/llvm/LTO/LTO.h b/llvm/include/llvm/LTO/LTO.h
|
|
||||||
index 534d9b6f3f2..9dfda126540 100644
|
|
||||||
--- a/llvm/include/llvm/LTO/LTO.h
|
|
||||||
+++ b/llvm/include/llvm/LTO/LTO.h
|
|
||||||
@@ -212,6 +212,7 @@ typedef std::function<std::unique_ptr<ThinBackendProc>(
|
|
||||||
|
|
||||||
/// This ThinBackend runs the individual backend jobs in-process.
|
|
||||||
ThinBackend createInProcessThinBackend(unsigned ParallelismLevel);
|
|
||||||
+ThinBackend createInProcessThinBackendNoThread(unsigned ParallelismLevel);
|
|
||||||
|
|
||||||
/// This ThinBackend writes individual module indexes to files, instead of
|
|
||||||
/// running the individual backend jobs. This backend is for distributed builds
|
|
||||||
@@ -281,6 +282,7 @@ public:
|
|
||||||
/// The client will receive at most one callback (via either AddStream or
|
|
||||||
/// Cache) for each task identifier.
|
|
||||||
Error run(AddStreamFn AddStream, NativeObjectCache Cache = nullptr);
|
|
||||||
+ Error runNoThread(AddStreamFn AddStream, NativeObjectCache Cache = nullptr);
|
|
||||||
|
|
||||||
private:
|
|
||||||
Config Conf;
|
|
||||||
@@ -397,6 +399,7 @@ private:
|
|
||||||
const SymbolResolution *&ResI, const SymbolResolution *ResE);
|
|
||||||
|
|
||||||
Error runRegularLTO(AddStreamFn AddStream);
|
|
||||||
+ Error runRegularLTONoThread(AddStreamFn AddStream);
|
|
||||||
Error runThinLTO(AddStreamFn AddStream, NativeObjectCache Cache);
|
|
||||||
|
|
||||||
mutable bool CalledGetMaxTasks = false;
|
|
||||||
diff --git a/llvm/include/llvm/LTO/LTOBackend.h b/llvm/include/llvm/LTO/LTOBackend.h
|
|
||||||
index d4743f6940f..2d6461fa82e 100644
|
|
||||||
--- a/llvm/include/llvm/LTO/LTOBackend.h
|
|
||||||
+++ b/llvm/include/llvm/LTO/LTOBackend.h
|
|
||||||
@@ -39,6 +39,9 @@ namespace lto {
|
|
||||||
Error backend(Config &C, AddStreamFn AddStream,
|
|
||||||
unsigned ParallelCodeGenParallelismLevel,
|
|
||||||
std::unique_ptr<Module> M, ModuleSummaryIndex &CombinedIndex);
|
|
||||||
+Error backendNoThread(Config &C, AddStreamFn AddStream,
|
|
||||||
+ unsigned ParallelCodeGenParallelismLevel,
|
|
||||||
+ std::unique_ptr<Module> M, ModuleSummaryIndex &CombinedIndex);
|
|
||||||
|
|
||||||
/// Runs a ThinLTO backend.
|
|
||||||
Error thinBackend(Config &C, unsigned Task, AddStreamFn AddStream, Module &M,
|
|
||||||
diff --git a/llvm/include/llvm/Support/ThreadPool.h b/llvm/include/llvm/Support/ThreadPool.h
|
|
||||||
index 4fdbd528b21..60ea5097114 100644
|
|
||||||
--- a/llvm/include/llvm/Support/ThreadPool.h
|
|
||||||
+++ b/llvm/include/llvm/Support/ThreadPool.h
|
|
||||||
@@ -98,4 +98,11 @@ private:
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
+#ifndef ThreadPool
|
|
||||||
+#undef LLVM_SUPPORT_THREAD_POOL_H
|
|
||||||
+#define ThreadPool SequentialThreadPool
|
|
||||||
+#include "llvm/Support/ThreadPool.h"
|
|
||||||
+#undef ThreadPool
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
#endif // LLVM_SUPPORT_THREAD_POOL_H
|
|
||||||
diff --git a/llvm/lib/LTO/LTO.cpp b/llvm/lib/LTO/LTO.cpp
|
|
||||||
index 3a955060dea..a7b4f45b18c 100644
|
|
||||||
--- a/llvm/lib/LTO/LTO.cpp
|
|
||||||
+++ b/llvm/lib/LTO/LTO.cpp
|
|
||||||
@@ -861,6 +861,58 @@ Error LTO::run(AddStreamFn AddStream, NativeObjectCache Cache) {
|
|
||||||
return Result;
|
|
||||||
}
|
|
||||||
|
|
||||||
+Error LTO::runNoThread(AddStreamFn AddStream, NativeObjectCache Cache) {
|
|
||||||
+ // Compute "dead" symbols, we don't want to import/export these!
|
|
||||||
+ DenseSet<GlobalValue::GUID> GUIDPreservedSymbols;
|
|
||||||
+ DenseMap<GlobalValue::GUID, PrevailingType> GUIDPrevailingResolutions;
|
|
||||||
+ for (auto &Res : GlobalResolutions) {
|
|
||||||
+ // Normally resolution have IR name of symbol. We can do nothing here
|
|
||||||
+ // otherwise. See comments in GlobalResolution struct for more details.
|
|
||||||
+ if (Res.second.IRName.empty())
|
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
+ GlobalValue::GUID GUID = GlobalValue::getGUID(
|
|
||||||
+ GlobalValue::dropLLVMManglingEscape(Res.second.IRName));
|
|
||||||
+
|
|
||||||
+ if (Res.second.VisibleOutsideSummary && Res.second.Prevailing)
|
|
||||||
+ GUIDPreservedSymbols.insert(GlobalValue::getGUID(
|
|
||||||
+ GlobalValue::dropLLVMManglingEscape(Res.second.IRName)));
|
|
||||||
+
|
|
||||||
+ GUIDPrevailingResolutions[GUID] =
|
|
||||||
+ Res.second.Prevailing ? PrevailingType::Yes : PrevailingType::No;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ auto isPrevailing = [&](GlobalValue::GUID G) {
|
|
||||||
+ auto It = GUIDPrevailingResolutions.find(G);
|
|
||||||
+ if (It == GUIDPrevailingResolutions.end())
|
|
||||||
+ return PrevailingType::Unknown;
|
|
||||||
+ return It->second;
|
|
||||||
+ };
|
|
||||||
+ computeDeadSymbolsWithConstProp(ThinLTO.CombinedIndex, GUIDPreservedSymbols,
|
|
||||||
+ isPrevailing, Conf.OptLevel > 0);
|
|
||||||
+
|
|
||||||
+ // Setup output file to emit statistics.
|
|
||||||
+ std::unique_ptr<ToolOutputFile> StatsFile = nullptr;
|
|
||||||
+ if (!Conf.StatsFile.empty()) {
|
|
||||||
+ EnableStatistics(false);
|
|
||||||
+ std::error_code EC;
|
|
||||||
+ StatsFile =
|
|
||||||
+ llvm::make_unique<ToolOutputFile>(Conf.StatsFile, EC, sys::fs::F_None);
|
|
||||||
+ if (EC)
|
|
||||||
+ return errorCodeToError(EC);
|
|
||||||
+ StatsFile->keep();
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ Error Result = runRegularLTONoThread(AddStream);
|
|
||||||
+ if (!Result)
|
|
||||||
+ Result = runThinLTO(AddStream, Cache);
|
|
||||||
+
|
|
||||||
+ if (StatsFile)
|
|
||||||
+ PrintStatisticsJSON(StatsFile->os());
|
|
||||||
+
|
|
||||||
+ return Result;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
Error LTO::runRegularLTO(AddStreamFn AddStream) {
|
|
||||||
for (auto &M : RegularLTO.ModsWithSummaries)
|
|
||||||
if (Error Err = linkRegularLTO(std::move(M),
|
|
||||||
@@ -928,6 +980,73 @@ Error LTO::runRegularLTO(AddStreamFn AddStream) {
|
|
||||||
std::move(RegularLTO.CombinedModule), ThinLTO.CombinedIndex);
|
|
||||||
}
|
|
||||||
|
|
||||||
+Error LTO::runRegularLTONoThread(AddStreamFn AddStream) {
|
|
||||||
+ for (auto &M : RegularLTO.ModsWithSummaries)
|
|
||||||
+ if (Error Err = linkRegularLTO(std::move(M),
|
|
||||||
+ /*LivenessFromIndex=*/true))
|
|
||||||
+ return Err;
|
|
||||||
+
|
|
||||||
+ // Make sure commons have the right size/alignment: we kept the largest from
|
|
||||||
+ // all the prevailing when adding the inputs, and we apply it here.
|
|
||||||
+ const DataLayout &DL = RegularLTO.CombinedModule->getDataLayout();
|
|
||||||
+ for (auto &I : RegularLTO.Commons) {
|
|
||||||
+ if (!I.second.Prevailing)
|
|
||||||
+ // Don't do anything if no instance of this common was prevailing.
|
|
||||||
+ continue;
|
|
||||||
+ GlobalVariable *OldGV = RegularLTO.CombinedModule->getNamedGlobal(I.first);
|
|
||||||
+ if (OldGV && DL.getTypeAllocSize(OldGV->getValueType()) == I.second.Size) {
|
|
||||||
+ // Don't create a new global if the type is already correct, just make
|
|
||||||
+ // sure the alignment is correct.
|
|
||||||
+ OldGV->setAlignment(I.second.Align);
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+ ArrayType *Ty =
|
|
||||||
+ ArrayType::get(Type::getInt8Ty(RegularLTO.Ctx), I.second.Size);
|
|
||||||
+ auto *GV = new GlobalVariable(*RegularLTO.CombinedModule, Ty, false,
|
|
||||||
+ GlobalValue::CommonLinkage,
|
|
||||||
+ ConstantAggregateZero::get(Ty), "");
|
|
||||||
+ GV->setAlignment(I.second.Align);
|
|
||||||
+ if (OldGV) {
|
|
||||||
+ OldGV->replaceAllUsesWith(ConstantExpr::getBitCast(GV, OldGV->getType()));
|
|
||||||
+ GV->takeName(OldGV);
|
|
||||||
+ OldGV->eraseFromParent();
|
|
||||||
+ } else {
|
|
||||||
+ GV->setName(I.first);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (Conf.PreOptModuleHook &&
|
|
||||||
+ !Conf.PreOptModuleHook(0, *RegularLTO.CombinedModule))
|
|
||||||
+ return Error::success();
|
|
||||||
+
|
|
||||||
+ if (!Conf.CodeGenOnly) {
|
|
||||||
+ for (const auto &R : GlobalResolutions) {
|
|
||||||
+ if (!R.second.isPrevailingIRSymbol())
|
|
||||||
+ continue;
|
|
||||||
+ if (R.second.Partition != 0 &&
|
|
||||||
+ R.second.Partition != GlobalResolution::External)
|
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
+ GlobalValue *GV =
|
|
||||||
+ RegularLTO.CombinedModule->getNamedValue(R.second.IRName);
|
|
||||||
+ // Ignore symbols defined in other partitions.
|
|
||||||
+ // Also skip declarations, which are not allowed to have internal linkage.
|
|
||||||
+ if (!GV || GV->hasLocalLinkage() || GV->isDeclaration())
|
|
||||||
+ continue;
|
|
||||||
+ GV->setUnnamedAddr(R.second.UnnamedAddr ? GlobalValue::UnnamedAddr::Global
|
|
||||||
+ : GlobalValue::UnnamedAddr::None);
|
|
||||||
+ if (EnableLTOInternalization && R.second.Partition == 0)
|
|
||||||
+ GV->setLinkage(GlobalValue::InternalLinkage);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (Conf.PostInternalizeModuleHook &&
|
|
||||||
+ !Conf.PostInternalizeModuleHook(0, *RegularLTO.CombinedModule))
|
|
||||||
+ return Error::success();
|
|
||||||
+ }
|
|
||||||
+ return backendNoThread(Conf, AddStream, RegularLTO.ParallelCodeGenParallelismLevel,
|
|
||||||
+ std::move(RegularLTO.CombinedModule), ThinLTO.CombinedIndex);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
/// This class defines the interface to the ThinLTO backend.
|
|
||||||
class lto::ThinBackendProc {
|
|
||||||
protected:
|
|
||||||
@@ -952,8 +1071,9 @@ public:
|
|
||||||
};
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
+template<class ThreadEngine>
|
|
||||||
class InProcessThinBackend : public ThinBackendProc {
|
|
||||||
- ThreadPool BackendThreadPool;
|
|
||||||
+ ThreadEngine BackendThreadPool;
|
|
||||||
AddStreamFn AddStream;
|
|
||||||
NativeObjectCache Cache;
|
|
||||||
std::set<GlobalValue::GUID> CfiFunctionDefs;
|
|
||||||
@@ -1065,9 +1185,19 @@ ThinBackend lto::createInProcessThinBackend(unsigned ParallelismLevel) {
|
|
||||||
return [=](Config &Conf, ModuleSummaryIndex &CombinedIndex,
|
|
||||||
const StringMap<GVSummaryMapTy> &ModuleToDefinedGVSummaries,
|
|
||||||
AddStreamFn AddStream, NativeObjectCache Cache) {
|
|
||||||
- return llvm::make_unique<InProcessThinBackend>(
|
|
||||||
+ return llvm::make_unique<InProcessThinBackend<ThreadPool>>(
|
|
||||||
+ Conf, CombinedIndex, ParallelismLevel, ModuleToDefinedGVSummaries,
|
|
||||||
+ AddStream, Cache);
|
|
||||||
+ };
|
|
||||||
+}
|
|
||||||
+ThinBackend lto::createInProcessThinBackendNoThread(unsigned ParallelismLevel) {
|
|
||||||
+ return [=](Config &Conf, ModuleSummaryIndex &CombinedIndex,
|
|
||||||
+ const StringMap<GVSummaryMapTy> &ModuleToDefinedGVSummaries,
|
|
||||||
+ AddStreamFn AddStream, NativeObjectCache Cache) {
|
|
||||||
+ ThinBackendProc* Backend = new InProcessThinBackend<SequentialThreadPool>(
|
|
||||||
Conf, CombinedIndex, ParallelismLevel, ModuleToDefinedGVSummaries,
|
|
||||||
AddStream, Cache);
|
|
||||||
+ return std::unique_ptr<ThinBackendProc>(Backend);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
diff --git a/llvm/lib/LTO/LTOBackend.cpp b/llvm/lib/LTO/LTOBackend.cpp
|
|
||||||
index 926c419e34a..2c263ed86a9 100644
|
|
||||||
--- a/llvm/lib/LTO/LTOBackend.cpp
|
|
||||||
+++ b/llvm/lib/LTO/LTOBackend.cpp
|
|
||||||
@@ -333,10 +333,11 @@ void codegen(Config &Conf, TargetMachine *TM, AddStreamFn AddStream,
|
|
||||||
DwoOut->keep();
|
|
||||||
}
|
|
||||||
|
|
||||||
-void splitCodeGen(Config &C, TargetMachine *TM, AddStreamFn AddStream,
|
|
||||||
+template<class ThreadPoolEngine>
|
|
||||||
+static void splitCodeGen_(Config &C, TargetMachine *TM, AddStreamFn AddStream,
|
|
||||||
unsigned ParallelCodeGenParallelismLevel,
|
|
||||||
std::unique_ptr<Module> Mod) {
|
|
||||||
- ThreadPool CodegenThreadPool(ParallelCodeGenParallelismLevel);
|
|
||||||
+ ThreadPoolEngine CodegenThreadPool(ParallelCodeGenParallelismLevel);
|
|
||||||
unsigned ThreadCount = 0;
|
|
||||||
const Target *T = &TM->getTarget();
|
|
||||||
|
|
||||||
@@ -380,6 +381,17 @@ void splitCodeGen(Config &C, TargetMachine *TM, AddStreamFn AddStream,
|
|
||||||
// can leave the function scope.
|
|
||||||
CodegenThreadPool.wait();
|
|
||||||
}
|
|
||||||
+void splitCodeGen(Config &C, TargetMachine *TM, AddStreamFn AddStream,
|
|
||||||
+ unsigned ParallelCodeGenParallelismLevel,
|
|
||||||
+ std::unique_ptr<Module> Mod) {
|
|
||||||
+ splitCodeGen_<ThreadPool>(C, TM, AddStream, ParallelCodeGenParallelismLevel, std::move(Mod));
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void splitCodeGenNoThread(Config &C, TargetMachine *TM, AddStreamFn AddStream,
|
|
||||||
+ unsigned ParallelCodeGenParallelismLevel,
|
|
||||||
+ std::unique_ptr<Module> Mod) {
|
|
||||||
+ splitCodeGen_<SequentialThreadPool>(C, TM, AddStream, ParallelCodeGenParallelismLevel, std::move(Mod));
|
|
||||||
+}
|
|
||||||
|
|
||||||
Expected<const Target *> initAndLookupTarget(Config &C, Module &Mod) {
|
|
||||||
if (!C.OverrideTriple.empty())
|
|
||||||
@@ -439,6 +451,38 @@ Error lto::backend(Config &C, AddStreamFn AddStream,
|
|
||||||
return finalizeOptimizationRemarks(std::move(DiagnosticOutputFile));
|
|
||||||
}
|
|
||||||
|
|
||||||
+Error lto::backendNoThread(Config &C, AddStreamFn AddStream,
|
|
||||||
+ unsigned ParallelCodeGenParallelismLevel,
|
|
||||||
+ std::unique_ptr<Module> Mod,
|
|
||||||
+ ModuleSummaryIndex &CombinedIndex) {
|
|
||||||
+ Expected<const Target *> TOrErr = initAndLookupTarget(C, *Mod);
|
|
||||||
+ if (!TOrErr)
|
|
||||||
+ return TOrErr.takeError();
|
|
||||||
+
|
|
||||||
+ std::unique_ptr<TargetMachine> TM = createTargetMachine(C, *TOrErr, *Mod);
|
|
||||||
+
|
|
||||||
+ // Setup optimization remarks.
|
|
||||||
+ auto DiagFileOrErr = lto::setupOptimizationRemarks(
|
|
||||||
+ Mod->getContext(), C.RemarksFilename, C.RemarksWithHotness);
|
|
||||||
+ if (!DiagFileOrErr)
|
|
||||||
+ return DiagFileOrErr.takeError();
|
|
||||||
+ auto DiagnosticOutputFile = std::move(*DiagFileOrErr);
|
|
||||||
+
|
|
||||||
+ if (!C.CodeGenOnly) {
|
|
||||||
+ if (!opt(C, TM.get(), 0, *Mod, /*IsThinLTO=*/false,
|
|
||||||
+ /*ExportSummary=*/&CombinedIndex, /*ImportSummary=*/nullptr))
|
|
||||||
+ return finalizeOptimizationRemarks(std::move(DiagnosticOutputFile));
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (ParallelCodeGenParallelismLevel == 1) {
|
|
||||||
+ codegen(C, TM.get(), AddStream, 0, *Mod);
|
|
||||||
+ } else {
|
|
||||||
+ splitCodeGenNoThread(C, TM.get(), AddStream, ParallelCodeGenParallelismLevel,
|
|
||||||
+ std::move(Mod));
|
|
||||||
+ }
|
|
||||||
+ return finalizeOptimizationRemarks(std::move(DiagnosticOutputFile));
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static void dropDeadSymbols(Module &Mod, const GVSummaryMapTy &DefinedGlobals,
|
|
||||||
const ModuleSummaryIndex &Index) {
|
|
||||||
std::vector<GlobalValue*> DeadGVs;
|
|
||||||
diff --git a/llvm/lib/Support/ThreadPool.cpp b/llvm/lib/Support/ThreadPool.cpp
|
|
||||||
index d0212ca1346..3d760edbcb7 100644
|
|
||||||
--- a/llvm/lib/Support/ThreadPool.cpp
|
|
||||||
+++ b/llvm/lib/Support/ThreadPool.cpp
|
|
||||||
@@ -19,8 +19,6 @@
|
|
||||||
|
|
||||||
using namespace llvm;
|
|
||||||
|
|
||||||
-#if LLVM_ENABLE_THREADS
|
|
||||||
-
|
|
||||||
// Default to hardware_concurrency
|
|
||||||
ThreadPool::ThreadPool() : ThreadPool(hardware_concurrency()) {}
|
|
||||||
|
|
||||||
@@ -107,7 +105,7 @@ ThreadPool::~ThreadPool() {
|
|
||||||
Worker.join();
|
|
||||||
}
|
|
||||||
|
|
||||||
-#else // LLVM_ENABLE_THREADS Disabled
|
|
||||||
+#define ThreadPool SequentialThreadPool
|
|
||||||
|
|
||||||
ThreadPool::ThreadPool() : ThreadPool(0) {}
|
|
||||||
|
|
||||||
@@ -142,5 +140,3 @@ std::shared_future<void> ThreadPool::asyncImpl(TaskTy Task) {
|
|
||||||
ThreadPool::~ThreadPool() {
|
|
||||||
wait();
|
|
||||||
}
|
|
||||||
-
|
|
||||||
-#endif
|
|
||||||
diff --git a/llvm/tools/gold/gold-plugin.cpp b/llvm/tools/gold/gold-plugin.cpp
|
|
||||||
index 738cafa6cac..8ef75d2589c 100644
|
|
||||||
--- a/llvm/tools/gold/gold-plugin.cpp
|
|
||||||
+++ b/llvm/tools/gold/gold-plugin.cpp
|
|
||||||
@@ -848,7 +848,7 @@ static std::unique_ptr<LTO> createLTO(IndexWriteCallback OnIndexWrite,
|
|
||||||
Conf.DisableVerify = options::DisableVerify;
|
|
||||||
Conf.OptLevel = options::OptLevel;
|
|
||||||
if (options::Parallelism)
|
|
||||||
- Backend = createInProcessThinBackend(options::Parallelism);
|
|
||||||
+ Backend = createInProcessThinBackendNoThread(options::Parallelism);
|
|
||||||
if (options::thinlto_index_only) {
|
|
||||||
std::string OldPrefix, NewPrefix;
|
|
||||||
getThinLTOOldAndNewPrefix(OldPrefix, NewPrefix);
|
|
||||||
@@ -856,6 +856,9 @@ static std::unique_ptr<LTO> createLTO(IndexWriteCallback OnIndexWrite,
|
|
||||||
options::thinlto_emit_imports_files,
|
|
||||||
LinkedObjectsFile, OnIndexWrite);
|
|
||||||
}
|
|
||||||
+ if(!Backend)
|
|
||||||
+ Backend = createInProcessThinBackendNoThread(llvm::heavyweight_hardware_concurrency());
|
|
||||||
+
|
|
||||||
|
|
||||||
Conf.OverrideTriple = options::triple;
|
|
||||||
Conf.DefaultTriple = sys::getDefaultTargetTriple();
|
|
||||||
@@ -1039,7 +1042,7 @@ static std::vector<std::pair<SmallString<128>, bool>> runLTO() {
|
|
||||||
if (!options::cache_dir.empty())
|
|
||||||
Cache = check(localCache(options::cache_dir, AddBuffer));
|
|
||||||
|
|
||||||
- check(Lto->run(AddStream, Cache));
|
|
||||||
+ check(Lto->runNoThread(AddStream, Cache));
|
|
||||||
|
|
||||||
// Write empty output files that may be expected by the distributed build
|
|
||||||
// system.
|
|
||||||
--
|
|
||||||
2.20.1
|
|
||||||
|
|
@ -0,0 +1,248 @@
|
|||||||
|
From e4e77bb8bf741f52b43b90987646f1c118914848 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jordan Rupprecht <rupprecht@google.com>
|
||||||
|
Date: Wed, 21 Aug 2019 18:00:17 +0000
|
||||||
|
Subject: [PATCH] [docs] Convert remaining command guide entries from md to
|
||||||
|
rst.
|
||||||
|
|
||||||
|
Summary:
|
||||||
|
Linking between markdown and rst files is currently not supported very well, e.g. the current llvm-addr2line docs [1] link to "llvm-symbolizer" instead of "llvm-symbolizer.html". This is weirdly broken in different ways depending on which versions of sphinx and recommonmark are being used, so workaround the bug by using rst everywhere.
|
||||||
|
|
||||||
|
[1] http://llvm.org/docs/CommandGuide/llvm-addr2line.html
|
||||||
|
|
||||||
|
Reviewers: jhenderson
|
||||||
|
|
||||||
|
Reviewed By: jhenderson
|
||||||
|
|
||||||
|
Subscribers: lebedev.ri, llvm-commits
|
||||||
|
|
||||||
|
Tags: #llvm
|
||||||
|
|
||||||
|
Differential Revision: https://reviews.llvm.org/D66305
|
||||||
|
|
||||||
|
llvm-svn: 369553
|
||||||
|
---
|
||||||
|
llvm/docs/CommandGuide/llvm-addr2line.md | 28 -----------------------
|
||||||
|
llvm/docs/CommandGuide/llvm-addr2line.rst | 38 +++++++++++++++++++++++++++++++
|
||||||
|
llvm/docs/CommandGuide/llvm-ranlib.md | 17 --------------
|
||||||
|
llvm/docs/CommandGuide/llvm-ranlib.rst | 23 +++++++++++++++++++
|
||||||
|
llvm/docs/CommandGuide/llvm-size.md | 10 --------
|
||||||
|
llvm/docs/CommandGuide/llvm-size.rst | 15 ++++++++++++
|
||||||
|
llvm/docs/CommandGuide/llvm-strings.md | 10 --------
|
||||||
|
llvm/docs/CommandGuide/llvm-strings.rst | 15 ++++++++++++
|
||||||
|
8 files changed, 91 insertions(+), 65 deletions(-)
|
||||||
|
delete mode 100644 llvm/docs/CommandGuide/llvm-addr2line.md
|
||||||
|
create mode 100644 llvm/docs/CommandGuide/llvm-addr2line.rst
|
||||||
|
delete mode 100644 llvm/docs/CommandGuide/llvm-ranlib.md
|
||||||
|
create mode 100644 llvm/docs/CommandGuide/llvm-ranlib.rst
|
||||||
|
delete mode 100644 llvm/docs/CommandGuide/llvm-size.md
|
||||||
|
create mode 100644 llvm/docs/CommandGuide/llvm-size.rst
|
||||||
|
delete mode 100644 llvm/docs/CommandGuide/llvm-strings.md
|
||||||
|
create mode 100644 llvm/docs/CommandGuide/llvm-strings.rst
|
||||||
|
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-addr2line.md b/llvm/docs/CommandGuide/llvm-addr2line.md
|
||||||
|
deleted file mode 100644
|
||||||
|
index 03224c4..0000000
|
||||||
|
--- a/llvm/docs/CommandGuide/llvm-addr2line.md
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,28 +0,0 @@
|
||||||
|
-# llvm-addr2line - a drop-in replacement for addr2line
|
||||||
|
-
|
||||||
|
-## SYNOPSIS
|
||||||
|
-
|
||||||
|
-**llvm-addr2line** [*options*]
|
||||||
|
-
|
||||||
|
-## DESCRIPTION
|
||||||
|
-
|
||||||
|
-**llvm-addr2line** is an alias for the [llvm-symbolizer](llvm-symbolizer) tool
|
||||||
|
-with different defaults. The goal is to make it a drop-in replacement for
|
||||||
|
-GNU's **addr2line**.
|
||||||
|
-
|
||||||
|
-Here are some of those differences:
|
||||||
|
-
|
||||||
|
-* Defaults not to print function names. Use [-f](llvm-symbolizer-opt-f)
|
||||||
|
- to enable that.
|
||||||
|
-
|
||||||
|
-* Defaults not to demangle function names. Use [-C](llvm-symbolizer-opt-C)
|
||||||
|
- to switch the demangling on.
|
||||||
|
-
|
||||||
|
-* Defaults not to print inlined frames. Use [-i](llvm-symbolizer-opt-i)
|
||||||
|
- to show inlined frames for a source code location in an inlined function.
|
||||||
|
-
|
||||||
|
-* Uses [--output-style=GNU](llvm-symbolizer-opt-output-style) by default.
|
||||||
|
-
|
||||||
|
-## SEE ALSO
|
||||||
|
-
|
||||||
|
-Refer to [llvm-symbolizer](llvm-symbolizer) for additional information.
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-addr2line.rst b/llvm/docs/CommandGuide/llvm-addr2line.rst
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..08f1b69
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/llvm/docs/CommandGuide/llvm-addr2line.rst
|
||||||
|
@@ -0,0 +1,38 @@
|
||||||
|
+llvm-addr2line - a drop-in replacement for addr2line
|
||||||
|
+====================================================
|
||||||
|
+
|
||||||
|
+.. program:: llvm-addr2line
|
||||||
|
+
|
||||||
|
+SYNOPSIS
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:program:`llvm-addr2line` [*options*]
|
||||||
|
+
|
||||||
|
+DESCRIPTION
|
||||||
|
+-----------
|
||||||
|
+
|
||||||
|
+:program:`llvm-addr2line` is an alias for the :manpage:`llvm-symbolizer(1)`
|
||||||
|
+tool with different defaults. The goal is to make it a drop-in replacement for
|
||||||
|
+GNU's :program:`addr2line`.
|
||||||
|
+
|
||||||
|
+Here are some of those differences:
|
||||||
|
+
|
||||||
|
+- Defaults not to print function names. Use `-f`_ to enable that.
|
||||||
|
+
|
||||||
|
+- Defaults not to demangle function names. Use `-C`_ to switch the
|
||||||
|
+ demangling on.
|
||||||
|
+
|
||||||
|
+- Defaults not to print inlined frames. Use `-i`_ to show inlined
|
||||||
|
+ frames for a source code location in an inlined function.
|
||||||
|
+
|
||||||
|
+- Uses `--output-style=GNU`_ by default.
|
||||||
|
+
|
||||||
|
+SEE ALSO
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:manpage:`llvm-symbolizer(1)`
|
||||||
|
+
|
||||||
|
+.. _-f: llvm-symbolizer.html#llvm-symbolizer-opt-f
|
||||||
|
+.. _-C: llvm-symbolizer.html#llvm-symbolizer-opt-c
|
||||||
|
+.. _-i: llvm-symbolizer.html#llvm-symbolizer-opt-i
|
||||||
|
+.. _--output-style=GNU: llvm-symbolizer.html#llvm-symbolizer-opt-output-style
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-ranlib.md b/llvm/docs/CommandGuide/llvm-ranlib.md
|
||||||
|
deleted file mode 100644
|
||||||
|
index 4377364..0000000
|
||||||
|
--- a/llvm/docs/CommandGuide/llvm-ranlib.md
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,17 +0,0 @@
|
||||||
|
-# llvm-ranlib - generates an archive index
|
||||||
|
-
|
||||||
|
-## SYNOPSIS
|
||||||
|
-
|
||||||
|
-**llvm-ranlib** [*options*]
|
||||||
|
-
|
||||||
|
-## DESCRIPTION
|
||||||
|
-
|
||||||
|
-**llvm-ranlib** is an alias for the [llvm-ar](llvm-ar.html) tool that generates
|
||||||
|
-an index for an archive. It can be used as a replacement for GNU's **ranlib**
|
||||||
|
-tool.
|
||||||
|
-
|
||||||
|
-Running **llvm-ranlib** is equivalent to running **llvm-ar s**.
|
||||||
|
-
|
||||||
|
-## SEE ALSO
|
||||||
|
-
|
||||||
|
-Refer to [llvm-ar](llvm-ar.html) for additional information.
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-ranlib.rst b/llvm/docs/CommandGuide/llvm-ranlib.rst
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..314a330
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/llvm/docs/CommandGuide/llvm-ranlib.rst
|
||||||
|
@@ -0,0 +1,23 @@
|
||||||
|
+llvm-ranlib - generates an archive index
|
||||||
|
+========================================
|
||||||
|
+
|
||||||
|
+.. program:: llvm-ranlib
|
||||||
|
+
|
||||||
|
+SYNOPSIS
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:program:`llvm-ranlib` [*options*]
|
||||||
|
+
|
||||||
|
+DESCRIPTION
|
||||||
|
+-----------
|
||||||
|
+
|
||||||
|
+:program:`llvm-ranlib` is an alias for the :doc:`llvm-ar <llvm-ar>` tool that
|
||||||
|
+generates an index for an archive. It can be used as a replacement for GNU’s
|
||||||
|
+:program:`ranlib` tool.
|
||||||
|
+
|
||||||
|
+Running :program:`llvm-ranlib` is equivalent to running ``llvm-ar s``.
|
||||||
|
+
|
||||||
|
+SEE ALSO
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:manpage:`llvm-ar(1)`
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-size.md b/llvm/docs/CommandGuide/llvm-size.md
|
||||||
|
deleted file mode 100644
|
||||||
|
index 3952708..0000000
|
||||||
|
--- a/llvm/docs/CommandGuide/llvm-size.md
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,10 +0,0 @@
|
||||||
|
-# llvm-size - print segment sizes
|
||||||
|
-
|
||||||
|
-## SYNOPSIS
|
||||||
|
-
|
||||||
|
-**llvm-size** [*options*]
|
||||||
|
-
|
||||||
|
-## DESCRIPTION
|
||||||
|
-
|
||||||
|
-**llvm-size** is a tool that prints segment sizes in object files. The goal is
|
||||||
|
-to make it a drop-in replacement for GNU's **size**.
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-size.rst b/llvm/docs/CommandGuide/llvm-size.rst
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..0dce15c
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/llvm/docs/CommandGuide/llvm-size.rst
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+llvm-size - print size information
|
||||||
|
+==================================
|
||||||
|
+
|
||||||
|
+.. program:: llvm-size
|
||||||
|
+
|
||||||
|
+SYNOPSIS
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:program:`llvm-size` [*options*]
|
||||||
|
+
|
||||||
|
+DESCRIPTION
|
||||||
|
+-----------
|
||||||
|
+
|
||||||
|
+:program:`llvm-size` is a tool that prints size information for object files.
|
||||||
|
+The goal is to make it a drop-in replacement for GNU’s :program:`size`.
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-strings.md b/llvm/docs/CommandGuide/llvm-strings.md
|
||||||
|
deleted file mode 100644
|
||||||
|
index b5871c4..0000000
|
||||||
|
--- a/llvm/docs/CommandGuide/llvm-strings.md
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,10 +0,0 @@
|
||||||
|
-# llvm-strings - print strings
|
||||||
|
-
|
||||||
|
-## SYNOPSIS
|
||||||
|
-
|
||||||
|
-**llvm-strings** [*options*]
|
||||||
|
-
|
||||||
|
-## DESCRIPTION
|
||||||
|
-
|
||||||
|
-**llvm-strings** is a tool that prints strings in object files. The goal is to
|
||||||
|
-make it a drop-in replacement for GNU's **size**.
|
||||||
|
diff --git a/llvm/docs/CommandGuide/llvm-strings.rst b/llvm/docs/CommandGuide/llvm-strings.rst
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..d8ab9cb
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/llvm/docs/CommandGuide/llvm-strings.rst
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+llvm-strings - print strings
|
||||||
|
+============================
|
||||||
|
+
|
||||||
|
+.. program:: llvm-strings
|
||||||
|
+
|
||||||
|
+SYNOPSIS
|
||||||
|
+--------
|
||||||
|
+
|
||||||
|
+:program:`llvm-strings` [*options*]
|
||||||
|
+
|
||||||
|
+DESCRIPTION
|
||||||
|
+-----------
|
||||||
|
+
|
||||||
|
+:program:`llvm-strings` is a tool that prints strings in files. The goal is to
|
||||||
|
+make it a drop-in replacement for GNU’s :program:`strings`.
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
@ -51,8 +51,14 @@ ln -s /usr/include include
|
|||||||
tar -xzf /usr/share/llvm/src/test.tar.gz
|
tar -xzf /usr/share/llvm/src/test.tar.gz
|
||||||
ln -s $ARCH.site.cfg.py test/lit.site.cfg.py
|
ln -s $ARCH.site.cfg.py test/lit.site.cfg.py
|
||||||
ln -s $ARCH.site.cfg.py test/Unit/lit.site.cfg.py
|
ln -s $ARCH.site.cfg.py test/Unit/lit.site.cfg.py
|
||||||
|
|
||||||
|
# llvm_obj_root is used to determine the directory the tests will run in.
|
||||||
|
# test/MC/MachO/gen-dwarf.s fails if llvm_obj_root is a parent directory
|
||||||
|
# of the source file. To workaround this, we set llvm_obj_root to a
|
||||||
|
# different directory than the one used to store the test sources.
|
||||||
|
# This also matches better how tests are run from the llvm source tree.
|
||||||
lit -v -s $threads_arg test \
|
lit -v -s $threads_arg test \
|
||||||
-Dllvm_obj_root=`pwd` \
|
-Dllvm_obj_root=$(mktemp -d) \
|
||||||
-Dllvm_test_root=`pwd`/test \
|
-Dllvm_test_root=`pwd`/test \
|
||||||
-Dllvm_unittest_bindir=$LIB_DIR/llvm \
|
-Dllvm_unittest_bindir=$LIB_DIR/llvm \
|
||||||
-Dllvm_shlib_dir=$LIB_DIR
|
-Dllvm_shlib_dir=$LIB_DIR
|
||||||
|
269
SPECS/llvm.spec
269
SPECS/llvm.spec
@ -6,29 +6,36 @@
|
|||||||
%bcond_with gold
|
%bcond_with gold
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
%global llvm_srcdir llvm-%{version}%{?rc_ver:rc%{rc_ver}}.src
|
%bcond_with compat_build
|
||||||
|
|
||||||
%global build_llvm_bindir %{buildroot}%{_bindir}
|
|
||||||
%global llvm_libdir %{_libdir}/%{name}
|
%global llvm_libdir %{_libdir}/%{name}
|
||||||
%global build_llvm_libdir %{buildroot}%{llvm_libdir}
|
%global build_llvm_libdir %{buildroot}%{llvm_libdir}
|
||||||
%global maj_ver 8
|
%global maj_ver 9
|
||||||
%global min_ver 0
|
%global min_ver 0
|
||||||
%global patch_ver 1
|
%global patch_ver 1
|
||||||
#%%global rc_ver 2
|
#%%global rc_ver 3
|
||||||
#%%global compat_version 7.0.1
|
%global baserelease 4
|
||||||
|
|
||||||
|
|
||||||
|
%if %{with compat_build}
|
||||||
|
%global pkg_name llvm%{maj_ver}.%{min_ver}
|
||||||
|
%global exec_suffix -%{maj_ver}.%{min_ver}
|
||||||
|
%global install_prefix %{_libdir}/%{name}
|
||||||
|
%global install_bindir %{install_prefix}/bin
|
||||||
|
%global install_includedir %{install_prefix}/include
|
||||||
|
%global install_libdir %{install_prefix}/lib
|
||||||
|
|
||||||
|
%global pkg_bindir %{install_bindir}
|
||||||
|
%global pkg_includedir %{_includedir}/%{name}
|
||||||
|
%global pkg_libdir %{install_libdir}
|
||||||
|
%else
|
||||||
%global pkg_name llvm
|
%global pkg_name llvm
|
||||||
%global install_prefix /usr
|
%global install_prefix /usr
|
||||||
%global install_libdir %{_libdir}
|
%global install_libdir %{_libdir}
|
||||||
%global pkg_libdir %{install_libdir}
|
%global pkg_libdir %{install_libdir}
|
||||||
|
%endif
|
||||||
|
|
||||||
%global build_install_prefix %{buildroot}%{install_prefix}
|
%global build_install_prefix %{buildroot}%{install_prefix}
|
||||||
%global build_pkgdocdir %{buildroot}%{_pkgdocdir}
|
|
||||||
|
|
||||||
#%%ifnarch i686
|
|
||||||
%global enable_test_pkg 1
|
|
||||||
#%%endif
|
|
||||||
|
|
||||||
%if !0%{?rhel}
|
%if !0%{?rhel}
|
||||||
# libedit-devel is a buildroot-only package in RHEL8, so we can't have a
|
# libedit-devel is a buildroot-only package in RHEL8, so we can't have a
|
||||||
@ -38,21 +45,36 @@
|
|||||||
|
|
||||||
Name: %{pkg_name}
|
Name: %{pkg_name}
|
||||||
Version: %{maj_ver}.%{min_ver}.%{patch_ver}
|
Version: %{maj_ver}.%{min_ver}.%{patch_ver}
|
||||||
Release: 1%{?rc_ver:.rc%{rc_ver}}%{?dist}
|
Release: %{baserelease}%{?rc_ver:.rc%{rc_ver}}%{?dist}
|
||||||
Summary: The Low Level Virtual Machine
|
Summary: The Low Level Virtual Machine
|
||||||
|
|
||||||
License: NCSA
|
License: NCSA
|
||||||
URL: http://llvm.org
|
URL: http://llvm.org
|
||||||
Source0: https://github.com/llvm/llvm-project/releases/download/llvmorg-%{version}%{?rc_ver:-%{rc_ver}}/%{llvm_srcdir}.tar.xz
|
Source0: http://%{?rc_ver:pre}releases.llvm.org/%{version}/%{?rc_ver:rc%{rc_ver}}/llvm-%{version}%{?rc_ver:rc%{rc_ver}}.src.tar.xz
|
||||||
|
%if %{without compat_build}
|
||||||
Source1: run-lit-tests
|
Source1: run-lit-tests
|
||||||
Source2: lit.fedora.cfg.py
|
Source2: lit.fedora.cfg.py
|
||||||
%if %{defined compat_version}
|
|
||||||
Source100: http://llvm.org/releases/%{compat_version}/%{name}-%{compat_version}.src.tar.xz
|
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
Patch2: 0001-Selectively-disable-threading-from-gold.patch
|
Patch0: 0001-Filter-out-cxxflags-not-supported-by-clang.patch
|
||||||
Patch3: 0001-Filter-out-cxxflags-not-supported-by-clang.patch
|
# TODO: I'm not sure why this is needed. Could be a change in newer version
|
||||||
Patch4: 0001-Deactivate-markdown-doc.patch
|
# of gold.
|
||||||
|
Patch1: 0001-Pass-target-to-gold-linker-to-avoid-faliures-on-i686.patch
|
||||||
|
Patch2: 0001-CMake-Split-static-library-exports-into-their-own-ex.patch
|
||||||
|
Patch3: 0001-CMake-Split-test-binary-exports-into-their-own-expor.patch
|
||||||
|
|
||||||
|
# RHEL-specific patches.
|
||||||
|
Patch101: 0001-Deactivate-markdown-doc.patch
|
||||||
|
# Patches to convert md files to rst since we don't have the md parser in RHEL.
|
||||||
|
Patch102: 0001-Docs-llvm-strip-Add-help-text-to-llvm-strip-rst-doc.patch
|
||||||
|
Patch103: 0001-docs-Convert-remaining-command-guide-entries-from-md.patch
|
||||||
|
|
||||||
|
# Fix crash in kernel bpf self-tests
|
||||||
|
Patch5: 0001-BPF-Handling-type-conversions-correctly-for-CO-RE.patch
|
||||||
|
Patch6: 0001-BPF-annotate-DIType-metadata-for-builtin-preseve_arr.patch
|
||||||
|
|
||||||
|
# Fix Rust codegen bug, https://github.com/rust-lang/rust/issues/69225
|
||||||
|
Patch7: 0001-Revert-SCEV-add-no-wrap-flag-for-SCEVAddExpr.patch
|
||||||
|
|
||||||
BuildRequires: gcc
|
BuildRequires: gcc
|
||||||
BuildRequires: gcc-c++
|
BuildRequires: gcc-c++
|
||||||
@ -62,7 +84,9 @@ BuildRequires: zlib-devel
|
|||||||
BuildRequires: libffi-devel
|
BuildRequires: libffi-devel
|
||||||
BuildRequires: ncurses-devel
|
BuildRequires: ncurses-devel
|
||||||
BuildRequires: python3-sphinx
|
BuildRequires: python3-sphinx
|
||||||
#BuildRequires: python3-recommonmark
|
%if !0%{?rhel}
|
||||||
|
BuildRequires: python3-recommonmark
|
||||||
|
%endif
|
||||||
BuildRequires: multilib-rpm-config
|
BuildRequires: multilib-rpm-config
|
||||||
%if %{with gold}
|
%if %{with gold}
|
||||||
BuildRequires: binutils-devel
|
BuildRequires: binutils-devel
|
||||||
@ -80,6 +104,8 @@ BuildRequires: python3-devel
|
|||||||
|
|
||||||
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
||||||
|
|
||||||
|
Provides: llvm(major) = %{maj_ver}
|
||||||
|
|
||||||
%description
|
%description
|
||||||
LLVM is a compiler infrastructure designed for compile-time, link-time,
|
LLVM is a compiler infrastructure designed for compile-time, link-time,
|
||||||
runtime, and idle-time optimization of programs from arbitrary programming
|
runtime, and idle-time optimization of programs from arbitrary programming
|
||||||
@ -89,6 +115,7 @@ tools as well as libraries with equivalent functionality.
|
|||||||
%package devel
|
%package devel
|
||||||
Summary: Libraries and header files for LLVM
|
Summary: Libraries and header files for LLVM
|
||||||
Requires: %{name}%{?_isa} = %{version}-%{release}
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
||||||
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
||||||
# The installed LLVM cmake files will add -ledit to the linker flags for any
|
# The installed LLVM cmake files will add -ledit to the linker flags for any
|
||||||
# app that requires the libLLVMLineEditor, so we need to make sure
|
# app that requires the libLLVMLineEditor, so we need to make sure
|
||||||
# libedit-devel is available.
|
# libedit-devel is available.
|
||||||
@ -98,6 +125,8 @@ Requires: libedit-devel
|
|||||||
Requires(post): %{_sbindir}/alternatives
|
Requires(post): %{_sbindir}/alternatives
|
||||||
Requires(postun): %{_sbindir}/alternatives
|
Requires(postun): %{_sbindir}/alternatives
|
||||||
|
|
||||||
|
Provides: llvm-devel(major) = %{maj_ver}
|
||||||
|
|
||||||
%description devel
|
%description devel
|
||||||
This package contains library and header files needed to develop new native
|
This package contains library and header files needed to develop new native
|
||||||
programs that use the LLVM infrastructure.
|
programs that use the LLVM infrastructure.
|
||||||
@ -123,11 +152,12 @@ Conflicts: %{name}-devel < 8
|
|||||||
%description static
|
%description static
|
||||||
Static libraries for the LLVM compiler infrastructure.
|
Static libraries for the LLVM compiler infrastructure.
|
||||||
|
|
||||||
%if 0%{?enable_test_pkg}
|
%if %{without compat_build}
|
||||||
|
|
||||||
%package test
|
%package test
|
||||||
Summary: LLVM regression tests
|
Summary: LLVM regression tests
|
||||||
Requires: %{name}%{?_isa} = %{version}-%{release}
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
||||||
|
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
||||||
Requires: python3-lit
|
Requires: python3-lit
|
||||||
# The regression tests need gold.
|
# The regression tests need gold.
|
||||||
Requires: binutils
|
Requires: binutils
|
||||||
@ -137,30 +167,22 @@ Requires: %{name}-devel%{?_isa} = %{version}-%{release}
|
|||||||
Requires: gcc
|
Requires: gcc
|
||||||
Requires: findutils
|
Requires: findutils
|
||||||
|
|
||||||
|
Provides: llvm-test(major) = %{maj_ver}
|
||||||
|
|
||||||
%description test
|
%description test
|
||||||
LLVM regression tests.
|
LLVM regression tests.
|
||||||
|
|
||||||
%endif
|
|
||||||
|
|
||||||
%package googletest
|
%package googletest
|
||||||
Summary: LLVM's modified googletest sources
|
Summary: LLVM's modified googletest sources
|
||||||
|
|
||||||
%description googletest
|
%description googletest
|
||||||
LLVM's modified googletest sources.
|
LLVM's modified googletest sources.
|
||||||
|
|
||||||
%prep
|
|
||||||
%if %{defined compat_version}
|
|
||||||
%setup -T -q -b 100 -n llvm-%{compat_version}.src
|
|
||||||
|
|
||||||
%setup -q -n llvm-%{version}%{?rc_ver:rc%{rc_ver}}.src
|
|
||||||
%patch2 -p2
|
|
||||||
%patch3 -p2
|
|
||||||
%patch4 -p2
|
|
||||||
|
|
||||||
%else
|
|
||||||
%autosetup -n llvm-%{version}%{?rc_ver:rc%{rc_ver}}.src -p2
|
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%autosetup -n llvm-%{version}%{?rc_ver:rc%{rc_ver}}.src -p2
|
||||||
|
|
||||||
pathfix.py -i %{__python3} -pn \
|
pathfix.py -i %{__python3} -pn \
|
||||||
test/BugPoint/compile-custom.ll.py \
|
test/BugPoint/compile-custom.ll.py \
|
||||||
tools/opt-viewer/*.py
|
tools/opt-viewer/*.py
|
||||||
@ -185,14 +207,16 @@ cd _build
|
|||||||
-DLLVM_PARALLEL_LINK_JOBS=1 \
|
-DLLVM_PARALLEL_LINK_JOBS=1 \
|
||||||
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||||
-DCMAKE_INSTALL_RPATH=";" \
|
-DCMAKE_INSTALL_RPATH=";" \
|
||||||
%ifarch s390 s390x %{arm} %ix86
|
%ifarch s390 %{arm} %ix86
|
||||||
-DCMAKE_C_FLAGS_RELWITHDEBINFO="%{optflags} -DNDEBUG" \
|
-DCMAKE_C_FLAGS_RELWITHDEBINFO="%{optflags} -DNDEBUG" \
|
||||||
-DCMAKE_CXX_FLAGS_RELWITHDEBINFO="%{optflags} -DNDEBUG" \
|
-DCMAKE_CXX_FLAGS_RELWITHDEBINFO="%{optflags} -DNDEBUG" \
|
||||||
%endif
|
%endif
|
||||||
|
%if %{without compat_build}
|
||||||
%if 0%{?__isa_bits} == 64
|
%if 0%{?__isa_bits} == 64
|
||||||
-DLLVM_LIBDIR_SUFFIX=64 \
|
-DLLVM_LIBDIR_SUFFIX=64 \
|
||||||
%else
|
%else
|
||||||
-DLLVM_LIBDIR_SUFFIX= \
|
-DLLVM_LIBDIR_SUFFIX= \
|
||||||
|
%endif
|
||||||
%endif
|
%endif
|
||||||
\
|
\
|
||||||
-DLLVM_TARGETS_TO_BUILD="X86;AMDGPU;PowerPC;NVPTX;SystemZ;AArch64;ARM;Mips;BPF" \
|
-DLLVM_TARGETS_TO_BUILD="X86;AMDGPU;PowerPC;NVPTX;SystemZ;AArch64;ARM;Mips;BPF" \
|
||||||
@ -216,9 +240,13 @@ cd _build
|
|||||||
-DLLVM_BUILD_EXAMPLES:BOOL=OFF \
|
-DLLVM_BUILD_EXAMPLES:BOOL=OFF \
|
||||||
\
|
\
|
||||||
-DLLVM_INCLUDE_UTILS:BOOL=ON \
|
-DLLVM_INCLUDE_UTILS:BOOL=ON \
|
||||||
|
%if %{with compat_build}
|
||||||
|
-DLLVM_INSTALL_UTILS:BOOL=OFF \
|
||||||
|
%else
|
||||||
-DLLVM_INSTALL_UTILS:BOOL=ON \
|
-DLLVM_INSTALL_UTILS:BOOL=ON \
|
||||||
-DLLVM_UTILS_INSTALL_DIR:PATH=%{build_llvm_bindir} \
|
-DLLVM_UTILS_INSTALL_DIR:PATH=%{_bindir} \
|
||||||
-DLLVM_TOOLS_INSTALL_DIR:PATH=bin \
|
-DLLVM_TOOLS_INSTALL_DIR:PATH=bin \
|
||||||
|
%endif
|
||||||
\
|
\
|
||||||
-DLLVM_INCLUDE_DOCS:BOOL=ON \
|
-DLLVM_INCLUDE_DOCS:BOOL=ON \
|
||||||
-DLLVM_BUILD_DOCS:BOOL=ON \
|
-DLLVM_BUILD_DOCS:BOOL=ON \
|
||||||
@ -232,54 +260,35 @@ cd _build
|
|||||||
-DLLVM_INSTALL_TOOLCHAIN_ONLY:BOOL=OFF \
|
-DLLVM_INSTALL_TOOLCHAIN_ONLY:BOOL=OFF \
|
||||||
\
|
\
|
||||||
-DSPHINX_WARNINGS_AS_ERRORS=OFF \
|
-DSPHINX_WARNINGS_AS_ERRORS=OFF \
|
||||||
-DCMAKE_INSTALL_PREFIX=%{build_install_prefix} \
|
-DLLVM_INSTALL_SPHINX_HTML_DIR=%{_pkgdocdir}/html \
|
||||||
-DLLVM_INSTALL_SPHINX_HTML_DIR=%{build_pkgdocdir}/html \
|
|
||||||
-DSPHINX_EXECUTABLE=%{_bindir}/sphinx-build-3
|
-DSPHINX_EXECUTABLE=%{_bindir}/sphinx-build-3
|
||||||
|
|
||||||
ninja -v -j2
|
# Build libLLVM.so first. This ensures that when libLLVM.so is linking, there
|
||||||
|
# are no other compile jobs running. This will help reduce OOM errors on the
|
||||||
%if %{defined compat_version}
|
# builders without having to artificially limit the number of concurrent jobs.
|
||||||
mkdir ../compat-build
|
%ninja_build LLVM
|
||||||
cd ../compat-build
|
%ninja_build
|
||||||
%cmake ../../%{name}-%{compat_version}.src \
|
|
||||||
-G Ninja \
|
|
||||||
-DBUILD_SHARED_LIBS=OFF \
|
|
||||||
-DCMAKE_BUILD_TYPE=Release \
|
|
||||||
-DLLVM_TARGETS_TO_BUILD="X86;AMDGPU;PowerPC;NVPTX;SystemZ;AArch64;ARM;Mips;BPF" \
|
|
||||||
-DLLVM_ENABLE_RTTI:BOOL=ON \
|
|
||||||
-DLLVM_ENABLE_ZLIB:BOOL=ON \
|
|
||||||
-DLLVM_ENABLE_FFI:BOOL=ON \
|
|
||||||
-DLLVM_BUILD_LLVM_DYLIB=ON
|
|
||||||
ninja -v LLVM
|
|
||||||
|
|
||||||
# Remove files we don't need to save disk space
|
|
||||||
mv lib/libLLVM-`echo %{compat_version} | cut -f1 -d .`.so ..
|
|
||||||
rm -Rf *
|
|
||||||
%endif
|
|
||||||
|
|
||||||
%install
|
%install
|
||||||
ninja -C _build -v install
|
%ninja_install -C _build
|
||||||
|
|
||||||
|
|
||||||
|
%if %{without compat_build}
|
||||||
mkdir -p %{buildroot}/%{_bindir}
|
mkdir -p %{buildroot}/%{_bindir}
|
||||||
mv %{buildroot}/%{_bindir}/llvm-config %{buildroot}/%{_bindir}/llvm-config-%{__isa_bits}
|
mv %{buildroot}/%{_bindir}/llvm-config %{buildroot}/%{_bindir}/llvm-config-%{__isa_bits}
|
||||||
ln -s llvm-config-%{__isa_bits} %{buildroot}/%{_bindir}/llvm-config
|
|
||||||
|
|
||||||
# Fix some man pages
|
# Fix some man pages
|
||||||
ln -s llvm-config.1 %{buildroot}%{_mandir}/man1/llvm-config-%{__isa_bits}.1
|
ln -s llvm-config.1 %{buildroot}%{_mandir}/man1/llvm-config-%{__isa_bits}.1
|
||||||
mv %{buildroot}%{_mandir}/man1/tblgen.1 %{buildroot}%{_mandir}/man1/llvm-tblgen.1
|
mv %{buildroot}%{_mandir}/man1/tblgen.1 %{buildroot}%{_mandir}/man1/llvm-tblgen.1
|
||||||
|
|
||||||
# Install binaries needed for lit tests
|
# Install binaries needed for lit tests
|
||||||
%if 0%{?enable_test_pkg}
|
%global test_binaries llvm-isel-fuzzer llvm-opt-fuzzer
|
||||||
%global test_binaries FileCheck count lli-child-target llvm-PerfectShuffle llvm-isel-fuzzer llvm-opt-fuzzer not yaml-bench
|
|
||||||
|
|
||||||
for f in %{test_binaries}
|
for f in %{test_binaries}
|
||||||
do
|
do
|
||||||
install -m 0755 ./_build/bin/$f %{build_llvm_bindir}
|
install -m 0755 ./_build/bin/$f %{buildroot}%{_bindir}
|
||||||
done
|
done
|
||||||
|
|
||||||
%endif
|
|
||||||
|
|
||||||
|
|
||||||
%multilib_fix_c_header --file %{_includedir}/llvm/Config/llvm-config.h
|
%multilib_fix_c_header --file %{_includedir}/llvm/Config/llvm-config.h
|
||||||
|
|
||||||
@ -302,7 +311,6 @@ install -d %{install_srcdir}
|
|||||||
install -d %{install_srcdir}/utils/
|
install -d %{install_srcdir}/utils/
|
||||||
cp -R utils/unittest %{install_srcdir}/utils/
|
cp -R utils/unittest %{install_srcdir}/utils/
|
||||||
|
|
||||||
%if 0%{?enable_test_pkg}
|
|
||||||
# Generate lit config files. Strip off the last line that initiates the
|
# Generate lit config files. Strip off the last line that initiates the
|
||||||
# test run, so we can customize the configuration.
|
# test run, so we can customize the configuration.
|
||||||
head -n -1 _build/test/lit.site.cfg.py >> %{lit_cfg}
|
head -n -1 _build/test/lit.site.cfg.py >> %{lit_cfg}
|
||||||
@ -337,81 +345,142 @@ install -m 0755 %{build_libdir}/LLVMHello.so %{buildroot}%{_libdir}
|
|||||||
echo "%{_datadir}/llvm/src/unittests/DebugInfo/PDB" > %{build_llvm_libdir}/unittests/DebugInfo/PDB/llvm.srcdir.txt
|
echo "%{_datadir}/llvm/src/unittests/DebugInfo/PDB" > %{build_llvm_libdir}/unittests/DebugInfo/PDB/llvm.srcdir.txt
|
||||||
mkdir -p %{buildroot}%{_datadir}/llvm/src/unittests/DebugInfo/PDB/
|
mkdir -p %{buildroot}%{_datadir}/llvm/src/unittests/DebugInfo/PDB/
|
||||||
cp -R unittests/DebugInfo/PDB/Inputs %{buildroot}%{_datadir}/llvm/src/unittests/DebugInfo/PDB/
|
cp -R unittests/DebugInfo/PDB/Inputs %{buildroot}%{_datadir}/llvm/src/unittests/DebugInfo/PDB/
|
||||||
|
|
||||||
|
%else
|
||||||
|
|
||||||
|
# Add version suffix to binaries
|
||||||
|
mkdir -p %{buildroot}/%{_bindir}
|
||||||
|
for f in %{buildroot}/%{install_bindir}/*; do
|
||||||
|
filename=`basename $f`
|
||||||
|
ln -s %{install_bindir}/$filename %{buildroot}/%{_bindir}/$filename%{exec_suffix}
|
||||||
|
done
|
||||||
|
|
||||||
|
# Move header files
|
||||||
|
mkdir -p %{buildroot}/%{pkg_includedir}
|
||||||
|
ln -s ../../../%{install_includedir}/llvm %{buildroot}/%{pkg_includedir}/llvm
|
||||||
|
ln -s ../../../%{install_includedir}/llvm-c %{buildroot}/%{pkg_includedir}/llvm-c
|
||||||
|
|
||||||
|
# Fix multi-lib
|
||||||
|
mv %{buildroot}%{_bindir}/llvm-config{%{exec_suffix},%{exec_suffix}-%{__isa_bits}}
|
||||||
|
%multilib_fix_c_header --file %{install_includedir}/llvm/Config/llvm-config.h
|
||||||
|
|
||||||
|
# Create ld.so.conf.d entry
|
||||||
|
mkdir -p %{buildroot}%{_sysconfdir}/ld.so.conf.d
|
||||||
|
cat >> %{buildroot}%{_sysconfdir}/ld.so.conf.d/%{name}-%{_arch}.conf << EOF
|
||||||
|
%{pkg_libdir}
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Add version suffix to man pages and move them to mandir.
|
||||||
|
mkdir -p %{buildroot}/%{_mandir}/man1
|
||||||
|
for f in `ls %{build_install_prefix}/share/man/man1/*`; do
|
||||||
|
filename=`basename $f | cut -f 1 -d '.'`
|
||||||
|
mv $f %{buildroot}%{_mandir}/man1/$filename%{exec_suffix}.1
|
||||||
|
done
|
||||||
|
|
||||||
|
# Remove opt-viewer, since this is just a compatibility package.
|
||||||
|
rm -Rf %{build_install_prefix}/share/opt-viewer
|
||||||
|
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
|
|
||||||
%if %{defined compat_version}
|
|
||||||
cd compat-build
|
|
||||||
install ../libLLVM-`echo %{compat_version} | cut -f1 -d .`.so %{buildroot}%{_libdir}
|
|
||||||
%endif
|
|
||||||
|
|
||||||
%check
|
%check
|
||||||
|
# TODO: Fix test failures on arm
|
||||||
# TODO: Fix arm
|
|
||||||
ninja check-all -C _build || \
|
ninja check-all -C _build || \
|
||||||
%ifarch %{arm}
|
%ifarch %{arm}
|
||||||
:
|
:
|
||||||
%else
|
%else
|
||||||
false
|
false
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
|
|
||||||
%ldconfig_scriptlets libs
|
%ldconfig_scriptlets libs
|
||||||
|
|
||||||
|
%if %{without compat_build}
|
||||||
|
|
||||||
%post devel
|
%post devel
|
||||||
%{_sbindir}/update-alternatives --install %{_bindir}/llvm-config llvm-config %{_bindir}/llvm-config-%{__isa_bits} %{__isa_bits}
|
%{_sbindir}/update-alternatives --install %{_bindir}/llvm-config llvm-config %{_bindir}/llvm-config-%{__isa_bits} %{__isa_bits}
|
||||||
|
|
||||||
%postun devel
|
%postun devel
|
||||||
if [ $1 -eq 0 ]; then
|
if [ $1 -eq 0 ]; then
|
||||||
%{_sbindir}/update-alternatives --remove llvm-config %{_bindir}/llvm-config-%{__isa_bits}
|
%{_sbindir}/update-alternatives --remove llvm-config %{_bindir}/llvm-config
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
%endif
|
||||||
|
|
||||||
%files
|
%files
|
||||||
%exclude %{_bindir}/llvm-config*
|
%exclude %{_mandir}/man1/llvm-config*
|
||||||
|
%{_mandir}/man1/*
|
||||||
|
%{_bindir}/*
|
||||||
|
|
||||||
|
%if %{without compat_build}
|
||||||
|
%exclude %{_bindir}/llvm-config-%{__isa_bits}
|
||||||
%exclude %{_bindir}/not
|
%exclude %{_bindir}/not
|
||||||
%exclude %{_bindir}/count
|
%exclude %{_bindir}/count
|
||||||
%exclude %{_bindir}/yaml-bench
|
%exclude %{_bindir}/yaml-bench
|
||||||
%exclude %{_bindir}/lli-child-target
|
%exclude %{_bindir}/lli-child-target
|
||||||
%exclude %{_bindir}/llvm-isel-fuzzer
|
%exclude %{_bindir}/llvm-isel-fuzzer
|
||||||
%exclude %{_bindir}/llvm-opt-fuzzer
|
%exclude %{_bindir}/llvm-opt-fuzzer
|
||||||
%{_bindir}/*
|
|
||||||
|
|
||||||
%exclude %{_mandir}/man1/llvm-config*
|
|
||||||
%{_mandir}/man1/*
|
|
||||||
|
|
||||||
%{_datadir}/opt-viewer
|
%{_datadir}/opt-viewer
|
||||||
|
%else
|
||||||
|
%exclude %{pkg_bindir}/llvm-config
|
||||||
|
%{pkg_bindir}
|
||||||
|
%endif
|
||||||
|
|
||||||
%files libs
|
%files libs
|
||||||
%{pkg_libdir}/libLLVM-%{maj_ver}.so
|
%{pkg_libdir}/libLLVM-%{maj_ver}.so
|
||||||
|
%if %{without compat_build}
|
||||||
%if %{with gold}
|
%if %{with gold}
|
||||||
%{_libdir}/LLVMgold.so
|
%{_libdir}/LLVMgold.so
|
||||||
%endif
|
%endif
|
||||||
%{_libdir}/libLLVM-%{maj_ver}.%{min_ver}*.so
|
%{_libdir}/libLLVM-%{maj_ver}.%{min_ver}*.so
|
||||||
%{_libdir}/libLTO.so*
|
%{_libdir}/libLTO.so*
|
||||||
%{pkg_libdir}/libOptRemarks.so*
|
%else
|
||||||
%if %{defined compat_version}
|
%config(noreplace) %{_sysconfdir}/ld.so.conf.d/%{name}-%{_arch}.conf
|
||||||
%{_libdir}/libLLVM-7.so
|
%if %{with gold}
|
||||||
|
%{_libdir}/%{name}/lib/LLVMgold.so
|
||||||
%endif
|
%endif
|
||||||
|
%{pkg_libdir}/libLLVM-%{maj_ver}.%{min_ver}*.so
|
||||||
|
%{pkg_libdir}/libLTO.so*
|
||||||
|
%exclude %{pkg_libdir}/libLTO.so
|
||||||
|
%endif
|
||||||
|
%{pkg_libdir}/libRemarks.so*
|
||||||
|
|
||||||
%files devel
|
%files devel
|
||||||
%{_bindir}/llvm-config*
|
%if %{without compat_build}
|
||||||
|
%{_bindir}/llvm-config-%{__isa_bits}
|
||||||
%{_mandir}/man1/llvm-config*
|
%{_mandir}/man1/llvm-config*
|
||||||
%{_includedir}/llvm
|
%{_includedir}/llvm
|
||||||
%{_includedir}/llvm-c
|
%{_includedir}/llvm-c
|
||||||
%{_libdir}/libLLVM.so
|
%{_libdir}/libLLVM.so
|
||||||
%{_libdir}/cmake/llvm
|
%{_libdir}/cmake/llvm
|
||||||
%exclude %{_libdir}/cmake/llvm/LLVMStaticExports.cmake
|
%exclude %{_libdir}/cmake/llvm/LLVMStaticExports.cmake
|
||||||
|
%exclude %{_libdir}/cmake/llvm/LLVMTestExports.cmake
|
||||||
|
%else
|
||||||
|
%{_bindir}/llvm-config%{exec_suffix}-%{__isa_bits}
|
||||||
|
%{pkg_bindir}/llvm-config
|
||||||
|
%{_mandir}/man1/llvm-config%{exec_suffix}.1.gz
|
||||||
|
%{install_includedir}/llvm
|
||||||
|
%{install_includedir}/llvm-c
|
||||||
|
%{pkg_includedir}/llvm
|
||||||
|
%{pkg_includedir}/llvm-c
|
||||||
|
%{pkg_libdir}/libLTO.so
|
||||||
|
%{pkg_libdir}/libLLVM.so
|
||||||
|
%{pkg_libdir}/cmake/llvm
|
||||||
|
%endif
|
||||||
|
|
||||||
%files doc
|
%files doc
|
||||||
%doc %{_pkgdocdir}/html
|
%doc %{_pkgdocdir}/html
|
||||||
|
|
||||||
%files static
|
%files static
|
||||||
|
%if %{without compat_build}
|
||||||
%{_libdir}/*.a
|
%{_libdir}/*.a
|
||||||
%exclude %{_libdir}/libLLVMTestingSupport.a
|
%exclude %{_libdir}/libLLVMTestingSupport.a
|
||||||
%{_libdir}/cmake/llvm/LLVMStaticExports.cmake
|
%{_libdir}/cmake/llvm/LLVMStaticExports.cmake
|
||||||
|
%else
|
||||||
|
%{_libdir}/%{name}/lib/*.a
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if %{without compat_build}
|
||||||
|
|
||||||
%if 0%{?enable_test_pkg}
|
|
||||||
%files test
|
%files test
|
||||||
%{_libexecdir}/tests/llvm/
|
%{_libexecdir}/tests/llvm/
|
||||||
%{llvm_libdir}/unittests/
|
%{llvm_libdir}/unittests/
|
||||||
@ -426,14 +495,42 @@ fi
|
|||||||
%{_bindir}/llvm-opt-fuzzer
|
%{_bindir}/llvm-opt-fuzzer
|
||||||
%{_libdir}/BugpointPasses.so
|
%{_libdir}/BugpointPasses.so
|
||||||
%{_libdir}/LLVMHello.so
|
%{_libdir}/LLVMHello.so
|
||||||
%endif
|
%{_libdir}/cmake/llvm/LLVMTestExports.cmake
|
||||||
|
|
||||||
%files googletest
|
%files googletest
|
||||||
%{_datadir}/llvm/src/utils
|
%{_datadir}/llvm/src/utils
|
||||||
%{_libdir}/libLLVMTestingSupport.a
|
%{_libdir}/libLLVMTestingSupport.a
|
||||||
|
|
||||||
|
%endif
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 27 2020 Josh Stone <jistone@redhat.com> - 9.0.1-4
|
||||||
|
- Fix a codegen bug for Rust
|
||||||
|
|
||||||
|
* Fri Jan 17 2020 Tom Stellard <tstellar@redhat.com> - 9.0.1-3
|
||||||
|
- Add explicit Requires from sub-packages to llvm-libs
|
||||||
|
|
||||||
|
* Fri Jan 10 2020 Tom Stellard <tstellar@redhat.com> - 9.0.1-2
|
||||||
|
- Fix crash with kernel bpf self-tests
|
||||||
|
|
||||||
|
* Thu Dec 19 2019 tstellar@redhat.com - 9.0.1-1
|
||||||
|
- 9.0.1 Release
|
||||||
|
|
||||||
|
* Wed Oct 30 2019 Tom Stellard <tstellar@redhat.com> - 9.0.0-5
|
||||||
|
- Remove work-around for threading issue in gold
|
||||||
|
|
||||||
|
* Wed Oct 30 2019 Tom Stellard <tstellar@redhat.com> - 9.0.0-4
|
||||||
|
- Build libLLVM.so first to avoid OOM errors
|
||||||
|
|
||||||
|
* Tue Oct 01 2019 Tom Stellard <tstellar@redhat.com> - 9.0.0-3
|
||||||
|
- Adjust run-lit-tests script to better match in tree testing
|
||||||
|
|
||||||
|
* Mon Sep 30 2019 Tom Stellard <tstellar@redhat.com> - 9.0.0-2
|
||||||
|
- Limit number of build threads using -l option for ninja
|
||||||
|
|
||||||
|
* Thu Sep 26 2019 Tom Stellard <tstellar@redhat.com> - 9.0.0-1
|
||||||
|
- 9.0.0 Release
|
||||||
|
|
||||||
* Thu Aug 1 2019 sguelton@redhat.com - 8.0.1-1
|
* Thu Aug 1 2019 sguelton@redhat.com - 8.0.1-1
|
||||||
- 8.0.1 release
|
- 8.0.1 release
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user