mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
Expand acronyms, suggested by Walter Pawley
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54362 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3bc9c6f3e7
commit
d3eda89f4c
@ -255,9 +255,9 @@
|
|||||||
|
|
||||||
<div class="doc_text">
|
<div class="doc_text">
|
||||||
<p>This document is a reference manual for the LLVM assembly language.
|
<p>This document is a reference manual for the LLVM assembly language.
|
||||||
LLVM is an SSA based representation that provides type safety,
|
LLVM is an Static Single Assignment (SSA) based representation that provides
|
||||||
low-level operations, flexibility, and the capability of representing
|
type safety, low-level operations, flexibility, and the capability of
|
||||||
'all' high-level languages cleanly. It is the common code
|
representing 'all' high-level languages cleanly. It is the common code
|
||||||
representation used throughout all phases of the LLVM compilation
|
representation used throughout all phases of the LLVM compilation
|
||||||
strategy.</p>
|
strategy.</p>
|
||||||
</div>
|
</div>
|
||||||
@ -522,9 +522,9 @@ All Global Variables and Functions have one of the following types of linkage:
|
|||||||
</dd>
|
</dd>
|
||||||
|
|
||||||
<dt><tt><b><a name="linkage_externweak">extern_weak</a></b></tt>: </dt>
|
<dt><tt><b><a name="linkage_externweak">extern_weak</a></b></tt>: </dt>
|
||||||
<dd>The semantics of this linkage follow the ELF model: the symbol is weak
|
<dd>The semantics of this linkage follow the ELF object file model: the
|
||||||
until linked, if not linked, the symbol becomes null instead of being an
|
symbol is weak until linked, if not linked, the symbol becomes null instead
|
||||||
undefined reference.
|
of being an undefined reference.
|
||||||
</dd>
|
</dd>
|
||||||
|
|
||||||
<dt><tt><b><a name="linkage_external">externally visible</a></b></tt>:</dt>
|
<dt><tt><b><a name="linkage_external">externally visible</a></b></tt>:</dt>
|
||||||
@ -538,7 +538,7 @@ All Global Variables and Functions have one of the following types of linkage:
|
|||||||
<p>
|
<p>
|
||||||
The next two types of linkage are targeted for Microsoft Windows platform
|
The next two types of linkage are targeted for Microsoft Windows platform
|
||||||
only. They are designed to support importing (exporting) symbols from (to)
|
only. They are designed to support importing (exporting) symbols from (to)
|
||||||
DLLs.
|
DLLs (Dynamic Link Libraries).
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<dl>
|
<dl>
|
||||||
@ -602,8 +602,8 @@ the future:</p>
|
|||||||
<dd>This calling convention attempts to make calls as fast as possible
|
<dd>This calling convention attempts to make calls as fast as possible
|
||||||
(e.g. by passing things in registers). This calling convention allows the
|
(e.g. by passing things in registers). This calling convention allows the
|
||||||
target to use whatever tricks it wants to produce fast code for the target,
|
target to use whatever tricks it wants to produce fast code for the target,
|
||||||
without having to conform to an externally specified ABI. Implementations of
|
without having to conform to an externally specified ABI (Application Binary
|
||||||
this convention should allow arbitrary
|
Interface). Implementations of this convention should allow arbitrary
|
||||||
<a href="CodeGenerator.html#tailcallopt">tail call optimization</a> to be
|
<a href="CodeGenerator.html#tailcallopt">tail call optimization</a> to be
|
||||||
supported. This calling convention does not support varargs and requires the
|
supported. This calling convention does not support varargs and requires the
|
||||||
prototype of all callees to exactly match the prototype of the function
|
prototype of all callees to exactly match the prototype of the function
|
||||||
@ -648,7 +648,8 @@ All Global Variables and Functions have one of the following visibility styles:
|
|||||||
<dl>
|
<dl>
|
||||||
<dt><b>"<tt>default</tt>" - Default style</b>:</dt>
|
<dt><b>"<tt>default</tt>" - Default style</b>:</dt>
|
||||||
|
|
||||||
<dd>On ELF, default visibility means that the declaration is visible to other
|
<dd>On targets that use the ELF object file format, default visibility means
|
||||||
|
that the declaration is visible to other
|
||||||
modules and, in shared libraries, means that the declared entity may be
|
modules and, in shared libraries, means that the declared entity may be
|
||||||
overridden. On Darwin, default visibility means that the declaration is
|
overridden. On Darwin, default visibility means that the declaration is
|
||||||
visible to other modules. Default visibility corresponds to "external
|
visible to other modules. Default visibility corresponds to "external
|
||||||
@ -760,7 +761,8 @@ optional <a href="#linkage">linkage type</a>, an optional
|
|||||||
name, a possibly empty list of arguments, an optional alignment, and an optional
|
name, a possibly empty list of arguments, an optional alignment, and an optional
|
||||||
<a href="#gc">garbage collector name</a>.</p>
|
<a href="#gc">garbage collector name</a>.</p>
|
||||||
|
|
||||||
<p>A function definition contains a list of basic blocks, forming the CFG for
|
<p>A function definition contains a list of basic blocks, forming the CFG
|
||||||
|
(Control Flow Graph) for
|
||||||
the function. Each basic block may optionally start with a label (giving the
|
the function. Each basic block may optionally start with a label (giving the
|
||||||
basic block a symbol table entry), contains a list of instructions, and ends
|
basic block a symbol table entry), contains a list of instructions, and ends
|
||||||
with a <a href="#terminators">terminator</a> instruction (such as a branch or
|
with a <a href="#terminators">terminator</a> instruction (such as a branch or
|
||||||
@ -957,7 +959,7 @@ aspect of the data layout. The specifications accepted are as follows: </p>
|
|||||||
<dd>Specifies that the target lays out data in big-endian form. That is, the
|
<dd>Specifies that the target lays out data in big-endian form. That is, the
|
||||||
bits with the most significance have the lowest address location.</dd>
|
bits with the most significance have the lowest address location.</dd>
|
||||||
<dt><tt>e</tt></dt>
|
<dt><tt>e</tt></dt>
|
||||||
<dd>Specifies that hte target lays out data in little-endian form. That is,
|
<dd>Specifies that the target lays out data in little-endian form. That is,
|
||||||
the bits with the least significance have the lowest address location.</dd>
|
the bits with the least significance have the lowest address location.</dd>
|
||||||
<dt><tt>p:<i>size</i>:<i>abi</i>:<i>pref</i></tt></dt>
|
<dt><tt>p:<i>size</i>:<i>abi</i>:<i>pref</i></tt></dt>
|
||||||
<dd>This specifies the <i>size</i> of a pointer and its <i>abi</i> and
|
<dd>This specifies the <i>size</i> of a pointer and its <i>abi</i> and
|
||||||
@ -989,7 +991,7 @@ are given in this list:</p>
|
|||||||
<li><tt>i8:8:8</tt> - i8 is 8-bit (byte) aligned</li>
|
<li><tt>i8:8:8</tt> - i8 is 8-bit (byte) aligned</li>
|
||||||
<li><tt>i16:16:16</tt> - i16 is 16-bit aligned</li>
|
<li><tt>i16:16:16</tt> - i16 is 16-bit aligned</li>
|
||||||
<li><tt>i32:32:32</tt> - i32 is 32-bit aligned</li>
|
<li><tt>i32:32:32</tt> - i32 is 32-bit aligned</li>
|
||||||
<li><tt>i64:32:64</tt> - i64 has abi alignment of 32-bits but preferred
|
<li><tt>i64:32:64</tt> - i64 has ABI alignment of 32-bits but preferred
|
||||||
alignment of 64-bits</li>
|
alignment of 64-bits</li>
|
||||||
<li><tt>f32:32:32</tt> - float is 32-bit aligned</li>
|
<li><tt>f32:32:32</tt> - float is 32-bit aligned</li>
|
||||||
<li><tt>f64:64:64</tt> - double is 64-bit aligned</li>
|
<li><tt>f64:64:64</tt> - double is 64-bit aligned</li>
|
||||||
@ -1023,7 +1025,8 @@ following rules:
|
|||||||
|
|
||||||
<p>The LLVM type system is one of the most important features of the
|
<p>The LLVM type system is one of the most important features of the
|
||||||
intermediate representation. Being typed enables a number of
|
intermediate representation. Being typed enables a number of
|
||||||
optimizations to be performed on the IR directly, without having to do
|
optimizations to be performed on the intermediate representation directly,
|
||||||
|
without having to do
|
||||||
extra analyses on the side before the transformation. A strong type
|
extra analyses on the side before the transformation. A strong type
|
||||||
system makes it easier to read the generated code and enables novel
|
system makes it easier to read the generated code and enables novel
|
||||||
analyses and transformations that are not feasible to perform on normal
|
analyses and transformations that are not feasible to perform on normal
|
||||||
@ -4515,7 +4518,8 @@ example, memory allocation.</p>
|
|||||||
|
|
||||||
<p>
|
<p>
|
||||||
LLVM support for <a href="GarbageCollection.html">Accurate Garbage
|
LLVM support for <a href="GarbageCollection.html">Accurate Garbage
|
||||||
Collection</a> requires the implementation and generation of these intrinsics.
|
Collection</a> (GC) requires the implementation and generation of these
|
||||||
|
intrinsics.
|
||||||
These intrinsics allow identification of <a href="#int_gcroot">GC roots on the
|
These intrinsics allow identification of <a href="#int_gcroot">GC roots on the
|
||||||
stack</a>, as well as garbage collector implementations that require <a
|
stack</a>, as well as garbage collector implementations that require <a
|
||||||
href="#int_gcread">read</a> and <a href="#int_gcwrite">write</a> barriers.
|
href="#int_gcread">read</a> and <a href="#int_gcwrite">write</a> barriers.
|
||||||
@ -4867,11 +4871,12 @@ performance.
|
|||||||
|
|
||||||
<p>
|
<p>
|
||||||
The '<tt>llvm.pcmarker</tt>' intrinsic is a method to export a Program Counter
|
The '<tt>llvm.pcmarker</tt>' intrinsic is a method to export a Program Counter
|
||||||
(PC) in a region of
|
(PC) in a region of
|
||||||
code to simulators and other tools. The method is target specific, but it is
|
code to simulators and other tools. The method is target specific, but it is
|
||||||
expected that the marker will use exported symbols to transmit the PC of the marker.
|
expected that the marker will use exported symbols to transmit the PC of the
|
||||||
The marker makes no guarantees that it will remain with any specific instruction
|
marker.
|
||||||
after optimizations. It is possible that the presence of a marker will inhibit
|
The marker makes no guarantees that it will remain with any specific instruction
|
||||||
|
after optimizations. It is possible that the presence of a marker will inhibit
|
||||||
optimizations. The intended use is to be inserted after optimizations to allow
|
optimizations. The intended use is to be inserted after optimizations to allow
|
||||||
correlations of simulation runs.
|
correlations of simulation runs.
|
||||||
</p>
|
</p>
|
||||||
@ -5691,7 +5696,8 @@ declare i8* @llvm.init.trampoline(i8* <tramp>, i8* <func>, i8* <n
|
|||||||
These intrinsic functions expand the "universal IR" of LLVM to represent
|
These intrinsic functions expand the "universal IR" of LLVM to represent
|
||||||
hardware constructs for atomic operations and memory synchronization. This
|
hardware constructs for atomic operations and memory synchronization. This
|
||||||
provides an interface to the hardware, not an interface to the programmer. It
|
provides an interface to the hardware, not an interface to the programmer. It
|
||||||
is aimed at a low enough level to allow any programming models or APIs which
|
is aimed at a low enough level to allow any programming models or APIs
|
||||||
|
(Application Programming Interfaces) which
|
||||||
need atomic behaviors to map cleanly onto it. It is also modeled primarily on
|
need atomic behaviors to map cleanly onto it. It is also modeled primarily on
|
||||||
hardware behavior. Just as hardware provides a "universal IR" for source
|
hardware behavior. Just as hardware provides a "universal IR" for source
|
||||||
languages, it also provides a starting point for developing a "universal"
|
languages, it also provides a starting point for developing a "universal"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user