1*9880d681SAndroid Build Coastguard Worker; RUN: llc --code-model=kernel -march=x86-64 <%s -asm-verbose=0 | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; PR4933 3*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128" 4*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-unknown-linux-gnu" 5*9880d681SAndroid Build Coastguard Worker%struct.kmem_cache_order_objects = type { i64 } 6*9880d681SAndroid Build Coastguard Workerdeclare i8* @memset(i8*, i32, i64) 7*9880d681SAndroid Build Coastguard Workerdefine void @unxlate_dev_mem_ptr(i64 %phis, i8* %addr) nounwind { 8*9880d681SAndroid Build Coastguard Worker %pte.addr.i = alloca %struct.kmem_cache_order_objects* 9*9880d681SAndroid Build Coastguard Worker %call8 = call i8* @memset(i8* bitcast ([512 x %struct.kmem_cache_order_objects]* @bm_pte to i8*), i32 0, i64 4096) 10*9880d681SAndroid Build Coastguard Worker; CHECK: movq $bm_pte, %rdi 11*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: xorl %esi, %esi 12*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: movl $4096, %edx 13*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: callq memset 14*9880d681SAndroid Build Coastguard Worker ret void 15*9880d681SAndroid Build Coastguard Worker} 16*9880d681SAndroid Build Coastguard Worker@bm_pte = internal global [512 x %struct.kmem_cache_order_objects] zeroinitializer, section ".bss.page_aligned", align 4096 17*9880d681SAndroid Build Coastguard Worker; CHECK: .section .bss.page_aligned,"aw",@nobits 18*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .p2align 12 19*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: bm_pte: 20*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .zero 4096 21*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size bm_pte, 4096 22