This patch introduces generic x86-64 edge kinds, and refactors the MachO/x86-64 backend to use these edge kinds. This simplifies the implementation of the MachO/x86-64 backend and makes it possible to write generic x86-64 passes and utilities. The new edge kinds are different from the original set used in the MachO/x86-64 backend. Several edge kinds that were not meaningfully distinguished in that backend (e.g. the PCRelMinusN edges) have been merged into single edge kinds in the new scheme (these edge kinds can be reintroduced later if we find a use for them). At the same time, new edge kinds have been introduced to convey extra information about the state of the graph. E.g. The Request*AndTransformTo** edges represent GOT/TLVP relocations prior to synthesis of the GOT/TLVP entries, and the 'Relaxable' suffix distinguishes edges that are candidates for optimization from edges which should be left as-is (e.g. to enable runtime redirection). ELF/x86-64 will be refactored to use these generic edges at some point in the future, and I anticipate a similar refactor to create a generic arm64 support header too. Differential Revision: https://reviews.llvm.org/D98305
59 lines
1.8 KiB
C++
59 lines
1.8 KiB
C++
//===----- x86_64.cpp - Generic JITLink x86-64 edge kinds, utilities ------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Generic utilities for graphs representing x86-64 objects.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/ExecutionEngine/JITLink/x86_64.h"
|
|
|
|
#define DEBUG_TYPE "jitlink"
|
|
|
|
namespace llvm {
|
|
namespace jitlink {
|
|
namespace x86_64 {
|
|
|
|
const char *getEdgeKindName(Edge::Kind K) {
|
|
switch (K) {
|
|
case Pointer64:
|
|
return "Pointer64";
|
|
case Pointer32:
|
|
return "Pointer32";
|
|
case Delta64:
|
|
return "Delta64";
|
|
case Delta32:
|
|
return "Delta32";
|
|
case NegDelta64:
|
|
return "NegDelta64";
|
|
case NegDelta32:
|
|
return "NegDelta32";
|
|
case BranchPCRel32:
|
|
return "BranchPCRel32";
|
|
case BranchPCRel32ToPtrJumpStub:
|
|
return "BranchPCRel32ToPtrJumpStub";
|
|
case BranchPCRel32ToPtrJumpStubRelaxable:
|
|
return "BranchPCRel32ToPtrJumpStubRelaxable";
|
|
case RequestGOTAndTransformToDelta32:
|
|
return "RequestGOTAndTransformToDelta32";
|
|
case PCRel32GOTLoadRelaxable:
|
|
return "PCRel32GOTLoadRelaxable";
|
|
case RequestGOTAndTransformToPCRel32GOTLoadRelaxable:
|
|
return "RequestGOTAndTransformToPCRel32GOTLoadRelaxable";
|
|
case PCRel32TLVPLoadRelaxable:
|
|
return "PCRel32TLVPLoadRelaxable";
|
|
case RequestTLVPAndTransformToPCRel32TLVPLoadRelaxable:
|
|
return "RequestTLVPAndTransformToPCRel32TLVPLoadRelaxable";
|
|
default:
|
|
return getGenericEdgeKindName(static_cast<Edge::Kind>(K));
|
|
}
|
|
}
|
|
|
|
} // end namespace x86_64
|
|
} // end namespace jitlink
|
|
} // end namespace llvm
|