diff mbox

[2/3] tm.texi documentation on macro PREFERRED_RENAME_CLASS

Message ID 4CBFE30C.7090308@codesourcery.com
State New
Headers show

Commit Message

Yao Qi Oct. 21, 2010, 6:51 a.m. UTC

Comments

Joseph Myers Oct. 21, 2010, 10:04 p.m. UTC | #1
tm.texi is a generated file.  You need to patch tm.texi.in and regenerate 
tm.texi.

In general new target macros should be avoided in favour of hooks (whose 
documentation source should be in target.def with a minimal @hook 
reference in tm.texi.in) unless one of the following applies:

* The macro is used in code built for the target, #if conditions, enum 
values, case labels or other places where a compile-time constant is 
required and so a hook cannot be used.

* The macro is so closely related to an existing set of macros that it 
does not make sense for some to be macros and others to be hooks; all 
should be converted at once.  (For example, when I added stdint.h support 
I added a set of macros such as INT_FAST8_TYPE.  These work almost the 
same as others such as SIZE_TYPE and all should be converted to hooks at 
once.  The appropriate hook conversion would not be one hook per macro; 
more likely, one for the miscellaneous C types such as SIZE_TYPE, one for 
SIG_ATOMIC_TYPE and one for the stdint.h types.  The hooks would not 
return strings like the macros do; they'd take enum values and return enum 
values, although an intermediate stage might be macros evaluating to enum 
values.)

* (Until the relevant parts of 
<http://gcc.gnu.org/ml/gcc/2010-10/msg00294.html> are implemented for the 
relevant part of the compiler.)  The macro is used somewhere without a 
hook facility at present, such as the driver or collect2.

* There is actual evidence of significant performance cost from using a 
hook.  (In general, however, the long-term plan is for LTO-based 
devirtualization to remove the performance penalty of hooks.  
<http://gcc.gnu.org/ml/gcc-patches/2010-06/msg02826.html> suggests this 
devirtualization wasn't usefully happening as of June, both because the 
target structure isn't const and because devirtualization happens too late 
for inlining.  I don't know if it's since moved on to be able to detect 
which fields of the structure are unmodified or to devirtualize earlier.)
Yao Qi Oct. 22, 2010, 8:55 a.m. UTC | #2
On 10/22/2010 06:04 AM, Joseph S. Myers wrote:
> tm.texi is a generated file.  You need to patch tm.texi.in and regenerate 
> tm.texi.
> 
> In general new target macros should be avoided in favour of hooks (whose 
> documentation source should be in target.def with a minimal @hook 
> reference in tm.texi.in) unless one of the following applies:
> 

Joseph,
Thanks for this good explanation.  I'll convert my target macro to hook.
Paolo, Anatoly,
Thanks for your review too.  I'll update my patches, and submit them again.

> * The macro is used in code built for the target, #if conditions, enum 
> values, case labels or other places where a compile-time constant is 
> required and so a hook cannot be used.
> 
> * The macro is so closely related to an existing set of macros that it 
> does not make sense for some to be macros and others to be hooks; all 
> should be converted at once.  (For example, when I added stdint.h support 
> I added a set of macros such as INT_FAST8_TYPE.  These work almost the 
> same as others such as SIZE_TYPE and all should be converted to hooks at 
> once.  The appropriate hook conversion would not be one hook per macro; 
> more likely, one for the miscellaneous C types such as SIZE_TYPE, one for 
> SIG_ATOMIC_TYPE and one for the stdint.h types.  The hooks would not 
> return strings like the macros do; they'd take enum values and return enum 
> values, although an intermediate stage might be macros evaluating to enum 
> values.)
> 
> * (Until the relevant parts of 
> <http://gcc.gnu.org/ml/gcc/2010-10/msg00294.html> are implemented for the 
> relevant part of the compiler.)  The macro is used somewhere without a 
> hook facility at present, such as the driver or collect2.
> 
> * There is actual evidence of significant performance cost from using a 
> hook.  (In general, however, the long-term plan is for LTO-based 
> devirtualization to remove the performance penalty of hooks.  
> <http://gcc.gnu.org/ml/gcc-patches/2010-06/msg02826.html> suggests this 
> devirtualization wasn't usefully happening as of June, both because the 
> target structure isn't const and because devirtualization happens too late 
> for inlining.  I don't know if it's since moved on to be able to detect 
> which fields of the structure are unmodified or to devirtualize earlier.)
>
diff mbox

Patch

gcc/
	* doc/tm.texi: Documentation on new macro
	PREFERRED_RENAME_CLASS.

diff --git a/gcc/doc/tm.texi b/gcc/doc/tm.texi
index e1e0957..40fc204 100644
--- a/gcc/doc/tm.texi
+++ b/gcc/doc/tm.texi
@@ -2581,6 +2581,19 @@  only if neither labeling works.
 This macro also has strict and non-strict variants.
 @end defmac
 
+@defmac PREFERRED_RENAME_CLASS (@var{class})
+A C expression that places additional restrictions on the register class
+to use when it is necessary to rename a register in class
+@var{class} to another class, or perhaps still @var{class},
+if you don't define this macro.
+
+Sometimes returning a more restrictive class makes better code.  For
+example, on ARM, thumb-2 instructions using @code{LOW_REGS} may be smaller than
+instructions using @code{GENERIC_REGS}.  By returning @code{LOW_REGS} from
+@code{PREFERRED_RENAME_CLASS}, code size can be reduced.
+
+@end defmac
+
 @defmac PREFERRED_RELOAD_CLASS (@var{x}, @var{class})
 A C expression that places additional restrictions on the register class
 to use when it is necessary to copy value @var{x} into a register in class