// REQUIRES: hexagon-registered-target
// RUN: %clang_cc1 -no-opaque-pointers -emit-llvm -triple hexagon-unknown-linux-musl %s -o - | FileCheck %s
;
// CHECK: call void @llvm.va_start(i8* %arraydecay1)
// CHECK: %arraydecay2 = getelementptr inbounds [1 x %struct.__va_list_tag],
// [1 x %struct.__va_list_tag]* %ap, i32 0, i32 0
// CHECK: br label %vaarg.maybe_reg
// CHECK: vaarg.maybe_reg: ; preds = %entry
// CHECK: %__current_saved_reg_area_pointer_p = getelementptr inbounds
// %struct.__va_list_tag, %struct.__va_list_tag* %arraydecay2, i32 0, i32 0
// CHECK: %__current_saved_reg_area_pointer = load i8*, i8**
// %__current_saved_reg_area_pointer_p
// CHECK: %__saved_reg_area_end_pointer_p = getelementptr inbounds
// %struct.__va_list_tag, %struct.__va_list_tag* %arraydecay2, i32 0, i32 1
// CHECK: %__saved_reg_area_end_pointer = load i8*, i8**
// %__saved_reg_area_end_pointer_p
// CHECK: %__new_saved_reg_area_pointer = getelementptr i8, i8*
// %__current_saved_reg_area_pointer, i32 4
// CHECK: %0 = icmp sgt i8* %__new_saved_reg_area_pointer,
// %__saved_reg_area_end_pointer
// CHECK: br i1 %0, label %vaarg.on_stack, label %vaarg.in_reg
// CHECK: vaarg.in_reg: ; preds =
// %vaarg.maybe_reg
// CHECK: %1 = bitcast i8* %__current_saved_reg_area_pointer to i32*
// CHECK: store i8* %__new_saved_reg_area_pointer, i8**
// %__current_saved_reg_area_pointer_p
// CHECK: br label %vaarg.end
// CHECK: vaarg.on_stack: ; preds =
// %vaarg.maybe_reg
// CHECK: %__overflow_area_pointer_p = getelementptr inbounds
// %struct.__va_list_tag, %struct.__va_list_tag* %arraydecay2, i32 0, i32 2
// CHECK: %__overflow_area_pointer = load i8*, i8** %__overflow_area_pointer_p
// CHECK: %__overflow_area_pointer.next = getelementptr i8, i8*
// %__overflow_area_pointer, i32 4
// CHECK: store i8* %__overflow_area_pointer.next, i8**
// %__overflow_area_pointer_p
// CHECK: store i8* %__overflow_area_pointer.next, i8**
// %__current_saved_reg_area_pointer_p
// CHECK: %2 = bitcast i8* %__overflow_area_pointer to i32*
// CHECK: br label %vaarg.end
// CHECK: vaarg.end: ; preds =
// %vaarg.on_stack, %vaarg.in_reg
// CHECK: %vaarg.addr = phi i32* [ %1, %vaarg.in_reg ], [ %2, %vaarg.on_stack
// ]
// CHECK: %3 = load i32, i32* %vaarg.addr
struct AAA aaa = ;
int
int