target/arm: Implement FPSCR.LTPSIZE for M-profile LOB extension
commit8128c8e8cc9489a8387c74075974f86dc0222e7f
authorPeter Maydell <peter.maydell@linaro.org>
Mon, 19 Oct 2020 15:13:01 +0000 (19 16:13 +0100)
committerPeter Maydell <peter.maydell@linaro.org>
Tue, 20 Oct 2020 15:12:01 +0000 (20 16:12 +0100)
tree573940f3a8b5ad0e08ea71d2f210f776b7620909
parentd31e2ce68d56f5bcc83831497e5fe4b8a7e18e85
target/arm: Implement FPSCR.LTPSIZE for M-profile LOB extension

If the M-profile low-overhead-branch extension is implemented, FPSCR
bits [18:16] are a new field LTPSIZE.  If MVE is not implemented
(currently always true for us) then this field always reads as 4 and
ignores writes.

These bits used to be the vector-length field for the old
short-vector extension, so we need to take care that they are not
misinterpreted as setting vec_len. We do this with a rearrangement
of the vfp_set_fpscr() code that deals with vec_len, vec_stride
and also the QC bit; this obviates the need for the M-profile
only masking step that we used to have at the start of the function.

We provide a new field in CPUState for LTPSIZE, even though this
will always be 4, in preparation for MVE, so we don't have to
come back later and split it out of the vfp.xregs[FPSCR] value.
(This state struct field will be saved and restored as part of
the FPSCR value via the vmstate_fpscr in machine.c.)

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20201019151301.2046-11-peter.maydell@linaro.org
target/arm/cpu.c
target/arm/cpu.h
target/arm/vfp_helper.c