summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/mips/mult-16.c
blob: 3e9b3785b1ba51ea725a93082858883634ac8197 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
/* This test requires widening_mul */
/* { dg-options "-mgp32 (-mips16) -fexpensive-optimizations" } */
/* { dg-skip-if "code quality test" { *-*-* } { "-O0" } { "" } } */
/* { dg-final { scan-assembler "\tmult\t" } } */
/* { dg-final { scan-assembler-not "\tmflo\t" } } */
/* { dg-final { scan-assembler "\tmfhi\t" } } */

typedef int DI __attribute__((mode(DI)));
typedef int SI __attribute__((mode(SI)));

MIPS16 SI
f (SI x, SI y)
{
  return ((DI) x * y) >> 32;
}