diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2016-08-02 08:56:52 +0000 |
---|---|---|
committer | Matt Arsenault <Matthew.Arsenault@amd.com> | 2016-08-02 08:56:52 +0000 |
commit | 6f1ae3c7db43a312d638cbcde2b431026d211d8d (patch) | |
tree | a00f39c7909c6588c880de8f5442b293ff2efdb6 /llvm/lib | |
parent | aa4845004df31da0f4b50d12bb2b86a3a65652d7 (diff) | |
download | bcm5719-llvm-6f1ae3c7db43a312d638cbcde2b431026d211d8d.tar.gz bcm5719-llvm-6f1ae3c7db43a312d638cbcde2b431026d211d8d.zip |
AArch64: Assert on branch displacement bits
llvm-svn: 277434
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Target/AArch64/AArch64InstrInfo.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/llvm/lib/Target/AArch64/AArch64InstrInfo.cpp b/llvm/lib/Target/AArch64/AArch64InstrInfo.cpp index 05bc1cbead2..d3599537a9d 100644 --- a/llvm/lib/Target/AArch64/AArch64InstrInfo.cpp +++ b/llvm/lib/Target/AArch64/AArch64InstrInfo.cpp @@ -132,6 +132,13 @@ static unsigned getBranchMaxDisplacementBytes(unsigned Opc) { unsigned Bits = getBranchDisplacementBits(Opc); unsigned MaxOffs = ((1 << (Bits - 1)) - 1) << 2; + + // Verify the displacement bits options have sane values. + // XXX: Is there a better place for this? + assert(MaxOffs >= 8 && + "max branch displacement must be enough to jump" + "over conditional branch expansion"); + return MaxOffs; } |