1# FIXME extra_args should accept files() 2dir = meson.current_source_dir() 3gen32 = [ 4 decodetree.process('insn16.decode', extra_args: [dir / 'insn16-32.decode', '--static-decode=decode_insn16', '--insnwidth=16']), 5 decodetree.process('insn32.decode', extra_args: '--static-decode=decode_insn32'), 6] 7 8gen64 = [ 9 decodetree.process('insn16.decode', extra_args: [dir / 'insn16-64.decode', '--static-decode=decode_insn16', '--insnwidth=16']), 10 decodetree.process('insn32.decode', extra_args: [dir / 'insn32-64.decode', '--static-decode=decode_insn32']), 11] 12 13riscv_ss = ss.source_set() 14riscv_ss.add(when: 'TARGET_RISCV32', if_true: gen32) 15riscv_ss.add(when: 'TARGET_RISCV64', if_true: gen64) 16riscv_ss.add(files( 17 'cpu.c', 18 'cpu_helper.c', 19 'csr.c', 20 'fpu_helper.c', 21 'gdbstub.c', 22 'op_helper.c', 23 'vector_helper.c', 24 'translate.c', 25)) 26 27riscv_softmmu_ss = ss.source_set() 28riscv_softmmu_ss.add(files( 29 'pmp.c', 30 'monitor.c', 31 'machine.c' 32)) 33 34target_arch += {'riscv': riscv_ss} 35target_softmmu_arch += {'riscv': riscv_softmmu_ss} 36