/* { dg-do compile } */ /* { dg-options "-O2 -march=rv64gc_zbkb -mabi=lp64" } */ /* { dg-skip-if "" { *-*-* } { "-g" "-flto"} } */ #include uint64_t foo1(uint32_t rs1, uint32_t rs2) { return __builtin_riscv_pack(rs1, rs2); } uint64_t foo2(uint8_t rs1, uint8_t rs2) { return __builtin_riscv_packh(rs1, rs2); } uint64_t foo3(uint16_t rs1, uint16_t rs2) { return __builtin_riscv_packw(rs1, rs2); } /* { dg-final { scan-assembler-times "pack\t" 1 } } */ /* { dg-final { scan-assembler-times {\mpackh} 1 } } */ /* { dg-final { scan-assembler-times {\mpackw} 1 } } */