mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			[AArch64][doc] Clarify -msve-vector-bits=128 behaviour
We've received reports about the -msve-vector-bits=128 bits being somewhat ambiguous.
It isn't clear whether -msve-vector-bits=128 forces vector-length-agnostic code or whether
-msve-vector-bits=scalable forces 128-bit vector-lengh-specific code.
The latter is a, perhaps unintuitive, reading that we want to exclude.
This patch makes it more explicit that -msve-vector-bits=128 is special and produces
vector-length *agnostic* code. In the end, I've rewritten the whole option documentation.
Checked make pdf that the output looks reasonable.
    * doc/invoke.texi (-msve-vector-bits): Clarify -msve-vector-bits=128
    behavior.
From-SVN: r267081
			
			
This commit is contained in:
		
							parent
							
								
									7cab07f089
								
							
						
					
					
						commit
						ee03c51c0b
					
				|  | @ -1,3 +1,8 @@ | ||||||
|  | 2018-12-13  Kyrylo Tkachov  <kyrylo.tkachov@arm.com> | ||||||
|  | 
 | ||||||
|  | 	* doc/invoke.texi (-msve-vector-bits): Clarify -msve-vector-bits=128 | ||||||
|  | 	behavior. | ||||||
|  | 
 | ||||||
| 2018-12-13  Wei Xiao  <wei3.xiao@intel.com> | 2018-12-13  Wei Xiao  <wei3.xiao@intel.com> | ||||||
| 
 | 
 | ||||||
| 	* common/config/i386/i386-common.c (processor_names): Add cascadelake. | 	* common/config/i386/i386-common.c (processor_names): Add cascadelake. | ||||||
|  |  | ||||||
|  | @ -15675,16 +15675,19 @@ an effect when SVE is enabled. | ||||||
| 
 | 
 | ||||||
| GCC supports two forms of SVE code generation: ``vector-length | GCC supports two forms of SVE code generation: ``vector-length | ||||||
| agnostic'' output that works with any size of vector register and | agnostic'' output that works with any size of vector register and | ||||||
| ``vector-length specific'' output that only works when the vector | ``vector-length specific'' output that allows GCC to make assumptions | ||||||
| registers are a particular size.  Replacing @var{bits} with | about the vector length when it is useful for optimization reasons. | ||||||
| @samp{scalable} selects vector-length agnostic output while | The possible values of @samp{bits} are: @samp{scalable}, @samp{128}, | ||||||
| replacing it with a number selects vector-length specific output. | @samp{256}, @samp{512}, @samp{1024} and @samp{2048}. | ||||||
| The possible lengths in the latter case are: 128, 256, 512, 1024 | Specifying @samp{scalable} selects vector-length agnostic | ||||||
| and 2048.  @samp{scalable} is the default. | output.  At present @samp{-msve-vector-bits=128} also generates vector-length | ||||||
| 
 | agnostic output.  All other values generate vector-length specific code. | ||||||
| At present, @samp{-msve-vector-bits=128} produces the same output | The behavior of these values may change in future releases and no value except | ||||||
| as @samp{-msve-vector-bits=scalable}. | @samp{scalable} should be relied on for producing code that is portable across | ||||||
|  | different hardware SVE vector lengths. | ||||||
| 
 | 
 | ||||||
|  | The default is @samp{-msve-vector-bits=scalable}, which produces | ||||||
|  | vector-length agnostic code. | ||||||
| @end table | @end table | ||||||
| 
 | 
 | ||||||
| @subsubsection @option{-march} and @option{-mcpu} Feature Modifiers | @subsubsection @option{-march} and @option{-mcpu} Feature Modifiers | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Kyrylo Tkachov
						Kyrylo Tkachov