[clang] [flang] add tbaa tags to global variables (PR #68727)
Tom Eccles via cfe-commits
cfe-commits at lists.llvm.org
Wed Oct 11 05:57:03 PDT 2023
================
@@ -406,7 +406,7 @@ AliasAnalysis::Source AliasAnalysis::getSource(mlir::Value v) {
attributes.set(Attribute::Pointer);
}
- if (type == SourceKind::Global)
+ if (type == SourceKind::Global || type == SourceKind::Direct)
----------------
tblah wrote:
So `SourceKind::Direct` isn't necessarily a global?
The use case for the tbaa alias analysis is we want to be able to add tags to global arrays. These can be boxed. The specific case I care about is
```
module mod
real, dimension(:), allocatable :: glbl
subroutine func(arg)
real, intent(in), dimension(:) :: arg
! glbl can't alias with arg
end subroutine
end module
```
The generated code looks something like
```
fir.global @_QMmodEglbl : !fir.box<!fir.heap<!fir.array<?xf32>>> { [...]}
func.func @_QMmodPfunc([...]) {
[...]
%glbl_addr = fir.address_of(@_QmodEa) : !fir.ref<!fir.box<!fir.heap<!fir.array<?xf32>>>>
%decl = fir.declare %glbl_addr [...]
[...]
%box = fir.load %decl
%addr = fir.box_addr %box : (!fir.box<!fir.heap<!fir.array<?xf32>>>) -> !fir.heap<!fir.array<?xf32>>
[...]
%element = fir.array_coor %addr(%shape) %index
%val = fir.array_coor %element
```
What I want to happen here is to notice that `%val` comes from a global variable and to tag that load as such. This is a lot clearer from the fortran source than the FIR so maybe we need to store more information somewhere.
As I understand it, you're saying that we can't know much about this variable because the global variable is boxed. Why is the box special?
https://github.com/llvm/llvm-project/pull/68727
More information about the cfe-commits
mailing list