From eb1c4db03967f28efd280ecb869009e9fe9c9dab Mon Sep 17 00:00:00 2001
From: Felix Fietkau <nbd@openwrt.org>
Date: Tue, 13 Jan 2009 03:21:25 +0000
Subject: [PATCH] add support for an optional staging directory for debug
 binaries

SVN-Revision: 14018
---
 Config.in                   |  7 +++++++
 include/package-debug.mk    | 26 ++++++++++++++++++++++++++
 include/package.mk          |  3 ++-
 package/base-files/Makefile |  1 +
 rules.mk                    |  1 +
 5 files changed, 37 insertions(+), 1 deletion(-)
 create mode 100644 include/package-debug.mk

diff --git a/Config.in b/Config.in
index a952f462f8..a5b3364612 100644
--- a/Config.in
+++ b/Config.in
@@ -106,6 +106,13 @@ config DEBUG
 	help
 		Disables stripping and adds -g3 to the CFLAGS
 
+config DEBUG_DIR
+	bool "Install debugging binaries into a staging directory"
+	default n
+	help
+		This will install all compiled package binaries into build_dir/target-*/debug-*/,
+		useful for cross-debugging via gdb/gdbserver
+
 config NO_STRIP
 	bool "Install unstripped binary on the target (useful for native compiling/debugging)"
 	default n
diff --git a/include/package-debug.mk b/include/package-debug.mk
new file mode 100644
index 0000000000..2a85bfebb8
--- /dev/null
+++ b/include/package-debug.mk
@@ -0,0 +1,26 @@
+# 
+# Copyright (C) 2006,2007 OpenWrt.org
+#
+# This is free software, licensed under the GNU General Public License v2.
+# See /LICENSE for more information.
+#
+
+ifeq ($(DUMP),)
+  define BuildTarget/debug
+
+    DEBUG_STAMP_$(1) := $(DEBUG_DIR)/stamp/$(1)
+
+    ifdef Package/$(1)/install
+      ifneq ($(CONFIG_PACKAGE_$(1))$(SDK)$(DEVELOPER),)
+        compile: $$(DEBUG_STAMP_$(1))
+      endif
+    endif
+
+    $$(DEBUG_STAMP_$(1)): $(PKG_BUILD_DIR)/.built
+		mkdir -p $(DEBUG_DIR)/stamp
+		$(call Package/$(1)/install,$(DEBUG_DIR))
+		touch $$(DEBUG_STAMP_$(1))
+
+
+  endef
+endif
diff --git a/include/package.mk b/include/package.mk
index 4e31258305..04625d9b94 100644
--- a/include/package.mk
+++ b/include/package.mk
@@ -27,6 +27,7 @@ include $(INCLUDE_DIR)/quilt.mk
 include $(INCLUDE_DIR)/package-defaults.mk
 include $(INCLUDE_DIR)/package-dumpinfo.mk
 include $(INCLUDE_DIR)/package-ipkg.mk
+include $(INCLUDE_DIR)/package-debug.mk
 include $(INCLUDE_DIR)/package-bin.mk
 include $(INCLUDE_DIR)/autotools.mk
 
@@ -146,7 +147,7 @@ endif
     $(Dumpinfo), \
     $(foreach target, \
       $(if $(Package/$(1)/targets),$(Package/$(1)/targets), \
-        $(if $(PKG_TARGETS),$(PKG_TARGETS), ipkg ) \
+        $(if $(PKG_TARGETS),$(PKG_TARGETS), ipkg $(if $(CONFIG_DEBUG_DIR),debug)) \
       ), $(BuildTarget/$(target)) \
     ) \
   )
diff --git a/package/base-files/Makefile b/package/base-files/Makefile
index 52e70e5ce6..581aa9365c 100644
--- a/package/base-files/Makefile
+++ b/package/base-files/Makefile
@@ -160,6 +160,7 @@ define Package/base-files$(TARGET)/install
 		$(SED) 's/$$$$/:13848:0:99999:7:::/' $(1)/etc/shadow \
 	)
 	$(SED) 's,$$$$R,$(REVISION),g' $(1)/etc/banner
+	mkdir -p $(1)/CONTROL
 	mkdir -p $(1)/dev
 	mkdir -p $(1)/etc/crontabs
 	mkdir -p $(1)/jffs
diff --git a/rules.mk b/rules.mk
index bb46f16b2d..5e44756214 100644
--- a/rules.mk
+++ b/rules.mk
@@ -64,6 +64,7 @@ PACKAGE_DIR:=$(BIN_DIR)/packages/$(ARCH)
 STAMP_DIR:=$(BUILD_DIR)/stamp
 STAMP_DIR_HOST=$(BUILD_DIR_HOST)/stamp
 TARGET_DIR:=$(BUILD_DIR)/root-$(BOARD)
+DEBUG_DIR:=$(BUILD_DIR)/debug-$(BOARD)
 IPKG_STATE_DIR:=$(TARGET_DIR)/usr/lib/ipkg
 
 TARGET_PATH:=$(TOOLCHAIN_DIR)/usr/bin:$(STAGING_DIR_HOST)/bin:$(STAGING_DIR)/host/bin:$(PATH)
-- 
GitLab