This patch implements IR-based Profile-Guided Optimization support in Flang through the following flags: - `-fprofile-generate` for instrumentation-based profile generation - `-fprofile-use=<dir>/file` for profile-guided optimization Resolves #74216 (implements IR PGO support phase) **Key changes:** - Frontend flag handling aligned with Clang/GCC semantics - Instrumentation hooks into LLVM PGO infrastructure - LIT tests verifying: - Instrumentation metadata generation - Profile loading from specified path - Branch weight attribution (IR checks) **Tests:** - Added gcc-flag-compatibility.f90 test module verifying: - Flag parsing boundary conditions - IR-level profile annotation consistency - Profile input path normalization rules - SPEC2006 benchmark results will be shared in comments For details on LLVM's PGO framework, refer to [Clang PGO Documentation](https://clang.llvm.org/docs/UsersManual.html#profile-guided-optimization). This implementation was developed by [XSCC Compiler Team](https://github.com/orgs/OpenXiangShan/teams/xscc). --------- Co-authored-by: ict-ql <168183727+ict-ql@users.noreply.github.com> Co-authored-by: Tom Eccles <t@freedommail.info>
73 lines
2.7 KiB
C++
73 lines
2.7 KiB
C++
//===--- CodeGenOptions.cpp - Shared codegen option handling --------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Frontend/Driver/CodeGenOptions.h"
|
|
#include "llvm/Analysis/TargetLibraryInfo.h"
|
|
#include "llvm/ProfileData/InstrProfCorrelator.h"
|
|
#include "llvm/TargetParser/Triple.h"
|
|
|
|
namespace llvm {
|
|
extern llvm::cl::opt<bool> DebugInfoCorrelate;
|
|
extern llvm::cl::opt<llvm::InstrProfCorrelator::ProfCorrelatorKind>
|
|
ProfileCorrelate;
|
|
} // namespace llvm
|
|
|
|
namespace llvm::driver {
|
|
|
|
TargetLibraryInfoImpl *createTLII(const llvm::Triple &TargetTriple,
|
|
driver::VectorLibrary Veclib) {
|
|
TargetLibraryInfoImpl *TLII = new TargetLibraryInfoImpl(TargetTriple);
|
|
|
|
using VectorLibrary = llvm::driver::VectorLibrary;
|
|
switch (Veclib) {
|
|
case VectorLibrary::Accelerate:
|
|
TLII->addVectorizableFunctionsFromVecLib(TargetLibraryInfoImpl::Accelerate,
|
|
TargetTriple);
|
|
break;
|
|
case VectorLibrary::LIBMVEC:
|
|
TLII->addVectorizableFunctionsFromVecLib(TargetLibraryInfoImpl::LIBMVEC,
|
|
TargetTriple);
|
|
break;
|
|
case VectorLibrary::MASSV:
|
|
TLII->addVectorizableFunctionsFromVecLib(TargetLibraryInfoImpl::MASSV,
|
|
TargetTriple);
|
|
break;
|
|
case VectorLibrary::SVML:
|
|
TLII->addVectorizableFunctionsFromVecLib(TargetLibraryInfoImpl::SVML,
|
|
TargetTriple);
|
|
break;
|
|
case VectorLibrary::SLEEF:
|
|
TLII->addVectorizableFunctionsFromVecLib(TargetLibraryInfoImpl::SLEEFGNUABI,
|
|
TargetTriple);
|
|
break;
|
|
case VectorLibrary::Darwin_libsystem_m:
|
|
TLII->addVectorizableFunctionsFromVecLib(
|
|
TargetLibraryInfoImpl::DarwinLibSystemM, TargetTriple);
|
|
break;
|
|
case VectorLibrary::ArmPL:
|
|
TLII->addVectorizableFunctionsFromVecLib(TargetLibraryInfoImpl::ArmPL,
|
|
TargetTriple);
|
|
break;
|
|
case VectorLibrary::AMDLIBM:
|
|
TLII->addVectorizableFunctionsFromVecLib(TargetLibraryInfoImpl::AMDLIBM,
|
|
TargetTriple);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return TLII;
|
|
}
|
|
|
|
std::string getDefaultProfileGenName() {
|
|
return llvm::DebugInfoCorrelate ||
|
|
llvm::ProfileCorrelate != InstrProfCorrelator::NONE
|
|
? "default_%m.proflite"
|
|
: "default_%m.profraw";
|
|
}
|
|
} // namespace llvm::driver
|