2019-09-04 22:29:52 +03:00
|
|
|
# A32 unconditional instructions
|
|
|
|
#
|
|
|
|
# Copyright (c) 2019 Linaro, Ltd
|
|
|
|
#
|
|
|
|
# This library is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
|
|
# License as published by the Free Software Foundation; either
|
2020-10-23 15:29:13 +03:00
|
|
|
# version 2.1 of the License, or (at your option) any later version.
|
2019-09-04 22:29:52 +03:00
|
|
|
#
|
|
|
|
# This library is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
# Lesser General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
|
|
# License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
#
|
|
|
|
# This file is processed by scripts/decodetree.py
|
|
|
|
#
|
|
|
|
# All insns that have 0xf in insn[31:28] are decoded here.
|
|
|
|
# All of those that have a COND field in insn[31:28] are in a32.decode
|
|
|
|
#
|
2019-09-04 22:30:22 +03:00
|
|
|
|
2019-09-04 22:30:25 +03:00
|
|
|
&empty !extern
|
2019-09-04 22:30:22 +03:00
|
|
|
&i !extern imm
|
2019-09-04 22:30:27 +03:00
|
|
|
&setend E
|
2019-09-04 22:30:22 +03:00
|
|
|
|
|
|
|
# Branch with Link and Exchange
|
|
|
|
|
|
|
|
%imm24h 0:s24 24:1 !function=times_2
|
|
|
|
|
|
|
|
BLX_i 1111 101 . ........................ &i imm=%imm24h
|
2019-09-04 22:30:24 +03:00
|
|
|
|
|
|
|
# System Instructions
|
|
|
|
|
|
|
|
&rfe rn w pu
|
|
|
|
&srs mode w pu
|
2019-09-04 22:30:26 +03:00
|
|
|
&cps mode imod M A I F
|
2019-09-04 22:30:24 +03:00
|
|
|
|
|
|
|
RFE 1111 100 pu:2 0 w:1 1 rn:4 0000 1010 0000 0000 &rfe
|
|
|
|
SRS 1111 100 pu:2 1 w:1 0 1101 0000 0101 000 mode:5 &srs
|
2019-09-04 22:30:26 +03:00
|
|
|
CPS 1111 0001 0000 imod:2 M:1 0 0000 000 A:1 I:1 F:1 0 mode:5 \
|
|
|
|
&cps
|
2019-09-04 22:30:25 +03:00
|
|
|
|
|
|
|
# Clear-Exclusive, Barriers
|
|
|
|
|
|
|
|
# QEMU does not require the option field for the barriers.
|
|
|
|
CLREX 1111 0101 0111 1111 1111 0000 0001 1111
|
|
|
|
DSB 1111 0101 0111 1111 1111 0000 0100 ----
|
|
|
|
DMB 1111 0101 0111 1111 1111 0000 0101 ----
|
|
|
|
ISB 1111 0101 0111 1111 1111 0000 0110 ----
|
|
|
|
SB 1111 0101 0111 1111 1111 0000 0111 0000
|
2019-09-04 22:30:27 +03:00
|
|
|
|
|
|
|
# Set Endianness
|
|
|
|
SETEND 1111 0001 0000 0001 0000 00 E:1 0 0000 0000 &setend
|
2019-09-04 22:30:28 +03:00
|
|
|
|
|
|
|
# Preload instructions
|
|
|
|
|
|
|
|
PLD 1111 0101 -101 ---- 1111 ---- ---- ---- # (imm, lit) 5te
|
|
|
|
PLDW 1111 0101 -001 ---- 1111 ---- ---- ---- # (imm, lit) 7mp
|
|
|
|
PLI 1111 0100 -101 ---- 1111 ---- ---- ---- # (imm, lit) 7
|
|
|
|
|
|
|
|
PLD 1111 0111 -101 ---- 1111 ----- -- 0 ---- # (register) 5te
|
|
|
|
PLDW 1111 0111 -001 ---- 1111 ----- -- 0 ---- # (register) 7mp
|
|
|
|
PLI 1111 0110 -101 ---- 1111 ----- -- 0 ---- # (register) 7
|
2019-09-04 22:30:29 +03:00
|
|
|
|
|
|
|
# Unallocated memory hints
|
|
|
|
#
|
|
|
|
# Since these are v7MP nops, and PLDW is v7MP and implemented as nop,
|
|
|
|
# (ab)use the PLDW helper.
|
|
|
|
|
|
|
|
PLDW 1111 0100 -001 ---- ---- ---- ---- ----
|
|
|
|
PLDW 1111 0110 -001 ---- ---- ---- ---0 ----
|