From patchwork Tue Jan 29 22:33:13 2013 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Yann E. MORIN" X-Patchwork-Id: 216679 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Received: from fraxinus.osuosl.org (fraxinus.osuosl.org [140.211.166.137]) by ozlabs.org (Postfix) with ESMTP id C59162C0096 for ; Wed, 30 Jan 2013 09:37:09 +1100 (EST) Received: from localhost (localhost [127.0.0.1]) by fraxinus.osuosl.org (Postfix) with ESMTP id 2A6AB1024CB; Tue, 29 Jan 2013 22:36:55 +0000 (UTC) X-Virus-Scanned: amavisd-new at osuosl.org X-Amavis-Alert: BAD HEADER SECTION, Duplicate header field: "References" Received: from fraxinus.osuosl.org ([127.0.0.1]) by localhost (.osuosl.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id nIVs3Ge8Q9U8; Tue, 29 Jan 2013 22:35:09 +0000 (UTC) Received: from ash.osuosl.org (ash.osuosl.org [140.211.166.34]) by fraxinus.osuosl.org (Postfix) with ESMTP id B2AC310269D; Tue, 29 Jan 2013 22:33:40 +0000 (UTC) X-Original-To: buildroot@lists.busybox.net Delivered-To: buildroot@osuosl.org Received: from whitealder.osuosl.org (whitealder.osuosl.org [140.211.166.138]) by ash.osuosl.org (Postfix) with ESMTP id 70E348F753 for ; Tue, 29 Jan 2013 22:33:50 +0000 (UTC) Received: from localhost (localhost [127.0.0.1]) by whitealder.osuosl.org (Postfix) with ESMTP id 217EF81486 for ; Tue, 29 Jan 2013 22:33:43 +0000 (UTC) X-Virus-Scanned: amavisd-new at osuosl.org X-Amavis-Alert: BAD HEADER SECTION, Duplicate header field: "References" Received: from whitealder.osuosl.org ([127.0.0.1]) by localhost (.osuosl.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id atTpbRrOy8-C for ; Tue, 29 Jan 2013 22:33:34 +0000 (UTC) X-Greylist: domain auto-whitelisted by SQLgrey-1.7.6 Received: from mail-wg0-f51.google.com (mail-wg0-f51.google.com [74.125.82.51]) by whitealder.osuosl.org (Postfix) with ESMTPS id 742B1814B9 for ; Tue, 29 Jan 2013 22:33:33 +0000 (UTC) Received: by mail-wg0-f51.google.com with SMTP id 8so690000wgl.18 for ; Tue, 29 Jan 2013 14:33:32 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=x-received:sender:from:to:cc:subject:date:message-id:x-mailer :in-reply-to:references:in-reply-to:references; bh=w+tUcbtYBz7kloDskxR/HB7yhtb8gRgSdVbsCcr6FcM=; b=RYRF34MiSdO/TymbzIx8oxFBRCb6z85Z7ZcyUSxvEOiKBCRTcyTmfVIXCxGXxsD7+p I9XWaJtthFP6eEn8dR3Qn7EM/OUdihQOpiQyg4zjQ5ClyT6MLYgcLVYx0cpFH/VOXglU bJZWyXpQv0Hdbxqpr30fXOqVkIIU7mJqQ21IVYE/goWUytRsJuP/lETUsrg9yz6bOJgQ ScttFPUsNNjRr2tg7hCYhBSRCsfkcFjNdpZRBKKcUP94U8GE12z/w1/xxE+3JB0h6XDX HJwNP3TnbaCcIFOBzWCsVZKzMrXik3eh6jAMQHe70dRAod49iAl9OYUJ8R4wYW9Z8lVH ysJQ== X-Received: by 10.180.93.41 with SMTP id cr9mr5089065wib.19.1359498811829; Tue, 29 Jan 2013 14:33:31 -0800 (PST) Received: from localhost.localdomain (ARennes-256-1-39-23.w90-32.abo.wanadoo.fr. [90.32.22.23]) by mx.google.com with ESMTPS id ge2sm5783222wib.4.2013.01.29.14.33.28 (version=TLSv1 cipher=RC4-SHA bits=128/128); Tue, 29 Jan 2013 14:33:30 -0800 (PST) From: "Yann E. MORIN" To: buildroot@busybox.net Date: Tue, 29 Jan 2013 23:33:13 +0100 Message-Id: X-Mailer: git-send-email 1.7.2.5 In-Reply-To: References: In-Reply-To: References: Cc: "Yann E. MORIN" Subject: [Buildroot] [PATCH 2/7] package/pmake: add host pmake X-BeenThere: buildroot@busybox.net X-Mailman-Version: 2.1.14 Precedence: list List-Id: Discussion and development of buildroot List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Errors-To: buildroot-bounces@busybox.net Sender: buildroot-bounces@busybox.net pmake is the make command used by the BSD. It will used to build BSD-related packages, coming later. Signed-off-by: "Yann E. MORIN" --- package/pmake/pmake-100_mk.patch | 2624 ++++++++++++++++++++++++++++++ package/pmake/pmake-110_mkdep.patch | 230 +++ package/pmake/pmake-120_fixes.patch | 266 +++ package/pmake/pmake-130_maxpathlen.patch | 39 + package/pmake/pmake-140_multiarch.patch | 354 ++++ package/pmake/pmake-150_mktemp.patch | 31 + package/pmake/pmake.mk | 46 + 7 files changed, 3590 insertions(+), 0 deletions(-) create mode 100644 package/pmake/pmake-100_mk.patch create mode 100644 package/pmake/pmake-110_mkdep.patch create mode 100644 package/pmake/pmake-120_fixes.patch create mode 100644 package/pmake/pmake-130_maxpathlen.patch create mode 100644 package/pmake/pmake-140_multiarch.patch create mode 100644 package/pmake/pmake-150_mktemp.patch create mode 100644 package/pmake/pmake.mk diff --git a/package/pmake/pmake-100_mk.patch b/package/pmake/pmake-100_mk.patch new file mode 100644 index 0000000..1786690 --- /dev/null +++ b/package/pmake/pmake-100_mk.patch @@ -0,0 +1,2624 @@ +Patch vampirised from Debian's package pmake_1.111-3.2: + http://snapshot.debian.org/archive/debian/20120601T033558Z/pool/main/p/pmake/ + +Signed-off-by: "Yann E. MORIN" + +--- pmake-1.111.orig/mk/Makefile ++++ pmake-1.111/mk/Makefile +@@ -0,0 +1,16 @@ ++# $NetBSD: Makefile,v 1.24 1999/02/13 02:54:36 lukem Exp $ ++# @(#)Makefile 8.1 (Berkeley) 6/8/93 ++ ++.include ++ ++.if ${MKSHARE} != "no" ++FILES= bsd.README bsd.doc.mk bsd.dep.mk bsd.files.mk bsd.inc.mk bsd.info.mk \ ++ bsd.kinc.mk bsd.kmod.mk bsd.lib.mk bsd.links.mk bsd.man.mk bsd.nls.mk \ ++ bsd.obj.mk bsd.own.mk bsd.prog.mk bsd.subdir.mk bsd.sys.mk sys.mk ++FILESDIR=/usr/share/mk ++.endif ++MKOBJ= no ++ ++FILESMODE=444 ++ ++.include +--- pmake-1.111.orig/mk/bsd.README ++++ pmake-1.111/mk/bsd.README +@@ -0,0 +1,536 @@ ++# $NetBSD: bsd.README,v 1.48 1999/02/13 03:04:09 lukem Exp $ ++# @(#)bsd.README 8.2 (Berkeley) 4/2/94 ++ ++This is the README file for the new make "include" files for the BSD ++source tree. The files are installed in /usr/share/mk, and are, by ++convention, named with the suffix ".mk". ++ ++Note, this file is not intended to replace reading through the .mk ++files for anything tricky. ++ ++=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= ++ ++RANDOM THINGS WORTH KNOWING: ++ ++The files are simply C-style #include files, and pretty much behave like ++you'd expect. The syntax is slightly different in that a single '.' is ++used instead of the hash mark, i.e. ".include ". ++ ++One difference that will save you lots of debugging time is that inclusion ++of the file is normally done at the *end* of the Makefile. The reason for ++this is because .mk files often modify variables and behavior based on the ++values of variables set in the Makefile. To make this work, remember that ++the FIRST target found is the target that is used, i.e. if the Makefile has: ++ ++ a: ++ echo a ++ a: ++ echo a number two ++ ++the command "make a" will echo "a". To make things confusing, the SECOND ++variable assignment is the overriding one, i.e. if the Makefile has: ++ ++ a= foo ++ a= bar ++ ++ b: ++ echo ${a} ++ ++the command "make b" will echo "bar". This is for compatibility with the ++way the V7 make behaved. ++ ++It's fairly difficult to make the BSD .mk files work when you're building ++multiple programs in a single directory. It's a lot easier split up the ++programs than to deal with the problem. Most of the agony comes from making ++the "obj" directory stuff work right, not because we switched to a new version ++of make. So, don't get mad at us, figure out a better way to handle multiple ++architectures so we can quit using the symbolic link stuff. (Imake doesn't ++count.) ++ ++The file .depend in the source directory is expected to contain dependencies ++for the source files. This file is read automatically by make after reading ++the Makefile. ++ ++The variable DESTDIR works as before. It's not set anywhere but will change ++the tree where the file gets installed. ++ ++The profiled libraries are no longer built in a different directory than ++the regular libraries. A new suffix, ".po", is used to denote a profiled ++object, and ".so" denotes a shared (position-independent) object. ++ ++The following variables that control how things are made/installed that ++are not set by default. These should not be set by Makefiles; they're for ++the user to define in MAKECONF (see bsd.own.mk, below) or on the make(1) ++command line: ++ ++BUILD If defined, 'make install' checks that the targets in the ++ source directories are up-to-date and remakes them if they ++ are out of date, instead of blindly trying to install ++ out of date or non-existant targets. ++ ++UPDATE If defined, 'make install' only installs targets that are ++ more recently modified in the source directories that their ++ installed counterparts. ++ ++MKCATPAGES If "no", don't build or install the catman pages. ++ ++MKDOC If "no", don't build or install the documentation. ++ ++MKINFO If "no", don't build or install Info documentation from ++ Texinfo source files. ++ ++MKLINT If "no", don't build or install the lint libraries. ++ ++MKMAN If "no", don't build or install the man or catman pages. ++ Also acts as "MKCATPAGES=no" ++ ++MKNLS If "no", don't build or install the NLS files. ++ ++MKOBJ If "no", don't create objdirs. ++ ++MKPIC If "no", don't build or install shared libraries. ++ ++MKPICINSTALL If "no", don't install the *_pic.a libraries. ++ ++MKPROFILE If "no", don't build or install the profiling libraries. ++ ++MKSHARE If "no", act as "MKCATPAGES=no MKDOC=no MKINFO=no MKMAN=no ++ MKNLS=no". I.e, don't build catman pages, documentation, ++ Info documentation, man pages, NLS files, ... ++ ++=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= ++ ++The include file has the default rules for all makes, in the BSD ++environment or otherwise. You probably don't want to touch this file. ++ ++=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= ++ ++The include file handles installing manual pages and their ++links. ++ ++It has a two targets: ++ ++ maninstall: ++ Install the manual page sources and their links. ++ catinstall: ++ Install the preformatted manual pages and their links. ++ ++It sets/uses the following variables: ++ ++MANDIR Base path for manual installation. ++ ++MANGRP Manual group. ++ ++MANOWN Manual owner. ++ ++MANMODE Manual mode. ++ ++MANSUBDIR Subdirectory under the manual page section, i.e. "/vax" ++ or "/tahoe" for machine specific manual pages. ++ ++MAN The manual pages to be installed (use a .1 - .9 suffix). ++ ++MLINKS List of manual page links (using a .1 - .9 suffix). The ++ linked-to file must come first, the linked file second, ++ and there may be multiple pairs. The files are soft-linked. ++ ++The include file includes a file named "../Makefile.inc" if ++it exists. ++ ++=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= ++ ++The include file contains source tree configuration parameters, ++such as the owners, groups, etc. for both manual pages and binaries, and ++a few global "feature configuration" parameters. ++ ++It has no targets. ++ ++To get system-specific configuration parameters, bsd.own.mk will try to ++include the file specified by the "MAKECONF" variable. If MAKECONF is not ++set, or no such file exists, the system make configuration file, /etc/mk.conf ++is included. These files may define any of the variables described below. ++ ++bsd.own.mk sets the following variables, if they are not already defined ++(defaults are in brackets): ++ ++BSDSRCDIR The real path to the system sources, so that 'make obj' ++ will work correctly. [/usr/src] ++ ++BSDOBJDIR The real path to the system 'obj' tree, so that 'make obj' ++ will work correctly. [/usr/obj] ++ ++BINGRP Binary group. [wheel] ++ ++BINOWN Binary owner. [root] ++ ++BINMODE Binary mode. [555] ++ ++NONBINMODE Mode for non-executable files. [444] ++ ++MANDIR Base path for manual installation. [/usr/share/man/cat] ++ ++MANGRP Manual group. [wheel] ++ ++MANOWN Manual owner. [root] ++ ++MANMODE Manual mode. [${NONBINMODE}] ++ ++MANINSTALL Manual installation type: maninstall, catinstall, or both ++ ++LIBDIR Base path for library installation. [/usr/lib] ++ ++LINTLIBDIR Base path for lint(1) library installation. [/usr/libdata/lint] ++ ++LIBGRP Library group. [${BINGRP}] ++ ++LIBOWN Library owner. [${BINOWN}] ++ ++LIBMODE Library mode. [${NONBINMODE}] ++ ++DOCDIR Base path for system documentation (e.g. PSD, USD, etc.) ++ installation. [/usr/share/doc] ++ ++DOCGRP Documentation group. [wheel] ++ ++DOCOWN Documentation owner. [root] ++ ++DOCMODE Documentation mode. [${NONBINMODE}] ++ ++NLSDIR Base path for National Language Support files installation. ++ [/usr/share/nls] ++ ++NLSGRP National Language Support files group. [wheel] ++ ++NLSOWN National Language Support files owner. [root] ++ ++NLSMODE National Language Support files mode. [${NONBINMODE}] ++ ++STRIPFLAG The flag passed to the install program to cause the binary ++ to be stripped. This is to be used when building your ++ own install script so that the entire system can be made ++ stripped/not-stripped using a single knob. [-s] ++ ++COPY The flag passed to the install program to cause the binary ++ to be copied rather than moved. This is to be used when ++ building our own install script so that the entire system ++ can either be installed with copies, or with moves using ++ a single knob. [-c] ++ ++Additionally, the following variables may be set by bsd.own.mk or in a ++make configuration file to modify the behaviour of the system build ++process (default values are in brackets along with comments, if set by ++bsd.own.mk): ++ ++EXPORTABLE_SYSTEM ++ Do not build /usr/src/domestic, even if it is present. ++ ++SKEY Compile in support for S/key authentication. [yes, set ++ unconditionally] ++ ++KERBEROS Compile in support for Kerberos 4 authentication. ++ ++KERBEROS5 Compile in support for Kerberos 5 authentication. ++ ++MANZ Compress manual pages at installation time. ++ ++SYS_INCLUDE Copy or symlink kernel include files into /usr/include. ++ Possible values are "symlinks" or "copies" (which is ++ the same as the variable being unset). ++ ++NOPROFILE Do not build profiled versions of system libraries ++ ++NOPIC Do not build PIC versions of system libraries, and ++ do not build shared libraries. ++ ++NOLINT Do not build lint libraries. ++ ++OBJECT_FMT Object file format. [set to "ELF" on ports that use ++ ELF -- currently if ${MACHINE_ARCH} is "alpha", "mips" ++ or "powerpc" or set to "a.out" on other ports]. ++ ++ ++bsd.own.mk is generally useful when building your own Makefiles so that ++they use the same default owners etc. as the rest of the tree. ++ ++=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= ++ ++The include file handles building programs from one or ++more source files, along with their manual pages. It has a limited number ++of suffixes, consistent with the current needs of the BSD tree. ++ ++It has eight targets: ++ ++ all: ++ build the program and its manual page ++ clean: ++ remove the program, any object files and the files a.out, ++ Errs, errs, mklog, and ${PROG}.core. ++ cleandir: ++ remove all of the files removed by the target clean, as ++ well as .depend, tags, and any manual pages. ++ `distclean' is a synonym for `cleandir'. ++ depend: ++ make the dependencies for the source files, and store ++ them in the file .depend. ++ includes: ++ install any header files. ++ install: ++ install the program and its manual pages; if the Makefile ++ does not itself define the target install, the targets ++ beforeinstall and afterinstall may also be used to cause ++ actions immediately before and after the install target ++ is executed. ++ lint: ++ run lint on the source files ++ tags: ++ create a tags file for the source files. ++ ++It sets/uses the following variables: ++ ++BINGRP Binary group. ++ ++BINOWN Binary owner. ++ ++BINMODE Binary mode. ++ ++CLEANFILES Additional files to remove for the clean and cleandir targets. ++ ++COPTS Additional flags to the compiler when creating C objects. ++ ++CPPFLAGS Additional flags to the C pre-processor ++ ++LDADD Additional loader objects. Usually used for libraries. ++ For example, to load with the compatibility and utility ++ libraries, use: ++ ++ LDADD+=-lutil -lcompat ++ ++LDFLAGS Additional loader flags. ++ ++LINKS The list of binary links; should be full pathnames, the ++ linked-to file coming first, followed by the linked ++ file. The files are hard-linked. For example, to link ++ /bin/test and /bin/[, use: ++ ++ LINKS= ${DESTDIR}/bin/test ${DESTDIR}/bin/[ ++ ++SYMLINKS The list of symbolic links; should be full pathnames. ++ Syntax is identical to LINKS. Note that DESTDIR is not ++ automatically included in the link. ++ ++MAN Manual pages (should end in .1 - .9). If no MAN variable is ++ defined, "MAN=${PROG}.1" is assumed. ++ ++PROG The name of the program to build. If not supplied, nothing ++ is built. ++ ++PROGNAME The name that the above program will be installed as, if ++ different from ${PROG}. ++ ++SRCS List of source files to build the program. If SRCS is not ++ defined, it's assumed to be ${PROG}.c. ++ ++DPADD Additional dependencies for the program. Usually used for ++ libraries. For example, to depend on the compatibility and ++ utility libraries use: ++ ++ DPADD+=${LIBCOMPAT} ${LIBUTIL} ++ ++ The following libraries are predefined for DPADD: ++ ++ LIBC?= ${DESTDIR}/usr/lib/libc.a ++ LIBC_PIC?= ${DESTDIR}/usr/lib/libc_pic.a ++ LIBCOMPAT?= ${DESTDIR}/usr/lib/libcompat.a ++ LIBCRYPT?= ${DESTDIR}/usr/lib/libcrypt.a ++ LIBCURSES?= ${DESTDIR}/usr/lib/libcurses.a ++ LIBDBM?= ${DESTDIR}/usr/lib/libdbm.a ++ LIBDES?= ${DESTDIR}/usr/lib/libdes.a ++ LIBEDIT?= ${DESTDIR}/usr/lib/libedit.a ++ LIBGCC?= ${DESTDIR}/usr/lib/libgcc.a ++ LIBGNUMALLOC?= ${DESTDIR}/usr/lib/libgnumalloc.a ++ LIBKDB?= ${DESTDIR}/usr/lib/libkdb.a ++ LIBKRB?= ${DESTDIR}/usr/lib/libkrb.a ++ LIBKVM?= ${DESTDIR}/usr/lib/libkvm.a ++ LIBL?= ${DESTDIR}/usr/lib/libl.a ++ LIBM?= ${DESTDIR}/usr/lib/libm.a ++ LIBMP?= ${DESTDIR}/usr/lib/libmp.a ++ LIBNTP?= ${DESTDIR}/usr/lib/libntp.a ++ LIBPC?= ${DESTDIR}/usr/lib/libpc.a ++ LIBPCAP?= ${DESTDIR}/usr/lib/libpcap.a ++ LIBPLOT?= ${DESTDIR}/usr/lib/libplot.a ++ LIBPOSIX?= ${DESTDIR}/usr/lib/libposix.a ++ LIBRESOLV?= ${DESTDIR}/usr/lib/libresolv.a ++ LIBRPCSVC?= ${DESTDIR}/usr/lib/librpcsvc.a ++ LIBSKEY?= ${DESTDIR}/usr/lib/libskey.a ++ LIBTERMCAP?= ${DESTDIR}/usr/lib/libtermcap.a ++ LIBTELNET?= ${DESTDIR}/usr/lib/libtelnet.a ++ LIBUTIL?= ${DESTDIR}/usr/lib/libutil.a ++ LIBWRAP?= ${DESTDIR}/usr/lib/libwrap.a ++ LIBY?= ${DESTDIR}/usr/lib/liby.a ++ LIBZ?= ${DESTDIR}/usr/lib/libz.a ++ ++ ++SHAREDSTRINGS If defined, a new .c.o rule is used that results in shared ++ strings, using xstr(1). Note that this will not work with ++ parallel makes. ++ ++STRIP The flag passed to the install program to cause the binary ++ to be stripped. ++ ++SUBDIR A list of subdirectories that should be built as well. ++ Each of the targets will execute the same target in the ++ subdirectories. ++ ++SCRIPTS A list of interpreter scripts [file.{sh,csh,pl,awk,...}]. ++ These are installed exactly like programs. ++ ++SCRIPTSNAME The name that the above program will be installed as, if ++ different from ${SCRIPTS}. These can be further specialized ++ by setting SCRIPTSNAME_