1/*
2 * RISC-V translation routines for the RVB Standard Extension.
3 *
4 * Copyright (c) 2020 Kito Cheng, kito.cheng@sifive.com
5 * Copyright (c) 2020 Frank Chang, frank.chang@sifive.com
6 *
7 * This program is free software; you can redistribute it and/or modify it
8 * under the terms and conditions of the GNU General Public License,
9 * version 2 or later, as published by the Free Software Foundation.
10 *
11 * This program is distributed in the hope it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
14 * more details.
15 *
16 * You should have received a copy of the GNU General Public License along with
17 * this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20static bool trans_clz(DisasContext *ctx, arg_clz *a)
21{
22    REQUIRE_EXT(ctx, RVB);
23    return gen_unary(ctx, a, gen_clz);
24}
25
26static bool trans_ctz(DisasContext *ctx, arg_ctz *a)
27{
28    REQUIRE_EXT(ctx, RVB);
29    return gen_unary(ctx, a, gen_ctz);
30}
31
32static bool trans_cpop(DisasContext *ctx, arg_cpop *a)
33{
34    REQUIRE_EXT(ctx, RVB);
35    return gen_unary(ctx, a, tcg_gen_ctpop_tl);
36}
37
38static bool trans_clzw(DisasContext *ctx, arg_clzw *a)
39{
40    REQUIRE_64BIT(ctx);
41    REQUIRE_EXT(ctx, RVB);
42    return gen_unary(ctx, a, gen_clzw);
43}
44
45static bool trans_ctzw(DisasContext *ctx, arg_ctzw *a)
46{
47    REQUIRE_64BIT(ctx);
48    REQUIRE_EXT(ctx, RVB);
49    return gen_unary(ctx, a, gen_ctzw);
50}
51
52static bool trans_cpopw(DisasContext *ctx, arg_cpopw *a)
53{
54    REQUIRE_64BIT(ctx);
55    REQUIRE_EXT(ctx, RVB);
56    return gen_unary(ctx, a, gen_cpopw);
57}
58