summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/mips/mult-16.c
blob: cb1707d912527d5c38b7fa80b14b43f10a2e97d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
/* { dg-options "-O2 -mgp32 (-mips16)" } */
/* { 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;
}