| @section WebAssembly backend |
| The WebAssembly module file format, at present, is a very simple |
| object file format with up to 11 numbered sections plus named |
| ``custom'' sections. At present, there is no standard for relocations |
| or symbols, though a @code{"name"} subsection can assign names to |
| function indices and local variables. |
| |
| As such, it offers no real advantages over ELF, and intermediate ELF |
| files can be used to produce WebAssembly modules. The WebAssembly |
| backend aims to enable the opposite: reading a WebAssembly module and |
| producing an ELF file containing the same information, which can then |
| be manipulated and inspected with standard tools. |
| |
| When writing WebAssembly modules, the WebAssembly backend attempts to |
| determine based on the section name whether to use a numeric section |
| id, a named section header, or to include the section verbatim, |
| assuming it already contains any necessary header. |
| |
| Function names are supported as symbols; local names and WebAssembly |
| relocation sections are currently unsupported. |
| |
| There are slight differences in the LEB128 integer implementations |
| between the WebAssembly specification and the BFD code; these result |
| in some malformed WebAssembly modules being treated as valid. |
| |
| @menu |
| * File layout:: |
| @end menu |
| |
| @node File layout, WebAssembly |
| @subsection File layout |
| For a description of the WebAssembly file format, see |
| @url{https://github.com/WebAssembly/design/blob/master/BinaryEncoding.md}. |