From 1e81f57bf0d3f52c990a54b70b5404e240b1fe89 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 17 May 2011 07:22:33 +0000 Subject: add a note llvm-svn: 131455 --- llvm/lib/Target/X86/README.txt | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'llvm/lib/Target/X86') diff --git a/llvm/lib/Target/X86/README.txt b/llvm/lib/Target/X86/README.txt index ea3014e7b92..560947a4a04 100644 --- a/llvm/lib/Target/X86/README.txt +++ b/llvm/lib/Target/X86/README.txt @@ -2040,3 +2040,29 @@ _clamp2: ## @clamp2 The move of 0 could be scheduled above the test to make it is xor reg,reg. //===---------------------------------------------------------------------===// + +GCC PR48986. We currently compile this: + +void bar(void); +void yyy(int* p) { + if (__sync_fetch_and_add(p, -1) == 1) + bar(); +} + +into: + movl $-1, %eax + lock + xaddl %eax, (%rdi) + cmpl $1, %eax + je LBB0_2 + +Instead we could generate: + + lock + dec %rdi + je LBB0_2 + +The trick is to match "fetch_and_add(X, -C) == C". + +//===---------------------------------------------------------------------===// + -- cgit v1.2.3