Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Reland "[clang][LoongArch] Set MaxAtomicInlineWidth and MaxAtomicProm…
…oteWidth for LoongArch" Differential Revision: https://reviews.llvm.org/D135526
- Loading branch information
1 parent
91aa909
commit defe7c0
Showing
3 changed files
with
89 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
// RUN: %clang_cc1 -triple loongarch32 -O1 -emit-llvm %s -o - \ | ||
// RUN: | FileCheck %s --check-prefix=LA32 | ||
// RUN: %clang_cc1 -triple loongarch64 -O1 -emit-llvm %s -o - \ | ||
// RUN: | FileCheck %s --check-prefix=LA64 | ||
|
||
/// This test demonstrates that MaxAtomicInlineWidth is set appropriately. | ||
|
||
#include <stdatomic.h> | ||
#include <stdint.h> | ||
|
||
void test_i8_atomics(_Atomic(int8_t) * a, int8_t b) { | ||
// LA32: load atomic i8, ptr %a seq_cst, align 1 | ||
// LA32: store atomic i8 %b, ptr %a seq_cst, align 1 | ||
// LA32: atomicrmw add ptr %a, i8 %b seq_cst | ||
// LA64: load atomic i8, ptr %a seq_cst, align 1 | ||
// LA64: store atomic i8 %b, ptr %a seq_cst, align 1 | ||
// LA64: atomicrmw add ptr %a, i8 %b seq_cst | ||
__c11_atomic_load(a, memory_order_seq_cst); | ||
__c11_atomic_store(a, b, memory_order_seq_cst); | ||
__c11_atomic_fetch_add(a, b, memory_order_seq_cst); | ||
} | ||
|
||
void test_i32_atomics(_Atomic(int32_t) * a, int32_t b) { | ||
// LA32: load atomic i32, ptr %a seq_cst, align 4 | ||
// LA32: store atomic i32 %b, ptr %a seq_cst, align 4 | ||
// LA32: atomicrmw add ptr %a, i32 %b seq_cst | ||
// LA64: load atomic i32, ptr %a seq_cst, align 4 | ||
// LA64: store atomic i32 %b, ptr %a seq_cst, align 4 | ||
// LA64: atomicrmw add ptr %a, i32 %b seq_cst | ||
__c11_atomic_load(a, memory_order_seq_cst); | ||
__c11_atomic_store(a, b, memory_order_seq_cst); | ||
__c11_atomic_fetch_add(a, b, memory_order_seq_cst); | ||
} | ||
|
||
void test_i64_atomics(_Atomic(int64_t) * a, int64_t b) { | ||
// LA32: call i64 @__atomic_load_8 | ||
// LA32: call void @__atomic_store_8 | ||
// LA32: call i64 @__atomic_fetch_add_8 | ||
// LA64: load atomic i64, ptr %a seq_cst, align 8 | ||
// LA64: store atomic i64 %b, ptr %a seq_cst, align 8 | ||
// LA64: atomicrmw add ptr %a, i64 %b seq_cst | ||
__c11_atomic_load(a, memory_order_seq_cst); | ||
__c11_atomic_store(a, b, memory_order_seq_cst); | ||
__c11_atomic_fetch_add(a, b, memory_order_seq_cst); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters