[PATCH] D63947: [WebAssembly] Assembler: Improve section parsing.
Wouter van Oortmerssen via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Jun 28 11:35:56 PDT 2019
aardappel created this revision.
aardappel added a reviewer: sbc100.
Herald added subscribers: llvm-commits, sunfish, aheejin, jgravelle-google, dschuff.
Herald added a project: LLVM.
Repository:
rL LLVM
https://reviews.llvm.org/D63947
Files:
lib/MC/MCParser/WasmAsmParser.cpp
lib/Target/WebAssembly/AsmParser/WebAssemblyAsmParser.cpp
Index: lib/Target/WebAssembly/AsmParser/WebAssemblyAsmParser.cpp
===================================================================
--- lib/Target/WebAssembly/AsmParser/WebAssemblyAsmParser.cpp
+++ lib/Target/WebAssembly/AsmParser/WebAssemblyAsmParser.cpp
@@ -748,6 +748,10 @@
auto SymName = Symbol->getName();
if (SymName.startswith(".L"))
return; // Local Symbol.
+ // Only create a new text section if we're already in one.
+ auto CWS = cast<MCSectionWasm>(getStreamer().getCurrentSection().first);
+ if (!CWS || !CWS->getKind().isText())
+ return;
auto SecName = ".text." + SymName;
auto WS = getContext().getWasmSection(SecName, SectionKind::getText());
getStreamer().SwitchSection(WS);
Index: lib/MC/MCParser/WasmAsmParser.cpp
===================================================================
--- lib/MC/MCParser/WasmAsmParser.cpp
+++ lib/MC/MCParser/WasmAsmParser.cpp
@@ -114,13 +114,17 @@
if (Lexer->isNot(AsmToken::String))
return error("expected string in directive, instead got: ", Lexer->getTok());
- SectionKind Kind = StringSwitch<SectionKind>(Name)
- .StartsWith(".data", SectionKind::getData())
- .StartsWith(".rodata", SectionKind::getReadOnly())
- .StartsWith(".text", SectionKind::getText())
- .StartsWith(".custom_section", SectionKind::getMetadata());
-
- MCSectionWasm* Section = getContext().getWasmSection(Name, Kind);
+ auto Kind = StringSwitch<Optional<SectionKind>>(Name)
+ .StartsWith(".data", SectionKind::getData())
+ .StartsWith(".rodata", SectionKind::getReadOnly())
+ .StartsWith(".text", SectionKind::getText())
+ .StartsWith(".custom_section", SectionKind::getMetadata())
+ .StartsWith(".bss", SectionKind::getBSS())
+ .Default(Optional<SectionKind>());
+ if (!Kind.hasValue())
+ return Parser->Error(Lexer->getLoc(), "unknown section kind: " + Name);
+
+ MCSectionWasm *Section = getContext().getWasmSection(Name, Kind.getValue());
// Update section flags if present in this .section directive
bool Passive = false;
@@ -139,28 +143,9 @@
if (expect(AsmToken::Comma, ",") || expect(AsmToken::At, "@") ||
expect(AsmToken::EndOfStatement, "eol"))
return true;
- struct SectionType {
- const char *Name;
- SectionKind Kind;
- };
- static SectionType SectionTypes[] = {
- {".text", SectionKind::getText()},
- {".rodata", SectionKind::getReadOnly()},
- {".data", SectionKind::getData()},
- {".custom_section", SectionKind::getMetadata()},
- // TODO: add more types.
- };
- for (size_t I = 0; I < sizeof(SectionTypes) / sizeof(SectionType); I++) {
- if (Name.startswith(SectionTypes[I].Name)) {
- auto WS = getContext().getWasmSection(Name, SectionTypes[I].Kind);
- getStreamer().SwitchSection(WS);
- return false;
- }
- }
- // Not found, just ignore this section.
- // For code in a text section WebAssemblyAsmParser automatically adds
- // one section per function, so they're optional to be specified with
- // this directive.
+
+ auto WS = getContext().getWasmSection(Name, Kind.getValue());
+ getStreamer().SwitchSection(WS);
return false;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D63947.207115.patch
Type: text/x-patch
Size: 3415 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190628/e3cf2598/attachment.bin>
More information about the llvm-commits
mailing list