-
-
Notifications
You must be signed in to change notification settings - Fork 5.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
optimizer: fix alloc opt on unknown offset with references (#47076)
Fixes issued mentioned in #47075 (comment)
- Loading branch information
Showing
4 changed files
with
59 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
; RUN: opt -enable-new-pm=0 -load libjulia-codegen%shlibext -AllocOpt -S %s | FileCheck %s | ||
|
||
source_filename = "text" | ||
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128-ni:10:11:12:13" | ||
target triple = "x86_64-linux-gnu" | ||
|
||
declare {}*** @julia.get_pgcstack() | ||
|
||
declare {} addrspace(10)* @julia.gc_alloc_obj({}**, i64, {} addrspace(10)*) | ||
|
||
declare void @julia.write_barrier({} addrspace(10)*, ...) | ||
|
||
define void @diffejulia_objective__1864_inner_1wrap({} addrspace(10)* %arg, i64 %iv.i) { | ||
entry: | ||
%i5 = call {}*** @julia.get_pgcstack() | ||
%i13 = bitcast {}*** %i5 to {}** | ||
%i14 = getelementptr inbounds {}*, {}** %i13, i64 -12 | ||
%i18 = call noalias nonnull dereferenceable(8000) dereferenceable_or_null(8000) {} addrspace(10)* @julia.gc_alloc_obj({}** %i14, i64 8000, {} addrspace(10)* addrspacecast ({}* inttoptr (i64 139756155247504 to {}*) to {} addrspace(10)*)) | ||
%_malloccache.i = bitcast {} addrspace(10)* %i18 to {} addrspace(10)* addrspace(10)* | ||
%i23 = getelementptr inbounds {} addrspace(10)*, {} addrspace(10)* addrspace(10)* %_malloccache.i, i64 %iv.i | ||
store {} addrspace(10)* %arg, {} addrspace(10)* addrspace(10)* %i23, align 8 | ||
%i24 = bitcast {} addrspace(10)* addrspace(10)* %_malloccache.i to {} addrspace(10)* | ||
call void ({} addrspace(10)*, ...) @julia.write_barrier({} addrspace(10)* %i24, {} addrspace(10)* %arg) | ||
%l = load {} addrspace(10)*, {} addrspace(10)* addrspace(10)* %i23 | ||
ret void | ||
} | ||
|
||
; CHECK: %[[i0:.+]] = alloca {} addrspace(10)*, i64 1000, align 16 | ||
; CHECK: %[[i1:.+]] = bitcast {} addrspace(10)** %[[i0]] to i8* | ||
; CHECK: %i18 = bitcast i8* %[[i1]] to {}* | ||
; CHECK: %_malloccache.i = bitcast {}* %i18 to {} addrspace(10)** | ||
; CHECK: %i23 = getelementptr inbounds {} addrspace(10)*, {} addrspace(10)** %_malloccache.i, i64 %iv.i | ||
; CHECK: store {} addrspace(10)* %arg, {} addrspace(10)** %i23, align 8 | ||
; CHECK: %i24 = bitcast {} addrspace(10)** %_malloccache.i to {}* | ||
; CHECK: %l = load {} addrspace(10)*, {} addrspace(10)** %i23, align 8 |
a68235c
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Executing the daily package evaluation, I will reply here when finished:
@nanosoldier
runtests(ALL, isdaily = true, configuration=(rr=true,))
a68235c
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Your package evaluation job has completed - possible new issues were detected. A full report can be found here.
a68235c
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@nanosoldier
runbenchmarks(ALL, isdaily = true)
a68235c
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Your benchmark job has completed - possible performance regressions were detected. A full report can be found here.