olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone

Blame SOURCES/glibc-rh1256317-14.patch

bca718
Again we have to fix librtkaio to use MODULE_NAME definitions to
bca718
work around the changes we are making and preserve ABI/API.
bca718
bca718
commit 279bc5b3c384c09746fbadb2b68c6db9e833c064
bca718
Author: Siddhesh Poyarekar <siddhesh@redhat.com>
bca718
Date:   Thu Nov 20 11:42:00 2014 +0530
bca718
bca718
    Use MODULE_NAME in stap-probe instead of IN_LIB
bca718
    
bca718
    Define MODULE_NAME in the build command and define IN_MODULE using
bca718
    MODULE_NAME.  Verified that the generated code is unchanged on x86_64.
bca718
    
bca718
    	* Makeconfig (module-cppflags-real): Define MODULE_NAME
bca718
    	instead of IN_MODULE.
bca718
    	* include/libc-symbols.h (IN_MODULE): Define using
bca718
    	MODULE_NAME.
bca718
    	(PASTE_NAME, PASTE_NAME1): New macros.
bca718
    	* include/stap-probe.h (LIBC_PROBE_1): Use MODULE_NAME instead
bca718
    	of IN_LIB.
bca718
    	(STAP_PROBE_ASM): Likewise.
bca718
bca718
Index: glibc-2.17-c758a686/Makeconfig
bca718
===================================================================
bca718
--- glibc-2.17-c758a686.orig/Makeconfig
bca718
+++ glibc-2.17-c758a686/Makeconfig
bca718
@@ -741,7 +741,7 @@ in-module = $(subst -,_,$(firstword $(li
bca718
 				    libc))
bca718
 
bca718
 module-cppflags-real = -include $(common-objpfx)libc-modules.h \
bca718
-		       -DIN_MODULE=MODULE_$(in-module)
bca718
+		       -DMODULE_NAME=$(in-module)
bca718
 
bca718
 # We don't need libc-modules.h and the MODULE_NAME definition for .v.i
bca718
 # files.  These targets don't (and will likely never need to) use the IS_IN
bca718
@@ -940,7 +940,7 @@ postclean-generated += soversions.mk sov
bca718
 before-compile += $(common-objpfx)libc-modules.h
bca718
 ifeq ($(soversions.mk-done),t)
bca718
 # Generate a header with macro definitions for use with the IS_IN macro.
bca718
-# These are the possible values for the IN_MODULE macro defined when building
bca718
+# These are the possible values for the MODULE_NAME macro defined when building
bca718
 # sources, to identify which module the translation unit is going to be built
bca718
 # into.
bca718
 $(common-objpfx)libc-modules.h: $(common-objpfx)libc-modules.stmp; @:
bca718
Index: glibc-2.17-c758a686/include/libc-symbols.h
bca718
===================================================================
bca718
--- glibc-2.17-c758a686.orig/include/libc-symbols.h
bca718
+++ glibc-2.17-c758a686/include/libc-symbols.h
bca718
@@ -20,8 +20,12 @@
bca718
 #ifndef _LIBC_SYMBOLS_H
bca718
 #define _LIBC_SYMBOLS_H	1
bca718
 
bca718
+#define IN_MODULE PASTE_NAME (MODULE_, MODULE_NAME)
bca718
 #define IS_IN(lib) (IN_MODULE == MODULE_##lib)
bca718
 
bca718
+#define PASTE_NAME(a,b)      PASTE_NAME1 (a,b)
bca718
+#define PASTE_NAME1(a,b)     a##b
bca718
+
bca718
 /* This file's macros are included implicitly in the compilation of every
bca718
    file in the C library by -imacros.
bca718
 
bca718
Index: glibc-2.17-c758a686/include/stap-probe.h
bca718
===================================================================
bca718
--- glibc-2.17-c758a686.orig/include/stap-probe.h
bca718
+++ glibc-2.17-c758a686/include/stap-probe.h
bca718
@@ -30,7 +30,7 @@
bca718
 
bca718
    Systemtap's header defines the macros STAP_PROBE (provider, name) and
bca718
    STAP_PROBEn (provider, name, arg1, ..., argn).  For "provider" we paste
bca718
-   in the IN_LIB name (libc, libpthread, etc.) automagically.  */
bca718
+   in MODULE_NAME (libc, libpthread, etc.) automagically.  */
bca718
 
bca718
 # ifndef NOT_IN_libc
bca718
 #  define IN_LIB	libc
bca718
@@ -45,7 +45,7 @@
bca718
 # endif
bca718
 
bca718
 # define LIBC_PROBE(name, n, ...)	\
bca718
-  LIBC_PROBE_1 (IN_LIB, name, n, ## __VA_ARGS__)
bca718
+  LIBC_PROBE_1 (MODULE_NAME, name, n, ## __VA_ARGS__)
bca718
 
bca718
 # define LIBC_PROBE_1(lib, name, n, ...) \
bca718
   STAP_PROBE##n (lib, name, ## __VA_ARGS__)
bca718
@@ -53,7 +53,7 @@
bca718
 # define STAP_PROBE0		STAP_PROBE
bca718
 
bca718
 # define LIBC_PROBE_ASM(name, template) \
bca718
-  STAP_PROBE_ASM (IN_LIB, name, template)
bca718
+  STAP_PROBE_ASM (MODULE_NAME, name, template)
bca718
 
bca718
 # define LIBC_PROBE_ASM_OPERANDS STAP_PROBE_ASM_OPERANDS
bca718
 
bca718
Index: glibc-2.17-c758a686/rtkaio/Makefile
bca718
===================================================================
bca718
--- glibc-2.17-c758a686.orig/rtkaio/Makefile
bca718
+++ glibc-2.17-c758a686/rtkaio/Makefile
bca718
@@ -70,7 +70,9 @@ CFLAGS-kaio_librt-cancellation.c = -fasy
bca718
 LDFLAGS-rtkaio.so = -Wl,-soname=lib$(libprefix)rt.so$(librt.so-version) \
bca718
 		    -Wl,--enable-new-dtags,-z,nodelete
bca718
 CPPFLAGS-librtkaio += -UIN_MODULE -DIN_MODULE=MODULE_librt \
bca718
-		      -UIS_IN_librt -DIS_IN_librt=1 -I$(..)rt
bca718
+		      -UMODULE_NAME -DMODULE_NAME=librt \
bca718
+		      -UIS_IN_librt -DIS_IN_librt=1 \
bca718
+		      -I$(..)rt
bca718
 
bca718
 rpath-dirs := $(patsubst rt,rtkaio,$(rpath-dirs))
bca718