2018-02-19 21:28:12 +01:00
|
|
|
#
|
|
|
|
# OpenRISC instruction decode definitions.
|
|
|
|
#
|
|
|
|
# Copyright (c) 2018 Richard Henderson <rth@twiddle.net>
|
|
|
|
#
|
|
|
|
# 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
|
|
|
|
# version 2 of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# 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/>.
|
|
|
|
#
|
|
|
|
|
|
|
|
####
|
|
|
|
# System Instructions
|
|
|
|
####
|
|
|
|
|
|
|
|
l_sys 001000 0000000000 k:16
|
|
|
|
l_trap 001000 0100000000 k:16
|
|
|
|
l_msync 001000 1000000000 00000000 00000000
|
|
|
|
l_psync 001000 1010000000 00000000 00000000
|
|
|
|
l_csync 001000 1100000000 00000000 00000000
|
2018-02-19 21:52:43 +01:00
|
|
|
|
|
|
|
####
|
|
|
|
# Branch Instructions
|
|
|
|
####
|
|
|
|
|
|
|
|
l_j 000000 n:s26
|
|
|
|
l_jal 000001 n:s26
|
|
|
|
l_bnf 000011 n:s26
|
|
|
|
l_bf 000100 n:s26
|
|
|
|
|
|
|
|
l_jr 010001 ---------- b:5 -----------
|
|
|
|
l_jalr 010010 ---------- b:5 -----------
|
2018-02-20 17:21:12 +01:00
|
|
|
|
|
|
|
####
|
|
|
|
# Memory Instructions
|
|
|
|
####
|
|
|
|
|
|
|
|
&load d a i
|
|
|
|
@load ...... d:5 a:5 i:s16 &load
|
|
|
|
|
|
|
|
%store_i 21:s5 0:11
|
|
|
|
&store a b i
|
|
|
|
@store ...... ..... a:5 b:5 ........... &store i=%store_i
|
|
|
|
|
|
|
|
l_lwa 011011 ..... ..... ........ ........ @load
|
|
|
|
l_lwz 100001 ..... ..... ........ ........ @load
|
|
|
|
l_lws 100010 ..... ..... ........ ........ @load
|
|
|
|
l_lbz 100011 ..... ..... ........ ........ @load
|
|
|
|
l_lbs 100100 ..... ..... ........ ........ @load
|
|
|
|
l_lhz 100101 ..... ..... ........ ........ @load
|
|
|
|
l_lhs 100110 ..... ..... ........ ........ @load
|
|
|
|
|
|
|
|
l_swa 110011 ..... ..... ........ ........ @store
|
|
|
|
l_sw 110101 ..... ..... ........ ........ @store
|
|
|
|
l_sb 110110 ..... ..... ........ ........ @store
|
|
|
|
l_sh 110111 ..... ..... ........ ........ @store
|