Arm/doc: separate @code from @item for older makeinfo
Checks
Commit Message
At least 4.12 doesn't like the constructs without a separator.
Comments
Hi Jan, Nick,
I tested my changes with a more recent version (Jul 2021).
$ makeinfo --version
texi2any (GNU texinfo) 6.8
The version 4.12 dates back to April 2008 (more than 15 years ago).
Are there any guidelines regarding the minimum supported versions for tools ?
What are the criteria for increasing the supported version of a tool ?
Best regards,
Matthieu
-----Original Message-----
From: Jan Beulich <jbeulich@suse.com>
Sent: Friday, January 5, 2024 8:25 AM
To: Binutils <binutils@sourceware.org>
Cc: nickc@redhat.com; Matthieu Longo <Matthieu.Longo@arm.com>
Subject: [PATCH] Arm/doc: separate @code from @item for older makeinfo
At least 4.12 doesn't like the constructs without a separator.
--- a/gas/doc/c-arm.texi
+++ b/gas/doc/c-arm.texi
@@ -289,199 +289,199 @@ See their availability and meaning below For @code{armv5te}, @code{armv5texp}, @code{armv5tej}, @code{armv6}, @code{armv6j}, @code{armv6k}, @code{armv6z}, @code{armv6kz}, @code{armv6zk}, @code{armv6t2}, @code{armv6kt2} and @code{armv6zt2}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv2 instructions.
-@item@code{+nofp}: Disables all FPU instrunctions.
+@item @code{+fp}: Enables VFPv2 instructions.
+@item @code{+nofp}: Disables all FPU instrunctions.
@end itemize
For @code{armv7}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+nofp}: Disables all FPU instructions.
+@item @code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+nofp}: Disables all FPU instructions.
@end itemize
For @code{armv7-a}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+vfpv3-d16}: Alias for @code{+fp}.
-@item@code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
-@item@code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision floating-point
+@item @code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+vfpv3-d16}: Alias for @code{+fp}.
+@item @code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
+@item @code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision
+floating-point
conversion instructions and 16 double-word registers.
-@item@code{+vfpv3-fp16}: Enables VFPv3 with half precision floating-point conversion
+@item @code{+vfpv3-fp16}: Enables VFPv3 with half precision
+floating-point conversion
instructions and 32 double-word registers.
-@item@code{+vfpv4-d16}: Enables VFPv4 instructions with 16 double-word registers.
-@item@code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
-@item@code{+simd}: Enables VFPv3 and NEONv1 instructions with 32 double-word
+@item @code{+vfpv4-d16}: Enables VFPv4 instructions with 16 double-word registers.
+@item @code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
+@item @code{+simd}: Enables VFPv3 and NEONv1 instructions with 32
+double-word
registers.
-@item@code{+neon}: Alias for @code{+simd}.
-@item@code{+neon-vfpv3}: Alias for @code{+simd}.
-@item@code{+neon-fp16}: Enables VFPv3, half precision floating-point conversion and
+@item @code{+neon}: Alias for @code{+simd}.
+@item @code{+neon-vfpv3}: Alias for @code{+simd}.
+@item @code{+neon-fp16}: Enables VFPv3, half precision floating-point
+conversion and
NEONv1 instructions with 32 double-word registers.
-@item@code{+neon-vfpv4}: Enables VFPv4 and NEONv1 with Fused-MAC instructions and 32
+@item @code{+neon-vfpv4}: Enables VFPv4 and NEONv1 with Fused-MAC
+instructions and 32
double-word registers.
-@item@code{+mp}: Enables Multiprocessing Extensions.
-@item@code{+sec}: Enables Security Extensions.
-@item@code{+nofp}: Disables all FPU and NEON instructions.
-@item@code{+nosimd}: Disables all NEON instructions.
+@item @code{+mp}: Enables Multiprocessing Extensions.
+@item @code{+sec}: Enables Security Extensions.
+@item @code{+nofp}: Disables all FPU and NEON instructions.
+@item @code{+nosimd}: Disables all NEON instructions.
@end itemize
For @code{armv7ve}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv4 instructions with 16 double-word registers.
-@item@code{+vfpv4-d16}: Alias for @code{+fp}.
-@item@code{+vfpv3-d16}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
-@item@code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision floating-point
+@item @code{+fp}: Enables VFPv4 instructions with 16 double-word registers.
+@item @code{+vfpv4-d16}: Alias for @code{+fp}.
+@item @code{+vfpv3-d16}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
+@item @code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision
+floating-point
conversion instructions and 16 double-word registers.
-@item@code{+vfpv3-fp16}: Enables VFPv3 with half precision floating-point conversion
+@item @code{+vfpv3-fp16}: Enables VFPv3 with half precision
+floating-point conversion
instructions and 32 double-word registers.
-@item@code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
-@item@code{+simd}: Enables VFPv4 and NEONv1 with Fused-MAC instructions and 32
+@item @code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
+@item @code{+simd}: Enables VFPv4 and NEONv1 with Fused-MAC
+instructions and 32
double-word registers.
-@item@code{+neon-vfpv4}: Alias for @code{+simd}.
-@item@code{+neon}: Enables VFPv3 and NEONv1 instructions with 32 double-word
+@item @code{+neon-vfpv4}: Alias for @code{+simd}.
+@item @code{+neon}: Enables VFPv3 and NEONv1 instructions with 32
+double-word
registers.
-@item@code{+neon-vfpv3}: Alias for @code{+neon}.
-@item@code{+neon-fp16}: Enables VFPv3, half precision floating-point conversion and
+@item @code{+neon-vfpv3}: Alias for @code{+neon}.
+@item @code{+neon-fp16}: Enables VFPv3, half precision floating-point
+conversion and
NEONv1 instructions with 32 double-word registers.
double-word registers.
-@item@code{+nofp}: Disables all FPU and NEON instructions.
-@item@code{+nosimd}: Disables all NEON instructions.
+@item @code{+nofp}: Disables all FPU and NEON instructions.
+@item @code{+nosimd}: Disables all NEON instructions.
@end itemize
For @code{armv7-r}:
@itemize @w{}
-@item@code{+fp.sp}: Enables single-precision only VFPv3 instructions with 16
+@item @code{+fp.sp}: Enables single-precision only VFPv3 instructions
+with 16
double-word registers.
-@item@code{+vfpv3xd}: Alias for @code{+fp.sp}.
-@item@code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+vfpv3-d16}: Alias for @code{+fp}.
-@item@code{+vfpv3xd-fp16}: Enables single-precision only VFPv3 and half
+@item @code{+vfpv3xd}: Alias for @code{+fp.sp}.
+@item @code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+vfpv3-d16}: Alias for @code{+fp}.
+@item @code{+vfpv3xd-fp16}: Enables single-precision only VFPv3 and
+half
floating-point conversion instructions with 16 double-word registers.
-@item@code{+vfpv3-d16-fp16}: Enables VFPv3 and half precision floating-point
+@item @code{+vfpv3-d16-fp16}: Enables VFPv3 and half precision
+floating-point
conversion instructions with 16 double-word registers.
-@item@code{+idiv}: Enables integer division instructions in ARM mode.
-@item@code{+nofp}: Disables all FPU instructions.
+@item @code{+idiv}: Enables integer division instructions in ARM mode.
+@item @code{+nofp}: Disables all FPU instructions.
@end itemize
For @code{armv7e-m}:
@itemize @w{}
-@item@code{+fp}: Enables single-precision only VFPv4 instructions with 16
+@item @code{+fp}: Enables single-precision only VFPv4 instructions with
+16
double-word registers.
-@item@code{+vfpvf4-sp-d16}: Alias for @code{+fp}.
-@item@code{+fpv5}: Enables single-precision only VFPv5 instructions with 16
+@item @code{+vfpvf4-sp-d16}: Alias for @code{+fp}.
+@item @code{+fpv5}: Enables single-precision only VFPv5 instructions
+with 16
double-word registers.
-@item@code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
-@item@code{+fpv5-d16"}: Alias for @code{+fp.dp}.
-@item@code{+nofp}: Disables all FPU instructions.
+@item @code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
+@item @code{+fpv5-d16"}: Alias for @code{+fp.dp}.
+@item @code{+nofp}: Disables all FPU instructions.
@end itemize
For @code{armv8-m.main}:
@itemize @w{}
-@item@code{+dsp}: Enables DSP Extension.
-@item@code{+fp}: Enables single-precision only VFPv5 instructions with 16
+@item @code{+dsp}: Enables DSP Extension.
+@item @code{+fp}: Enables single-precision only VFPv5 instructions with
+16
double-word registers.
-@item@code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
-@item@code{+cdecp0} (CDE extensions for v8-m architecture with coprocessor 0), -@item@code{+cdecp1} (CDE extensions for v8-m architecture with coprocessor 1), -@item@code{+cdecp2} (CDE extensions for v8-m architecture with coprocessor 2), -@item@code{+cdecp3} (CDE extensions for v8-m architecture with coprocessor 3), -@item@code{+cdecp4} (CDE extensions for v8-m architecture with coprocessor 4), -@item@code{+cdecp5} (CDE extensions for v8-m architecture with coprocessor 5), -@item@code{+cdecp6} (CDE extensions for v8-m architecture with coprocessor 6), -@item@code{+cdecp7} (CDE extensions for v8-m architecture with coprocessor 7),
-@item@code{+nofp}: Disables all FPU instructions.
-@item@code{+nodsp}: Disables DSP Extension.
+@item @code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
+@item @code{+cdecp0} (CDE extensions for v8-m architecture with
+coprocessor 0), @item @code{+cdecp1} (CDE extensions for v8-m
+architecture with coprocessor 1), @item @code{+cdecp2} (CDE extensions
+for v8-m architecture with coprocessor 2), @item @code{+cdecp3} (CDE
+extensions for v8-m architecture with coprocessor 3), @item
+@code{+cdecp4} (CDE extensions for v8-m architecture with coprocessor
+4), @item @code{+cdecp5} (CDE extensions for v8-m architecture with
+coprocessor 5), @item @code{+cdecp6} (CDE extensions for v8-m
+architecture with coprocessor 6), @item @code{+cdecp7} (CDE extensions for v8-m architecture with coprocessor 7), @item @code{+nofp}: Disables all FPU instructions.
+@item @code{+nodsp}: Disables DSP Extension.
@end itemize
For @code{armv8.1-m.main}:
@itemize @w{}
-@item@code{+dsp}: Enables DSP Extension.
-@item@code{+fp}: Enables single and half precision scalar Floating Point Extensions
+@item @code{+dsp}: Enables DSP Extension.
+@item @code{+fp}: Enables single and half precision scalar Floating
+Point Extensions
for Armv8.1-M Mainline with 16 double-word registers.
-@item@code{+fp.dp}: Enables double precision scalar Floating Point Extensions for
+@item @code{+fp.dp}: Enables double precision scalar Floating Point
+Extensions for
Armv8.1-M Mainline, implies @code{+fp}.
-@item@code{+mve}: Enables integer only M-profile Vector Extension for
+@item @code{+mve}: Enables integer only M-profile Vector Extension for
Armv8.1-M Mainline, implies @code{+dsp}.
-@item@code{+mve.fp}: Enables Floating Point M-profile Vector Extension for
+@item @code{+mve.fp}: Enables Floating Point M-profile Vector Extension
+for
Armv8.1-M Mainline, implies @code{+mve} and @code{+fp}.
-@item@code{+nofp}: Disables all FPU instructions.
-@item@code{+nodsp}: Disables DSP Extension.
-@item@code{+nomve}: Disables all M-profile Vector Extensions.
+@item @code{+nofp}: Disables all FPU instructions.
+@item @code{+nodsp}: Disables DSP Extension.
+@item @code{+nomve}: Disables all M-profile Vector Extensions.
@end itemize
For @code{armv8-a}:
@itemize @w{}
-@item@code{+crc}: Enables CRC32 Extension.
-@item@code{+simd}: Enables VFP and NEON for Armv8-A.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+crc}: Enables CRC32 Extension.
+@item @code{+simd}: Enables VFP and NEON for Armv8-A.
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction
+Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
-@item@code{+nocrypto}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
+@item @code{+nocrypto}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.1-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A.
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction
+Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
-@item@code{+nocrypto}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
+@item @code{+nocrypto}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.2-a} and @code{armv8.3-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A.
-@item@code{+fp16}: Enables FP16 Extension for Armv8.2-A, implies @code{+simd}.
-@item@code{+fp16fml}: Enables FP16 Floating Point Multiplication Variant Extensions
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A.
+@item @code{+fp16}: Enables FP16 Extension for Armv8.2-A, implies @code{+simd}.
+@item @code{+fp16fml}: Enables FP16 Floating Point Multiplication
+Variant Extensions
for Armv8.2-A, implies @code{+fp16}.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+dotprod}: Enables Dot Product Extensions for Armv8.2-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+dotprod}: Enables Dot Product Extensions for Armv8.2-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction
+Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
-@item@code{+nocrypto}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
+@item @code{+nocrypto}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.4-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product Extensions for
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product
+Extensions for
Armv8.2-A.
-@item@code{+fp16}: Enables FP16 Floating Point and Floating Point Multiplication
+@item @code{+fp16}: Enables FP16 Floating Point and Floating Point
+Multiplication
Variant Extensions for Armv8.2-A, implies @code{+simd}.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction
+Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
-@item@code{+nocryptp}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
+@item @code{+nocryptp}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.5-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product Extensions for
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product
+Extensions for
Armv8.2-A.
-@item@code{+fp16}: Enables FP16 Floating Point and Floating Point Multiplication
+@item @code{+fp16}: Enables FP16 Floating Point and Floating Point
+Multiplication
Variant Extensions for Armv8.2-A, implies @code{+simd}.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
-@item@code{+nocryptp}: Disables Cryptography Extensions.
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
+@item @code{+nocryptp}: Disables Cryptography Extensions.
@end itemize
@cindex @code{-mfpu=} command-line option, ARM
On 05.01.2024 12:12, Matthieu Longo wrote:
> I tested my changes with a more recent version (Jul 2021).
> $ makeinfo --version
> texi2any (GNU texinfo) 6.8
>
> The version 4.12 dates back to April 2008 (more than 15 years ago).
>
> Are there any guidelines regarding the minimum supported versions for tools ?
For makeinfo in particular top-level configure.ac has this:
# For an installed makeinfo, we require it to be from texinfo 4.7 or
# higher, else we use the "missing" dummy.
> What are the criteria for increasing the supported version of a tool ?
I have no idea, but I think it is in general a good idea to keep old
tools working when that's easy to arrange for.
Also - please don't top-post, and please trim reply context.
Jan
@@ -289,199 +289,199 @@ See their availability and meaning below
For @code{armv5te}, @code{armv5texp}, @code{armv5tej}, @code{armv6}, @code{armv6j}, @code{armv6k}, @code{armv6z}, @code{armv6kz}, @code{armv6zk}, @code{armv6t2}, @code{armv6kt2} and @code{armv6zt2}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv2 instructions.
-@item@code{+nofp}: Disables all FPU instrunctions.
+@item @code{+fp}: Enables VFPv2 instructions.
+@item @code{+nofp}: Disables all FPU instrunctions.
@end itemize
For @code{armv7}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+nofp}: Disables all FPU instructions.
+@item @code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+nofp}: Disables all FPU instructions.
@end itemize
For @code{armv7-a}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+vfpv3-d16}: Alias for @code{+fp}.
-@item@code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
-@item@code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision floating-point
+@item @code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+vfpv3-d16}: Alias for @code{+fp}.
+@item @code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
+@item @code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision floating-point
conversion instructions and 16 double-word registers.
-@item@code{+vfpv3-fp16}: Enables VFPv3 with half precision floating-point conversion
+@item @code{+vfpv3-fp16}: Enables VFPv3 with half precision floating-point conversion
instructions and 32 double-word registers.
-@item@code{+vfpv4-d16}: Enables VFPv4 instructions with 16 double-word registers.
-@item@code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
-@item@code{+simd}: Enables VFPv3 and NEONv1 instructions with 32 double-word
+@item @code{+vfpv4-d16}: Enables VFPv4 instructions with 16 double-word registers.
+@item @code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
+@item @code{+simd}: Enables VFPv3 and NEONv1 instructions with 32 double-word
registers.
-@item@code{+neon}: Alias for @code{+simd}.
-@item@code{+neon-vfpv3}: Alias for @code{+simd}.
-@item@code{+neon-fp16}: Enables VFPv3, half precision floating-point conversion and
+@item @code{+neon}: Alias for @code{+simd}.
+@item @code{+neon-vfpv3}: Alias for @code{+simd}.
+@item @code{+neon-fp16}: Enables VFPv3, half precision floating-point conversion and
NEONv1 instructions with 32 double-word registers.
-@item@code{+neon-vfpv4}: Enables VFPv4 and NEONv1 with Fused-MAC instructions and 32
+@item @code{+neon-vfpv4}: Enables VFPv4 and NEONv1 with Fused-MAC instructions and 32
double-word registers.
-@item@code{+mp}: Enables Multiprocessing Extensions.
-@item@code{+sec}: Enables Security Extensions.
-@item@code{+nofp}: Disables all FPU and NEON instructions.
-@item@code{+nosimd}: Disables all NEON instructions.
+@item @code{+mp}: Enables Multiprocessing Extensions.
+@item @code{+sec}: Enables Security Extensions.
+@item @code{+nofp}: Disables all FPU and NEON instructions.
+@item @code{+nosimd}: Disables all NEON instructions.
@end itemize
For @code{armv7ve}:
@itemize @w{}
-@item@code{+fp}: Enables VFPv4 instructions with 16 double-word registers.
-@item@code{+vfpv4-d16}: Alias for @code{+fp}.
-@item@code{+vfpv3-d16}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
-@item@code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision floating-point
+@item @code{+fp}: Enables VFPv4 instructions with 16 double-word registers.
+@item @code{+vfpv4-d16}: Alias for @code{+fp}.
+@item @code{+vfpv3-d16}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+vfpv3}: Enables VFPv3 instructions with 32 double-word registers.
+@item @code{+vfpv3-d16-fp16}: Enables VFPv3 with half precision floating-point
conversion instructions and 16 double-word registers.
-@item@code{+vfpv3-fp16}: Enables VFPv3 with half precision floating-point conversion
+@item @code{+vfpv3-fp16}: Enables VFPv3 with half precision floating-point conversion
instructions and 32 double-word registers.
-@item@code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
-@item@code{+simd}: Enables VFPv4 and NEONv1 with Fused-MAC instructions and 32
+@item @code{+vfpv4}: Enables VFPv4 instructions with 32 double-word registers.
+@item @code{+simd}: Enables VFPv4 and NEONv1 with Fused-MAC instructions and 32
double-word registers.
-@item@code{+neon-vfpv4}: Alias for @code{+simd}.
-@item@code{+neon}: Enables VFPv3 and NEONv1 instructions with 32 double-word
+@item @code{+neon-vfpv4}: Alias for @code{+simd}.
+@item @code{+neon}: Enables VFPv3 and NEONv1 instructions with 32 double-word
registers.
-@item@code{+neon-vfpv3}: Alias for @code{+neon}.
-@item@code{+neon-fp16}: Enables VFPv3, half precision floating-point conversion and
+@item @code{+neon-vfpv3}: Alias for @code{+neon}.
+@item @code{+neon-fp16}: Enables VFPv3, half precision floating-point conversion and
NEONv1 instructions with 32 double-word registers.
double-word registers.
-@item@code{+nofp}: Disables all FPU and NEON instructions.
-@item@code{+nosimd}: Disables all NEON instructions.
+@item @code{+nofp}: Disables all FPU and NEON instructions.
+@item @code{+nosimd}: Disables all NEON instructions.
@end itemize
For @code{armv7-r}:
@itemize @w{}
-@item@code{+fp.sp}: Enables single-precision only VFPv3 instructions with 16
+@item @code{+fp.sp}: Enables single-precision only VFPv3 instructions with 16
double-word registers.
-@item@code{+vfpv3xd}: Alias for @code{+fp.sp}.
-@item@code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
-@item@code{+vfpv3-d16}: Alias for @code{+fp}.
-@item@code{+vfpv3xd-fp16}: Enables single-precision only VFPv3 and half
+@item @code{+vfpv3xd}: Alias for @code{+fp.sp}.
+@item @code{+fp}: Enables VFPv3 instructions with 16 double-word registers.
+@item @code{+vfpv3-d16}: Alias for @code{+fp}.
+@item @code{+vfpv3xd-fp16}: Enables single-precision only VFPv3 and half
floating-point conversion instructions with 16 double-word registers.
-@item@code{+vfpv3-d16-fp16}: Enables VFPv3 and half precision floating-point
+@item @code{+vfpv3-d16-fp16}: Enables VFPv3 and half precision floating-point
conversion instructions with 16 double-word registers.
-@item@code{+idiv}: Enables integer division instructions in ARM mode.
-@item@code{+nofp}: Disables all FPU instructions.
+@item @code{+idiv}: Enables integer division instructions in ARM mode.
+@item @code{+nofp}: Disables all FPU instructions.
@end itemize
For @code{armv7e-m}:
@itemize @w{}
-@item@code{+fp}: Enables single-precision only VFPv4 instructions with 16
+@item @code{+fp}: Enables single-precision only VFPv4 instructions with 16
double-word registers.
-@item@code{+vfpvf4-sp-d16}: Alias for @code{+fp}.
-@item@code{+fpv5}: Enables single-precision only VFPv5 instructions with 16
+@item @code{+vfpvf4-sp-d16}: Alias for @code{+fp}.
+@item @code{+fpv5}: Enables single-precision only VFPv5 instructions with 16
double-word registers.
-@item@code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
-@item@code{+fpv5-d16"}: Alias for @code{+fp.dp}.
-@item@code{+nofp}: Disables all FPU instructions.
+@item @code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
+@item @code{+fpv5-d16"}: Alias for @code{+fp.dp}.
+@item @code{+nofp}: Disables all FPU instructions.
@end itemize
For @code{armv8-m.main}:
@itemize @w{}
-@item@code{+dsp}: Enables DSP Extension.
-@item@code{+fp}: Enables single-precision only VFPv5 instructions with 16
+@item @code{+dsp}: Enables DSP Extension.
+@item @code{+fp}: Enables single-precision only VFPv5 instructions with 16
double-word registers.
-@item@code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
-@item@code{+cdecp0} (CDE extensions for v8-m architecture with coprocessor 0),
-@item@code{+cdecp1} (CDE extensions for v8-m architecture with coprocessor 1),
-@item@code{+cdecp2} (CDE extensions for v8-m architecture with coprocessor 2),
-@item@code{+cdecp3} (CDE extensions for v8-m architecture with coprocessor 3),
-@item@code{+cdecp4} (CDE extensions for v8-m architecture with coprocessor 4),
-@item@code{+cdecp5} (CDE extensions for v8-m architecture with coprocessor 5),
-@item@code{+cdecp6} (CDE extensions for v8-m architecture with coprocessor 6),
-@item@code{+cdecp7} (CDE extensions for v8-m architecture with coprocessor 7),
-@item@code{+nofp}: Disables all FPU instructions.
-@item@code{+nodsp}: Disables DSP Extension.
+@item @code{+fp.dp}: Enables VFPv5 instructions with 16 double-word registers.
+@item @code{+cdecp0} (CDE extensions for v8-m architecture with coprocessor 0),
+@item @code{+cdecp1} (CDE extensions for v8-m architecture with coprocessor 1),
+@item @code{+cdecp2} (CDE extensions for v8-m architecture with coprocessor 2),
+@item @code{+cdecp3} (CDE extensions for v8-m architecture with coprocessor 3),
+@item @code{+cdecp4} (CDE extensions for v8-m architecture with coprocessor 4),
+@item @code{+cdecp5} (CDE extensions for v8-m architecture with coprocessor 5),
+@item @code{+cdecp6} (CDE extensions for v8-m architecture with coprocessor 6),
+@item @code{+cdecp7} (CDE extensions for v8-m architecture with coprocessor 7),
+@item @code{+nofp}: Disables all FPU instructions.
+@item @code{+nodsp}: Disables DSP Extension.
@end itemize
For @code{armv8.1-m.main}:
@itemize @w{}
-@item@code{+dsp}: Enables DSP Extension.
-@item@code{+fp}: Enables single and half precision scalar Floating Point Extensions
+@item @code{+dsp}: Enables DSP Extension.
+@item @code{+fp}: Enables single and half precision scalar Floating Point Extensions
for Armv8.1-M Mainline with 16 double-word registers.
-@item@code{+fp.dp}: Enables double precision scalar Floating Point Extensions for
+@item @code{+fp.dp}: Enables double precision scalar Floating Point Extensions for
Armv8.1-M Mainline, implies @code{+fp}.
-@item@code{+mve}: Enables integer only M-profile Vector Extension for
+@item @code{+mve}: Enables integer only M-profile Vector Extension for
Armv8.1-M Mainline, implies @code{+dsp}.
-@item@code{+mve.fp}: Enables Floating Point M-profile Vector Extension for
+@item @code{+mve.fp}: Enables Floating Point M-profile Vector Extension for
Armv8.1-M Mainline, implies @code{+mve} and @code{+fp}.
-@item@code{+nofp}: Disables all FPU instructions.
-@item@code{+nodsp}: Disables DSP Extension.
-@item@code{+nomve}: Disables all M-profile Vector Extensions.
+@item @code{+nofp}: Disables all FPU instructions.
+@item @code{+nodsp}: Disables DSP Extension.
+@item @code{+nomve}: Disables all M-profile Vector Extensions.
@end itemize
For @code{armv8-a}:
@itemize @w{}
-@item@code{+crc}: Enables CRC32 Extension.
-@item@code{+simd}: Enables VFP and NEON for Armv8-A.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+crc}: Enables CRC32 Extension.
+@item @code{+simd}: Enables VFP and NEON for Armv8-A.
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
-@item@code{+nocrypto}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
+@item @code{+nocrypto}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.1-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A.
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
-@item@code{+nocrypto}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON and Cryptography Extensions.
+@item @code{+nocrypto}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.2-a} and @code{armv8.3-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A.
-@item@code{+fp16}: Enables FP16 Extension for Armv8.2-A, implies @code{+simd}.
-@item@code{+fp16fml}: Enables FP16 Floating Point Multiplication Variant Extensions
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A.
+@item @code{+fp16}: Enables FP16 Extension for Armv8.2-A, implies @code{+simd}.
+@item @code{+fp16fml}: Enables FP16 Floating Point Multiplication Variant Extensions
for Armv8.2-A, implies @code{+fp16}.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+dotprod}: Enables Dot Product Extensions for Armv8.2-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+dotprod}: Enables Dot Product Extensions for Armv8.2-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
-@item@code{+nocrypto}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
+@item @code{+nocrypto}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.4-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product Extensions for
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product Extensions for
Armv8.2-A.
-@item@code{+fp16}: Enables FP16 Floating Point and Floating Point Multiplication
+@item @code{+fp16}: Enables FP16 Floating Point and Floating Point Multiplication
Variant Extensions for Armv8.2-A, implies @code{+simd}.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
-@item@code{+predres}: Enables Execution and Data Prediction Restriction Instruction
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+sb}: Enables Speculation Barrier Instruction for Armv8-A.
+@item @code{+predres}: Enables Execution and Data Prediction Restriction Instruction
for Armv8-A.
-@item@code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
-@item@code{+nocryptp}: Disables Cryptography Extensions.
+@item @code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
+@item @code{+nocryptp}: Disables Cryptography Extensions.
@end itemize
For @code{armv8.5-a}:
@itemize @w{}
-@item@code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product Extensions for
+@item @code{+simd}: Enables VFP and NEON for Armv8.1-A and Dot Product Extensions for
Armv8.2-A.
-@item@code{+fp16}: Enables FP16 Floating Point and Floating Point Multiplication
+@item @code{+fp16}: Enables FP16 Floating Point and Floating Point Multiplication
Variant Extensions for Armv8.2-A, implies @code{+simd}.
-@item@code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
-@item@code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
-@item@code{+nocryptp}: Disables Cryptography Extensions.
+@item @code{+crypto}: Enables Cryptography Extensions for Armv8-A, implies @code{+simd}.
+@item @code{+nofp}: Disables all FPU, NEON, Cryptography and Dot Product Extensions.
+@item @code{+nocryptp}: Disables Cryptography Extensions.
@end itemize
@cindex @code{-mfpu=} command-line option, ARM