Blame SOURCES/valgrind-3.13.0-arm-index-hardwire.patch

b895e3
diff --git a/coregrind/m_redir.c b/coregrind/m_redir.c
b895e3
index b8cc022..d54cae7 100644
b895e3
--- a/coregrind/m_redir.c
b895e3
+++ b/coregrind/m_redir.c
b895e3
@@ -1485,6 +1485,17 @@ void VG_(redir_initialise) ( void )
b895e3
          (Addr)&VG_(arm_linux_REDIR_FOR_strcmp),
b895e3
          complain_about_stripped_glibc_ldso
b895e3
       );
b895e3
+      /* index */
b895e3
+      add_hardwired_spec(
b895e3
+         "ld-linux.so.3", "index",
b895e3
+         (Addr)&VG_(arm_linux_REDIR_FOR_index),
b895e3
+         complain_about_stripped_glibc_ldso
b895e3
+      );
b895e3
+      add_hardwired_spec(
b895e3
+         "ld-linux-armhf.so.3", "index",
b895e3
+         (Addr)&VG_(arm_linux_REDIR_FOR_index),
b895e3
+         complain_about_stripped_glibc_ldso
b895e3
+      );
b895e3
    }
b895e3
 
b895e3
 #  elif defined(VGP_arm64_linux)
b895e3
diff --git a/coregrind/m_trampoline.S b/coregrind/m_trampoline.S
b895e3
index a532071..0488b54 100644
b895e3
--- a/coregrind/m_trampoline.S
b895e3
+++ b/coregrind/m_trampoline.S
b895e3
@@ -625,26 +625,26 @@ VG_(arm_linux_REDIR_FOR_strlen):
b895e3
 	bx	lr
b895e3
 	UD2_4
b895e3
 
b895e3
-//.global VG_(arm_linux_REDIR_FOR_index)
b895e3
-//VG_(arm_linux_REDIR_FOR_index):
b895e3
-//	ldrb	r3, [r0, #0]	@ zero_extendqisi2
b895e3
-//	and	r1, r1, #255
b895e3
-//	cmp	r3, r1
b895e3
-//	@ lr needed for prologue
b895e3
-//	bne	.L9
b895e3
-//	bx	lr
b895e3
-//.L12:
b895e3
-//	ldrb	r3, [r0, #1]!	@ zero_extendqisi2
b895e3
-//	cmp	r3, r1
b895e3
-//	beq	.L11
b895e3
-//.L9:
b895e3
-//	cmp	r3, #0
b895e3
-//	bne	.L12
b895e3
-//	mov	r0, #0
b895e3
-//	bx	lr
b895e3
-//.L11:
b895e3
-//	bx	lr
b895e3
-//	UD2_4
b895e3
+.global VG_(arm_linux_REDIR_FOR_index)
b895e3
+VG_(arm_linux_REDIR_FOR_index):
b895e3
+	ldrb	r3, [r0, #0]	@ zero_extendqisi2
b895e3
+	and	r1, r1, #255
b895e3
+	cmp	r3, r1
b895e3
+	@ lr needed for prologue
b895e3
+	bne	.L9
b895e3
+	bx	lr
b895e3
+.L12:
b895e3
+	ldrb	r3, [r0, #1]!	@ zero_extendqisi2
b895e3
+	cmp	r3, r1
b895e3
+	beq	.L11
b895e3
+.L9:
b895e3
+	cmp	r3, #0
b895e3
+	bne	.L12
b895e3
+	mov	r0, #0
b895e3
+	bx	lr
b895e3
+.L11:
b895e3
+	bx	lr
b895e3
+	UD2_4
b895e3
 
b895e3
 .global VG_(arm_linux_REDIR_FOR_memcpy)
b895e3
 VG_(arm_linux_REDIR_FOR_memcpy):
b895e3
diff --git a/coregrind/pub_core_trampoline.h b/coregrind/pub_core_trampoline.h
b895e3
index 3a9bafe..e29427d 100644
b895e3
--- a/coregrind/pub_core_trampoline.h
b895e3
+++ b/coregrind/pub_core_trampoline.h
b895e3
@@ -100,7 +100,7 @@ extern Addr VG_(ppctoc_magic_redirect_return_stub);
b895e3
 extern Addr  VG_(arm_linux_SUBST_FOR_sigreturn);
b895e3
 extern Addr  VG_(arm_linux_SUBST_FOR_rt_sigreturn);
b895e3
 extern UInt  VG_(arm_linux_REDIR_FOR_strlen)( void* );
b895e3
-//extern void* VG_(arm_linux_REDIR_FOR_index) ( void*, Int );
b895e3
+extern void* VG_(arm_linux_REDIR_FOR_index) ( void*, Int );
b895e3
 extern void* VG_(arm_linux_REDIR_FOR_memcpy)( void*, void*, Int );
b895e3
 extern void* VG_(arm_linux_REDIR_FOR_strcmp)( void*, void* );
b895e3
 #endif