1 // REQUIRES: sat
2 // RUN: %cc% %ccflags% %ccout% %T/%basename_t.o %s; llvm-objdump --mcpu=%mcpu% -d %T/%basename_t.o | FileCheck --allow-unused-prefixes --check-prefixes %prefixes% %s
3 
4 #include "cmsis_compiler.h"
5 
6 static volatile uint32_t s32 = 10;
7 static volatile uint32_t u32 = 10U;
8 
ssat()9 void ssat() {
10     // CHECK-LABEL: <ssat>:
11     // CHECK: ssat {{r[0-9]+}}, #0x2, {{r[0-9]+}}
12     volatile uint32_t c = __SSAT(s32, 2u);
13     // CHECK: ssat {{r[0-9]+}}, #0x5, {{r[0-9]+}}
14     volatile uint32_t d = __SSAT(s32, 5u);
15     // CHECK: {{(bx lr)|(pop {.*pc})}}
16 }
17 
usat()18 void usat() {
19     // CHECK-LABEL: <usat>:
20     // CHECK: usat {{r[0-9]+}}, #0x2, {{r[0-9]+}}
21     volatile uint32_t c = __USAT(u32, 2u);
22     // CHECK: usat {{r[0-9]+}}, #0x5, {{r[0-9]+}}
23     volatile uint32_t d = __USAT(u32, 5u);
24     // CHECK: {{(bx lr)|(pop {.*pc})}}
25 }
26 
27