Skip to content

Commit

Permalink
Merge of resolve of merge (conflict) 7b7a193 Cherry pick a couple of …
Browse files Browse the repository at this point in the history
…commits to improve llvm-spirv perf.. '"xmain"' -> '"xmain-web"' (7 commits) (KhronosGroup#49)

* Resolve of merge (conflict) 7b7a193 Cherry pick a couple of commits to improve llvm-spirv perf.. '"xmain"' -> '"xmain-web"' (7 commits)

  CONFLICT (content): Merge conflict in test/transcoding/annotate_attribute.ll
  CONFLICT (content): Merge conflict in test/transcoding/NoSignedUnsignedWrap.ll

  commit 7b7a193
  Author: Alexey Sotkin <[email protected]>
  Date:   Tue Oct 26 11:12:43 2021 +0300

      Cherry pick a couple of commits to improve llvm-spirv performance (KhronosGroup#46)

      * [NFC] Optimize adding of decorations (KhronosGroup#1233)

      Use std::undordered_set instead of std::multiset with custom comparator.
      It is a bit unclear why std::multiset was required since there is no
      order requirement for OpDecorate instructions in SPIR-V spec, in addition old
      data structure was highly inefficient.

      * [NFC] Optimize OCLUtil::toString usage in checkError function (KhronosGroup#1229)

      `toString` function is called to convert an LLVM IR instruction to a string,
      mostly in order to include it into an error message in case LLVM IR is invalid.
      The problem is that this function is called even when IR is valid which
      significantly slows translator's work.

      This patch reworks `toString` usage in `checkError` method to generate a string
      only in case when LLVM IR is invalid.

      Co-authored-by: Mariya Podchishchaeva <[email protected]>
      Co-authored-by: Viktoria Maximova <[email protected]>

* Resolve of merge (conflict) 7b7a193 Cherry pick a couple of commits to improve llvm-spirv perf.. '"xmain"' -> '"xmain-web"' (7 commits)

  CONFLICT (content): Merge conflict in test/transcoding/annotate_attribute.ll
  CONFLICT (content): Merge conflict in test/transcoding/NoSignedUnsignedWrap.ll

  commit 7b7a193
  Author: Alexey Sotkin <[email protected]>
  Date:   Tue Oct 26 11:12:43 2021 +0300

      Cherry pick a couple of commits to improve llvm-spirv performance (KhronosGroup#46)

      * [NFC] Optimize adding of decorations (KhronosGroup#1233)

      Use std::undordered_set instead of std::multiset with custom comparator.
      It is a bit unclear why std::multiset was required since there is no
      order requirement for OpDecorate instructions in SPIR-V spec, in addition old
      data structure was highly inefficient.

      * [NFC] Optimize OCLUtil::toString usage in checkError function (KhronosGroup#1229)

      `toString` function is called to convert an LLVM IR instruction to a string,
      mostly in order to include it into an error message in case LLVM IR is invalid.
      The problem is that this function is called even when IR is valid which
      significantly slows translator's work.

      This patch reworks `toString` usage in `checkError` method to generate a string
      only in case when LLVM IR is invalid.

      Co-authored-by: Mariya Podchishchaeva <[email protected]>
      Co-authored-by: Viktoria Maximova <[email protected]>

Co-authored-by: iclsrc <[email protected]>
  • Loading branch information
iclsrc committed Oct 26, 2021
2 parents a8c89fa + 7c1e63c commit 548dc67
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 3 deletions.
4 changes: 4 additions & 0 deletions test/transcoding/NoSignedUnsignedWrap.ll
Original file line number Diff line number Diff line change
Expand Up @@ -39,10 +39,14 @@
; RUN: llvm-spirv -r %t.spv -o %t.rev.bc
; RUN: llvm-dis < %t.rev.bc | FileCheck %s --check-prefix=CHECK-LLVM-NEGATIVE

; INTEL_CUSTOMIZATION
; Check SPIR-V versions in a format magic number + version
; CHECK-SPIRV-EXT: 119734787 65536
; CHECK-SPIRV-EXT: Extension "SPV_KHR_no_integer_wrap_decoration"
; CHECK-SPIRV-NOEXT: 119734787 66560
; end INTEL_CUSTOMIZATION

; CHECK-SPIRV: Extension "SPV_KHR_no_integer_wrap_decoration"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} NoSignedWrap
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} NoUnsignedWrap
;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,11 @@
; CHECK-SPIRV: Extension "SPV_INTEL_function_pointers"
; CHECK-SPIRV: EntryPoint 6 [[KERNEL_ID:[0-9]+]] "test"
; CHECK-SPIRV: Decorate [[ADD_ID:[0-9]+]] LinkageAttributes "_Z3addii"
; CHECK-SPIRV: Decorate [[SUB_ID:[0-9]+]] LinkageAttributes "_Z3subii"
; CHECK-SPIRV: Decorate [[VARIANTS_TABLE_ADD_NAME:[0-9]+]] LinkageAttributes "_Z3addii{{.*}}"
; CHECK-SPIRV: Decorate [[VARIANTS_TABLE_SUB_NAME:[0-9]+]] LinkageAttributes "_Z3subii{{.*}}"
; CHECK-SPIRV: Decorate [[ADD_ID]] VectorVariantsTableINTEL "_Z3addii$SIMDTable()"
; CHECK-SPIRV: Decorate [[VARIANTS_TABLE_ADD_NAME:[0-9]+]] LinkageAttributes "_Z3addii{{.*}}"
; CHECK-SPIRV: Decorate [[SUB_ID:[0-9]+]] LinkageAttributes "_Z3subii"
; CHECK-SPIRV: Decorate [[SUB_ID]] VectorVariantsTableINTEL "_Z3subii$SIMDTable()"
; CHECK-SPIRV: Decorate [[VARIANTS_TABLE_SUB_NAME:[0-9]+]] LinkageAttributes "_Z3subii{{.*}}"
; CHECK-SPIRV: TypeInt [[TYPE_INT_ID:[0-9]+]] 32 0
; CHECK-SPIRV: TypeInt [[TYPE_INT64_ID:[0-9]+]] 64 0
; CHECK-SPIRV: Constant [[TYPE_INT64_ID]] [[CONST_ONE:[0-9]+]] 1
Expand Down
2 changes: 2 additions & 0 deletions test/transcoding/annotate_attribute.ll
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,10 @@
; RUN: llvm-as %s -o %t.bc
; RUN: llvm-spirv %t.bc --spirv-ext=+SPV_INTEL_fpga_memory_accesses,+SPV_INTEL_fpga_memory_attributes -spirv-text -o - | FileCheck %s --check-prefix=CHECK-SPIRV

; INTEL_CUSTOMIZATION
; Check SPIR-V versions in a format magic number + version
; CHECK-SPIRV: 119734787 66560
; end INTEL_CUSTOMIZATION

; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} UserSemantic "42"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} UserSemantic "bar"
Expand Down

0 comments on commit 548dc67

Please sign in to comment.