tools-libfsimage-prefix.diff
authorHans van Kranenburg <hans@knorrie.org>
Mon, 25 May 2020 15:08:18 +0000 (17:08 +0200)
committerHans van Kranenburg <hans@knorrie.org>
Tue, 23 Aug 2022 11:40:41 +0000 (13:40 +0200)
\o/

tools/Rules.mk
tools/libfsimage/Rules.mk
tools/libfsimage/common/Makefile

index 051a5d35557a5a199619aacfb96d94acc12939f6..ccde2d47e4494977fee72e6f89b2c0b5ab58be18 100644 (file)
@@ -16,6 +16,8 @@ INSTALL = $(XEN_ROOT)/tools/cross-install
 
 LDFLAGS += $(PREPEND_LDFLAGS_XEN_TOOLS)
 
+LDFLAGS_RPATH = -Wl,-rpath,'$${ORIGIN}$(if $(1),/$(1))'
+
 XEN_INCLUDE        = $(XEN_ROOT)/tools/include
 
 include $(XEN_ROOT)/tools/libs/uselibs.mk
index bb6d42abb494fd9892c83946de3e7c79a68649e7..38cc5396ace40170c60952f1d29c3fd1046f8c86 100644 (file)
@@ -3,10 +3,11 @@ include $(XEN_ROOT)/tools/Rules.mk
 CFLAGS += -Wno-unknown-pragmas -I$(XEN_ROOT)/tools/libfsimage/common/ -DFSIMAGE_FSDIR=\"$(FSDIR)\"
 CFLAGS += -Werror -D_GNU_SOURCE
 LDFLAGS += -L../common/
+LDFLAGS += $(call LDFLAGS_RPATH,../..)
 
 PIC_OBJS := $(patsubst %.c,%.opic,$(LIB_SRCS-y))
 
-FSDIR = $(libdir)/xenfsimage
+FSDIR = $(LIBEXEC_LIB)/xenfsimage
 
 FSLIB = fsimage.so
 
index 24bc90e73e719cda28be538e5e18e5745f1173ce..88d964a13766877b89825d9ac21c14840559748a 100644 (file)
@@ -4,6 +4,8 @@ include $(XEN_ROOT)/tools/libfsimage/Rules.mk
 MAJOR = 4.16
 MINOR = 0
 
+CFLAGS += -DFSDIR="\"$(LIBEXEC_LIB)/fs\""
+
 LDFLAGS-$(CONFIG_SunOS) = -Wl,-M -Wl,mapfile-SunOS
 LDFLAGS-$(CONFIG_Linux) = -Wl,mapfile-GNU
 LDFLAGS += $(LDFLAGS-y)
@@ -22,11 +24,11 @@ all: $(LIB)
 
 .PHONY: install
 install: all
-       $(INSTALL_DIR) $(DESTDIR)$(libdir)
+       $(INSTALL_DIR) $(DESTDIR)$(LIBEXEC_LIB)
        $(INSTALL_DIR) $(DESTDIR)$(includedir)
-       $(INSTALL_PROG) libxenfsimage.so.$(MAJOR).$(MINOR) $(DESTDIR)$(libdir)
-       ln -sf libxenfsimage.so.$(MAJOR).$(MINOR) $(DESTDIR)$(libdir)/libxenfsimage.so.$(MAJOR)
-       ln -sf libxenfsimage.so.$(MAJOR) $(DESTDIR)$(libdir)/libxenfsimage.so
+       $(INSTALL_PROG) libxenfsimage.so.$(MAJOR).$(MINOR) $(DESTDIR)$(LIBEXEC_LIB)
+       ln -sf libxenfsimage.so.$(MAJOR).$(MINOR) $(DESTDIR)$(LIBEXEC_LIB)/libxenfsimage.so.$(MAJOR)
+       ln -sf libxenfsimage.so.$(MAJOR) $(DESTDIR)$(LIBEXEC_LIB)/libxenfsimage.so
        $(INSTALL_DATA) xenfsimage.h $(DESTDIR)$(includedir)
        $(INSTALL_DATA) xenfsimage_plugin.h $(DESTDIR)$(includedir)
        $(INSTALL_DATA) xenfsimage_grub.h $(DESTDIR)$(includedir)
@@ -36,9 +38,9 @@ uninstall:
        rm -f $(DESTDIR)$(includedir)/xenfsimage_grub.h
        rm -f $(DESTDIR)$(includedir)/xenfsimage_plugin.h
        rm -f $(DESTDIR)$(includedir)/xenfsimage.h
-       rm -f $(DESTDIR)$(libdir)/libxenfsimage.so
-       rm -f $(DESTDIR)$(libdir)/libxenfsimage.so.$(MAJOR)
-       rm -f $(DESTDIR)$(libdir)/libxenfsimage.so.$(MAJOR).$(MINOR)
+       rm -f $(DESTDIR)$(LIBEXEC_LIB)/libxenfsimage.so
+       rm -f $(DESTDIR)$(LIBEXEC_LIB)/libxenfsimage.so.$(MAJOR)
+       rm -f $(DESTDIR)$(LIBEXEC_LIB)/libxenfsimage.so.$(MAJOR).$(MINOR)
 
 clean distclean::
        rm -f $(LIB)