Files
clang-p2996/llvm/lib/Target/SystemZ/MCTargetDesc/SystemZMCAsmInfo.cpp
tltao 783901bd20 [SystemZ] Rename SystemZ ATT Asm dialect to GNU Asm dialect (#112800)
The ATT assembler dialect on SystemZ seems to have been taken from the
existing ATT/Intel code. However, on SystemZ, ATT does not hold any
meaning. In reality, we are splitting the difference between GNU Asm
syntax and HLASM Asm syntax, so it makes sense to rename ATT to GNU
instead.

Co-authored-by: Tony Tao <tonytao@ca.ibm.com>
2024-10-18 10:26:50 -04:00

52 lines
1.6 KiB
C++

//===-- SystemZMCAsmInfo.cpp - SystemZ asm properties ---------------------===//
//
// 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 "SystemZMCAsmInfo.h"
#include "llvm/MC/MCContext.h"
#include "llvm/MC/MCSectionELF.h"
using namespace llvm;
SystemZMCAsmInfoELF::SystemZMCAsmInfoELF(const Triple &TT) {
AssemblerDialect = AD_GNU;
CalleeSaveStackSlotSize = 8;
CodePointerSize = 8;
Data64bitsDirective = "\t.quad\t";
ExceptionsType = ExceptionHandling::DwarfCFI;
IsLittleEndian = false;
MaxInstLength = 6;
SupportsDebugInformation = true;
UsesELFSectionDirectiveForBSS = true;
ZeroDirective = "\t.space\t";
}
SystemZMCAsmInfoGOFF::SystemZMCAsmInfoGOFF(const Triple &TT) {
AllowAdditionalComments = false;
AllowAtInName = true;
AllowAtAtStartOfIdentifier = true;
AllowDollarAtStartOfIdentifier = true;
AllowHashAtStartOfIdentifier = true;
AssemblerDialect = AD_HLASM;
CalleeSaveStackSlotSize = 8;
CodePointerSize = 8;
CommentString = "*";
DotIsPC = false;
EmitGNUAsmStartIndentationMarker = false;
EmitLabelsInUpperCase = true;
ExceptionsType = ExceptionHandling::ZOS;
IsLittleEndian = false;
MaxInstLength = 6;
RestrictCommentStringToStartOfStatement = true;
StarIsPC = true;
SupportsDebugInformation = true;
}
bool SystemZMCAsmInfoGOFF::isAcceptableChar(char C) const {
return MCAsmInfo::isAcceptableChar(C) || C == '#';
}