llvm/llvm/test/CodeGen/Thumb2/bug-subw.ll

; pr23772 - [ARM] r226200 can emit illegal thumb2 instruction: "sub sp, r12, #80"
; RUN: llc -march=thumb -mcpu=cortex-m3 -O3 -filetype=asm -o - %s | FileCheck %s
; CHECK-NOT: sub{{.*}} sp, r{{.*}}, #
; CHECK:     .fnend
; TODO: Missed optimization. The three instructions generated to subtract SP can be converged to a single one
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:32"
target triple = "thumbv7m-unknown-unknown"
%B = type {ptr}
%R = type {i32}
%U = type {ptr, i8, i8}
%E = type {ptr, ptr}
%X = type {i32, i8, i8}
declare external ptr @memalloc(i32, i32, i32)
declare external void @memfree(ptr, i32, i32)
define void @foo(ptr %pb$, ptr %pr$) nounwind {
L.0:
	%pb = alloca ptr
	%pr = alloca ptr
	store ptr %pb$, ptr %pb
	store ptr %pr$, ptr %pr
	%pe = alloca ptr
	%0 = load ptr, ptr %pb
	store ptr %0, ptr %pe
	%1 = load ptr, ptr %pr
	%2 = load i32, ptr %1
	switch i32 %2, label %L.1 [
		i32 1, label %L.3
	]
L.3:
	%px = alloca ptr
	%3 = load ptr, ptr %pr
	store ptr %3, ptr %px
	%4 = load ptr, ptr %px
	%5 = load i32, ptr %4
	%6 = icmp ne i32 %5, 0
	br i1 %6, label %L.5, label %L.4
L.5:
	%pu = alloca ptr
	%7 = call ptr @memalloc(i32 8, i32 4, i32 0)
	store ptr %7, ptr %pu
	%8 = load ptr, ptr %px
	%9 = getelementptr %X, ptr %8, i32 0, i32 1
	%10 = load i8, ptr %9
	%11 = load ptr, ptr %pu
	%12 = getelementptr %U, ptr %11, i32 0, i32 1
	store i8 %10, ptr %12
	%13 = load ptr, ptr %pe
	%14 = getelementptr %E, ptr %13, i32 0, i32 1
	%15 = load ptr, ptr %14
	%16 = load ptr, ptr %pu
	store ptr %15, ptr %16
	%17 = load ptr, ptr %pu
	%18 = load ptr, ptr %pe
	%19 = getelementptr %E, ptr %18, i32 0, i32 1
	store ptr %17, ptr %19
	br label %L.4
L.4:
	%20 = load ptr, ptr %px
	call void @memfree(ptr %20, i32 8, i32 0)
	br label %L.2
L.1:
	br label %L.2
L.2:
	br label %return
return:
	ret void
}