mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 10:43:43 +00:00
bpf, docs: Clarify that MOVSX is only for BPF_X not BPF_K
Per discussion on the mailing list at https://mailarchive.ietf.org/arch/msg/bpf/uQiqhURdtxV_ZQOTgjCdm-seh74/ the MOVSX operation is only defined to support register extension. The document didn't previously state this and incorrectly implied that one could use an immediate value. Signed-off-by: Dave Thaler <dthaler1968@gmail.com> Acked-by: David Vernet <void@manifault.com> Acked-by: Yonghong Song <yonghong.song@linux.dev> Link: https://lore.kernel.org/r/20240118232954.27206-1-dthaler1968@gmail.com Signed-off-by: Alexei Starovoitov <ast@kernel.org>
This commit is contained in:
parent
b3f086a7a1
commit
20e109ea98
@ -317,7 +317,8 @@ The ``BPF_MOVSX`` instruction does a move operation with sign extension.
|
|||||||
``BPF_ALU | BPF_MOVSX`` :term:`sign extends<Sign Extend>` 8-bit and 16-bit operands into 32
|
``BPF_ALU | BPF_MOVSX`` :term:`sign extends<Sign Extend>` 8-bit and 16-bit operands into 32
|
||||||
bit operands, and zeroes the remaining upper 32 bits.
|
bit operands, and zeroes the remaining upper 32 bits.
|
||||||
``BPF_ALU64 | BPF_MOVSX`` :term:`sign extends<Sign Extend>` 8-bit, 16-bit, and 32-bit
|
``BPF_ALU64 | BPF_MOVSX`` :term:`sign extends<Sign Extend>` 8-bit, 16-bit, and 32-bit
|
||||||
operands into 64 bit operands.
|
operands into 64 bit operands. Unlike other arithmetic instructions,
|
||||||
|
``BPF_MOVSX`` is only defined for register source operands (``BPF_X``).
|
||||||
|
|
||||||
Shift operations use a mask of 0x3F (63) for 64-bit operations and 0x1F (31)
|
Shift operations use a mask of 0x3F (63) for 64-bit operations and 0x1F (31)
|
||||||
for 32-bit operations.
|
for 32-bit operations.
|
||||||
|
Loading…
Reference in New Issue
Block a user