mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-05 09:24:28 +00:00
Add support for the .zero directive.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114077 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -180,6 +180,7 @@ private:
|
|||||||
bool ParseDirectiveValue(unsigned Size); // ".byte", ".long", ...
|
bool ParseDirectiveValue(unsigned Size); // ".byte", ".long", ...
|
||||||
bool ParseDirectiveFill(); // ".fill"
|
bool ParseDirectiveFill(); // ".fill"
|
||||||
bool ParseDirectiveSpace(); // ".space"
|
bool ParseDirectiveSpace(); // ".space"
|
||||||
|
bool ParseDirectiveZero(); // ".zero"
|
||||||
bool ParseDirectiveSet(); // ".set"
|
bool ParseDirectiveSet(); // ".set"
|
||||||
bool ParseDirectiveOrg(); // ".org"
|
bool ParseDirectiveOrg(); // ".org"
|
||||||
// ".align{,32}", ".p2align{,w,l}"
|
// ".align{,32}", ".p2align{,w,l}"
|
||||||
@ -871,6 +872,8 @@ bool AsmParser::ParseStatement() {
|
|||||||
return ParseDirectiveFill();
|
return ParseDirectiveFill();
|
||||||
if (IDVal == ".space")
|
if (IDVal == ".space")
|
||||||
return ParseDirectiveSpace();
|
return ParseDirectiveSpace();
|
||||||
|
if (IDVal == ".zero")
|
||||||
|
return ParseDirectiveZero();
|
||||||
|
|
||||||
// Symbol attribute directives
|
// Symbol attribute directives
|
||||||
|
|
||||||
@ -1353,6 +1356,25 @@ bool AsmParser::ParseDirectiveSpace() {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// ParseDirectiveZero
|
||||||
|
/// ::= .zero expression
|
||||||
|
bool AsmParser::ParseDirectiveZero() {
|
||||||
|
CheckForValidSection();
|
||||||
|
|
||||||
|
int64_t NumBytes;
|
||||||
|
if (ParseAbsoluteExpression(NumBytes))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if (getLexer().isNot(AsmToken::EndOfStatement))
|
||||||
|
return TokError("unexpected token in '.zero' directive");
|
||||||
|
|
||||||
|
Lex();
|
||||||
|
|
||||||
|
getStreamer().EmitFill(NumBytes, 0, DEFAULT_ADDRSPACE);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/// ParseDirectiveFill
|
/// ParseDirectiveFill
|
||||||
/// ::= .fill expression , expression , expression
|
/// ::= .fill expression , expression , expression
|
||||||
bool AsmParser::ParseDirectiveFill() {
|
bool AsmParser::ParseDirectiveFill() {
|
||||||
|
15
test/MC/ELF/zero.s
Normal file
15
test/MC/ELF/zero.s
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | elf-dump --dump-section-data | FileCheck %s
|
||||||
|
|
||||||
|
.zero 4
|
||||||
|
|
||||||
|
// CHECK: ('sh_name', 1) # '.text'
|
||||||
|
// CHECK: ('sh_type', 1)
|
||||||
|
// CHECK: ('sh_flags', 6)
|
||||||
|
// CHECK: ('sh_addr', 0)
|
||||||
|
// CHECK: ('sh_offset', 64)
|
||||||
|
// CHECK: ('sh_size', 4)
|
||||||
|
// CHECK: ('sh_link', 0)
|
||||||
|
// CHECK: ('sh_info', 0)
|
||||||
|
// CHECK: ('sh_addralign', 4)
|
||||||
|
// CHECK: ('sh_entsize', 0)
|
||||||
|
// CHECK: ('_section_data', '00000000')
|
Reference in New Issue
Block a user