diff options
Diffstat (limited to 'dynamic-layers/clang-layer')
25 files changed, 583 insertions, 559 deletions
diff --git a/dynamic-layers/clang-layer/recipes-core/dnn/files/run-ptest b/dynamic-layers/clang-layer/recipes-core/dnn/files/run-ptest new file mode 100755 index 00000000..82d4df58 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-core/dnn/files/run-ptest | |||
| @@ -0,0 +1,15 @@ | |||
| 1 | #!/bin/sh | ||
| 2 | |||
| 3 | cd tests | ||
| 4 | ./api-c | ||
| 5 | if [ $? -eq 0 ]; then | ||
| 6 | echo 'PASS: api-c' | ||
| 7 | else | ||
| 8 | echo 'FAIL: api-c' | ||
| 9 | fi | ||
| 10 | ./test_c_symbols-c | ||
| 11 | if [ $? -eq 0 ]; then | ||
| 12 | echo 'PASS: test_c_symbols-c' | ||
| 13 | else | ||
| 14 | echo 'FAIL: test_c_symbols-c' | ||
| 15 | fi | ||
diff --git a/dynamic-layers/clang-layer/recipes-core/dnn/onednn_3.5.3.bb b/dynamic-layers/clang-layer/recipes-core/dnn/onednn_3.5.3.bb new file mode 100644 index 00000000..531f80c6 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-core/dnn/onednn_3.5.3.bb | |||
| @@ -0,0 +1,57 @@ | |||
| 1 | HOMEPAGE = "https://www.oneapi.com" | ||
| 2 | SUMMARY = "Deep Neural Network Library" | ||
| 3 | DESCRIPTION = "This software is a user mode library that accelerates\ | ||
| 4 | deep-learning applications and frameworks on Intel architecture." | ||
| 5 | LICENSE = "Apache-2.0 & BSD-3-Clause & BSL-1.0" | ||
| 6 | LIC_FILES_CHKSUM = "file://LICENSE;md5=3b64000f6e7d52516017622a37a94ce9 \ | ||
| 7 | file://tests/gtests/gtest/LICENSE;md5=cbbd27594afd089daa160d3a16dd515a \ | ||
| 8 | file://src/cpu/x64/xbyak/COPYRIGHT;md5=3b9bf048d063d54cdb28964db558bcc7 \ | ||
| 9 | file://src/common/ittnotify/LICENSE.BSD;md5=e671ff178b24a95a382ba670503c66fb \ | ||
| 10 | " | ||
| 11 | SECTION = "lib" | ||
| 12 | |||
| 13 | inherit pkgconfig cmake ptest | ||
| 14 | |||
| 15 | DNN_BRANCH = "rls-v${@'.'.join(d.getVar('PV').split('.')[0:2])}" | ||
| 16 | |||
| 17 | SRCREV = "66f0cb9eb66affd2da3bf5f8d897376f04aae6af" | ||
| 18 | SRC_URI = "git://github.com/oneapi-src/oneDNN.git;branch=${DNN_BRANCH};protocol=https \ | ||
| 19 | file://run-ptest \ | ||
| 20 | " | ||
| 21 | |||
| 22 | UPSTREAM_CHECK_GITTAGREGEX = "^v(?P<pver>(\d+(\.\d+)+))$" | ||
| 23 | |||
| 24 | CVE_PRODUCT = "intel:math_kernel_library" | ||
| 25 | |||
| 26 | COMPATIBLE_HOST = '(x86_64).*-linux' | ||
| 27 | COMPATIBLE_HOST:libc-musl = 'null' | ||
| 28 | |||
| 29 | EXTRA_OECMAKE += " \ | ||
| 30 | -DDNNL_LIBRARY_TYPE=SHARED \ | ||
| 31 | -DDNNL_BUILD_EXAMPLES=ON \ | ||
| 32 | -DDNNL_BUILD_TESTS=ON \ | ||
| 33 | -DDNNL_CPU_RUNTIME=OMP \ | ||
| 34 | -DDNNL_ARCH_OPT_FLAGS="" \ | ||
| 35 | -DCMAKE_SKIP_RPATH=ON \ | ||
| 36 | -DONEDNN_BUILD_GRAPH=OFF \ | ||
| 37 | -DCMAKE_POLICY_VERSION_MINIMUM=3.5 \ | ||
| 38 | " | ||
| 39 | |||
| 40 | PACKAGECONFIG ??= "gpu" | ||
| 41 | PACKAGECONFIG[gpu] = "-DDNNL_GPU_RUNTIME=OCL, , opencl-headers virtual/opencl-icd, intel-compute-runtime" | ||
| 42 | |||
| 43 | do_install:append () { | ||
| 44 | install -d ${D}${bindir}/mkl-dnn/tests/benchdnn/inputs | ||
| 45 | install -m 0755 ${B}/tests/benchdnn/benchdnn ${D}${bindir}/mkl-dnn/tests/benchdnn | ||
| 46 | cp -r ${B}/tests/benchdnn/inputs/* ${D}${bindir}/mkl-dnn/tests/benchdnn/inputs | ||
| 47 | } | ||
| 48 | |||
| 49 | do_install_ptest () { | ||
| 50 | install -d ${D}${PTEST_PATH}/tests | ||
| 51 | install -m 0755 ${B}/tests/api-c ${D}${PTEST_PATH}/tests | ||
| 52 | install -m 0755 ${B}/tests/test_c_symbols-c ${D}${PTEST_PATH}/tests | ||
| 53 | } | ||
| 54 | |||
| 55 | PACKAGES =+ "${PN}-test" | ||
| 56 | |||
| 57 | FILES:${PN}-test = "${bindir}/mkl-dnn/*" | ||
diff --git a/dynamic-layers/clang-layer/recipes-devtools/clang/files/0001-skip-building-tests.patch b/dynamic-layers/clang-layer/recipes-devtools/clang/files/0001-skip-building-tests.patch deleted file mode 100644 index 9a7b8445..00000000 --- a/dynamic-layers/clang-layer/recipes-devtools/clang/files/0001-skip-building-tests.patch +++ /dev/null | |||
| @@ -1,51 +0,0 @@ | |||
| 1 | From 48e50f06b1bbed94cdf5207587161d4bfce7366e Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 3 | Date: Wed, 21 Aug 2019 14:35:31 +0800 | ||
| 4 | Subject: [PATCH] llvm-spirv: skip building tests | ||
| 5 | |||
| 6 | Some of these need clang to be built and since we're building this in-tree, | ||
| 7 | that leads to problems when compiling libcxx, compiler-rt which aren't built | ||
| 8 | in-tree. | ||
| 9 | |||
| 10 | Instead of using SPIRV_SKIP_CLANG_BUILD to skip clang build and adding this to | ||
| 11 | all components, disable the building of tests altogether. | ||
| 12 | |||
| 13 | Upstream-Status: Inappropriate | ||
| 14 | |||
| 15 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 16 | Signed-off-by: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 17 | --- | ||
| 18 | CMakeLists.txt | 10 ---------- | ||
| 19 | 1 file changed, 10 deletions(-) | ||
| 20 | |||
| 21 | diff --git a/CMakeLists.txt b/CMakeLists.txt | ||
| 22 | index 1208741..20ca3e6 100644 | ||
| 23 | --- a/CMakeLists.txt | ||
| 24 | +++ b/CMakeLists.txt | ||
| 25 | @@ -15,13 +15,6 @@ if(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR) | ||
| 26 | set(CMAKE_CXX_STANDARD 11) | ||
| 27 | set(CMAKE_CXX_STANDARD_REQUIRED ON) | ||
| 28 | |||
| 29 | - if(LLVM_INCLUDE_TESTS) | ||
| 30 | - set(LLVM_TEST_COMPONENTS | ||
| 31 | - llvm-as | ||
| 32 | - llvm-dis | ||
| 33 | - ) | ||
| 34 | - endif(LLVM_INCLUDE_TESTS) | ||
| 35 | - | ||
| 36 | find_package(LLVM 9.0.0 REQUIRED | ||
| 37 | COMPONENTS | ||
| 38 | Analysis | ||
| 39 | @@ -56,9 +49,6 @@ set(LLVM_SPIRV_INCLUDE_DIRS ${CMAKE_CURRENT_SOURCE_DIR}/include) | ||
| 40 | |||
| 41 | add_subdirectory(lib/SPIRV) | ||
| 42 | add_subdirectory(tools/llvm-spirv) | ||
| 43 | -if(LLVM_INCLUDE_TESTS) | ||
| 44 | - add_subdirectory(test) | ||
| 45 | -endif(LLVM_INCLUDE_TESTS) | ||
| 46 | |||
| 47 | install( | ||
| 48 | FILES | ||
| 49 | -- | ||
| 50 | 2.17.1 | ||
| 51 | |||
diff --git a/dynamic-layers/clang-layer/recipes-devtools/clang/files/BasicBlockUtils-Add-metadata-fixing-in-SplitBlockPre.patch b/dynamic-layers/clang-layer/recipes-devtools/clang/files/BasicBlockUtils-Add-metadata-fixing-in-SplitBlockPre.patch deleted file mode 100644 index cd519971..00000000 --- a/dynamic-layers/clang-layer/recipes-devtools/clang/files/BasicBlockUtils-Add-metadata-fixing-in-SplitBlockPre.patch +++ /dev/null | |||
| @@ -1,111 +0,0 @@ | |||
| 1 | From eeb816d95f0910bd246e37bb2bb3923acf0edf6b Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Aleksander Us <aleksander.us@intel.com> | ||
| 3 | Date: Mon, 26 Aug 2019 15:47:41 +0300 | ||
| 4 | Subject: [PATCH] [BasicBlockUtils] Add metadata fixing in | ||
| 5 | SplitBlockPredecessors. | ||
| 6 | |||
| 7 | In case when BB is header of some loop and predecessor is latch of | ||
| 8 | this loop, metadata was not attached to newly created basic block. | ||
| 9 | This led to loss of loop metadata for other passes. | ||
| 10 | |||
| 11 | Upstream-Status: Submitted [https://reviews.llvm.org/D66892] | ||
| 12 | |||
| 13 | https://github.com/intel/llvm-patches/commit/8af4449e2d201707f7f2f832b473a0439e255f32 | ||
| 14 | |||
| 15 | Signed-off-by: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 16 | --- | ||
| 17 | lib/Transforms/Utils/BasicBlockUtils.cpp | 23 ++++++++---- | ||
| 18 | test/Transforms/LoopSimplify/loop_metadata.ll | 36 +++++++++++++++++++ | ||
| 19 | 2 files changed, 52 insertions(+), 7 deletions(-) | ||
| 20 | create mode 100644 test/Transforms/LoopSimplify/loop_metadata.ll | ||
| 21 | |||
| 22 | diff --git a/lib/Transforms/Utils/BasicBlockUtils.cpp b/lib/Transforms/Utils/BasicBlockUtils.cpp | ||
| 23 | index 5fa371377c8..3a90ae061fb 100644 | ||
| 24 | --- a/lib/Transforms/Utils/BasicBlockUtils.cpp | ||
| 25 | +++ b/lib/Transforms/Utils/BasicBlockUtils.cpp | ||
| 26 | @@ -579,24 +579,33 @@ BasicBlock *llvm::SplitBlockPredecessors(BasicBlock *BB, | ||
| 27 | |||
| 28 | // The new block unconditionally branches to the old block. | ||
| 29 | BranchInst *BI = BranchInst::Create(BB, NewBB); | ||
| 30 | + bool IsBBHeader = LI && LI->isLoopHeader(BB); | ||
| 31 | + Loop *BBLoop = LI ? LI->getLoopFor(BB) : nullptr; | ||
| 32 | // Splitting the predecessors of a loop header creates a preheader block. | ||
| 33 | - if (LI && LI->isLoopHeader(BB)) | ||
| 34 | + if (IsBBHeader) | ||
| 35 | // Using the loop start line number prevents debuggers stepping into the | ||
| 36 | // loop body for this instruction. | ||
| 37 | - BI->setDebugLoc(LI->getLoopFor(BB)->getStartLoc()); | ||
| 38 | + BI->setDebugLoc(BBLoop->getStartLoc()); | ||
| 39 | else | ||
| 40 | BI->setDebugLoc(BB->getFirstNonPHIOrDbg()->getDebugLoc()); | ||
| 41 | |||
| 42 | // Move the edges from Preds to point to NewBB instead of BB. | ||
| 43 | - for (unsigned i = 0, e = Preds.size(); i != e; ++i) { | ||
| 44 | + for (BasicBlock *Pred : Preds) { | ||
| 45 | + Instruction *PI = Pred->getTerminator(); | ||
| 46 | // This is slightly more strict than necessary; the minimum requirement | ||
| 47 | // is that there be no more than one indirectbr branching to BB. And | ||
| 48 | // all BlockAddress uses would need to be updated. | ||
| 49 | - assert(!isa<IndirectBrInst>(Preds[i]->getTerminator()) && | ||
| 50 | + assert(!isa<IndirectBrInst>(PI) && | ||
| 51 | "Cannot split an edge from an IndirectBrInst"); | ||
| 52 | - assert(!isa<CallBrInst>(Preds[i]->getTerminator()) && | ||
| 53 | - "Cannot split an edge from a CallBrInst"); | ||
| 54 | - Preds[i]->getTerminator()->replaceUsesOfWith(BB, NewBB); | ||
| 55 | + assert(!isa<CallBrInst>(PI) && "Cannot split an edge from a CallBrInst"); | ||
| 56 | + if (IsBBHeader && BBLoop->contains(Pred) && BBLoop->isLoopLatch(Pred)) { | ||
| 57 | + // Update loop metadata if it exists. | ||
| 58 | + if (MDNode *LoopMD = PI->getMetadata(LLVMContext::MD_loop)) { | ||
| 59 | + BI->setMetadata(LLVMContext::MD_loop, LoopMD); | ||
| 60 | + PI->setMetadata(LLVMContext::MD_loop, nullptr); | ||
| 61 | + } | ||
| 62 | + } | ||
| 63 | + PI->replaceUsesOfWith(BB, NewBB); | ||
| 64 | } | ||
| 65 | |||
| 66 | // Insert a new PHI node into NewBB for every PHI node in BB and that new PHI | ||
| 67 | diff --git a/test/Transforms/LoopSimplify/loop_metadata.ll b/test/Transforms/LoopSimplify/loop_metadata.ll | ||
| 68 | new file mode 100644 | ||
| 69 | index 00000000000..c15c92fe3ae | ||
| 70 | --- /dev/null | ||
| 71 | +++ b/test/Transforms/LoopSimplify/loop_metadata.ll | ||
| 72 | @@ -0,0 +1,36 @@ | ||
| 73 | +; RUN: opt -S -loop-simplify < %s | FileCheck %s | ||
| 74 | + | ||
| 75 | +; CHECK: for.cond.loopexit: | ||
| 76 | +; CHECK: br label %for.cond, !llvm.loop !0 | ||
| 77 | +; CHECK: br i1 %cmp1, label %for.body1, label %for.cond.loopexit | ||
| 78 | + | ||
| 79 | +define void @foo() { | ||
| 80 | +entry: | ||
| 81 | + br label %for.cond | ||
| 82 | + | ||
| 83 | +for.cond: ; preds = %for.cond1, %entry | ||
| 84 | + %j = phi i32 [ 0, %entry ], [ %add, %for.cond1 ] | ||
| 85 | + %cmp = icmp ult i32 %j, 8 | ||
| 86 | + br i1 %cmp, label %for.body, label %for.end | ||
| 87 | + | ||
| 88 | +for.body: ; preds = %for.cond | ||
| 89 | + %dummy1 = add i32 1, 1 | ||
| 90 | + %add = add nuw nsw i32 %j, 1 | ||
| 91 | + br label %for.cond1 | ||
| 92 | + | ||
| 93 | +for.cond1: ; preds = %for.body1, %for.body | ||
| 94 | + %i.0 = phi i32 [ 1, %for.body ], [ %inc, %for.body1 ] | ||
| 95 | + %cmp1 = icmp ult i32 %i.0, 8 | ||
| 96 | + br i1 %cmp1, label %for.body1, label %for.cond, !llvm.loop !0 | ||
| 97 | + | ||
| 98 | +for.body1: ; preds = %for.cond1 | ||
| 99 | + %dummy2 = add i32 1, 1 | ||
| 100 | + %inc = add nuw nsw i32 %i.0, 1 | ||
| 101 | + br label %for.cond1 | ||
| 102 | + | ||
| 103 | +for.end: ; preds = %for.cond | ||
| 104 | + ret void | ||
| 105 | +} | ||
| 106 | + | ||
| 107 | +!0 = distinct !{!0, !1} | ||
| 108 | +!1 = !{!"llvm.loop.unroll.full"} | ||
| 109 | -- | ||
| 110 | 2.18.0 | ||
| 111 | |||
diff --git a/dynamic-layers/clang-layer/recipes-devtools/clang/files/IndVarSimplify-Do-not-use-SCEV-expander-for-IVCount-.patch b/dynamic-layers/clang-layer/recipes-devtools/clang/files/IndVarSimplify-Do-not-use-SCEV-expander-for-IVCount-.patch deleted file mode 100644 index 48307deb..00000000 --- a/dynamic-layers/clang-layer/recipes-devtools/clang/files/IndVarSimplify-Do-not-use-SCEV-expander-for-IVCount-.patch +++ /dev/null | |||
| @@ -1,146 +0,0 @@ | |||
| 1 | From 35e218a886f4c066eabd18685240d55270bd5a6d Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Aleksander Us <aleksander.us@intel.com> | ||
| 3 | Date: Mon, 26 Aug 2019 15:45:47 +0300 | ||
| 4 | Subject: [PATCH] [IndVarSimplify] Do not use SCEV expander for IVCount in | ||
| 5 | LFTR when possible. | ||
| 6 | |||
| 7 | SCEV analysis cannot properly cache instruction with poison flags | ||
| 8 | (for example, add nsw outside of loop will not be reused by expander). | ||
| 9 | This can lead to generating of additional instructions by SCEV expander. | ||
| 10 | |||
| 11 | Example IR: | ||
| 12 | |||
| 13 | ... | ||
| 14 | %maxval = add nuw nsw i32 %a1, %a2 | ||
| 15 | ... | ||
| 16 | for.body: | ||
| 17 | ... | ||
| 18 | %cmp22 = icmp ult i32 %ivadd, %maxval | ||
| 19 | br i1 %cmp22, label %for.body, label %for.end | ||
| 20 | ... | ||
| 21 | |||
| 22 | SCEV expander will generate copy of %maxval in preheader but without | ||
| 23 | nuw/nsw flags. This can be avoided by explicit check that iv count | ||
| 24 | value gives the same SCEV expressions as calculated by LFTR. | ||
| 25 | |||
| 26 | Upstream-Status: Submitted [https://reviews.llvm.org/D66890] | ||
| 27 | |||
| 28 | https://github.com/intel/llvm-patches/commit/fd6a6c97341a56fd21bc32bc940afea751312e8f | ||
| 29 | |||
| 30 | Signed-off-by: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 31 | --- | ||
| 32 | lib/Transforms/Scalar/IndVarSimplify.cpp | 12 +++++++++- | ||
| 33 | test/Transforms/IndVarSimplify/add_nsw.ll | 23 ++++++++++++++++++++ | ||
| 34 | test/Transforms/IndVarSimplify/lftr-reuse.ll | 9 +++----- | ||
| 35 | test/Transforms/IndVarSimplify/udiv.ll | 1 + | ||
| 36 | 4 files changed, 38 insertions(+), 7 deletions(-) | ||
| 37 | create mode 100644 test/Transforms/IndVarSimplify/add_nsw.ll | ||
| 38 | |||
| 39 | diff --git a/lib/Transforms/Scalar/IndVarSimplify.cpp b/lib/Transforms/Scalar/IndVarSimplify.cpp | ||
| 40 | index f9fc698a4a9..5e04dac8aa6 100644 | ||
| 41 | --- a/lib/Transforms/Scalar/IndVarSimplify.cpp | ||
| 42 | +++ b/lib/Transforms/Scalar/IndVarSimplify.cpp | ||
| 43 | @@ -2375,6 +2375,17 @@ static Value *genLoopLimit(PHINode *IndVar, BasicBlock *ExitingBB, | ||
| 44 | if (UsePostInc) | ||
| 45 | IVLimit = SE->getAddExpr(IVLimit, SE->getOne(IVLimit->getType())); | ||
| 46 | |||
| 47 | + // If computed limit is equal to old limit then do not use SCEV expander | ||
| 48 | + // because it can lost NUW/NSW flags and create extra instructions. | ||
| 49 | + BranchInst *BI = cast<BranchInst>(ExitingBB->getTerminator()); | ||
| 50 | + if (ICmpInst *Cmp = dyn_cast<ICmpInst>(BI->getOperand(0))) { | ||
| 51 | + Value *Limit = Cmp->getOperand(0); | ||
| 52 | + if (!L->isLoopInvariant(Limit)) | ||
| 53 | + Limit = Cmp->getOperand(1); | ||
| 54 | + if (SE->getSCEV(Limit) == IVLimit) | ||
| 55 | + return Limit; | ||
| 56 | + } | ||
| 57 | + | ||
| 58 | // Expand the code for the iteration count. | ||
| 59 | assert(SE->isLoopInvariant(IVLimit, L) && | ||
| 60 | "Computed iteration count is not loop invariant!"); | ||
| 61 | @@ -2383,7 +2394,6 @@ static Value *genLoopLimit(PHINode *IndVar, BasicBlock *ExitingBB, | ||
| 62 | // SCEV expression (IVInit) for a pointer type IV value (IndVar). | ||
| 63 | Type *LimitTy = ExitCount->getType()->isPointerTy() ? | ||
| 64 | IndVar->getType() : ExitCount->getType(); | ||
| 65 | - BranchInst *BI = cast<BranchInst>(ExitingBB->getTerminator()); | ||
| 66 | return Rewriter.expandCodeFor(IVLimit, LimitTy, BI); | ||
| 67 | } | ||
| 68 | } | ||
| 69 | diff --git a/test/Transforms/IndVarSimplify/add_nsw.ll b/test/Transforms/IndVarSimplify/add_nsw.ll | ||
| 70 | new file mode 100644 | ||
| 71 | index 00000000000..abd1cbb6c51 | ||
| 72 | --- /dev/null | ||
| 73 | +++ b/test/Transforms/IndVarSimplify/add_nsw.ll | ||
| 74 | @@ -0,0 +1,23 @@ | ||
| 75 | +; RUN: opt -indvars -S %s | FileCheck %s | ||
| 76 | + | ||
| 77 | +target datalayout = "e-p:32:32-i64:64-n8:16:32" | ||
| 78 | + | ||
| 79 | +; CHECK: for.body.preheader: | ||
| 80 | +; CHECK-NOT: add | ||
| 81 | +; CHECK: for.body: | ||
| 82 | + | ||
| 83 | +define void @foo(i32 %a1, i32 %a2) { | ||
| 84 | +entry: | ||
| 85 | + %maxval = add nuw nsw i32 %a1, %a2 | ||
| 86 | + %cmp = icmp slt i32 %maxval, 1 | ||
| 87 | + br i1 %cmp, label %for.end, label %for.body | ||
| 88 | + | ||
| 89 | +for.body: ; preds = %entry, %for.body | ||
| 90 | + %j.02 = phi i32 [ 0, %entry ], [ %add31, %for.body ] | ||
| 91 | + %add31 = add nuw nsw i32 %j.02, 1 | ||
| 92 | + %cmp22 = icmp slt i32 %add31, %maxval | ||
| 93 | + br i1 %cmp22, label %for.body, label %for.end | ||
| 94 | + | ||
| 95 | +for.end: ; preds = %for.body | ||
| 96 | + ret void | ||
| 97 | +} | ||
| 98 | diff --git a/test/Transforms/IndVarSimplify/lftr-reuse.ll b/test/Transforms/IndVarSimplify/lftr-reuse.ll | ||
| 99 | index 14ae9738696..509d662b767 100644 | ||
| 100 | --- a/test/Transforms/IndVarSimplify/lftr-reuse.ll | ||
| 101 | +++ b/test/Transforms/IndVarSimplify/lftr-reuse.ll | ||
| 102 | @@ -67,11 +67,9 @@ define void @expandOuterRecurrence(i32 %arg) nounwind { | ||
| 103 | ; CHECK-NEXT: [[CMP1:%.*]] = icmp slt i32 0, [[SUB1]] | ||
| 104 | ; CHECK-NEXT: br i1 [[CMP1]], label [[OUTER_PREHEADER:%.*]], label [[EXIT:%.*]] | ||
| 105 | ; CHECK: outer.preheader: | ||
| 106 | -; CHECK-NEXT: [[TMP0:%.*]] = add i32 [[ARG]], -1 | ||
| 107 | ; CHECK-NEXT: br label [[OUTER:%.*]] | ||
| 108 | ; CHECK: outer: | ||
| 109 | -; CHECK-NEXT: [[INDVARS_IV:%.*]] = phi i32 [ [[TMP0]], [[OUTER_PREHEADER]] ], [ [[INDVARS_IV_NEXT:%.*]], [[OUTER_INC:%.*]] ] | ||
| 110 | -; CHECK-NEXT: [[I:%.*]] = phi i32 [ [[I_INC:%.*]], [[OUTER_INC]] ], [ 0, [[OUTER_PREHEADER]] ] | ||
| 111 | +; CHECK-NEXT: [[I:%.*]] = phi i32 [ [[I_INC:%.*]], [[OUTER_INC:%.*]] ], [ 0, [[OUTER_PREHEADER]] ] | ||
| 112 | ; CHECK-NEXT: [[SUB2:%.*]] = sub nsw i32 [[ARG]], [[I]] | ||
| 113 | ; CHECK-NEXT: [[SUB3:%.*]] = sub nsw i32 [[SUB2]], 1 | ||
| 114 | ; CHECK-NEXT: [[CMP2:%.*]] = icmp slt i32 0, [[SUB3]] | ||
| 115 | @@ -81,14 +79,13 @@ define void @expandOuterRecurrence(i32 %arg) nounwind { | ||
| 116 | ; CHECK: inner: | ||
| 117 | ; CHECK-NEXT: [[J:%.*]] = phi i32 [ 0, [[INNER_PH]] ], [ [[J_INC:%.*]], [[INNER]] ] | ||
| 118 | ; CHECK-NEXT: [[J_INC]] = add nuw nsw i32 [[J]], 1 | ||
| 119 | -; CHECK-NEXT: [[EXITCOND:%.*]] = icmp ne i32 [[J_INC]], [[INDVARS_IV]] | ||
| 120 | +; CHECK-NEXT: [[EXITCOND:%.*]] = icmp ne i32 [[J_INC]], [[SUB3]] | ||
| 121 | ; CHECK-NEXT: br i1 [[EXITCOND]], label [[INNER]], label [[OUTER_INC_LOOPEXIT:%.*]] | ||
| 122 | ; CHECK: outer.inc.loopexit: | ||
| 123 | ; CHECK-NEXT: br label [[OUTER_INC]] | ||
| 124 | ; CHECK: outer.inc: | ||
| 125 | ; CHECK-NEXT: [[I_INC]] = add nuw nsw i32 [[I]], 1 | ||
| 126 | -; CHECK-NEXT: [[INDVARS_IV_NEXT]] = add i32 [[INDVARS_IV]], -1 | ||
| 127 | -; CHECK-NEXT: [[EXITCOND1:%.*]] = icmp ne i32 [[I_INC]], [[TMP0]] | ||
| 128 | +; CHECK-NEXT: [[EXITCOND1:%.*]] = icmp ne i32 [[I_INC]], [[SUB1]] | ||
| 129 | ; CHECK-NEXT: br i1 [[EXITCOND1]], label [[OUTER]], label [[EXIT_LOOPEXIT:%.*]] | ||
| 130 | ; CHECK: exit.loopexit: | ||
| 131 | ; CHECK-NEXT: br label [[EXIT]] | ||
| 132 | diff --git a/test/Transforms/IndVarSimplify/udiv.ll b/test/Transforms/IndVarSimplify/udiv.ll | ||
| 133 | index b3f2c2a6a66..3530343ef4a 100644 | ||
| 134 | --- a/test/Transforms/IndVarSimplify/udiv.ll | ||
| 135 | +++ b/test/Transforms/IndVarSimplify/udiv.ll | ||
| 136 | @@ -133,6 +133,7 @@ declare i32 @printf(i8* nocapture, ...) nounwind | ||
| 137 | ; CHECK-LABEL: @foo( | ||
| 138 | ; CHECK: for.body.preheader: | ||
| 139 | ; CHECK-NOT: udiv | ||
| 140 | +; CHECK: for.body: | ||
| 141 | |||
| 142 | define void @foo(double* %p, i64 %n) nounwind { | ||
| 143 | entry: | ||
| 144 | -- | ||
| 145 | 2.18.0 | ||
| 146 | |||
diff --git a/dynamic-layers/clang-layer/recipes-devtools/clang/llvm-project-source.bbappend b/dynamic-layers/clang-layer/recipes-devtools/clang/llvm-project-source.bbappend deleted file mode 100644 index 65115bce..00000000 --- a/dynamic-layers/clang-layer/recipes-devtools/clang/llvm-project-source.bbappend +++ /dev/null | |||
| @@ -1,10 +0,0 @@ | |||
| 1 | FILESEXTRAPATHS_prepend_intel-x86-common := "${THISDIR}/files:" | ||
| 2 | |||
| 3 | SRC_URI_append_intel-x86-common = " \ | ||
| 4 | file://BasicBlockUtils-Add-metadata-fixing-in-SplitBlockPre.patch;patchdir=llvm \ | ||
| 5 | file://IndVarSimplify-Do-not-use-SCEV-expander-for-IVCount-.patch;patchdir=llvm \ | ||
| 6 | git://github.com/KhronosGroup/SPIRV-LLVM-Translator.git;protocol=https;branch=llvm_release_90;destsuffix=git/llvm/projects/llvm-spirv;name=spirv \ | ||
| 7 | file://0001-skip-building-tests.patch;patchdir=llvm/projects/llvm-spirv \ | ||
| 8 | " | ||
| 9 | |||
| 10 | SRCREV_spirv = "07f29780e5c4128924508d5d1c00bdf9ff7fd43d" | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/0002-Build-not-able-to-locate-cpp_generation_tool.patch b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/0002-Build-not-able-to-locate-cpp_generation_tool.patch new file mode 100644 index 00000000..45288ce1 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/0002-Build-not-able-to-locate-cpp_generation_tool.patch | |||
| @@ -0,0 +1,41 @@ | |||
| 1 | From 8c330d0cb5167612296801f0202b0de35e9ca88d Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Dongwon Kim <dongwon.kim@intel.com> | ||
| 3 | Date: Sat, 21 Aug 2021 16:09:39 -0700 | ||
| 4 | Subject: [PATCH 2/5] Build not able to locate cpp_generation_tool. | ||
| 5 | |||
| 6 | Upstream-Status: Inappropriate [oe specific] | ||
| 7 | |||
| 8 | Signed-off-by: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 9 | Signed-off-by: Dongwon Kim <dongwon.kim@intel.com> | ||
| 10 | --- | ||
| 11 | shared/source/built_ins/kernels/CMakeLists.txt | 10 +++++----- | ||
| 12 | 1 file changed, 5 insertions(+), 5 deletions(-) | ||
| 13 | |||
| 14 | Index: git/shared/source/built_ins/kernels/CMakeLists.txt | ||
| 15 | =================================================================== | ||
| 16 | --- git.orig/shared/source/built_ins/kernels/CMakeLists.txt | ||
| 17 | +++ git/shared/source/built_ins/kernels/CMakeLists.txt | ||
| 18 | @@ -122,9 +122,9 @@ function(compile_builtin core_type platf | ||
| 19 | endif() | ||
| 20 | add_custom_command( | ||
| 21 | OUTPUT ${OUTPUT_FILE_CPP} | ||
| 22 | - COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${BINARY_OUTPUT}.bin --output ${OUTPUT_FILE_CPP} --array ${mode}_${BASENAME} --device ${RELEASE_FILENAME} | ||
| 23 | + COMMAND cpp_generate_tool --file ${BINARY_OUTPUT}.bin --output ${OUTPUT_FILE_CPP} --array ${mode}_${BASENAME} --device ${RELEASE_FILENAME} | ||
| 24 | WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} | ||
| 25 | - DEPENDS ${OUTPUT_FILES_BINARIES} $<TARGET_FILE:cpp_generate_tool> | ||
| 26 | + DEPENDS ${OUTPUT_FILES_BINARIES} cpp_generate_tool | ||
| 27 | ) | ||
| 28 | list(APPEND BUILTINS_COMMANDS "${OUTPUT_FILE_CPP}") | ||
| 29 | else() | ||
| 30 | @@ -176,9 +176,9 @@ function(generate_cpp_spirv builtin) | ||
| 31 | endif() | ||
| 32 | add_custom_command( | ||
| 33 | OUTPUT ${OUTPUT_FILE_CPP} | ||
| 34 | - COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${GENERATED_SPV_INPUT} --output ${OUTPUT_FILE_CPP} --array ${BASENAME} | ||
| 35 | + COMMAND cpp_generate_tool --file ${GENERATED_SPV_INPUT} --output ${OUTPUT_FILE_CPP} --array ${BASENAME} | ||
| 36 | WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} | ||
| 37 | - DEPENDS ${GENERATED_SPV_INPUT} $<TARGET_FILE:cpp_generate_tool> | ||
| 38 | + DEPENDS ${GENERATED_SPV_INPUT} cpp_generate_tool | ||
| 39 | ) | ||
| 40 | set(OUTPUT_LIST_CPP_FILES ${OUTPUT_LIST_CPP_FILES} ${OUTPUT_FILE_CPP} PARENT_SCOPE) | ||
| 41 | else() | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/0003-external-ocloc.patch b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/0003-external-ocloc.patch new file mode 100644 index 00000000..2001d839 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/0003-external-ocloc.patch | |||
| @@ -0,0 +1,38 @@ | |||
| 1 | From 0006db5f55a9f08bd3452558a53704cd3bbb790f Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Dongwon Kim <dongwon.kim@intel.com> | ||
| 3 | Date: Wed, 2 Mar 2022 15:52:45 -0800 | ||
| 4 | Subject: [PATCH 3/5] external ocloc | ||
| 5 | |||
| 6 | Upstream-Status: Inappropriate | ||
| 7 | |||
| 8 | Signed-off-by: Dongwon Kim <dongwon.kim@intel.com> | ||
| 9 | --- | ||
| 10 | cmake/ocloc_cmd_prefix.cmake | 14 ++++++++------ | ||
| 11 | 1 file changed, 8 insertions(+), 6 deletions(-) | ||
| 12 | |||
| 13 | Index: git/cmake/ocloc_cmd_prefix.cmake | ||
| 14 | =================================================================== | ||
| 15 | --- git.orig/cmake/ocloc_cmd_prefix.cmake | ||
| 16 | +++ git/cmake/ocloc_cmd_prefix.cmake | ||
| 17 | @@ -4,13 +4,15 @@ | ||
| 18 | # SPDX-License-Identifier: MIT | ||
| 19 | # | ||
| 20 | |||
| 21 | -if(WIN32) | ||
| 22 | - set(ocloc_cmd_prefix ocloc) | ||
| 23 | -else() | ||
| 24 | - if(DEFINED NEO__IGC_LIBRARY_PATH) | ||
| 25 | - set(ocloc_cmd_prefix ${CMAKE_COMMAND} -E env "LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib>" $<TARGET_FILE:ocloc>) | ||
| 26 | +if(NOT DEFINED ocloc_cmd_prefix) | ||
| 27 | + if(WIN32) | ||
| 28 | + set(ocloc_cmd_prefix ocloc) | ||
| 29 | else() | ||
| 30 | - set(ocloc_cmd_prefix ${CMAKE_COMMAND} -E env "LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib>" $<TARGET_FILE:ocloc>) | ||
| 31 | + if(DEFINED NEO__IGC_LIBRARY_PATH) | ||
| 32 | + set(ocloc_cmd_prefix LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>) | ||
| 33 | + else() | ||
| 34 | + set(ocloc_cmd_prefix LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>) | ||
| 35 | + endif() | ||
| 36 | endif() | ||
| 37 | endif() | ||
| 38 | |||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/dont-use-ld-library-path.patch b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/dont-use-ld-library-path.patch deleted file mode 100644 index 6f7cdff8..00000000 --- a/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime/dont-use-ld-library-path.patch +++ /dev/null | |||
| @@ -1,46 +0,0 @@ | |||
| 1 | From ad3e325c1af4d6533fd9b3dfc5208267b678327a Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 3 | Date: Thu, 6 Feb 2020 18:25:19 +0800 | ||
| 4 | Subject: [PATCH] don't use LD_LIBRARY_PATH for native offline compiler | ||
| 5 | |||
| 6 | Let us supply the correct path for it to be able to find the correct | ||
| 7 | libraries. | ||
| 8 | |||
| 9 | Upstream-Status: Inappropriate | ||
| 10 | |||
| 11 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 12 | Signed-off-by: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 13 | --- | ||
| 14 | runtime/built_ins/kernels/CMakeLists.txt | 2 +- | ||
| 15 | runtime/scheduler/scheduler_binary.cmake | 2 +- | ||
| 16 | 2 files changed, 2 insertions(+), 2 deletions(-) | ||
| 17 | |||
| 18 | diff --git a/runtime/built_ins/kernels/CMakeLists.txt b/runtime/built_ins/kernels/CMakeLists.txt | ||
| 19 | index 863dba145..a385cf768 100644 | ||
| 20 | --- a/runtime/built_ins/kernels/CMakeLists.txt | ||
| 21 | +++ b/runtime/built_ins/kernels/CMakeLists.txt | ||
| 22 | @@ -66,7 +66,7 @@ function(compile_builtin gen_type platform_type builtin bits builtin_options) | ||
| 23 | if(DEFINED NEO__IGC_LIBRARY_PATH) | ||
| 24 | set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH} $<TARGET_FILE:ocloc>) | ||
| 25 | else() | ||
| 26 | - set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc> $<TARGET_FILE:ocloc>) | ||
| 27 | + set(cloc_cmd_prefix ocloc) | ||
| 28 | endif() | ||
| 29 | endif() | ||
| 30 | list(APPEND __cloc__options__ "-cl-kernel-arg-info") | ||
| 31 | diff --git a/runtime/scheduler/scheduler_binary.cmake b/runtime/scheduler/scheduler_binary.cmake | ||
| 32 | index a7015b909..a720d2f5c 100644 | ||
| 33 | --- a/runtime/scheduler/scheduler_binary.cmake | ||
| 34 | +++ b/runtime/scheduler/scheduler_binary.cmake | ||
| 35 | @@ -37,7 +37,7 @@ function(compile_kernel target gen_type platform_type kernel) | ||
| 36 | if(DEFINED NEO__IGC_LIBRARY_PATH) | ||
| 37 | set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH} $<TARGET_FILE:ocloc>) | ||
| 38 | else() | ||
| 39 | - set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc> $<TARGET_FILE:ocloc>) | ||
| 40 | + set(cloc_cmd_prefix ocloc) | ||
| 41 | endif() | ||
| 42 | endif() | ||
| 43 | list(APPEND __cloc__options__ "-cl-kernel-arg-info") | ||
| 44 | -- | ||
| 45 | 2.17.1 | ||
| 46 | |||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime_20.04.15428.bb b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime_20.04.15428.bb deleted file mode 100644 index f6cfaf19..00000000 --- a/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime_20.04.15428.bb +++ /dev/null | |||
| @@ -1,43 +0,0 @@ | |||
| 1 | SUMMARY = "The Intel(R) Graphics Compute Runtime for OpenCL(TM)" | ||
| 2 | DESCRIPTION = "The Intel(R) Graphics Compute Runtime for OpenCL(TM) \ | ||
| 3 | is an open source project to converge Intel's development efforts \ | ||
| 4 | on OpenCL(TM) compute stacks supporting the GEN graphics hardware \ | ||
| 5 | architecture." | ||
| 6 | |||
| 7 | LICENSE = "MIT" | ||
| 8 | LIC_FILES_CHKSUM = "file://LICENSE;md5=ae27f47fd6755510247c19e547e4c804 \ | ||
| 9 | file://third_party/opencl_headers/LICENSE;md5=dcefc90f4c3c689ec0c2489064e7273b" | ||
| 10 | |||
| 11 | SRC_URI = "git://github.com/intel/compute-runtime.git;protocol=https \ | ||
| 12 | " | ||
| 13 | |||
| 14 | SRC_URI_append_class-target = " \ | ||
| 15 | file://dont-use-ld-library-path.patch \ | ||
| 16 | " | ||
| 17 | SRCREV = "98006aa2bf282ebc5914359e0e4c5f1c539de56f" | ||
| 18 | |||
| 19 | S = "${WORKDIR}/git" | ||
| 20 | |||
| 21 | DEPENDS += " intel-graphics-compiler gmmlib clang" | ||
| 22 | DEPENDS_append_class-target = " intel-compute-runtime-native" | ||
| 23 | |||
| 24 | RDEPENDS_${PN} += " intel-graphics-compiler gmmlib" | ||
| 25 | |||
| 26 | inherit cmake pkgconfig | ||
| 27 | |||
| 28 | COMPATIBLE_HOST = '(x86_64).*-linux' | ||
| 29 | COMPATIBLE_HOST_libc-musl = "null" | ||
| 30 | |||
| 31 | EXTRA_OECMAKE = " \ | ||
| 32 | -DIGC_DIR=${STAGING_INCDIR}/igc \ | ||
| 33 | -DBUILD_TYPE=Release \ | ||
| 34 | -DSKIP_UNIT_TESTS=1 \ | ||
| 35 | -DCCACHE_ALLOWED=FALSE \ | ||
| 36 | " | ||
| 37 | |||
| 38 | FILES_${PN} += "${libdir}/intel-opencl/libigdrcl.so" | ||
| 39 | |||
| 40 | BBCLASSEXTEND = "native nativesdk" | ||
| 41 | |||
| 42 | UPSTREAM_CHECK_GITTAGREGEX = "(?P<pver>\d+(\.\d+)+)" | ||
| 43 | EXCLUDE_FROM_WORLD = "1" | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime_25.13.33276.16.bb b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime_25.13.33276.16.bb new file mode 100644 index 00000000..b13daaa8 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/compute-runtime/intel-compute-runtime_25.13.33276.16.bb | |||
| @@ -0,0 +1,61 @@ | |||
| 1 | SUMMARY = "The Intel(R) Graphics Compute Runtime for OpenCL(TM)" | ||
| 2 | DESCRIPTION = "The Intel(R) Graphics Compute Runtime for OpenCL(TM) \ | ||
| 3 | is an open source project to converge Intel's development efforts \ | ||
| 4 | on OpenCL(TM) compute stacks supporting the GEN graphics hardware \ | ||
| 5 | architecture." | ||
| 6 | |||
| 7 | LICENSE = "MIT & Apache-2.0" | ||
| 8 | LIC_FILES_CHKSUM = "file://LICENSE.md;md5=eca6ec6997e18db166db7109cdbe611c \ | ||
| 9 | file://third_party/opencl_headers/LICENSE;md5=3b83ef96387f14655fc854ddc3c6bd57" | ||
| 10 | |||
| 11 | SRC_URI = "git://github.com/intel/compute-runtime.git;protocol=https;branch=releases/25.13 \ | ||
| 12 | file://0002-Build-not-able-to-locate-cpp_generation_tool.patch \ | ||
| 13 | file://0003-external-ocloc.patch \ | ||
| 14 | " | ||
| 15 | |||
| 16 | SRCREV = "a9961bdfaa07250fd52ff930bf8f31fb4e3b7799" | ||
| 17 | |||
| 18 | DEPENDS += " intel-graphics-compiler gmmlib libva qemu-native" | ||
| 19 | |||
| 20 | RDEPENDS:${PN} += " intel-graphics-compiler gmmlib" | ||
| 21 | |||
| 22 | inherit cmake pkgconfig qemu | ||
| 23 | |||
| 24 | COMPATIBLE_HOST = '(x86_64).*-linux' | ||
| 25 | COMPATIBLE_HOST:libc-musl = "null" | ||
| 26 | |||
| 27 | EXTRA_OECMAKE = " \ | ||
| 28 | -DIGC_DIR=${STAGING_INCDIR}/igc \ | ||
| 29 | -DBUILD_TYPE=Release \ | ||
| 30 | -DSKIP_UNIT_TESTS=1 \ | ||
| 31 | -DCCACHE_ALLOWED=FALSE \ | ||
| 32 | -DNEO_DISABLE_LD_LLD=ON \ | ||
| 33 | -DNEO_DISABLE_LD_GOLD=ON \ | ||
| 34 | " | ||
| 35 | |||
| 36 | EXTRA_OECMAKE:append:class-target = " \ | ||
| 37 | -Docloc_cmd_prefix=ocloc \ | ||
| 38 | -DCMAKE_CROSSCOMPILING_EMULATOR=${WORKDIR}/qemuwrapper \ | ||
| 39 | " | ||
| 40 | |||
| 41 | PACKAGECONFIG ??= "" | ||
| 42 | PACKAGECONFIG[levelzero] = "-DBUILD_WITH_L0=ON, -DBUILD_WITH_L0=OFF, level-zero" | ||
| 43 | |||
| 44 | do_configure:prepend:class-target () { | ||
| 45 | # Write out a qemu wrapper that will be used by cmake. | ||
| 46 | qemu_binary="${@qemu_wrapper_cmdline(d, d.getVar('STAGING_DIR_HOST'), [d.expand('${B}/bin'),d.expand('${STAGING_DIR_HOST}${libdir}'),d.expand('${STAGING_DIR_HOST}${base_libdir}')])}" | ||
| 47 | cat > ${WORKDIR}/qemuwrapper << EOF | ||
| 48 | #!/bin/sh | ||
| 49 | $qemu_binary "\$@" | ||
| 50 | EOF | ||
| 51 | chmod +x ${WORKDIR}/qemuwrapper | ||
| 52 | } | ||
| 53 | |||
| 54 | FILES:${PN} += " \ | ||
| 55 | ${libdir}/intel-opencl/libigdrcl.so \ | ||
| 56 | ${libdir}/libocloc.so \ | ||
| 57 | " | ||
| 58 | |||
| 59 | FILES:${PN}-dev = "${includedir}" | ||
| 60 | |||
| 61 | UPSTREAM_CHECK_GITTAGREGEX = "(?P<pver>\d+(\.\d+)+)" | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-BiF-CMakeLists.txt-remove-opt-from-DEPENDS.patch b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-BiF-CMakeLists.txt-remove-opt-from-DEPENDS.patch new file mode 100644 index 00000000..456a8c65 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-BiF-CMakeLists.txt-remove-opt-from-DEPENDS.patch | |||
| @@ -0,0 +1,32 @@ | |||
| 1 | From 1b98a931c3bf8daccc48cd618335ff35e3d382da Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Anuj Mittal <anuj.mittal@intel.com> | ||
| 3 | Date: Tue, 12 Oct 2021 23:46:42 +0800 | ||
| 4 | Subject: [PATCH] BiF/CMakeLists.txt: remove opt from DEPENDS | ||
| 5 | |||
| 6 | Otherwise it starts failing with: | ||
| 7 | |||
| 8 | | ninja: error: 'IGC/VectorCompiler/lib/BiF/opt', needed by 'IGC/VectorCompiler/lib/BiF/VCBiFPrintfOCL32.opt.bc', missing and no known rule to make it | ||
| 9 | |||
| 10 | We don't need to explicitly make sure opt is built when | ||
| 11 | using prebuilt binaries. | ||
| 12 | |||
| 13 | Upstream-Status: Inappropriate | ||
| 14 | |||
| 15 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 16 | --- | ||
| 17 | IGC/VectorCompiler/lib/BiF/cmake/Functions.cmake | 2 +- | ||
| 18 | 1 file changed, 1 insertion(+), 1 deletion(-) | ||
| 19 | |||
| 20 | Index: git/IGC/VectorCompiler/lib/BiF/cmake/Functions.cmake | ||
| 21 | =================================================================== | ||
| 22 | --- git.orig/IGC/VectorCompiler/lib/BiF/cmake/Functions.cmake | ||
| 23 | +++ git/IGC/VectorCompiler/lib/BiF/cmake/Functions.cmake | ||
| 24 | @@ -121,7 +121,7 @@ function(vc_build_bif RES_FILE CMCL_SRC_ | ||
| 25 | COMMENT "vc_build_bif: Translating CMCL builtins: ${BIF_CLANG_BC_NAME_FINAL} -> ${BIF_OPT_BC_NAME}" | ||
| 26 | COMMAND CMCLTranslatorTool ${OPT_OPAQUE_ARG} -o ${BIF_CMCL_BC_PATH} ${BIF_CLANG_BC_PATH_FINAL} | ||
| 27 | COMMAND ${LLVM_OPT_EXE} ${OPT_OPAQUE_ARG} --O2 -o ${BIF_OPT_BC_PATH} ${BIF_CMCL_BC_PATH} | ||
| 28 | - DEPENDS CMCLTranslatorTool ${LLVM_OPT_EXE} ${OPT_BC_DEPENDS}) | ||
| 29 | + DEPENDS CMCLTranslatorTool ${BIF_CLANG_BC_PATH_FINAL}) | ||
| 30 | |||
| 31 | add_custom_target(${TARGET_NAME} | ||
| 32 | DEPENDS ${BIF_OPT_BC_PATH} | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-Build-not-able-to-locate-BiFManager-bin.patch b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-Build-not-able-to-locate-BiFManager-bin.patch new file mode 100644 index 00000000..87b094aa --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-Build-not-able-to-locate-BiFManager-bin.patch | |||
| @@ -0,0 +1,27 @@ | |||
| 1 | From 048512728eea53b3772a3f80ac9743bfc462487e Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Yogesh Tyagi <yogesh.tyagi@intel.com> | ||
| 3 | Date: Thu, 2 Jan 2025 15:59:27 +0530 | ||
| 4 | Subject: [PATCH] Build not able to locate BiFManager-bin | ||
| 5 | |||
| 6 | Upstream-Status: Inappropriate [oe specific] | ||
| 7 | |||
| 8 | Signed-off-by: Yogesh Tyagi <yogesh.tyagi@intel.com> | ||
| 9 | --- | ||
| 10 | IGC/BiFModule/CMakeLists.txt | 4 ++-- | ||
| 11 | 1 file changed, 2 insertions(+), 2 deletions(-) | ||
| 12 | |||
| 13 | Index: git/IGC/BiFModule/CMakeLists.txt | ||
| 14 | =================================================================== | ||
| 15 | --- git.orig/IGC/BiFModule/CMakeLists.txt | ||
| 16 | +++ git/IGC/BiFModule/CMakeLists.txt | ||
| 17 | @@ -655,8 +655,8 @@ set(IGC_BUILD__PROJ__BiFModuleCache_OCL | ||
| 18 | |||
| 19 | add_custom_command( | ||
| 20 | OUTPUT "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.h" "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bifbc" | ||
| 21 | - COMMAND $<TARGET_FILE:BiFManager-bin> "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_32.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_64.bc" "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bifbc" "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.h" | ||
| 22 | - DEPENDS "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_32.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_64.bc"$<TARGET_FILE:BiFManager-bin> | ||
| 23 | + COMMAND BiFManager-bin "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_32.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_64.bc" "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bifbc" "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.h" | ||
| 24 | + DEPENDS "${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_32.bc" "${IGC_BUILD__BIF_DIR}/IGCsize_t_64.bc" BiFManager-bin | ||
| 25 | COMMENT "BiF: ${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bc: Spliting output .bc." | ||
| 26 | COMMAND_EXPAND_LISTS | ||
| 27 | ) | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-external-SPIRV-Tools-change-path-to-tools-and-header.patch b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-external-SPIRV-Tools-change-path-to-tools-and-header.patch new file mode 100644 index 00000000..fc66b71d --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-external-SPIRV-Tools-change-path-to-tools-and-header.patch | |||
| @@ -0,0 +1,30 @@ | |||
| 1 | From 251e2854dd206ebf66e5908d3277e4585fe2a63b Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Anuj Mittal <anuj.mittal@intel.com> | ||
| 3 | Date: Mon, 9 Jan 2023 11:43:05 +0800 | ||
| 4 | Subject: [PATCH] external/SPIRV-Tools: change path to tools and headers | ||
| 5 | |||
| 6 | We clone the SPIRV headers and tools in a different directory to ensure | ||
| 7 | file path substitutions take place. | ||
| 8 | |||
| 9 | Upstream-Status: Inappropriate | ||
| 10 | |||
| 11 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 12 | --- | ||
| 13 | external/SPIRV-Tools/CMakeLists.txt | 4 ++-- | ||
| 14 | 1 file changed, 2 insertions(+), 2 deletions(-) | ||
| 15 | |||
| 16 | Index: git/external/SPIRV-Tools/CMakeLists.txt | ||
| 17 | =================================================================== | ||
| 18 | --- git.orig/external/SPIRV-Tools/CMakeLists.txt | ||
| 19 | +++ git/external/SPIRV-Tools/CMakeLists.txt | ||
| 20 | @@ -45,8 +45,8 @@ else() #By default use build from source | ||
| 21 | message(STATUS "[SPIRV-Tools] : Building from source") | ||
| 22 | message(STATUS "[SPIRV-Tools] : Current source dir: ${CMAKE_CURRENT_SOURCE_DIR}") | ||
| 23 | |||
| 24 | - set(SPIRV-Headers_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../../SPIRV-Headers") # used in subdirectory | ||
| 25 | - set(SPIRV-Tools_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../../SPIRV-Tools") | ||
| 26 | + set(SPIRV-Headers_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../SPIRV-Headers") # used in subdirectory | ||
| 27 | + set(SPIRV-Tools_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../SPIRV-Tools") | ||
| 28 | |||
| 29 | set(SPIRV-Tools_OUTPUT_DIR "${IGC_OPTION__OUTPUT_DIR}/external/SPIRV-Tools/build") | ||
| 30 | set(IGC_BUILD__SPIRV-Headers_DIR "${SPIRV-Headers_SOURCE_DIR}") | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-fix-tblgen.patch b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-fix-tblgen.patch new file mode 100644 index 00000000..3d9ae02f --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-fix-tblgen.patch | |||
| @@ -0,0 +1,23 @@ | |||
| 1 | From 1641dc87b2ed6b6b87b2cef824e4d66da65b0b30 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Anuj Mittal <anuj.mittal@intel.com> | ||
| 3 | Date: Thu, 19 May 2022 22:50:09 +0800 | ||
| 4 | Subject: [PATCH] fix tblgen | ||
| 5 | |||
| 6 | Upstream-Status: Inappropriate [OE specific] | ||
| 7 | --- | ||
| 8 | IGC/cmake/igc_llvm.cmake | 2 +- | ||
| 9 | 1 file changed, 1 insertion(+), 1 deletion(-) | ||
| 10 | |||
| 11 | diff --git a/IGC/cmake/igc_llvm.cmake b/IGC/cmake/igc_llvm.cmake | ||
| 12 | index b708cc904..fe4668890 100644 | ||
| 13 | --- a/IGC/cmake/igc_llvm.cmake | ||
| 14 | +++ b/IGC/cmake/igc_llvm.cmake | ||
| 15 | @@ -53,7 +53,7 @@ else() | ||
| 16 | set(LLVM_OPT_EXE "opt" CACHE STRING "") | ||
| 17 | |||
| 18 | set(LLVM_TABLEGEN_EXE "llvm-tblgen") | ||
| 19 | - if(CMAKE_CROSSCOMPILING) | ||
| 20 | + if(TRUE) | ||
| 21 | if(DEFINED LLVM_TABLEGEN) | ||
| 22 | set(LLVM_TABLEGEN_EXE ${LLVM_TABLEGEN}) | ||
| 23 | else() | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-skip-execution-of-ElfPackager.patch b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-skip-execution-of-ElfPackager.patch deleted file mode 100644 index 65342d9c..00000000 --- a/dynamic-layers/clang-layer/recipes-opencl/igc/files/0001-skip-execution-of-ElfPackager.patch +++ /dev/null | |||
| @@ -1,43 +0,0 @@ | |||
| 1 | From 5501fab763aa2b11437fbdb19e07a11157a7d3e6 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 3 | Date: Thu, 6 Feb 2020 14:56:56 +0800 | ||
| 4 | Subject: [PATCH] skip execution of ElfPackager | ||
| 5 | |||
| 6 | ElfPackager adds the ability to convert llvm bitcode into elf files for | ||
| 7 | easier partitioning. Skip for now until we start building a native | ||
| 8 | version for this. | ||
| 9 | |||
| 10 | Upstream-Status: Inappropriate [configuration specific] | ||
| 11 | |||
| 12 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 13 | Signed-off-by: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 14 | --- | ||
| 15 | IGC/ElfPackager/CMakeLists.txt | 12 ++++++------ | ||
| 16 | 1 file changed, 6 insertions(+), 6 deletions(-) | ||
| 17 | |||
| 18 | diff --git a/IGC/ElfPackager/CMakeLists.txt b/IGC/ElfPackager/CMakeLists.txt | ||
| 19 | index 563ac9d6..c6c74ce9 100644 | ||
| 20 | --- a/IGC/ElfPackager/CMakeLists.txt | ||
| 21 | +++ b/IGC/ElfPackager/CMakeLists.txt | ||
| 22 | @@ -71,12 +71,12 @@ include_directories ( | ||
| 23 | ${IGC_SOURCE_DIR}/AdaptorOCL/CLElfLib/ | ||
| 24 | ) | ||
| 25 | |||
| 26 | -if(NOT ANDROID) | ||
| 27 | - add_custom_command(TARGET ${IGC_BUILD__PROJ__ElfPackager} | ||
| 28 | - POST_BUILD | ||
| 29 | - COMMAND $<TARGET_FILE:${IGC_BUILD__PROJ__ElfPackager}> -includeSizet -funcList ${CMAKE_CURRENT_SOURCE_DIR}/function_bin.txt ${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bc ${IGC_BUILD__BIF_DIR}/igdclbif.bin | ||
| 30 | - ) | ||
| 31 | -endif() | ||
| 32 | +#if(NOT ANDROID) | ||
| 33 | +# add_custom_command(TARGET ${IGC_BUILD__PROJ__ElfPackager} | ||
| 34 | +# POST_BUILD | ||
| 35 | +# COMMAND $<TARGET_FILE:${IGC_BUILD__PROJ__ElfPackager}> -includeSizet -funcList ${CMAKE_CURRENT_SOURCE_DIR}/function_bin.txt ${IGC_BUILD__BIF_DIR}/OCLBiFImpl.bc ${IGC_BUILD__BIF_DIR}/igdclbif.bin | ||
| 36 | +# ) | ||
| 37 | +#endif() | ||
| 38 | |||
| 39 | |||
| 40 | add_dependencies("${IGC_BUILD__PROJ__ElfPackager}" "${IGC_BUILD__PROJ__BiFModule_OCL}") | ||
| 41 | -- | ||
| 42 | 2.17.1 | ||
| 43 | |||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/files/0003-Improve-Reproducibility-for-src-package.patch b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0003-Improve-Reproducibility-for-src-package.patch new file mode 100644 index 00000000..4269fadf --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/igc/files/0003-Improve-Reproducibility-for-src-package.patch | |||
| @@ -0,0 +1,33 @@ | |||
| 1 | From ca136c04d4ac60e3febc8ea2b9c4d4736365a424 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Lee Chee Yang <chee.yang.lee@intel.com> | ||
| 3 | Date: Wed, 2 Sep 2020 08:28:35 +0800 | ||
| 4 | Subject: [PATCH] Improve Reproducibility for src package | ||
| 5 | |||
| 6 | Improve reproducibility for intel-graphics-compiler-src package. | ||
| 7 | needs to pass build path as environment variable to the build. | ||
| 8 | this only works on bison 3.7 onward, hence check for bison version | ||
| 9 | before adding the flags. | ||
| 10 | Upstream-Status: Inappropriate [applying --file-prefix-map in such way does not work for upstream] | ||
| 11 | Signed-off-by: Lee Chee Yang <chee.yang.lee@intel.com> | ||
| 12 | --- | ||
| 13 | visa/CMakeLists.txt | 7 +++++-- | ||
| 14 | 1 file changed, 5 insertions(+), 2 deletions(-) | ||
| 15 | |||
| 16 | Index: git/visa/CMakeLists.txt | ||
| 17 | =================================================================== | ||
| 18 | --- git.orig/visa/CMakeLists.txt | ||
| 19 | +++ git/visa/CMakeLists.txt | ||
| 20 | @@ -135,8 +135,11 @@ endif() | ||
| 21 | set(bison_output_file ${CMAKE_CURRENT_BINARY_DIR}/CISA.tab.cpp) | ||
| 22 | set(flex_output_file ${CMAKE_CURRENT_BINARY_DIR}/lex.CISA.cpp) | ||
| 23 | |||
| 24 | -BISON_TARGET(CISAParser CISA.y ${bison_output_file} COMPILE_FLAGS "-vt -p CISA") | ||
| 25 | -FLEX_TARGET(CISAScanner CISA.l ${flex_output_file} COMPILE_FLAGS "-PCISA ${WIN_FLEX_FLAG}") | ||
| 26 | +if(BISON_VERSION VERSION_GREATER_EQUAL "3.7.0") | ||
| 27 | + set(BISON_EXTRA_FLAGS " --file-prefix-map=$ENV{B}=/igc/ ") | ||
| 28 | +endif() | ||
| 29 | +BISON_TARGET(CISAParser CISA.y ${bison_output_file} COMPILE_FLAGS "-l -vt -p CISA ${BISON_EXTRA_FLAGS} ") | ||
| 30 | +FLEX_TARGET(CISAScanner CISA.l ${flex_output_file} COMPILE_FLAGS "-PCISA -L ${WIN_FLEX_FLAG} ") | ||
| 31 | ADD_FLEX_BISON_DEPENDENCY(CISAScanner CISAParser) | ||
| 32 | set(CISAScanner_dependencies) | ||
| 33 | |||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/intel-graphics-compiler_1.0.3151.bb b/dynamic-layers/clang-layer/recipes-opencl/igc/intel-graphics-compiler_1.0.3151.bb deleted file mode 100644 index d4827283..00000000 --- a/dynamic-layers/clang-layer/recipes-opencl/igc/intel-graphics-compiler_1.0.3151.bb +++ /dev/null | |||
| @@ -1,32 +0,0 @@ | |||
| 1 | SUMMARY = "The Intel(R) Graphics Compiler for OpenCL(TM)" | ||
| 2 | DESCRIPTION = "The Intel(R) Graphics Compiler for OpenCL(TM) is an \ | ||
| 3 | llvm based compiler for OpenCL(TM) targeting Intel Gen graphics \ | ||
| 4 | hardware architecture." | ||
| 5 | |||
| 6 | LICENSE = "MIT & BSD-3-Clause" | ||
| 7 | LIC_FILES_CHKSUM = "file://IGC/BiFModule/Implementation/ExternalLibraries/libclc/LICENSE.TXT;md5=311cfc1a5b54bab8ed34a0b5fba4373e \ | ||
| 8 | file://IGC/Compiler/LegalizationPass.cpp;beginline=1;endline=25;md5=4abf1738ff96b18e34186eb763e28eeb" | ||
| 9 | |||
| 10 | SRC_URI = "git://github.com/intel/intel-graphics-compiler.git;protocol=https; \ | ||
| 11 | file://0001-skip-execution-of-ElfPackager.patch \ | ||
| 12 | " | ||
| 13 | |||
| 14 | SRCREV = "ee341708a3d95738e942b6d3c5cd25b1f4b430f1" | ||
| 15 | |||
| 16 | S = "${WORKDIR}/git" | ||
| 17 | |||
| 18 | inherit cmake | ||
| 19 | |||
| 20 | COMPATIBLE_HOST = '(x86_64).*-linux' | ||
| 21 | COMPATIBLE_HOST_libc-musl = "null" | ||
| 22 | |||
| 23 | DEPENDS += " flex-native bison-native clang opencl-clang" | ||
| 24 | DEPENDS_append_class-target = " clang-cross-x86_64" | ||
| 25 | |||
| 26 | RDEPENDS_${PN} += "opencl-clang" | ||
| 27 | |||
| 28 | EXTRA_OECMAKE = "-DIGC_PREFERRED_LLVM_VERSION=9.0.0 -DPYTHON_EXECUTABLE=${HOSTTOOLS_DIR}/python3" | ||
| 29 | |||
| 30 | BBCLASSEXTEND = "native nativesdk" | ||
| 31 | |||
| 32 | UPSTREAM_CHECK_GITTAGREGEX = "^igc-(?P<pver>(?!19\..*)\d+(\.\d+)+)$" | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/igc/intel-graphics-compiler_2.10.10.bb b/dynamic-layers/clang-layer/recipes-opencl/igc/intel-graphics-compiler_2.10.10.bb new file mode 100644 index 00000000..f3c19ce1 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/igc/intel-graphics-compiler_2.10.10.bb | |||
| @@ -0,0 +1,78 @@ | |||
| 1 | SUMMARY = "The Intel(R) Graphics Compiler for OpenCL(TM)" | ||
| 2 | DESCRIPTION = "The Intel(R) Graphics Compiler for OpenCL(TM) is an \ | ||
| 3 | llvm based compiler for OpenCL(TM) targeting Intel Gen graphics \ | ||
| 4 | hardware architecture." | ||
| 5 | |||
| 6 | LICENSE = "MIT & Apache-2.0" | ||
| 7 | LIC_FILES_CHKSUM = "file://IGC/BiFModule/Implementation/ExternalLibraries/libclc/LICENSE.TXT;md5=311cfc1a5b54bab8ed34a0b5fba4373e \ | ||
| 8 | file://LICENSE.md;md5=488d74376edf2765f6e78d271543dde3 \ | ||
| 9 | file://NOTICES.txt;md5=b81a52411c84df3419f20bad4d755880" | ||
| 10 | |||
| 11 | SRC_URI = "git://github.com/intel/intel-graphics-compiler.git;protocol=https;name=igc;branch=releases/2.10.x \ | ||
| 12 | git://github.com/intel/vc-intrinsics.git;protocol=https;destsuffix=${BB_GIT_DEFAULT_DESTSUFFIX}/vc-intrinsics;name=vc;nobranch=1 \ | ||
| 13 | git://github.com/KhronosGroup/SPIRV-Tools.git;protocol=https;destsuffix=${BB_GIT_DEFAULT_DESTSUFFIX}/SPIRV-Tools;name=spirv-tools;branch=main \ | ||
| 14 | git://github.com/KhronosGroup/SPIRV-Headers.git;protocol=https;destsuffix=${BB_GIT_DEFAULT_DESTSUFFIX}/SPIRV-Headers;name=spirv-headers;branch=main \ | ||
| 15 | file://0003-Improve-Reproducibility-for-src-package.patch \ | ||
| 16 | file://0001-BiF-CMakeLists.txt-remove-opt-from-DEPENDS.patch \ | ||
| 17 | file://0001-external-SPIRV-Tools-change-path-to-tools-and-header.patch \ | ||
| 18 | file://0001-Build-not-able-to-locate-BiFManager-bin.patch \ | ||
| 19 | " | ||
| 20 | |||
| 21 | SRC_URI:append:class-native = " file://0001-fix-tblgen.patch" | ||
| 22 | |||
| 23 | SRCREV_igc = "83925314d4fc32b017fcbfcd73e0667ba833fb8f" | ||
| 24 | SRCREV_vc = "9d255266e1df8f1dc5d11e1fbb03213acfaa4fc7" | ||
| 25 | SRCREV_spirv-tools = "f289d047f49fb60488301ec62bafab85573668cc" | ||
| 26 | SRCREV_spirv-headers = "0e710677989b4326ac974fd80c5308191ed80965" | ||
| 27 | |||
| 28 | SRCREV_FORMAT = "igc_vc_spirv-tools_spirv-headers" | ||
| 29 | |||
| 30 | # Used to replace with relative path in reproducibility patch | ||
| 31 | export B | ||
| 32 | |||
| 33 | inherit cmake pkgconfig qemu python3native | ||
| 34 | |||
| 35 | CXXFLAGS:append = " -Wno-error=nonnull" | ||
| 36 | |||
| 37 | COMPATIBLE_HOST = '(x86_64).*-linux' | ||
| 38 | COMPATIBLE_HOST:libc-musl = "null" | ||
| 39 | |||
| 40 | DEPENDS += " flex-native bison-native clang clang-cross-x86_64 opencl-clang qemu-native python3-mako-native \ | ||
| 41 | python3-pyyaml-native \ | ||
| 42 | " | ||
| 43 | |||
| 44 | RDEPENDS:${PN} += "opencl-clang" | ||
| 45 | |||
| 46 | PACKAGECONFIG ??= "vc" | ||
| 47 | PACKAGECONFIG[vc] = "-DIGC_BUILD__VC_ENABLED=ON -DIGC_OPTION__LINK_KHRONOS_SPIRV_TRANSLATOR=ON -DIGC_OPTION__SPIRV_TRANSLATOR_MODE=Prebuilds,-DIGC_BUILD__VC_ENABLED=OFF," | ||
| 48 | |||
| 49 | EXTRA_OECMAKE = " \ | ||
| 50 | -DIGC_OPTION__LLVM_PREFERRED_VERSION=${LLVMVERSION} \ | ||
| 51 | -DVC_INTRINSICS_SRC="${S}/vc-intrinsics" \ | ||
| 52 | -DIGC_OPTION__LLVM_MODE=Prebuilds \ | ||
| 53 | -DLLVM_TABLEGEN=${STAGING_BINDIR_NATIVE}/llvm-tblgen \ | ||
| 54 | -DLLVM_LINK_EXE=${STAGING_BINDIR_NATIVE}/llvm-link \ | ||
| 55 | -DCLANG_EXE=${STAGING_BINDIR_NATIVE}/clang \ | ||
| 56 | -DCMAKE_CROSSCOMPILING_EMULATOR=${WORKDIR}/qemuwrapper \ | ||
| 57 | -DCMAKE_POLICY_VERSION_MINIMUM=3.5 \ | ||
| 58 | " | ||
| 59 | |||
| 60 | do_configure:prepend:class-target () { | ||
| 61 | # Write out a qemu wrapper that will be used by cmake. | ||
| 62 | qemu_binary="${@qemu_wrapper_cmdline(d, d.getVar('STAGING_DIR_HOST'), [d.expand('${STAGING_DIR_HOST}${libdir}'),d.expand('${STAGING_DIR_HOST}${base_libdir}')])}" | ||
| 63 | cat > ${WORKDIR}/qemuwrapper << EOF | ||
| 64 | #!/bin/sh | ||
| 65 | $qemu_binary "\$@" | ||
| 66 | EOF | ||
| 67 | chmod +x ${WORKDIR}/qemuwrapper | ||
| 68 | } | ||
| 69 | |||
| 70 | |||
| 71 | UPSTREAM_CHECK_GITTAGREGEX = "^v(?P<pver>\d+(\.\d+)+)$" | ||
| 72 | |||
| 73 | FILES:${PN} += " \ | ||
| 74 | ${libdir}/igc2/NOTICES.txt \ | ||
| 75 | " | ||
| 76 | |||
| 77 | # libigc.so contains buildpaths | ||
| 78 | INSANE_SKIP:${PN} += "buildpaths" | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/0001-cl_headers-CMakeLists.txt-use-clang-from-native-sysr.patch b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/0001-cl_headers-CMakeLists.txt-use-clang-from-native-sysr.patch new file mode 100644 index 00000000..031a77c7 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/0001-cl_headers-CMakeLists.txt-use-clang-from-native-sysr.patch | |||
| @@ -0,0 +1,49 @@ | |||
| 1 | From 5aea653e611b59c70e529a1bd71885a509831557 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Anuj Mittal <anuj.mittal@intel.com> | ||
| 3 | Date: Tue, 1 Aug 2023 11:15:31 +0800 | ||
| 4 | Subject: [PATCH] cl_headers/CMakeLists.txt: use clang from native sysroot | ||
| 5 | |||
| 6 | Allow clang to be found in target sysroot for target builds and dont try | ||
| 7 | to compile cross binaries, we do that ourselves. | ||
| 8 | |||
| 9 | Upstream-Status: Inappropriate [oe-specific] | ||
| 10 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 11 | --- | ||
| 12 | CMakeLists.txt | 8 ++++---- | ||
| 13 | cl_headers/CMakeLists.txt | 2 +- | ||
| 14 | 2 files changed, 5 insertions(+), 5 deletions(-) | ||
| 15 | |||
| 16 | diff --git a/CMakeLists.txt b/CMakeLists.txt | ||
| 17 | index 5864009..60ba39e 100644 | ||
| 18 | --- a/CMakeLists.txt | ||
| 19 | +++ b/CMakeLists.txt | ||
| 20 | @@ -35,10 +35,10 @@ set(CMAKE_MODULE_PATH | ||
| 21 | |||
| 22 | include(CMakeFunctions) | ||
| 23 | |||
| 24 | -if(CMAKE_CROSSCOMPILING AND OPENCL_CLANG_BUILD_EXTERNAL) | ||
| 25 | - include(CrossCompile) | ||
| 26 | - llvm_create_cross_target(${PROJECT_NAME} NATIVE "" Release) | ||
| 27 | -endif() | ||
| 28 | +#if(CMAKE_CROSSCOMPILING AND OPENCL_CLANG_BUILD_EXTERNAL) | ||
| 29 | +# include(CrossCompile) | ||
| 30 | +# llvm_create_cross_target(${PROJECT_NAME} NATIVE "" Release) | ||
| 31 | +#endif() | ||
| 32 | |||
| 33 | if(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR) | ||
| 34 | set(USE_PREBUILT_LLVM ON) | ||
| 35 | diff --git a/cl_headers/CMakeLists.txt b/cl_headers/CMakeLists.txt | ||
| 36 | index 16cabb7..4423536 100644 | ||
| 37 | --- a/cl_headers/CMakeLists.txt | ||
| 38 | +++ b/cl_headers/CMakeLists.txt | ||
| 39 | @@ -1,6 +1,6 @@ | ||
| 40 | set(CL_HEADERS_LIB cl_headers) | ||
| 41 | if(USE_PREBUILT_LLVM) | ||
| 42 | - find_program(CLANG_COMMAND clang PATHS ${LLVM_TOOLS_BINARY_DIR} NO_DEFAULT_PATH) | ||
| 43 | + find_program(CLANG_COMMAND clang PATHS ${LLVM_TOOLS_BINARY_DIR}) | ||
| 44 | else() | ||
| 45 | set(CLANG_COMMAND $<TARGET_FILE:clang>) | ||
| 46 | endif() | ||
| 47 | -- | ||
| 48 | 2.37.3 | ||
| 49 | |||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/0002-Request-native-clang-only-when-cross-compiling-464.patch b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/0002-Request-native-clang-only-when-cross-compiling-464.patch new file mode 100644 index 00000000..2f1814f8 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/0002-Request-native-clang-only-when-cross-compiling-464.patch | |||
| @@ -0,0 +1,60 @@ | |||
| 1 | From 43c806ef321b1f677a49d28c89fb7ffecf539c2d Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Tim Creech <timothy.m.creech@intel.com> | ||
| 3 | Date: Wed, 28 Jun 2023 03:45:51 -0400 | ||
| 4 | Subject: [PATCH 2/2] Request native clang only when cross-compiling (#464) | ||
| 5 | |||
| 6 | * Request native clang only when cross-compiling | ||
| 7 | |||
| 8 | LLVM_USE_HOST_TOOLS may be set if LLVM is configured with | ||
| 9 | LLVM_OPTIMIZED_TABLEGEN, which does not necessarily indicate | ||
| 10 | cross-compilation or that clang will only execute on the target. | ||
| 11 | |||
| 12 | By checking that CMAKE_CROSSCOMPILING is set, we ensure that we only | ||
| 13 | build/use clang again if necessary for host execution. | ||
| 14 | |||
| 15 | * fixup: CMAKE_CROSSCOMPILING implies LLVM_USE_HOST_TOOLS | ||
| 16 | |||
| 17 | Co-authored-by: Wenju He <wenju.he@intel.com> | ||
| 18 | |||
| 19 | * fixup: also use CMAKE_CROSSCOMPILING in top-level CMakeLists.txt | ||
| 20 | |||
| 21 | --------- | ||
| 22 | |||
| 23 | Co-authored-by: Wenju He <wenju.he@intel.com> | ||
| 24 | |||
| 25 | Upstream-Status: Backport [https://github.com/intel/opencl-clang/commit/53843eee13cfb2357919ee02714a43bef1af0f86] | ||
| 26 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 27 | --- | ||
| 28 | CMakeLists.txt | 2 +- | ||
| 29 | cl_headers/CMakeLists.txt | 2 +- | ||
| 30 | 2 files changed, 2 insertions(+), 2 deletions(-) | ||
| 31 | |||
| 32 | diff --git a/CMakeLists.txt b/CMakeLists.txt | ||
| 33 | index e772de9..5864009 100644 | ||
| 34 | --- a/CMakeLists.txt | ||
| 35 | +++ b/CMakeLists.txt | ||
| 36 | @@ -35,7 +35,7 @@ set(CMAKE_MODULE_PATH | ||
| 37 | |||
| 38 | include(CMakeFunctions) | ||
| 39 | |||
| 40 | -if(LLVM_USE_HOST_TOOLS AND OPENCL_CLANG_BUILD_EXTERNAL) | ||
| 41 | +if(CMAKE_CROSSCOMPILING AND OPENCL_CLANG_BUILD_EXTERNAL) | ||
| 42 | include(CrossCompile) | ||
| 43 | llvm_create_cross_target(${PROJECT_NAME} NATIVE "" Release) | ||
| 44 | endif() | ||
| 45 | diff --git a/cl_headers/CMakeLists.txt b/cl_headers/CMakeLists.txt | ||
| 46 | index 18296c2..16cabb7 100644 | ||
| 47 | --- a/cl_headers/CMakeLists.txt | ||
| 48 | +++ b/cl_headers/CMakeLists.txt | ||
| 49 | @@ -4,7 +4,7 @@ if(USE_PREBUILT_LLVM) | ||
| 50 | else() | ||
| 51 | set(CLANG_COMMAND $<TARGET_FILE:clang>) | ||
| 52 | endif() | ||
| 53 | -if(LLVM_USE_HOST_TOOLS AND NOT OPENCL_CLANG_BUILD_EXTERNAL) | ||
| 54 | +if(CMAKE_CROSSCOMPILING AND NOT OPENCL_CLANG_BUILD_EXTERNAL) | ||
| 55 | build_native_tool(clang CLANG_COMMAND) | ||
| 56 | endif() | ||
| 57 | |||
| 58 | -- | ||
| 59 | 2.37.3 | ||
| 60 | |||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/point-to-correct-llvm-tblgen.patch b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/point-to-correct-llvm-tblgen.patch deleted file mode 100644 index 417e0221..00000000 --- a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/files/point-to-correct-llvm-tblgen.patch +++ /dev/null | |||
| @@ -1,43 +0,0 @@ | |||
| 1 | From 2ce2619b544678541e0cc56494e2927086718613 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Anuj Mittal <anuj.mittal@intel.com> | ||
| 3 | Date: Tue, 26 Mar 2019 14:11:29 +0800 | ||
| 4 | Subject: [PATCH] point to correct llvm-tblgen | ||
| 5 | |||
| 6 | Let llvm-tblgen path be passed from recipe itself. | ||
| 7 | |||
| 8 | Also since we're going to do the patching ourselves, no need to look for | ||
| 9 | git through cmake. | ||
| 10 | |||
| 11 | Upstream-Status: Inappropriate [OE specific] | ||
| 12 | |||
| 13 | Signed-off-by: Anuj Mittal <anuj.mittal@intel.com> | ||
| 14 | Signed-off-by: Naveen Saini <naveen.kumar.saini@intel.com> | ||
| 15 | --- | ||
| 16 | CMakeLists.txt | 4 ++-- | ||
| 17 | 1 file changed, 2 insertions(+), 2 deletions(-) | ||
| 18 | |||
| 19 | diff --git a/CMakeLists.txt b/CMakeLists.txt | ||
| 20 | index 1371a67..f83ffcc 100644 | ||
| 21 | --- a/CMakeLists.txt | ||
| 22 | +++ b/CMakeLists.txt | ||
| 23 | @@ -53,7 +53,7 @@ endif(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR) | ||
| 24 | include(AddLLVM) | ||
| 25 | include(TableGen) | ||
| 26 | |||
| 27 | -find_package(Git REQUIRED) | ||
| 28 | +#find_package(Git REQUIRED) | ||
| 29 | |||
| 30 | if (NOT WIN32) | ||
| 31 | add_subdirectory( linux_linker ) | ||
| 32 | @@ -138,7 +138,7 @@ endif(NOT USE_PREBUILT_LLVM) | ||
| 33 | set (COMPILE_OPTIONS_TD opencl_clang_options.td) | ||
| 34 | set (COMPILE_OPTIONS_INC opencl_clang_options.inc) | ||
| 35 | |||
| 36 | -set(LLVM_TABLEGEN_EXE "llvm-tblgen") | ||
| 37 | +#set(LLVM_TABLEGEN_EXE "llvm-tblgen") | ||
| 38 | set(LLVM_TARGET_DEFINITIONS ${COMPILE_OPTIONS_TD}) | ||
| 39 | if(USE_PREBUILT_LLVM) | ||
| 40 | set(TABLEGEN_ADDITIONAL -I ${LLVM_INCLUDE_DIRS}) | ||
| 41 | -- | ||
| 42 | 2.17.1 | ||
| 43 | |||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang.inc b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang.inc new file mode 100644 index 00000000..943ddf46 --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang.inc | |||
| @@ -0,0 +1,34 @@ | |||
| 1 | SUMMARY = "Common clang is a thin wrapper library around clang" | ||
| 2 | DESCRIPTION = "Common clang has OpenCL-oriented API and is capable \ | ||
| 3 | to compile OpenCL C kernels to SPIR-V modules." | ||
| 4 | |||
| 5 | LICENSE = "NCSA" | ||
| 6 | LIC_FILES_CHKSUM = "file://LICENSE;md5=e8a15bf1416762a09ece07e44c79118c" | ||
| 7 | |||
| 8 | SRC_URI = "git://github.com/intel/opencl-clang.git;branch=${BRANCH};protocol=https \ | ||
| 9 | file://0002-Request-native-clang-only-when-cross-compiling-464.patch \ | ||
| 10 | file://0001-cl_headers-CMakeLists.txt-use-clang-from-native-sysr.patch \ | ||
| 11 | " | ||
| 12 | |||
| 13 | inherit cmake | ||
| 14 | DEPENDS += "clang" | ||
| 15 | DEPENDS:append:class-target = " opencl-clang-native" | ||
| 16 | |||
| 17 | COMPATIBLE_HOST = '(x86_64).*-linux' | ||
| 18 | COMPATIBLE_HOST:libc-musl = "null" | ||
| 19 | |||
| 20 | DEPENDS += " spirv-llvm-translator" | ||
| 21 | |||
| 22 | EXTRA_OECMAKE += "\ | ||
| 23 | -DLLVM_TABLEGEN_EXE=${STAGING_BINDIR_NATIVE}/llvm-tblgen \ | ||
| 24 | -DCMAKE_SKIP_RPATH=TRUE \ | ||
| 25 | -DPREFERRED_LLVM_VERSION=${LLVMVERSION} \ | ||
| 26 | -DCMAKE_POLICY_VERSION_MINIMUM=3.5 \ | ||
| 27 | " | ||
| 28 | |||
| 29 | do_install:append:class-native() { | ||
| 30 | install -d ${D}${bindir} | ||
| 31 | install -m 0755 ${B}/bin/linux_resource_linker ${D}${bindir}/ | ||
| 32 | } | ||
| 33 | |||
| 34 | BBCLASSEXTEND = "native nativesdk" | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang_15.0.0.bb b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang_15.0.0.bb new file mode 100644 index 00000000..e946c31c --- /dev/null +++ b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang_15.0.0.bb | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | require opencl-clang.inc | ||
| 2 | |||
| 3 | SRCREV = "60fd799cc58755c16d951f9ebfde6d0f9b8554dd" | ||
| 4 | |||
| 5 | BRANCH = "ocl-open-150" | ||
diff --git a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang_9.0.0.bb b/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang_9.0.0.bb deleted file mode 100644 index 695749cc..00000000 --- a/dynamic-layers/clang-layer/recipes-opencl/opencl-clang/opencl-clang_9.0.0.bb +++ /dev/null | |||
| @@ -1,34 +0,0 @@ | |||
| 1 | SUMMARY = "Common clang is a thin wrapper library around clang" | ||
| 2 | DESCRIPTION = "Common clang has OpenCL-oriented API and is capable \ | ||
| 3 | to compile OpenCL C kernels to SPIR-V modules." | ||
| 4 | |||
| 5 | LICENSE = "NCSA" | ||
| 6 | LIC_FILES_CHKSUM = "file://LICENSE;md5=e8a15bf1416762a09ece07e44c79118c" | ||
| 7 | |||
| 8 | SRC_URI = "git://github.com/intel/opencl-clang.git;branch=ocl-open-90;protocol=https \ | ||
| 9 | file://point-to-correct-llvm-tblgen.patch \ | ||
| 10 | " | ||
| 11 | |||
| 12 | SRCREV = "e6049638474112ad26db13eb167a16b2d497b841" | ||
| 13 | |||
| 14 | S = "${WORKDIR}/git" | ||
| 15 | |||
| 16 | inherit cmake | ||
| 17 | DEPENDS += "clang" | ||
| 18 | |||
| 19 | DEPENDS_append_class-target = " opencl-clang-native" | ||
| 20 | |||
| 21 | COMPATIBLE_HOST = '(x86_64).*-linux' | ||
| 22 | COMPATIBLE_HOST_libc-musl = "null" | ||
| 23 | |||
| 24 | EXTRA_OECMAKE += "\ | ||
| 25 | -DLLVM_TABLEGEN_EXE=${STAGING_BINDIR_NATIVE}/llvm-tblgen \ | ||
| 26 | -DCMAKE_SKIP_RPATH=TRUE \ | ||
| 27 | " | ||
| 28 | |||
| 29 | do_install_append_class-native() { | ||
| 30 | install -d ${D}${bindir} | ||
| 31 | install -m 0755 ${B}/linux_linker/linux_resource_linker ${D}${bindir}/ | ||
| 32 | } | ||
| 33 | |||
| 34 | BBCLASSEXTEND = "native nativesdk" | ||
