blob: 5f9a9f2b2e70e6bc2b5decfeb55a42b02757bba3 [file] [log] [blame]
#-------------------------------------------------------------------------------
# Build the mlir bytecode modules with iree-compile. Note the last two flags
# are for RVV support.
# https://github.com/llvm/llvm-project/blob/0eeab8b/llvm/lib/Target/RISCV/RISCVSubtarget.cpp#L30-L51
#-------------------------------------------------------------------------------
sparrow_modules(
NAME
simple_float_mul
SRC
"simple_float_mul.mlir"
C_IDENTIFIER
"samples_simple_vec_mul_simple_float_mul"
FLAGS
"-iree-input-type=stablehlo"
"-riscv-v-fixed-length-vector-lmul-max=8"
VMVX
INLINE_HAL
)
sparrow_modules(
NAME
simple_int_mul
SRC
"simple_int_mul.mlir"
C_IDENTIFIER
"samples_simple_vec_mul_simple_int_mul"
FLAGS
"-iree-input-type=stablehlo"
"-riscv-v-fixed-length-vector-lmul-max=8"
VMVX
INLINE_HAL
)
#-------------------------------------------------------------------------------
# Binaries to execute the MLIR bytecode modules
#-------------------------------------------------------------------------------
# Different util libraries available:
# util_static: static library using regular HAL
# util_vmvx: vmvx using regular HAL
# util_static_inline: static library using inline HAL
# util_vmvx_inline: vmvx using inline HAL
# If the program requires a larger stack size, add
#
# LINKOPTS
# "LINKER:--defsym=__stack_size__=<new stack size>"
#
# to increase it.
iree_cc_binary(
NAME
simple_float_vec_mul_bytecode_vmvx
SRCS
"float_vec.c"
DEPS
::simple_float_mul_bytecode_module_vmvx_c
model_util::util_vmvx_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_VMVX"
)
iree_cc_binary(
NAME
simple_float_vec_mul_emitc_vmvx
SRCS
"float_vec.c"
DEPS
::simple_float_mul_c_module_vmvx_emitc
model_util::util_vmvx_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_EMITC"
"-DBUILD_VMVX"
)
iree_cc_binary(
NAME
simple_float_vec_mul_bytecode_static
SRCS
"float_vec.c"
DEPS
::simple_float_mul_bytecode_module_static_c
::simple_float_mul_bytecode_module_static_lib
iree::vm::bytecode::module
model_util::util_static_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
)
iree_cc_binary(
NAME
simple_float_vec_mul_emitc_static
SRCS
"float_vec.c"
DEPS
::simple_float_mul_c_module_static_emitc
::simple_float_mul_c_module_static_lib
model_util::util_static_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_EMITC"
)
iree_cc_binary(
NAME
simple_int_vec_mul_bytecode_vmvx
SRCS
"int_vec.c"
DEPS
::simple_int_mul_bytecode_module_vmvx_c
model_util::util_vmvx_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_VMVX"
)
iree_cc_binary(
NAME
simple_int_vec_mul_emitc_vmvx
SRCS
"int_vec.c"
DEPS
::simple_int_mul_c_module_vmvx_emitc
model_util::util_vmvx_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_EMITC"
"-DBUILD_VMVX"
)
iree_cc_binary(
NAME
simple_int_vec_mul_bytecode_static
SRCS
"int_vec.c"
DEPS
::simple_int_mul_bytecode_module_static_c
::simple_int_mul_bytecode_module_static_lib
iree::vm::bytecode::module
model_util::util_static_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
)
sparrow_test(
NAME
simple_int_vec_mul_emitc_static
SRCS
"int_vec.c"
DEPS
::simple_int_mul_c_module_static_emitc
::simple_int_mul_c_module_static_lib
model_util::util_static_inline
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_EMITC"
TESTFILES
"simple_test.run"
"simple_int_static_bin_test.run"
)
# Kelvin-only systemc tests
if (${BUILD_WITH_KELVIN})
add_custom_command(
TARGET
samples_simple_vec_mul_simple_int_vec_mul_bytecode_static
POST_BUILD
COMMAND
${CMAKE_OBJCOPY} -g -O binary
simple_int_vec_mul_bytecode_static
simple_int_vec_mul_bytecode_static.bin
BYPRODUCTS
simple_int_vec_mul_bytecode_static.bin
COMMENT
"Objcopy the binary file"
)
add_custom_command(
TARGET
samples_simple_vec_mul_simple_int_vec_mul_emitc_static
POST_BUILD
COMMAND
${CMAKE_OBJCOPY} -g -O binary
simple_int_vec_mul_emitc_static
simple_int_vec_mul_emitc_static.bin
BYPRODUCTS
simple_int_vec_mul_emitc_static.bin
COMMENT
"Objcopy the binary file"
)
endif()