diff options
author | Chris Lattner <sabre@nondot.org> | 2008-12-02 06:32:34 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-12-02 06:32:34 +0000 |
commit | 0cdc0bbb8a2b9c3ea044c1bffb0565032ce9e80c (patch) | |
tree | 71f9812580b373cbfd6b73ca6f6945f529f96234 /llvm/lib | |
parent | 87beb9b909da8cfd1fd88f259cc767d972c07f0e (diff) | |
download | bcm5719-llvm-0cdc0bbb8a2b9c3ea044c1bffb0565032ce9e80c.tar.gz bcm5719-llvm-0cdc0bbb8a2b9c3ea044c1bffb0565032ce9e80c.zip |
add a note
llvm-svn: 60404
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Target/README.txt | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/llvm/lib/Target/README.txt b/llvm/lib/Target/README.txt index 3c689dbe46e..518c9893c8c 100644 --- a/llvm/lib/Target/README.txt +++ b/llvm/lib/Target/README.txt @@ -1252,3 +1252,24 @@ have the concept of a "C signed subtraction" operator that which is undefined on overflow. //===---------------------------------------------------------------------===// + +This was noticed in the entryblock for grokdeclarator in 403.gcc: + + %tmp = icmp eq i32 %decl_context, 4 + %decl_context_addr.0 = select i1 %tmp, i32 3, i32 %decl_context + %tmp1 = icmp eq i32 %decl_context_addr.0, 1 + %decl_context_addr.1 = select i1 %tmp1, i32 0, i32 %decl_context_addr.0 + +tmp1 should be simplified to something like: + (!tmp || decl_context == 1) + +This allows recursive simplifications, tmp1 is used all over the place in +the function, e.g. by: + + %tmp23 = icmp eq i32 %decl_context_addr.1, 0 ; <i1> [#uses=1] + %tmp24 = xor i1 %tmp1, true ; <i1> [#uses=1] + %or.cond8 = and i1 %tmp23, %tmp24 ; <i1> [#uses=1] + +later. + + |