Updates to decodetree.py for risc-v.
-----BEGIN PGP SIGNATURE----- iQEcBAABAgAGBQJb2d23AAoJEGTfOOivfiFfNcoH/1cc/fSj7O9TkaWi1SPSDuDh FzO19HHjM0ZqdUc5tRg47YKDaYpMsE1+py73YW81P5vyp8KXqGohRii8l2SoGHXX uUMgXnoSg+i2G5YFzLYMlEuTS73FP2/sD+9bXcDrdJ7c2+/qiYN2KfmWWUAIxQSw WX6BRDhBSq+GGJfhKsIf8QVNtsOs7TnGfDisWMh6t0BLKho3Fqx6XwMTltfKZbEq xLcw3FK4EpP9gQxl2GViK/YS2wo7HRC4zvugLIjRnFUusU7o4/Hpo6tUK+N6lgZd ZTULcWWrNuMTEs1YkpdNpEqcSrq7Gh6WCnJStPzxL3CTXunIdwM2VlbyvjOU+n0= =snc9 -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/rth/tags/pull-dt-20181031' into staging Updates to decodetree.py for risc-v. # gpg: Signature made Wed 31 Oct 2018 16:52:07 GMT # gpg: using RSA key 64DF38E8AF7E215F # gpg: Good signature from "Richard Henderson <richard.henderson@linaro.org>" # Primary key fingerprint: 7A48 1E78 868B 4DB6 A85A 05C0 64DF 38E8 AF7E 215F * remotes/rth/tags/pull-dt-20181031: decodetree: Allow multiple input files decodetree: Remove "insn" argument from trans_* expanders decodetree: Add !extern flag to argument sets Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
ef30274865
@ -63,13 +63,16 @@
|
|||||||
#
|
#
|
||||||
# *** Argument set syntax:
|
# *** Argument set syntax:
|
||||||
#
|
#
|
||||||
# args_def := '&' identifier ( args_elt )+
|
# args_def := '&' identifier ( args_elt )+ ( !extern )?
|
||||||
# args_elt := identifier
|
# args_elt := identifier
|
||||||
#
|
#
|
||||||
# Each args_elt defines an argument within the argument set.
|
# Each args_elt defines an argument within the argument set.
|
||||||
# Each argument set will be rendered as a C structure "arg_$name"
|
# Each argument set will be rendered as a C structure "arg_$name"
|
||||||
# with each of the fields being one of the member arguments.
|
# with each of the fields being one of the member arguments.
|
||||||
#
|
#
|
||||||
|
# If !extern is specified, the backing structure is assumed to
|
||||||
|
# have been already declared, typically via a second decoder.
|
||||||
|
#
|
||||||
# Argument set examples:
|
# Argument set examples:
|
||||||
#
|
#
|
||||||
# ®3 ra rb rc
|
# ®3 ra rb rc
|
||||||
@ -167,19 +170,20 @@ input_file = ''
|
|||||||
output_file = None
|
output_file = None
|
||||||
output_fd = None
|
output_fd = None
|
||||||
insntype = 'uint32_t'
|
insntype = 'uint32_t'
|
||||||
|
decode_function = 'decode'
|
||||||
|
|
||||||
re_ident = '[a-zA-Z][a-zA-Z0-9_]*'
|
re_ident = '[a-zA-Z][a-zA-Z0-9_]*'
|
||||||
|
|
||||||
|
|
||||||
def error(lineno, *args):
|
def error_with_file(file, lineno, *args):
|
||||||
"""Print an error message from file:line and args and exit."""
|
"""Print an error message from file:line and args and exit."""
|
||||||
global output_file
|
global output_file
|
||||||
global output_fd
|
global output_fd
|
||||||
|
|
||||||
if lineno:
|
if lineno:
|
||||||
r = '{0}:{1}: error:'.format(input_file, lineno)
|
r = '{0}:{1}: error:'.format(file, lineno)
|
||||||
elif input_file:
|
elif input_file:
|
||||||
r = '{0}: error:'.format(input_file)
|
r = '{0}: error:'.format(file)
|
||||||
else:
|
else:
|
||||||
r = 'error:'
|
r = 'error:'
|
||||||
for a in args:
|
for a in args:
|
||||||
@ -191,6 +195,8 @@ def error(lineno, *args):
|
|||||||
os.remove(output_file)
|
os.remove(output_file)
|
||||||
exit(1)
|
exit(1)
|
||||||
|
|
||||||
|
def error(lineno, *args):
|
||||||
|
error_with_file(input_file, lineno, args)
|
||||||
|
|
||||||
def output(*args):
|
def output(*args):
|
||||||
global output_fd
|
global output_fd
|
||||||
@ -392,8 +398,9 @@ class FunctionField:
|
|||||||
|
|
||||||
class Arguments:
|
class Arguments:
|
||||||
"""Class representing the extracted fields of a format"""
|
"""Class representing the extracted fields of a format"""
|
||||||
def __init__(self, nm, flds):
|
def __init__(self, nm, flds, extern):
|
||||||
self.name = nm
|
self.name = nm
|
||||||
|
self.extern = extern
|
||||||
self.fields = sorted(flds)
|
self.fields = sorted(flds)
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
@ -403,10 +410,11 @@ class Arguments:
|
|||||||
return 'arg_' + self.name
|
return 'arg_' + self.name
|
||||||
|
|
||||||
def output_def(self):
|
def output_def(self):
|
||||||
output('typedef struct {\n')
|
if not self.extern:
|
||||||
for n in self.fields:
|
output('typedef struct {\n')
|
||||||
output(' int ', n, ';\n')
|
for n in self.fields:
|
||||||
output('} ', self.struct_name(), ';\n\n')
|
output(' int ', n, ';\n')
|
||||||
|
output('} ', self.struct_name(), ';\n\n')
|
||||||
# end Arguments
|
# end Arguments
|
||||||
|
|
||||||
|
|
||||||
@ -414,6 +422,7 @@ class General:
|
|||||||
"""Common code between instruction formats and instruction patterns"""
|
"""Common code between instruction formats and instruction patterns"""
|
||||||
def __init__(self, name, lineno, base, fixb, fixm, udfm, fldm, flds):
|
def __init__(self, name, lineno, base, fixb, fixm, udfm, fldm, flds):
|
||||||
self.name = name
|
self.name = name
|
||||||
|
self.file = input_file
|
||||||
self.lineno = lineno
|
self.lineno = lineno
|
||||||
self.base = base
|
self.base = base
|
||||||
self.fixedbits = fixb
|
self.fixedbits = fixb
|
||||||
@ -460,20 +469,19 @@ class Pattern(General):
|
|||||||
output('typedef ', self.base.base.struct_name(),
|
output('typedef ', self.base.base.struct_name(),
|
||||||
' arg_', self.name, ';\n')
|
' arg_', self.name, ';\n')
|
||||||
output(translate_scope, 'bool ', translate_prefix, '_', self.name,
|
output(translate_scope, 'bool ', translate_prefix, '_', self.name,
|
||||||
'(DisasContext *ctx, arg_', self.name,
|
'(DisasContext *ctx, arg_', self.name, ' *a);\n')
|
||||||
' *a, ', insntype, ' insn);\n')
|
|
||||||
|
|
||||||
def output_code(self, i, extracted, outerbits, outermask):
|
def output_code(self, i, extracted, outerbits, outermask):
|
||||||
global translate_prefix
|
global translate_prefix
|
||||||
ind = str_indent(i)
|
ind = str_indent(i)
|
||||||
arg = self.base.base.name
|
arg = self.base.base.name
|
||||||
output(ind, '/* line ', str(self.lineno), ' */\n')
|
output(ind, '/* ', self.file, ':', str(self.lineno), ' */\n')
|
||||||
if not extracted:
|
if not extracted:
|
||||||
output(ind, self.base.extract_name(), '(&u.f_', arg, ', insn);\n')
|
output(ind, self.base.extract_name(), '(&u.f_', arg, ', insn);\n')
|
||||||
for n, f in self.fields.items():
|
for n, f in self.fields.items():
|
||||||
output(ind, 'u.f_', arg, '.', n, ' = ', f.str_extract(), ';\n')
|
output(ind, 'u.f_', arg, '.', n, ' = ', f.str_extract(), ';\n')
|
||||||
output(ind, 'return ', translate_prefix, '_', self.name,
|
output(ind, 'return ', translate_prefix, '_', self.name,
|
||||||
'(ctx, &u.f_', arg, ', insn);\n')
|
'(ctx, &u.f_', arg, ');\n')
|
||||||
# end Pattern
|
# end Pattern
|
||||||
|
|
||||||
|
|
||||||
@ -540,7 +548,11 @@ def parse_arguments(lineno, name, toks):
|
|||||||
global re_ident
|
global re_ident
|
||||||
|
|
||||||
flds = []
|
flds = []
|
||||||
|
extern = False
|
||||||
for t in toks:
|
for t in toks:
|
||||||
|
if re_fullmatch('!extern', t):
|
||||||
|
extern = True
|
||||||
|
continue
|
||||||
if not re_fullmatch(re_ident, t):
|
if not re_fullmatch(re_ident, t):
|
||||||
error(lineno, 'invalid argument set token "{0}"'.format(t))
|
error(lineno, 'invalid argument set token "{0}"'.format(t))
|
||||||
if t in flds:
|
if t in flds:
|
||||||
@ -549,7 +561,7 @@ def parse_arguments(lineno, name, toks):
|
|||||||
|
|
||||||
if name in arguments:
|
if name in arguments:
|
||||||
error(lineno, 'duplicate argument set', name)
|
error(lineno, 'duplicate argument set', name)
|
||||||
arguments[name] = Arguments(name, flds)
|
arguments[name] = Arguments(name, flds, extern)
|
||||||
# end parse_arguments
|
# end parse_arguments
|
||||||
|
|
||||||
|
|
||||||
@ -573,13 +585,14 @@ def add_field_byname(lineno, flds, new_name, old_name):
|
|||||||
|
|
||||||
def infer_argument_set(flds):
|
def infer_argument_set(flds):
|
||||||
global arguments
|
global arguments
|
||||||
|
global decode_function
|
||||||
|
|
||||||
for arg in arguments.values():
|
for arg in arguments.values():
|
||||||
if eq_fields_for_args(flds, arg.fields):
|
if eq_fields_for_args(flds, arg.fields):
|
||||||
return arg
|
return arg
|
||||||
|
|
||||||
name = str(len(arguments))
|
name = decode_function + str(len(arguments))
|
||||||
arg = Arguments(name, flds.keys())
|
arg = Arguments(name, flds.keys(), False)
|
||||||
arguments[name] = arg
|
arguments[name] = arg
|
||||||
return arg
|
return arg
|
||||||
|
|
||||||
@ -587,6 +600,7 @@ def infer_argument_set(flds):
|
|||||||
def infer_format(arg, fieldmask, flds):
|
def infer_format(arg, fieldmask, flds):
|
||||||
global arguments
|
global arguments
|
||||||
global formats
|
global formats
|
||||||
|
global decode_function
|
||||||
|
|
||||||
const_flds = {}
|
const_flds = {}
|
||||||
var_flds = {}
|
var_flds = {}
|
||||||
@ -606,7 +620,7 @@ def infer_format(arg, fieldmask, flds):
|
|||||||
continue
|
continue
|
||||||
return (fmt, const_flds)
|
return (fmt, const_flds)
|
||||||
|
|
||||||
name = 'Fmt_' + str(len(formats))
|
name = decode_function + '_Fmt_' + str(len(formats))
|
||||||
if not arg:
|
if not arg:
|
||||||
arg = infer_argument_set(flds)
|
arg = infer_argument_set(flds)
|
||||||
|
|
||||||
@ -909,8 +923,9 @@ def build_tree(pats, outerbits, outermask):
|
|||||||
if innermask == 0:
|
if innermask == 0:
|
||||||
pnames = []
|
pnames = []
|
||||||
for p in pats:
|
for p in pats:
|
||||||
pnames.append(p.name + ':' + str(p.lineno))
|
pnames.append(p.name + ':' + p.file + ':' + str(p.lineno))
|
||||||
error(pats[0].lineno, 'overlapping patterns:', pnames)
|
error_with_file(pats[0].file, pats[0].lineno,
|
||||||
|
'overlapping patterns:', pnames)
|
||||||
|
|
||||||
fullmask = outermask | innermask
|
fullmask = outermask | innermask
|
||||||
|
|
||||||
@ -971,8 +986,8 @@ def main():
|
|||||||
global insnwidth
|
global insnwidth
|
||||||
global insntype
|
global insntype
|
||||||
global insnmask
|
global insnmask
|
||||||
|
global decode_function
|
||||||
|
|
||||||
decode_function = 'decode'
|
|
||||||
decode_scope = 'static '
|
decode_scope = 'static '
|
||||||
|
|
||||||
long_opts = ['decode=', 'translate=', 'output=', 'insnwidth=']
|
long_opts = ['decode=', 'translate=', 'output=', 'insnwidth=']
|
||||||
@ -1001,10 +1016,11 @@ def main():
|
|||||||
|
|
||||||
if len(args) < 1:
|
if len(args) < 1:
|
||||||
error(0, 'missing input file')
|
error(0, 'missing input file')
|
||||||
input_file = args[0]
|
for filename in args:
|
||||||
f = open(input_file, 'r')
|
input_file = filename
|
||||||
parse_file(f)
|
f = open(filename, 'r')
|
||||||
f.close()
|
parse_file(f)
|
||||||
|
f.close()
|
||||||
|
|
||||||
t = build_tree(patterns, 0, 0)
|
t = build_tree(patterns, 0, 0)
|
||||||
prop_format(t)
|
prop_format(t)
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -51,12 +51,11 @@ int print_insn_or1k(bfd_vma addr, disassemble_info *info)
|
|||||||
return 4;
|
return 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define INSN(opcode, format, ...) \
|
#define INSN(opcode, format, ...) \
|
||||||
static bool trans_l_##opcode(disassemble_info *info, \
|
static bool trans_l_##opcode(disassemble_info *info, arg_l_##opcode *a) \
|
||||||
arg_l_##opcode *a, uint32_t insn) \
|
{ \
|
||||||
{ \
|
output("l." #opcode, format, ##__VA_ARGS__); \
|
||||||
output("l." #opcode, format, ##__VA_ARGS__); \
|
return true; \
|
||||||
return true; \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
INSN(add, "r%d, r%d, r%d", a->d, a->a, a->b)
|
INSN(add, "r%d, r%d, r%d", a->d, a->a, a->b)
|
||||||
@ -146,12 +145,12 @@ INSN(psync, "")
|
|||||||
INSN(csync, "")
|
INSN(csync, "")
|
||||||
INSN(rfe, "")
|
INSN(rfe, "")
|
||||||
|
|
||||||
#define FP_INSN(opcode, suffix, format, ...) \
|
#define FP_INSN(opcode, suffix, format, ...) \
|
||||||
static bool trans_lf_##opcode##_##suffix(disassemble_info *info, \
|
static bool trans_lf_##opcode##_##suffix(disassemble_info *info, \
|
||||||
arg_lf_##opcode##_##suffix *a, uint32_t insn) \
|
arg_lf_##opcode##_##suffix *a) \
|
||||||
{ \
|
{ \
|
||||||
output("lf." #opcode "." #suffix, format, ##__VA_ARGS__); \
|
output("lf." #opcode "." #suffix, format, ##__VA_ARGS__); \
|
||||||
return true; \
|
return true; \
|
||||||
}
|
}
|
||||||
|
|
||||||
FP_INSN(add, s, "r%d, r%d, r%d", a->d, a->a, a->b)
|
FP_INSN(add, s, "r%d, r%d, r%d", a->d, a->a, a->b)
|
||||||
|
@ -434,105 +434,105 @@ static void gen_msbu(DisasContext *dc, TCGv srca, TCGv srcb)
|
|||||||
gen_ove_cy(dc);
|
gen_ove_cy(dc);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_add(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_add(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_add(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
gen_add(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_addc(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_addc(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_addc(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
gen_addc(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sub(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_sub(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_sub(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
gen_sub(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_and(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_and(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_and_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_and_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_or(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_or(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_or_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_or_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_xor(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_xor(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_xor_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_xor_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sll(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_sll(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_shl_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_shl_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_srl(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_srl(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_shr_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_shr_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sra(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_sra(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_sar_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_sar_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_ror(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_ror(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_rotr_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_rotr_tl(cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_exths(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_l_exths(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_ext16s_tl(cpu_R[a->d], cpu_R[a->a]);
|
tcg_gen_ext16s_tl(cpu_R[a->d], cpu_R[a->a]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_extbs(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_l_extbs(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_ext8s_tl(cpu_R[a->d], cpu_R[a->a]);
|
tcg_gen_ext8s_tl(cpu_R[a->d], cpu_R[a->a]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_exthz(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_l_exthz(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_ext16u_tl(cpu_R[a->d], cpu_R[a->a]);
|
tcg_gen_ext16u_tl(cpu_R[a->d], cpu_R[a->a]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_extbz(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_l_extbz(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_ext8u_tl(cpu_R[a->d], cpu_R[a->a]);
|
tcg_gen_ext8u_tl(cpu_R[a->d], cpu_R[a->a]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_cmov(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_cmov(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
TCGv zero;
|
TCGv zero;
|
||||||
|
|
||||||
@ -544,7 +544,7 @@ static bool trans_l_cmov(DisasContext *dc, arg_dab *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_ff1(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_l_ff1(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_ctzi_tl(cpu_R[a->d], cpu_R[a->a], -1);
|
tcg_gen_ctzi_tl(cpu_R[a->d], cpu_R[a->a], -1);
|
||||||
@ -552,7 +552,7 @@ static bool trans_l_ff1(DisasContext *dc, arg_da *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_fl1(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_l_fl1(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_clzi_tl(cpu_R[a->d], cpu_R[a->a], TARGET_LONG_BITS);
|
tcg_gen_clzi_tl(cpu_R[a->d], cpu_R[a->a], TARGET_LONG_BITS);
|
||||||
@ -560,47 +560,47 @@ static bool trans_l_fl1(DisasContext *dc, arg_da *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_mul(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_mul(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_mul(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
gen_mul(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_mulu(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_mulu(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_mulu(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
gen_mulu(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_div(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_div(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_div(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
gen_div(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_divu(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_l_divu(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_divu(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
gen_divu(dc, cpu_R[a->d], cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_muld(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_l_muld(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
gen_muld(dc, cpu_R[a->a], cpu_R[a->b]);
|
gen_muld(dc, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_muldu(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_l_muldu(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
gen_muldu(dc, cpu_R[a->a], cpu_R[a->b]);
|
gen_muldu(dc, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_j(DisasContext *dc, arg_l_j *a, uint32_t insn)
|
static bool trans_l_j(DisasContext *dc, arg_l_j *a)
|
||||||
{
|
{
|
||||||
target_ulong tmp_pc = dc->base.pc_next + a->n * 4;
|
target_ulong tmp_pc = dc->base.pc_next + a->n * 4;
|
||||||
|
|
||||||
@ -610,7 +610,7 @@ static bool trans_l_j(DisasContext *dc, arg_l_j *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_jal(DisasContext *dc, arg_l_jal *a, uint32_t insn)
|
static bool trans_l_jal(DisasContext *dc, arg_l_jal *a)
|
||||||
{
|
{
|
||||||
target_ulong tmp_pc = dc->base.pc_next + a->n * 4;
|
target_ulong tmp_pc = dc->base.pc_next + a->n * 4;
|
||||||
target_ulong ret_pc = dc->base.pc_next + 8;
|
target_ulong ret_pc = dc->base.pc_next + 8;
|
||||||
@ -640,26 +640,26 @@ static void do_bf(DisasContext *dc, arg_l_bf *a, TCGCond cond)
|
|||||||
dc->delayed_branch = 2;
|
dc->delayed_branch = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_bf(DisasContext *dc, arg_l_bf *a, uint32_t insn)
|
static bool trans_l_bf(DisasContext *dc, arg_l_bf *a)
|
||||||
{
|
{
|
||||||
do_bf(dc, a, TCG_COND_NE);
|
do_bf(dc, a, TCG_COND_NE);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_bnf(DisasContext *dc, arg_l_bf *a, uint32_t insn)
|
static bool trans_l_bnf(DisasContext *dc, arg_l_bf *a)
|
||||||
{
|
{
|
||||||
do_bf(dc, a, TCG_COND_EQ);
|
do_bf(dc, a, TCG_COND_EQ);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_jr(DisasContext *dc, arg_l_jr *a, uint32_t insn)
|
static bool trans_l_jr(DisasContext *dc, arg_l_jr *a)
|
||||||
{
|
{
|
||||||
tcg_gen_mov_tl(jmp_pc, cpu_R[a->b]);
|
tcg_gen_mov_tl(jmp_pc, cpu_R[a->b]);
|
||||||
dc->delayed_branch = 2;
|
dc->delayed_branch = 2;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_jalr(DisasContext *dc, arg_l_jalr *a, uint32_t insn)
|
static bool trans_l_jalr(DisasContext *dc, arg_l_jalr *a)
|
||||||
{
|
{
|
||||||
tcg_gen_mov_tl(jmp_pc, cpu_R[a->b]);
|
tcg_gen_mov_tl(jmp_pc, cpu_R[a->b]);
|
||||||
tcg_gen_movi_tl(cpu_R[9], dc->base.pc_next + 8);
|
tcg_gen_movi_tl(cpu_R[9], dc->base.pc_next + 8);
|
||||||
@ -667,7 +667,7 @@ static bool trans_l_jalr(DisasContext *dc, arg_l_jalr *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_lwa(DisasContext *dc, arg_load *a, uint32_t insn)
|
static bool trans_l_lwa(DisasContext *dc, arg_load *a)
|
||||||
{
|
{
|
||||||
TCGv ea;
|
TCGv ea;
|
||||||
|
|
||||||
@ -692,43 +692,43 @@ static void do_load(DisasContext *dc, arg_load *a, TCGMemOp mop)
|
|||||||
tcg_temp_free(ea);
|
tcg_temp_free(ea);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_lwz(DisasContext *dc, arg_load *a, uint32_t insn)
|
static bool trans_l_lwz(DisasContext *dc, arg_load *a)
|
||||||
{
|
{
|
||||||
do_load(dc, a, MO_TEUL);
|
do_load(dc, a, MO_TEUL);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_lws(DisasContext *dc, arg_load *a, uint32_t insn)
|
static bool trans_l_lws(DisasContext *dc, arg_load *a)
|
||||||
{
|
{
|
||||||
do_load(dc, a, MO_TESL);
|
do_load(dc, a, MO_TESL);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_lbz(DisasContext *dc, arg_load *a, uint32_t insn)
|
static bool trans_l_lbz(DisasContext *dc, arg_load *a)
|
||||||
{
|
{
|
||||||
do_load(dc, a, MO_UB);
|
do_load(dc, a, MO_UB);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_lbs(DisasContext *dc, arg_load *a, uint32_t insn)
|
static bool trans_l_lbs(DisasContext *dc, arg_load *a)
|
||||||
{
|
{
|
||||||
do_load(dc, a, MO_SB);
|
do_load(dc, a, MO_SB);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_lhz(DisasContext *dc, arg_load *a, uint32_t insn)
|
static bool trans_l_lhz(DisasContext *dc, arg_load *a)
|
||||||
{
|
{
|
||||||
do_load(dc, a, MO_TEUW);
|
do_load(dc, a, MO_TEUW);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_lhs(DisasContext *dc, arg_load *a, uint32_t insn)
|
static bool trans_l_lhs(DisasContext *dc, arg_load *a)
|
||||||
{
|
{
|
||||||
do_load(dc, a, MO_TESW);
|
do_load(dc, a, MO_TESW);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_swa(DisasContext *dc, arg_store *a, uint32_t insn)
|
static bool trans_l_swa(DisasContext *dc, arg_store *a)
|
||||||
{
|
{
|
||||||
TCGv ea, val;
|
TCGv ea, val;
|
||||||
TCGLabel *lab_fail, *lab_done;
|
TCGLabel *lab_fail, *lab_done;
|
||||||
@ -771,30 +771,30 @@ static void do_store(DisasContext *dc, arg_store *a, TCGMemOp mop)
|
|||||||
tcg_temp_free(t0);
|
tcg_temp_free(t0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sw(DisasContext *dc, arg_store *a, uint32_t insn)
|
static bool trans_l_sw(DisasContext *dc, arg_store *a)
|
||||||
{
|
{
|
||||||
do_store(dc, a, MO_TEUL);
|
do_store(dc, a, MO_TEUL);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sb(DisasContext *dc, arg_store *a, uint32_t insn)
|
static bool trans_l_sb(DisasContext *dc, arg_store *a)
|
||||||
{
|
{
|
||||||
do_store(dc, a, MO_UB);
|
do_store(dc, a, MO_UB);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sh(DisasContext *dc, arg_store *a, uint32_t insn)
|
static bool trans_l_sh(DisasContext *dc, arg_store *a)
|
||||||
{
|
{
|
||||||
do_store(dc, a, MO_TEUW);
|
do_store(dc, a, MO_TEUW);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_nop(DisasContext *dc, arg_l_nop *a, uint32_t insn)
|
static bool trans_l_nop(DisasContext *dc, arg_l_nop *a)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_addi(DisasContext *dc, arg_rri *a, uint32_t insn)
|
static bool trans_l_addi(DisasContext *dc, arg_rri *a)
|
||||||
{
|
{
|
||||||
TCGv t0;
|
TCGv t0;
|
||||||
|
|
||||||
@ -805,7 +805,7 @@ static bool trans_l_addi(DisasContext *dc, arg_rri *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_addic(DisasContext *dc, arg_rri *a, uint32_t insn)
|
static bool trans_l_addic(DisasContext *dc, arg_rri *a)
|
||||||
{
|
{
|
||||||
TCGv t0;
|
TCGv t0;
|
||||||
|
|
||||||
@ -816,7 +816,7 @@ static bool trans_l_addic(DisasContext *dc, arg_rri *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_muli(DisasContext *dc, arg_rri *a, uint32_t insn)
|
static bool trans_l_muli(DisasContext *dc, arg_rri *a)
|
||||||
{
|
{
|
||||||
TCGv t0;
|
TCGv t0;
|
||||||
|
|
||||||
@ -827,7 +827,7 @@ static bool trans_l_muli(DisasContext *dc, arg_rri *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_maci(DisasContext *dc, arg_l_maci *a, uint32_t insn)
|
static bool trans_l_maci(DisasContext *dc, arg_l_maci *a)
|
||||||
{
|
{
|
||||||
TCGv t0;
|
TCGv t0;
|
||||||
|
|
||||||
@ -837,28 +837,28 @@ static bool trans_l_maci(DisasContext *dc, arg_l_maci *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_andi(DisasContext *dc, arg_rrk *a, uint32_t insn)
|
static bool trans_l_andi(DisasContext *dc, arg_rrk *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_andi_tl(cpu_R[a->d], cpu_R[a->a], a->k);
|
tcg_gen_andi_tl(cpu_R[a->d], cpu_R[a->a], a->k);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_ori(DisasContext *dc, arg_rrk *a, uint32_t insn)
|
static bool trans_l_ori(DisasContext *dc, arg_rrk *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_ori_tl(cpu_R[a->d], cpu_R[a->a], a->k);
|
tcg_gen_ori_tl(cpu_R[a->d], cpu_R[a->a], a->k);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_xori(DisasContext *dc, arg_rri *a, uint32_t insn)
|
static bool trans_l_xori(DisasContext *dc, arg_rri *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_xori_tl(cpu_R[a->d], cpu_R[a->a], a->i);
|
tcg_gen_xori_tl(cpu_R[a->d], cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_mfspr(DisasContext *dc, arg_l_mfspr *a, uint32_t insn)
|
static bool trans_l_mfspr(DisasContext *dc, arg_l_mfspr *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
|
|
||||||
@ -873,7 +873,7 @@ static bool trans_l_mfspr(DisasContext *dc, arg_l_mfspr *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_mtspr(DisasContext *dc, arg_l_mtspr *a, uint32_t insn)
|
static bool trans_l_mtspr(DisasContext *dc, arg_l_mtspr *a)
|
||||||
{
|
{
|
||||||
if (is_user(dc)) {
|
if (is_user(dc)) {
|
||||||
gen_illegal_exception(dc);
|
gen_illegal_exception(dc);
|
||||||
@ -901,66 +901,66 @@ static bool trans_l_mtspr(DisasContext *dc, arg_l_mtspr *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_mac(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_l_mac(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
gen_mac(dc, cpu_R[a->a], cpu_R[a->b]);
|
gen_mac(dc, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_msb(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_l_msb(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
gen_msb(dc, cpu_R[a->a], cpu_R[a->b]);
|
gen_msb(dc, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_macu(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_l_macu(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
gen_macu(dc, cpu_R[a->a], cpu_R[a->b]);
|
gen_macu(dc, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_msbu(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_l_msbu(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
gen_msbu(dc, cpu_R[a->a], cpu_R[a->b]);
|
gen_msbu(dc, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_slli(DisasContext *dc, arg_dal *a, uint32_t insn)
|
static bool trans_l_slli(DisasContext *dc, arg_dal *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_shli_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
tcg_gen_shli_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_srli(DisasContext *dc, arg_dal *a, uint32_t insn)
|
static bool trans_l_srli(DisasContext *dc, arg_dal *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_shri_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
tcg_gen_shri_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_srai(DisasContext *dc, arg_dal *a, uint32_t insn)
|
static bool trans_l_srai(DisasContext *dc, arg_dal *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_sari_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
tcg_gen_sari_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_rori(DisasContext *dc, arg_dal *a, uint32_t insn)
|
static bool trans_l_rori(DisasContext *dc, arg_dal *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_rotri_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
tcg_gen_rotri_tl(cpu_R[a->d], cpu_R[a->a], a->l & (TARGET_LONG_BITS - 1));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_movhi(DisasContext *dc, arg_l_movhi *a, uint32_t insn)
|
static bool trans_l_movhi(DisasContext *dc, arg_l_movhi *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_movi_tl(cpu_R[a->d], a->k << 16);
|
tcg_gen_movi_tl(cpu_R[a->d], a->k << 16);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_macrc(DisasContext *dc, arg_l_macrc *a, uint32_t insn)
|
static bool trans_l_macrc(DisasContext *dc, arg_l_macrc *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
tcg_gen_trunc_i64_tl(cpu_R[a->d], cpu_mac);
|
tcg_gen_trunc_i64_tl(cpu_R[a->d], cpu_mac);
|
||||||
@ -968,127 +968,127 @@ static bool trans_l_macrc(DisasContext *dc, arg_l_macrc *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfeq(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfeq(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_EQ, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_EQ, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfne(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfne(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_NE, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_NE, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfgtu(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfgtu(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_GTU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_GTU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfgeu(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfgeu(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_GEU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_GEU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfltu(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfltu(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_LTU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_LTU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfleu(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfleu(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_LEU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_LEU, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfgts(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfgts(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_GT, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_GT, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfges(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfges(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_GE, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_GE, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sflts(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sflts(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_LT, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_LT, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfles(DisasContext *dc, arg_ab *a, TCGCond cond)
|
static bool trans_l_sfles(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcond_tl(TCG_COND_LE, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
tcg_gen_setcond_tl(TCG_COND_LE, cpu_sr_f, cpu_R[a->a], cpu_R[a->b]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfeqi(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfeqi(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_EQ, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_EQ, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfnei(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfnei(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_NE, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_NE, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfgtui(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfgtui(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_GTU, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_GTU, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfgeui(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfgeui(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_GEU, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_GEU, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfltui(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfltui(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_LTU, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_LTU, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfleui(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfleui(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_LEU, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_LEU, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfgtsi(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfgtsi(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_GT, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_GT, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfgesi(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfgesi(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_GE, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_GE, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sfltsi(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sfltsi(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_LT, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_LT, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sflesi(DisasContext *dc, arg_ai *a, TCGCond cond)
|
static bool trans_l_sflesi(DisasContext *dc, arg_ai *a)
|
||||||
{
|
{
|
||||||
tcg_gen_setcondi_tl(TCG_COND_LE, cpu_sr_f, cpu_R[a->a], a->i);
|
tcg_gen_setcondi_tl(TCG_COND_LE, cpu_sr_f, cpu_R[a->a], a->i);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_sys(DisasContext *dc, arg_l_sys *a, uint32_t insn)
|
static bool trans_l_sys(DisasContext *dc, arg_l_sys *a)
|
||||||
{
|
{
|
||||||
tcg_gen_movi_tl(cpu_pc, dc->base.pc_next);
|
tcg_gen_movi_tl(cpu_pc, dc->base.pc_next);
|
||||||
gen_exception(dc, EXCP_SYSCALL);
|
gen_exception(dc, EXCP_SYSCALL);
|
||||||
@ -1096,7 +1096,7 @@ static bool trans_l_sys(DisasContext *dc, arg_l_sys *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_trap(DisasContext *dc, arg_l_trap *a, uint32_t insn)
|
static bool trans_l_trap(DisasContext *dc, arg_l_trap *a)
|
||||||
{
|
{
|
||||||
tcg_gen_movi_tl(cpu_pc, dc->base.pc_next);
|
tcg_gen_movi_tl(cpu_pc, dc->base.pc_next);
|
||||||
gen_exception(dc, EXCP_TRAP);
|
gen_exception(dc, EXCP_TRAP);
|
||||||
@ -1104,23 +1104,23 @@ static bool trans_l_trap(DisasContext *dc, arg_l_trap *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_msync(DisasContext *dc, arg_l_msync *a, uint32_t insn)
|
static bool trans_l_msync(DisasContext *dc, arg_l_msync *a)
|
||||||
{
|
{
|
||||||
tcg_gen_mb(TCG_MO_ALL);
|
tcg_gen_mb(TCG_MO_ALL);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_psync(DisasContext *dc, arg_l_psync *a, uint32_t insn)
|
static bool trans_l_psync(DisasContext *dc, arg_l_psync *a)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_csync(DisasContext *dc, arg_l_csync *a, uint32_t insn)
|
static bool trans_l_csync(DisasContext *dc, arg_l_csync *a)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_l_rfe(DisasContext *dc, arg_l_rfe *a, uint32_t insn)
|
static bool trans_l_rfe(DisasContext *dc, arg_l_rfe *a)
|
||||||
{
|
{
|
||||||
if (is_user(dc)) {
|
if (is_user(dc)) {
|
||||||
gen_illegal_exception(dc);
|
gen_illegal_exception(dc);
|
||||||
@ -1162,49 +1162,49 @@ static void do_fpcmp(DisasContext *dc, arg_ab *a,
|
|||||||
gen_helper_update_fpcsr(cpu_env);
|
gen_helper_update_fpcsr(cpu_env);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_add_s(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_lf_add_s(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
do_fp3(dc, a, gen_helper_float_add_s);
|
do_fp3(dc, a, gen_helper_float_add_s);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_sub_s(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_lf_sub_s(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
do_fp3(dc, a, gen_helper_float_sub_s);
|
do_fp3(dc, a, gen_helper_float_sub_s);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_mul_s(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_lf_mul_s(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
do_fp3(dc, a, gen_helper_float_mul_s);
|
do_fp3(dc, a, gen_helper_float_mul_s);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_div_s(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_lf_div_s(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
do_fp3(dc, a, gen_helper_float_div_s);
|
do_fp3(dc, a, gen_helper_float_div_s);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_rem_s(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_lf_rem_s(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
do_fp3(dc, a, gen_helper_float_rem_s);
|
do_fp3(dc, a, gen_helper_float_rem_s);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_itof_s(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_lf_itof_s(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
do_fp2(dc, a, gen_helper_itofs);
|
do_fp2(dc, a, gen_helper_itofs);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_ftoi_s(DisasContext *dc, arg_da *a, uint32_t insn)
|
static bool trans_lf_ftoi_s(DisasContext *dc, arg_da *a)
|
||||||
{
|
{
|
||||||
do_fp2(dc, a, gen_helper_ftois);
|
do_fp2(dc, a, gen_helper_ftois);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_madd_s(DisasContext *dc, arg_dab *a, uint32_t insn)
|
static bool trans_lf_madd_s(DisasContext *dc, arg_dab *a)
|
||||||
{
|
{
|
||||||
check_r0_write(a->d);
|
check_r0_write(a->d);
|
||||||
gen_helper_float_madd_s(cpu_R[a->d], cpu_env, cpu_R[a->d],
|
gen_helper_float_madd_s(cpu_R[a->d], cpu_env, cpu_R[a->d],
|
||||||
@ -1213,37 +1213,37 @@ static bool trans_lf_madd_s(DisasContext *dc, arg_dab *a, uint32_t insn)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_sfeq_s(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_lf_sfeq_s(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
do_fpcmp(dc, a, gen_helper_float_eq_s, false, false);
|
do_fpcmp(dc, a, gen_helper_float_eq_s, false, false);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_sfne_s(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_lf_sfne_s(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
do_fpcmp(dc, a, gen_helper_float_eq_s, true, false);
|
do_fpcmp(dc, a, gen_helper_float_eq_s, true, false);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_sfgt_s(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_lf_sfgt_s(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
do_fpcmp(dc, a, gen_helper_float_lt_s, false, true);
|
do_fpcmp(dc, a, gen_helper_float_lt_s, false, true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_sfge_s(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_lf_sfge_s(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
do_fpcmp(dc, a, gen_helper_float_le_s, false, true);
|
do_fpcmp(dc, a, gen_helper_float_le_s, false, true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_sflt_s(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_lf_sflt_s(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
do_fpcmp(dc, a, gen_helper_float_lt_s, false, false);
|
do_fpcmp(dc, a, gen_helper_float_lt_s, false, false);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool trans_lf_sfle_s(DisasContext *dc, arg_ab *a, uint32_t insn)
|
static bool trans_lf_sfle_s(DisasContext *dc, arg_ab *a)
|
||||||
{
|
{
|
||||||
do_fpcmp(dc, a, gen_helper_float_le_s, false, false);
|
do_fpcmp(dc, a, gen_helper_float_le_s, false, false);
|
||||||
return true;
|
return true;
|
||||||
|
Loading…
Reference in New Issue
Block a user