summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2010-01-19 18:52:28 +0000
committerChris Lattner <sabre@nondot.org>2010-01-19 18:52:28 +0000
commit4340cb324665f7561cead81096c027e6bb9cdab5 (patch)
treef31de303402944afe6cee39f17d5bee7ab8fa4c0
parent0c65fd49022849e1ba5d94459ea0128d7ab6c45f (diff)
downloadbcm5719-llvm-4340cb324665f7561cead81096c027e6bb9cdab5.tar.gz
bcm5719-llvm-4340cb324665f7561cead81096c027e6bb9cdab5.zip
add an MCAsmStreamer::EmitFill specialization of EmitFill that
emits one directive instead of N. Not doing this would be a significant regression on the # bytes generated by .fill. llvm-svn: 93889
-rw-r--r--llvm/lib/MC/MCAsmStreamer.cpp15
-rw-r--r--llvm/test/MC/AsmParser/directive_space.s7
2 files changed, 18 insertions, 4 deletions
diff --git a/llvm/lib/MC/MCAsmStreamer.cpp b/llvm/lib/MC/MCAsmStreamer.cpp
index 4e571ff98c5..317e74d5b32 100644
--- a/llvm/lib/MC/MCAsmStreamer.cpp
+++ b/llvm/lib/MC/MCAsmStreamer.cpp
@@ -61,6 +61,7 @@ public:
virtual void EmitBytes(StringRef Data);
virtual void EmitValue(const MCExpr *Value, unsigned Size);
+ virtual void EmitFill(uint64_t NumBytes, uint8_t FillValue);
virtual void EmitValueToAlignment(unsigned ByteAlignment, int64_t Value = 0,
unsigned ValueSize = 1,
@@ -199,6 +200,20 @@ void MCAsmStreamer::EmitValue(const MCExpr *Value, unsigned Size) {
OS << ' ' << *truncateToSize(Value, Size) << '\n';
}
+/// EmitFill - Emit NumBytes bytes worth of the value specified by
+/// FillValue. This implements directives such as '.space'.
+void MCAsmStreamer::EmitFill(uint64_t NumBytes, uint8_t FillValue) {
+ if (const char *ZeroDirective = MAI.getZeroDirective()) {
+ OS << ZeroDirective << NumBytes;
+ if (FillValue != 0)
+ OS << ',' << (int)FillValue;
+ OS << '\n';
+ } else {
+ // Emit a byte at a time.
+ MCStreamer::EmitFill(NumBytes, FillValue);
+ }
+}
+
void MCAsmStreamer::EmitValueToAlignment(unsigned ByteAlignment, int64_t Value,
unsigned ValueSize,
unsigned MaxBytesToEmit) {
diff --git a/llvm/test/MC/AsmParser/directive_space.s b/llvm/test/MC/AsmParser/directive_space.s
index a897654c07c..e6353a4af4d 100644
--- a/llvm/test/MC/AsmParser/directive_space.s
+++ b/llvm/test/MC/AsmParser/directive_space.s
@@ -1,12 +1,11 @@
-# RUN: llvm-mc -triple i386-unknown-unknown %s | FileCheck %s
+# RUN: llvm-mc -triple i386-apple-darwin %s | FileCheck %s
# CHECK: TEST0:
-# CHECK: .byte 0
+# CHECK: .space 1
TEST0:
.space 1
# CHECK: TEST1:
-# CHECK: .byte 3
-# CHECK: .byte 3
+# CHECK: .space 2,3
TEST1:
.space 2, 3
OpenPOWER on IntegriCloud