Skip to content
  1. Dec 04, 2010
  2. Dec 03, 2010
  3. Dec 02, 2010
    • Chris Lattner's avatar
      Reflow to a style doug prefers, increasing indentation :-) · 5cd84755
      Chris Lattner authored
      llvm-svn: 120746
      5cd84755
    • Chris Lattner's avatar
      fix PR8726 by teaching the aggregate init optimization code to handle · c5cc2fb9
      Chris Lattner authored
      structs with references in them correctly.
      
      llvm-svn: 120722
      c5cc2fb9
    • Fariborz Jahanian's avatar
      IR Gen. part of API support for __block cxx · 50198098
      Fariborz Jahanian authored
      objects imported into blocks. //rdar://8594790.
      Will have a test case coming (as well as one
      sent to llvm test suite).
      
      llvm-svn: 120713
      50198098
    • Chris Lattner's avatar
      Improve codegen for initializer lists to use memset more aggressively · 27a3631b
      Chris Lattner authored
      when an initializer is variable (I handled the constant case in a previous
      patch).  This has three pieces:
      
      1. Enhance AggValueSlot to have a 'isZeroed' bit to tell CGExprAgg that
         the memory being stored into has previously been memset to zero.
      2. Teach CGExprAgg to not emit stores of zero to isZeroed memory.
      3. Teach CodeGenFunction::EmitAggExpr to scan initializers to determine
         whether they are profitable to emit a memset + inividual stores vs
         stores for everything.
      
      The heuristic used is that a global has to be more than 16 bytes and
      has to be 3/4 zero to be candidate for this xform.  The two testcases
      are illustrative of the scenarios this catches.  We now codegen test9 into:
      
       call void @llvm.memset.p0i8.i64(i8* %0, i8 0, i64 400, i32 4, i1 false)
       %.array = getelementptr inbounds [100 x i32]* %Arr, i32 0, i32 0
       %tmp = load i32* %X.addr, align 4
       store i32 %tmp, i32* %.array
      
      and test10 into:
      
        call void @llvm.memset.p0i8.i64(i8* %0, i8 0, i64 392, i32 8, i1 false)
        %tmp = getelementptr inbounds %struct.b* %S, i32 0, i32 0
        %tmp1 = getelementptr inbounds %struct.a* %tmp, i32 0, i32 0
        %tmp2 = load i32* %X.addr, align 4
        store i32 %tmp2, i32* %tmp1, align 4
        %tmp5 = getelementptr inbounds %struct.b* %S, i32 0, i32 3
        %tmp10 = getelementptr inbounds %struct.a* %tmp5, i32 0, i32 4
        %tmp11 = load i32* %X.addr, align 4
        store i32 %tmp11, i32* %tmp10, align 4
      
      Previously we produced 99 stores of zero for test9 and also tons for test10.
      This xforms should substantially speed up -O0 builds when it kicks in as well
      as reducing code size and optimizer heartburn on insane cases.  This resolves
      PR279.
      
      llvm-svn: 120692
      27a3631b
    • Chris Lattner's avatar
      attempt to fix a buildbot failure, apparently apache fails to build. · 4fc8fb09
      Chris Lattner authored
      llvm-svn: 120688
      4fc8fb09
    • Eric Christopher's avatar
      Add support for the common and nocommon attributes. · 8a2ee390
      Eric Christopher authored
      rdar://8560647
      
      llvm-svn: 120650
      8a2ee390
    • Chris Lattner's avatar
      Enhance the init generation logic to emit a memset followed by a few stores when · e6af8862
      Chris Lattner authored
      a global is larger than 32 bytes and has fewer than 6 non-zero values in the
      initializer.  Previously we'd turn something like this:
      
      char test8(int X) {
        char str[10000] = "abc";
      
      into a 10K global variable which we then memcpy'd from.  Now we generate:
      
        %str = alloca [10000 x i8], align 16
        %tmp = getelementptr inbounds [10000 x i8]* %str, i64 0, i64 0
        call void @llvm.memset.p0i8.i64(i8* %tmp, i8 0, i64 10000, i32 16, i1 false)
        store i8 97, i8* %tmp, align 16
        %0 = getelementptr [10000 x i8]* %str, i64 0, i64 1
        store i8 98, i8* %0, align 1
        %1 = getelementptr [10000 x i8]* %str, i64 0, i64 2
        store i8 99, i8* %1, align 2
      
      Which is much smaller in space and also likely faster.
      
      This is part of PR279
      
      llvm-svn: 120645
      e6af8862
    • John McCall's avatar
      Simplify the ASTs by consolidating ObjCImplicitGetterSetterExpr and ObjCPropertyRefExpr · b7bd14fa
      John McCall authored
      into the latter.
      
      llvm-svn: 120643
      b7bd14fa
  4. Dec 01, 2010
  5. Nov 30, 2010
  6. Nov 29, 2010
  7. Nov 28, 2010
  8. Nov 25, 2010
  9. Nov 24, 2010
Loading