# RUN: llvm-mc -triple hexagon -filetype=obj %s | llvm-objdump -d - | FileCheck %s # Hexagon Programmer's Reference Manual 11.1.1 ALU32/ALU # Add # CHECK: f1 c3 15 b0 r17 = add(r21, #31) # CHECK: 11 df 15 f3 r17 = add(r21, r31) # CHECK: 11 df 55 f6 r17 = add(r21, r31):sat # And # CHECK: f1 c3 15 76 r17 = and(r21, #31) # CHECK: f1 c3 95 76 r17 = or(r21, #31) # CHECK: 11 df 15 f1 r17 = and(r21, r31) # CHECK: 11 df 35 f1 r17 = or(r21, r31) # CHECK: 11 df 75 f1 r17 = xor(r21, r31) # CHECK: 11 d5 9f f1 r17 = and(r21, ~r31) # CHECK: 11 d5 bf f1 r17 = or(r21, ~r31) # Nop # CHECK: 00 c0 00 7f nop # Subtract # CHECK: b1 c2 5f 76 r17 = sub(#21, r31) # CHECK: 11 df 35 f3 r17 = sub(r31, r21) # CHECK: 11 df d5 f6 r17 = sub(r31, r21):sat # Sign extend # CHECK: 11 c0 bf 70 r17 = sxtb(r31) # Transfer immediate # CHECK: 15 c0 31 72 r17.h = #21 # CHECK: 15 c0 31 71 r17.l = #21 # CHECK: f1 ff 5f 78 r17 = #32767 # CHECK: f1 ff df 78 r17 = #-1 # Transfer register # CHECK: 11 c0 75 70 r17 = r21 # Vector add halfwords # CHECK: 11 df 15 f6 r17 = vaddh(r21, r31) # CHECK: 11 df 35 f6 r17 = vaddh(r21, r31):sat # CHECK: 11 df 75 f6 r17 = vadduh(r21, r31):sat # Vector average halfwords # CHECK: 11 df 15 f7 r17 = vavgh(r21, r31) # CHECK: 11 df 35 f7 r17 = vavgh(r21, r31):rnd # CHECK: 11 df 75 f7 r17 = vnavgh(r31, r21) # Vector subtract halfwords # CHECK: 11 df 95 f6 r17 = vsubh(r31, r21) # CHECK: 11 df b5 f6 r17 = vsubh(r31, r21):sat # CHECK: 11 df f5 f6 r17 = vsubuh(r31, r21):sat # Zero extend # CHECK: 11 c0 d5 70 r17 = zxth(r21)