1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-15 22:30:04 +00:00

Document the codesize, optimize and warn pragmas

git-svn-id: svn://svn.cc65.org/cc65/trunk@3131 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
cuz 2004-06-15 21:20:34 +00:00
parent ca2b070935
commit 255392eb15

View File

@ -133,12 +133,13 @@ Here is a description of all the command line options:
Set the name of the code segment. Set the name of the code segment.
<label id="option-codesize">
<tag><tt>--codesize x</tt></tag> <tag><tt>--codesize x</tt></tag>
This options allows finer control about speed vs. size decisions in the This options allows finer control about speed vs. size decisions in the code
code generation phase. It gives the allowed size increase factor (in generation and optimization phases. It gives the allowed size increase
percent). The default is 100 when not using <tt/-Oi/ and 200 when using factor (in percent). The default is 100 when not using <tt/-Oi/ and 200 when
<tt/-Oi/ (<tt/-Oi/ is the same as <tt/--codesize 200/). using <tt/-Oi/ (<tt/-Oi/ is the same as <tt/--codesize 200/).
<tag><tt>--cpu CPU</tt></tag> <tag><tt>--cpu CPU</tt></tag>
@ -315,6 +316,7 @@ Here is a description of all the command line options:
search list. search list.
<label id="option-O">
<tag><tt>-O, -Oi, -Or, -Os</tt></tag> <tag><tt>-O, -Oi, -Or, -Os</tt></tag>
Enable an optimizer run over the produced code. Enable an optimizer run over the produced code.
@ -364,6 +366,7 @@ Here is a description of all the command line options:
version. version.
<label id="option-W">
<tag><tt>-W</tt></tag> <tag><tt>-W</tt></tag>
This option will suppress any warnings generated by the compiler. Since This option will suppress any warnings generated by the compiler. Since
@ -732,7 +735,7 @@ parameter with the <tt/#pragma/.
</verb></tscreen> </verb></tscreen>
<sect1><tt>#pragma checkstack (on|off)</tt><label id="pragma-checkstack"><p> <sect1><tt>#pragma checkstack ([push,]on|off)</tt><label id="pragma-checkstack"><p>
Tells the compiler to insert calls to a stack checking subroutine to detect Tells the compiler to insert calls to a stack checking subroutine to detect
stack overflows. The stack checking code will lead to somewhat larger and stack overflows. The stack checking code will lead to somewhat larger and
@ -745,7 +748,7 @@ parameter with the <tt/#pragma/.
The <tt/#pragma/ understands the push and pop parameters as explained above. The <tt/#pragma/ understands the push and pop parameters as explained above.
<sect1><tt>#pragma codeseg (&lt;name&gt;)</tt><p> <sect1><tt>#pragma codeseg ([push,]&lt;name&gt;)</tt><p>
This pragma changes the name used for the CODE segment (the CODE segment This pragma changes the name used for the CODE segment (the CODE segment
is used to store executable code). The argument is a string enclosed in is used to store executable code). The argument is a string enclosed in
@ -763,7 +766,17 @@ parameter with the <tt/#pragma/.
</verb></tscreen> </verb></tscreen>
<sect1><tt>#pragma dataseg (&lt;name&gt;)</tt><p> <sect1><tt>#pragma codesize ([push,]&lt;int&gt;)</tt><label id="pragma-codesize"><p>
This pragma allows finer control about speed vs. size decisions in the code
generation and optimization phase. It gives the allowed size increase factor
(in percent). The default is can be changed by use of the <tt/<ref
id="option-codesize" name="--codesize">/ compiler option.
The <tt/#pragma/ understands the push and pop parameters as explained above.
<sect1><tt>#pragma dataseg ([push,]&lt;name&gt;)</tt><p>
This pragma changes the name used for the DATA segment (the DATA segment This pragma changes the name used for the DATA segment (the DATA segment
is used to store initialized data). The argument is a string enclosed in is used to store initialized data). The argument is a string enclosed in
@ -781,7 +794,23 @@ parameter with the <tt/#pragma/.
</verb></tscreen> </verb></tscreen>
<sect1><tt>#pragma rodataseg (&lt;name&gt;)</tt><p> <sect1><tt>#pragma optimize ([push,]on|off)</tt><label id="pragma-optimize"><p>
Switch optimization on or off. If the argument is "off", optimization is
disabled, otherwise it is enabled. Please note that this pragma only effects
whole functions. The setting in effect when the function is encountered will
determine if the generated code is optimized or not.
Optimization and code generation is also controlled by the <ref
id="pragma-codesize" name="codesize pragma">.
The default is "off", but may be changed with the <tt/<ref name="-O"
id="option-O">/ compiler option.
The <tt/#pragma/ understands the push and pop parameters as explained above.
<sect1><tt>#pragma rodataseg ([push,]&lt;name&gt;)</tt><p>
This pragma changes the name used for the RODATA segment (the RODATA This pragma changes the name used for the RODATA segment (the RODATA
segment is used to store readonly data). The argument is a string segment is used to store readonly data). The argument is a string
@ -833,7 +862,7 @@ parameter with the <tt/#pragma/.
The <tt/#pragma/ understands the push and pop parameters as explained above. The <tt/#pragma/ understands the push and pop parameters as explained above.
<sect1><tt>#pragma signedchars (on|off)</tt><label id="pragma-signedchars"><p> <sect1><tt>#pragma signedchars ([push,]on|off)</tt><label id="pragma-signedchars"><p>
Changes the signedness of the default character type. If the argument is Changes the signedness of the default character type. If the argument is
"on", default characters are signed, otherwise characters are unsigned. "on", default characters are signed, otherwise characters are unsigned.
@ -844,7 +873,7 @@ parameter with the <tt/#pragma/.
The <tt/#pragma/ understands the push and pop parameters as explained above. The <tt/#pragma/ understands the push and pop parameters as explained above.
<sect1><tt>#pragma staticlocals (on|off)</tt><label id="pragma-staticlocals"<p> <sect1><tt>#pragma staticlocals ([push,]on|off)</tt><label id="pragma-staticlocals"<p>
Use variables in the bss segment instead of variables on the stack. This Use variables in the bss segment instead of variables on the stack. This
pragma changes the default set by the compiler option <tt/-Cl/. If the pragma changes the default set by the compiler option <tt/-Cl/. If the
@ -854,6 +883,15 @@ parameter with the <tt/#pragma/.
The <tt/#pragma/ understands the push and pop parameters as explained above. The <tt/#pragma/ understands the push and pop parameters as explained above.
<sect1><tt>#pragma warn ([push,]on|off)</tt><label id="pragma-warn"><p>
Switch compiler warnings on or off. If the argument is "off", warnings are
disabled, otherwise they're enabled. The default is "on", but may be changed
with the <tt/<ref name="-W" id="option-W">/ compiler option.
The <tt/#pragma/ understands the push and pop parameters as explained above.
<sect1><tt>#pragma zpsym (&lt;name&gt;)</tt><p> <sect1><tt>#pragma zpsym (&lt;name&gt;)</tt><p>
Tell the compiler that the - previously as external declared - symbol with Tell the compiler that the - previously as external declared - symbol with