blob: c521d7fdb89e1d05b63d03bec85dda7d6c174914 [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
#-------------------------------------------------------------------------------
springbok_modules(
NAME
simple_float_mul
SRC
"simple_float_mul.mlir"
C_IDENTIFIER
"samples_simple_vec_mul_simple_float_mul"
FLAGS
"-iree-input-type=mhlo"
"-riscv-v-vector-bits-min=512"
"-riscv-v-fixed-length-vector-lmul-max=8"
PUBLIC
)
springbok_modules(
NAME
simple_int_mul
SRC
"simple_int_mul.mlir"
C_IDENTIFIER
"samples_simple_vec_mul_simple_int_mul"
FLAGS
"-iree-input-type=mhlo"
"-riscv-v-vector-bits-min=512"
"-riscv-v-fixed-length-vector-lmul-max=8"
PUBLIC
)
#-------------------------------------------------------------------------------
# Binaries to execute the MLIR bytecode modules
#-------------------------------------------------------------------------------
# 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_static
SRCS
"float_vec.c"
DEPS
::simple_float_mul_bytecode_module_static
::simple_float_mul_bytecode_module_static_c
iree::vm::bytecode_module
model_util::util
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_c
::simple_float_mul_c_module_static_emitc
model_util::util
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_EMITC"
)
iree_cc_binary(
NAME
simple_int_vec_mul_bytecode_static
SRCS
"int_vec.c"
DEPS
::simple_int_mul_bytecode_module_static
::simple_int_mul_bytecode_module_static_c
iree::vm::bytecode_module
model_util::util
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
)
springbok_test(
NAME
simple_int_vec_mul_emitc_static
SRCS
"int_vec.c"
DEPS
::simple_int_mul_c_module_static_c
::simple_int_mul_c_module_static_emitc
model_util::util
LINKOPTS
"LINKER:--defsym=__stack_size__=20k"
COPTS
"-DBUILD_EMITC"
TESTFILES
"simple_test.run"
)