Path: blob/main/contrib/llvm-project/llvm/lib/Target/NVPTX/NVPTXAliasAnalysis.cpp
35271 views
//===--------------------- NVPTXAliasAnalysis.cpp--------------------------===//1//2// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.3// See https://llvm.org/LICENSE.txt for license information.4// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception5//6//===----------------------------------------------------------------------===//7/// \file8/// This is the NVPTX address space based alias analysis pass.9//===----------------------------------------------------------------------===//1011#include "NVPTXAliasAnalysis.h"12#include "MCTargetDesc/NVPTXBaseInfo.h"13#include "NVPTX.h"14#include "llvm/Analysis/ValueTracking.h"15#include "llvm/IR/CallingConv.h"16#include "llvm/IR/Instructions.h"1718using namespace llvm;1920#define DEBUG_TYPE "NVPTX-aa"2122AnalysisKey NVPTXAA::Key;2324char NVPTXAAWrapperPass::ID = 0;25char NVPTXExternalAAWrapper::ID = 0;2627INITIALIZE_PASS(NVPTXAAWrapperPass, "nvptx-aa",28"NVPTX Address space based Alias Analysis", false, true)2930INITIALIZE_PASS(NVPTXExternalAAWrapper, "nvptx-aa-wrapper",31"NVPTX Address space based Alias Analysis Wrapper", false, true)3233ImmutablePass *llvm::createNVPTXAAWrapperPass() {34return new NVPTXAAWrapperPass();35}3637ImmutablePass *llvm::createNVPTXExternalAAWrapperPass() {38return new NVPTXExternalAAWrapper();39}4041NVPTXAAWrapperPass::NVPTXAAWrapperPass() : ImmutablePass(ID) {42initializeNVPTXAAWrapperPassPass(*PassRegistry::getPassRegistry());43}4445void NVPTXAAWrapperPass::getAnalysisUsage(AnalysisUsage &AU) const {46AU.setPreservesAll();47}4849static AliasResult::Kind getAliasResult(unsigned AS1, unsigned AS2) {50if ((AS1 == ADDRESS_SPACE_GENERIC) || (AS2 == ADDRESS_SPACE_GENERIC))51return AliasResult::MayAlias;5253// PTX s6.4.1.1. Generic Addressing:54// A generic address maps to global memory unless it falls within55// the window for const, local, or shared memory. The Kernel56// Function Parameters (.param) window is contained within the57// .global window.58//59// Therefore a global pointer may alias with a param pointer on some60// GPUs via addrspacecast(param->generic->global) when cvta.param61// instruction is used (PTX 7.7+ and SM_70+).62//63// TODO: cvta.param is not yet supported. We need to change aliasing64// rules once it is added.6566return (AS1 == AS2 ? AliasResult::MayAlias : AliasResult::NoAlias);67}6869AliasResult NVPTXAAResult::alias(const MemoryLocation &Loc1,70const MemoryLocation &Loc2, AAQueryInfo &AAQI,71const Instruction *) {72unsigned AS1 = Loc1.Ptr->getType()->getPointerAddressSpace();73unsigned AS2 = Loc2.Ptr->getType()->getPointerAddressSpace();7475return getAliasResult(AS1, AS2);76}7778// TODO: .param address space may be writable in presence of cvta.param, but79// this instruction is currently not supported. NVPTXLowerArgs also does not80// allow any writes to .param pointers.81static bool isConstOrParam(unsigned AS) {82return AS == AddressSpace::ADDRESS_SPACE_CONST ||83AS == AddressSpace::ADDRESS_SPACE_PARAM;84}8586ModRefInfo NVPTXAAResult::getModRefInfoMask(const MemoryLocation &Loc,87AAQueryInfo &AAQI,88bool IgnoreLocals) {89if (isConstOrParam(Loc.Ptr->getType()->getPointerAddressSpace()))90return ModRefInfo::NoModRef;9192const Value *Base = getUnderlyingObject(Loc.Ptr);93if (isConstOrParam(Base->getType()->getPointerAddressSpace()))94return ModRefInfo::NoModRef;9596return ModRefInfo::ModRef;97}9899100