diff --git a/valgrind-3.7.0-addToXA.patch b/valgrind-3.7.0-addToXA.patch
new file mode 100644
index 0000000..e20b0ed
--- /dev/null
+++ b/valgrind-3.7.0-addToXA.patch
@@ -0,0 +1,11 @@
+--- valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12489)
++++ valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12490)
+@@ -2661,7 +2661,7 @@ static void parse_type_DIE ( /*MOD*/XArr
+       boundE.cuOff = posn;
+       vg_assert(parser->qparentE[parser->sp].Te.TyArray.boundRs);
+       VG_(addToXA)( parser->qparentE[parser->sp].Te.TyArray.boundRs,
+-                    &boundE );
++                    &boundE.cuOff );
+       /* And record the child itself */
+       goto acquire_Bound;
+    }
diff --git a/valgrind-3.7.0-debug-leak1.patch b/valgrind-3.7.0-debug-leak1.patch
new file mode 100644
index 0000000..18fd375
--- /dev/null
+++ b/valgrind-3.7.0-debug-leak1.patch
@@ -0,0 +1,10 @@
+--- valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12408)
++++ valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12409)
+@@ -2547,6 +2547,7 @@ static void parse_type_DIE ( /*MOD*/XArr
+             const members in C++ code which are compile time constants
+             that do no exist in the class. They're not of any interest
+             to us so we ignore them. */
++         ML_(TyEnt__make_EMPTY)(&fieldE);
+       }
+    }
+ 
diff --git a/valgrind-3.7.0-debug-leak2.patch b/valgrind-3.7.0-debug-leak2.patch
new file mode 100644
index 0000000..3ab3090
--- /dev/null
+++ b/valgrind-3.7.0-debug-leak2.patch
@@ -0,0 +1,22 @@
+--- valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12418)
++++ valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12419)
+@@ -3644,9 +3644,6 @@ void new_dwarf3_reader_wrk (
+          cu_amount_used = cu_offset_now - cc.cu_start_offset;
+       }
+ 
+-      if (cu_offset_now == debug_info_sz)
+-         break;
+-
+       /* Preen to level -2.  DIEs have level >= 0 so -2 cannot occur
+          anywhere else at all.  Our fake the-entire-address-space
+          range is at level -1, so preening to -2 should completely
+@@ -3655,6 +3652,9 @@ void new_dwarf3_reader_wrk (
+       varstack_preen( &varparser, td3, -2 );
+       /* Similarly, empty the type stack out. */
+       typestack_preen( &typarser, td3, -2 );
++
++      if (cu_offset_now == debug_info_sz)
++         break;
+       /* else keep going */
+ 
+       TRACE_D3("set_abbv_Cursor cache: %lu queries, %lu misses\n",
diff --git a/valgrind-3.7.0-rvalue-ref.patch b/valgrind-3.7.0-rvalue-ref.patch
new file mode 100644
index 0000000..677c4a3
--- /dev/null
+++ b/valgrind-3.7.0-rvalue-ref.patch
@@ -0,0 +1,201 @@
+--- valgrind-3.7.0/coregrind/m_debuginfo/tytypes.c	(revision 12361)
++++ valgrind-3.7.0/coregrind/m_debuginfo/tytypes.c	(revision 12362)
+@@ -54,9 +54,10 @@ Bool ML_(TyEnt__is_type)( TyEnt* te )
+       case Te_EMPTY: case Te_INDIR: case Te_UNKNOWN: 
+       case Te_Atom:  case Te_Field: case Te_Bound:
+          return False;
+-      case Te_TyBase:   case Te_TyPorR: case Te_TyTyDef:
+-      case Te_TyStOrUn: case Te_TyEnum: case Te_TyArray:
+-      case Te_TyFn:     case Te_TyQual: case Te_TyVoid:
++      case Te_TyBase:   case Te_TyPtr:     case Te_TyRef:
++      case Te_TyPtrMbr: case Te_TyRvalRef: case Te_TyTyDef:
++      case Te_TyStOrUn: case Te_TyEnum:    case Te_TyArray:
++      case Te_TyFn:     case Te_TyQual:    case Te_TyVoid:
+          return True;
+       default:
+          vg_assert(0);
+@@ -127,10 +128,20 @@ void ML_(pp_TyEnt)( TyEnt* te )
+                      te->Te.TyBase.name ? te->Te.TyBase.name
+                                         : (UChar*)"(null)" );
+          break;
+-      case Te_TyPorR:
+-         VG_(printf)("Te_TyPorR(%d,%c,0x%05lx)",
+-                     te->Te.TyPorR.szB,
+-                     te->Te.TyPorR.isPtr ? 'P' : 'R',
++      case Te_TyPtr:
++         VG_(printf)("Te_TyPtr(%d,0x%05lx)", te->Te.TyPorR.szB,
++                     te->Te.TyPorR.typeR);
++         break;
++      case Te_TyRef:
++         VG_(printf)("Te_TyRef(%d,0x%05lx)", te->Te.TyPorR.szB,
++                     te->Te.TyPorR.typeR);
++         break;
++      case Te_TyPtrMbr:
++         VG_(printf)("Te_TyMbr(%d,0x%05lx)", te->Te.TyPorR.szB,
++                     te->Te.TyPorR.typeR);
++         break;
++      case Te_TyRvalRef:
++         VG_(printf)("Te_TyRvalRef(%d,0x%05lx)", te->Te.TyPorR.szB,
+                      te->Te.TyPorR.typeR);
+          break;
+       case Te_TyTyDef:
+@@ -237,9 +248,21 @@ void ML_(pp_TyEnt_C_ishly)( XArray* /* o
+          if (!ent->Te.TyBase.name) goto unhandled;
+          VG_(printf)("%s", ent->Te.TyBase.name);
+          break;
+-      case Te_TyPorR:
++      case Te_TyPtr:
+          ML_(pp_TyEnt_C_ishly)(tyents, ent->Te.TyPorR.typeR);
+-         VG_(printf)("%s", ent->Te.TyPorR.isPtr ? "*" : "&");
++         VG_(printf)("*");
++         break;
++      case Te_TyRef:
++         ML_(pp_TyEnt_C_ishly)(tyents, ent->Te.TyPorR.typeR);
++         VG_(printf)("&");
++         break;
++      case Te_TyPtrMbr:
++         ML_(pp_TyEnt_C_ishly)(tyents, ent->Te.TyPorR.typeR);
++         VG_(printf)("*");
++         break;
++      case Te_TyRvalRef:
++         ML_(pp_TyEnt_C_ishly)(tyents, ent->Te.TyPorR.typeR);
++         VG_(printf)("&&");
+          break;
+       case Te_TyEnum:
+          if (!ent->Te.TyEnum.name) goto unhandled;
+@@ -503,12 +526,13 @@ Word ML_(TyEnt__cmp_by_all_except_cuOff)
+       if (r != 0) return r;
+       r = Asciiz__cmp(te1->Te.TyBase.name, te2->Te.TyBase.name);
+       return r;
+-   case Te_TyPorR:
++   case Te_TyPtr:
++   case Te_TyRef:
++   case Te_TyPtrMbr:
++   case Te_TyRvalRef:
+       r = Int__cmp(te1->Te.TyPorR.szB, te2->Te.TyPorR.szB);
+       if (r != 0) return r;
+       r = UWord__cmp(te1->Te.TyPorR.typeR, te2->Te.TyPorR.typeR);
+-      if (r != 0) return r;
+-      r = Bool__cmp(te1->Te.TyPorR.isPtr, te2->Te.TyPorR.isPtr);
+       return r;
+    case Te_TyTyDef:
+       r = UWord__cmp(te1->Te.TyTyDef.typeR, te2->Te.TyTyDef.typeR);
+@@ -584,7 +608,10 @@ void ML_(TyEnt__make_EMPTY) ( TyEnt* te
+       case Te_TyBase:
+          if (te->Te.TyBase.name) ML_(dinfo_free)(te->Te.TyBase.name);
+          break;
+-      case Te_TyPorR:
++      case Te_TyPtr:
++      case Te_TyRef:
++      case Te_TyPtrMbr:
++      case Te_TyRvalRef:
+          break;
+       case Te_TyTyDef:
+          if (te->Te.TyTyDef.name) ML_(dinfo_free)(te->Te.TyTyDef.name);
+@@ -661,7 +688,10 @@ MaybeULong ML_(sizeOfType)( XArray* /* o
+          if (ent2->tag == Te_UNKNOWN)
+             return mk_MaybeULong_Nothing(); /*UNKNOWN*/
+          return ML_(sizeOfType)( tyents, ent->Te.TyTyDef.typeR );
+-      case Te_TyPorR:
++      case Te_TyPtr:
++      case Te_TyRef:
++      case Te_TyPtrMbr:
++      case Te_TyRvalRef:
+          vg_assert(ent->Te.TyPorR.szB == 4 || ent->Te.TyPorR.szB == 8);
+          return mk_MaybeULong_Just( ent->Te.TyPorR.szB );
+       case Te_TyStOrUn:
+@@ -738,7 +768,10 @@ XArray* /*UChar*/ ML_(describe_type)( /*
+          case Te_TyEnum:
+          case Te_TyFn:
+          case Te_TyVoid:
+-         case Te_TyPorR:
++         case Te_TyPtr:
++         case Te_TyRef:
++         case Te_TyPtrMbr:
++         case Te_TyRvalRef:
+          case Te_TyBase:
+             goto done;
+ 
+--- valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12361)
++++ valgrind-3.7.0/coregrind/m_debuginfo/readdwarf3.c	(revision 12362)
+@@ -2221,19 +2221,41 @@ static void parse_type_DIE ( /*MOD*/XArr
+       goto acquire_Type;
+    }
+ 
++   /*
++    * An example of DW_TAG_rvalue_reference_type:
++    *
++    * $ readelf --debug-dump /usr/lib/debug/usr/lib/libstdc++.so.6.0.16.debug
++    *  <1><1014>: Abbrev Number: 55 (DW_TAG_rvalue_reference_type)
++    *     <1015>   DW_AT_byte_size   : 4
++    *     <1016>   DW_AT_type        : <0xe52>
++    */
+    if (dtag == DW_TAG_pointer_type || dtag == DW_TAG_reference_type
+-       || dtag == DW_TAG_ptr_to_member_type) {
++       || dtag == DW_TAG_ptr_to_member_type
++       || dtag == DW_TAG_rvalue_reference_type) {
+       /* This seems legit for _pointer_type and _reference_type.  I
+          don't know if rolling _ptr_to_member_type in here really is
+          legit, but it's better than not handling it at all. */
+       VG_(memset)(&typeE, 0, sizeof(typeE));
+       typeE.cuOff = D3_INVALID_CUOFF;
+-      typeE.tag   = Te_TyPorR;
++      switch (dtag) {
++      case DW_TAG_pointer_type:
++         typeE.tag = Te_TyPtr;
++         break;
++      case DW_TAG_reference_type:
++         typeE.tag = Te_TyRef;
++         break;
++      case DW_TAG_ptr_to_member_type:
++         typeE.tag = Te_TyPtrMbr;
++         break;
++      case DW_TAG_rvalue_reference_type:
++         typeE.tag = Te_TyRvalRef;
++         break;
++      default:
++         vg_assert(False);
++      }
+       /* target type defaults to void */
+       typeE.Te.TyPorR.typeR = D3_FAKEVOID_CUOFF;
+-      typeE.Te.TyPorR.isPtr = dtag == DW_TAG_pointer_type
+-                              || dtag == DW_TAG_ptr_to_member_type;
+-      /* These three type kinds don't *have* to specify their size, in
++      /* These four type kinds don't *have* to specify their size, in
+          which case we assume it's a machine word.  But if they do
+          specify it, it must be a machine word :-)  This probably
+          assumes that the word size of the Dwarf3 we're reading is the
+@@ -2882,7 +2904,10 @@ static Bool TyEnt__subst_R_fields ( XArr
+          break;
+       case Te_TyBase:
+          break;
+-      case Te_TyPorR:
++      case Te_TyPtr:
++      case Te_TyRef:
++      case Te_TyPtrMbr:
++      case Te_TyRvalRef:
+          te->Te.TyPorR.typeR
+             = chase_cuOff( &b, ents, ents_cache, te->Te.TyPorR.typeR );
+          if (b) changed = True;
+--- valgrind-3.7.0/coregrind/m_debuginfo/priv_tytypes.h	(revision 12361)
++++ valgrind-3.7.0/coregrind/m_debuginfo/priv_tytypes.h	(revision 12362)
+@@ -45,7 +45,10 @@ typedef
+       Te_Field,    /* struct/class field defn */
+       Te_Bound,    /* array bounds indication, for one dimension */
+       Te_TyBase,   /* base type */
+-      Te_TyPorR,   /* pointer or reference type */
++      Te_TyPtr,    /* pointer type */
++      Te_TyRef,    /* reference type */
++      Te_TyPtrMbr, /* pointer to member type */
++      Te_TyRvalRef,/* rvalue reference type */
+       Te_TyTyDef,  /* a renaming of some other type */
+       Te_TyStOrUn, /* structure or union type */
+       Te_TyEnum,   /* an enum type */
+@@ -101,7 +104,6 @@ typedef
+          struct {
+             Int   szB;
+             UWord typeR;
+-            Bool  isPtr;
+          } TyPorR;
+          struct {
+             UChar* name;  /* in mallocville */
diff --git a/valgrind.spec b/valgrind.spec
index 94052ba..7c70552 100644
--- a/valgrind.spec
+++ b/valgrind.spec
@@ -22,7 +22,11 @@ Patch11: valgrind-3.7.0-scsi-ioctls.patch
 Patch12: valgrind-3.7.0-enable-armv5.patch
 Patch13: valgrind-3.7.0-ldso-supp.patch
 Patch14: valgrind-3.7.0-unspecified-type.patch
-Patch15: valgrind-3.7.0-debug-types.patch
+Patch15: valgrind-3.7.0-rvalue-ref.patch
+Patch16: valgrind-3.7.0-debug-leak1.patch
+Patch17: valgrind-3.7.0-debug-leak2.patch
+Patch18: valgrind-3.7.0-addToXA.patch
+Patch19: valgrind-3.7.0-debug-types.patch
 
 Obsoletes: valgrind-callgrind
 %ifarch x86_64 ppc64
@@ -117,6 +121,10 @@ for details.
 %patch13 -p1
 %patch14 -p1
 %patch15 -p1
+%patch16 -p1
+%patch17 -p1
+%patch18 -p1
+%patch19 -p1
 
 %build
 CC=gcc
@@ -213,7 +221,8 @@ echo ===============END TESTING===============
 %changelog
 * Mon May  7 2012 Jakub Jelinek <jakub@redhat.com> 3.7.0-3
 - adjust suppressions so that it works even with ld-2.15.so (#806854)
-- handle DW_TAG_unspecified_type (#810284, KDE#278313)
+- handle DW_TAG_unspecified_type and DW_TAG_rvalue_reference_type
+  (#810284, KDE#278313)
 - handle .debug_types sections (#810286, KDE#284124)
 
 * Sun Mar  4 2012 Peter Robinson <pbrobinson@fedoraproject.org> 3.7.0-2