| ; RUN: llc -O0 -mhwmult=16bit < %s | FileCheck %s | 
 | ; RUN: llc -O0 -mattr=+hwmult16 < %s | FileCheck %s | 
 |  | 
 | target datalayout = "e-p:16:16:16-i8:8:8-i16:16:16-i32:16:32-n8:16-a0:16:16" | 
 | target triple = "msp430---elf" | 
 |  | 
 | @g_i32 = global i32 123, align 8 | 
 | @g_i64 = global i64 456, align 8 | 
 | @g_i16 = global i16 789, align 8 | 
 |  | 
 | define i16 @mpyi() #0 { | 
 | entry: | 
 | ; CHECK: mpyi: | 
 |  | 
 | ; CHECK: call #__mspabi_mpyi_hw | 
 |   %0 = load volatile i16, i16* @g_i16, align 8 | 
 |   %1 = mul i16 %0, %0 | 
 |  | 
 |   ret i16 %1 | 
 | } | 
 |  | 
 | define i32 @mpyli() #0 { | 
 | entry: | 
 | ; CHECK: mpyli: | 
 |  | 
 | ; CHECK: call #__mspabi_mpyl_hw | 
 |   %0 = load volatile i32, i32* @g_i32, align 8 | 
 |   %1 = mul i32 %0, %0 | 
 |  | 
 |   ret i32 %1 | 
 | } | 
 |  | 
 | define i64 @mpylli() #0 { | 
 | entry: | 
 | ; CHECK: mpylli: | 
 |  | 
 | ; CHECK: call #__mspabi_mpyll_hw | 
 |   %0 = load volatile i64, i64* @g_i64, align 8 | 
 |   %1 = mul i64 %0, %0 | 
 |  | 
 |   ret i64 %1 | 
 | } | 
 |  | 
 | attributes #0 = { nounwind } |