; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -mtriple=xtensa -mattr=+windowed < %s | FileCheck %s --check-prefixes=XTENSA ; RUN: llc -mtriple=xtensa -mattr=+windowed,s32c1i < %s | FileCheck %s --check-prefixes=XTENSA-ATOMIC define i8 @atomic_load_i8_unordered(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i8_unordered: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 0 ; XTENSA-NEXT: l32r a8, .LCPI0_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i8_unordered: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l8ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i8, ptr %a unordered, align 1 ret i8 %1 } define i8 @atomic_load_i8_monotonic(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i8_monotonic: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 0 ; XTENSA-NEXT: l32r a8, .LCPI1_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i8_monotonic: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l8ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i8, ptr %a monotonic, align 1 ret i8 %1 } define i8 @atomic_load_i8_acquire(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i8_acquire: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 2 ; XTENSA-NEXT: l32r a8, .LCPI2_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i8_acquire: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l8ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i8, ptr %a acquire, align 1 ret i8 %1 } define i8 @atomic_load_i8_seq_cst(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i8_seq_cst: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 5 ; XTENSA-NEXT: l32r a8, .LCPI3_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i8_seq_cst: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l8ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i8, ptr %a seq_cst, align 1 ret i8 %1 } define i16 @atomic_load_i16_unordered(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i16_unordered: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 0 ; XTENSA-NEXT: l32r a8, .LCPI4_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i16_unordered: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l16ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i16, ptr %a unordered, align 2 ret i16 %1 } define i16 @atomic_load_i16_monotonic(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i16_monotonic: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 0 ; XTENSA-NEXT: l32r a8, .LCPI5_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i16_monotonic: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l16ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i16, ptr %a monotonic, align 2 ret i16 %1 } define i16 @atomic_load_i16_acquire(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i16_acquire: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 2 ; XTENSA-NEXT: l32r a8, .LCPI6_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i16_acquire: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l16ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i16, ptr %a acquire, align 2 ret i16 %1 } define i16 @atomic_load_i16_seq_cst(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i16_seq_cst: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 5 ; XTENSA-NEXT: l32r a8, .LCPI7_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i16_seq_cst: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l16ui a2, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i16, ptr %a seq_cst, align 2 ret i16 %1 } define i32 @atomic_load_i32_unordered(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i32_unordered: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 0 ; XTENSA-NEXT: l32r a8, .LCPI8_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i32_unordered: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l32i a2, a2, 0 ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i32, ptr %a unordered, align 4 ret i32 %1 } define i32 @atomic_load_i32_monotonic(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i32_monotonic: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 0 ; XTENSA-NEXT: l32r a8, .LCPI9_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i32_monotonic: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l32i a2, a2, 0 ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i32, ptr %a monotonic, align 4 ret i32 %1 } define i32 @atomic_load_i32_acquire(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i32_acquire: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 2 ; XTENSA-NEXT: l32r a8, .LCPI10_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i32_acquire: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l32i a2, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i32, ptr %a acquire, align 4 ret i32 %1 } define i32 @atomic_load_i32_seq_cst(ptr %a) nounwind { ; XTENSA-LABEL: atomic_load_i32_seq_cst: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a11, 5 ; XTENSA-NEXT: l32r a8, .LCPI11_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: or a2, a10, a10 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_load_i32_seq_cst: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: l32i a2, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw %1 = load atomic i32, ptr %a seq_cst, align 4 ret i32 %1 } define void @atomic_store_i8_unordered(ptr %a, i8 %b) nounwind { ; XTENSA-LABEL: atomic_store_i8_unordered: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 0 ; XTENSA-NEXT: l32r a8, .LCPI12_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i8_unordered: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: s8i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i8 %b, ptr %a unordered, align 1 ret void } define void @atomic_store_i8_monotonic(ptr %a, i8 %b) nounwind { ; XTENSA-LABEL: atomic_store_i8_monotonic: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 0 ; XTENSA-NEXT: l32r a8, .LCPI13_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i8_monotonic: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: s8i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i8 %b, ptr %a monotonic, align 1 ret void } define void @atomic_store_i8_release(ptr %a, i8 %b) nounwind { ; XTENSA-LABEL: atomic_store_i8_release: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 3 ; XTENSA-NEXT: l32r a8, .LCPI14_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i8_release: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: s8i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i8 %b, ptr %a release, align 1 ret void } define void @atomic_store_i8_seq_cst(ptr %a, i8 %b) nounwind { ; XTENSA-LABEL: atomic_store_i8_seq_cst: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 5 ; XTENSA-NEXT: l32r a8, .LCPI15_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i8_seq_cst: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: s8i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw store atomic i8 %b, ptr %a seq_cst, align 1 ret void } define void @atomic_store_i16_unordered(ptr %a, i16 %b) nounwind { ; XTENSA-LABEL: atomic_store_i16_unordered: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 0 ; XTENSA-NEXT: l32r a8, .LCPI16_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i16_unordered: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: s16i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i16 %b, ptr %a unordered, align 2 ret void } define void @atomic_store_i16_monotonic(ptr %a, i16 %b) nounwind { ; XTENSA-LABEL: atomic_store_i16_monotonic: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 0 ; XTENSA-NEXT: l32r a8, .LCPI17_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i16_monotonic: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: s16i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i16 %b, ptr %a monotonic, align 2 ret void } define void @atomic_store_i16_release(ptr %a, i16 %b) nounwind { ; XTENSA-LABEL: atomic_store_i16_release: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 3 ; XTENSA-NEXT: l32r a8, .LCPI18_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i16_release: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: s16i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i16 %b, ptr %a release, align 2 ret void } define void @atomic_store_i16_seq_cst(ptr %a, i16 %b) nounwind { ; XTENSA-LABEL: atomic_store_i16_seq_cst: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 5 ; XTENSA-NEXT: l32r a8, .LCPI19_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i16_seq_cst: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: s16i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw store atomic i16 %b, ptr %a seq_cst, align 2 ret void } define void @atomic_store_i32_unordered(ptr %a, i32 %b) nounwind { ; XTENSA-LABEL: atomic_store_i32_unordered: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 0 ; XTENSA-NEXT: l32r a8, .LCPI20_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i32_unordered: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: s32i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i32 %b, ptr %a unordered, align 4 ret void } define void @atomic_store_i32_monotonic(ptr %a, i32 %b) nounwind { ; XTENSA-LABEL: atomic_store_i32_monotonic: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 0 ; XTENSA-NEXT: l32r a8, .LCPI21_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i32_monotonic: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: s32i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i32 %b, ptr %a monotonic, align 4 ret void } define void @atomic_store_i32_release(ptr %a, i32 %b) nounwind { ; XTENSA-LABEL: atomic_store_i32_release: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 3 ; XTENSA-NEXT: l32r a8, .LCPI22_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i32_release: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: s32i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: retw store atomic i32 %b, ptr %a release, align 4 ret void } define void @atomic_store_i32_seq_cst(ptr %a, i32 %b) nounwind { ; XTENSA-LABEL: atomic_store_i32_seq_cst: ; XTENSA: # %bb.0: ; XTENSA-NEXT: entry a1, 32 ; XTENSA-NEXT: or a11, a3, a3 ; XTENSA-NEXT: or a10, a2, a2 ; XTENSA-NEXT: movi a12, 5 ; XTENSA-NEXT: l32r a8, .LCPI23_0 ; XTENSA-NEXT: callx8 a8 ; XTENSA-NEXT: retw ; ; XTENSA-ATOMIC-LABEL: atomic_store_i32_seq_cst: ; XTENSA-ATOMIC: # %bb.0: ; XTENSA-ATOMIC-NEXT: entry a1, 32 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: s32i a3, a2, 0 ; XTENSA-ATOMIC-NEXT: memw ; XTENSA-ATOMIC-NEXT: retw store atomic i32 %b, ptr %a seq_cst, align 4 ret void }