34 lines
1.4 KiB
Text
34 lines
1.4 KiB
Text
|
@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}.
|