summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin F. Quinn <kevquinn@gentoo.org>2006-01-22 14:18:48 +0000
committerKevin F. Quinn <kevquinn@gentoo.org>2006-01-22 14:18:48 +0000
commit2bdaf19e91d57f4b3f0a0280e3885d18a6834c1f (patch)
tree5a3cab189611f5adad3ef80a3c6f4b699bf99cb8
parentMarked ppc stable for bug #119634; Stabilize Gnome-2.12.2 (diff)
downloadgentoo-2-2bdaf19e91d57f4b3f0a0280e3885d18a6834c1f.tar.gz
gentoo-2-2bdaf19e91d57f4b3f0a0280e3885d18a6834c1f.tar.bz2
gentoo-2-2bdaf19e91d57f4b3f0a0280e3885d18a6834c1f.zip
New eclass providing a support function pax-mark, to wrap use of chpax/paxctl
-rw-r--r--eclass/pax-utils.eclass92
1 files changed, 92 insertions, 0 deletions
diff --git a/eclass/pax-utils.eclass b/eclass/pax-utils.eclass
new file mode 100644
index 000000000000..b8a6f1860259
--- /dev/null
+++ b/eclass/pax-utils.eclass
@@ -0,0 +1,92 @@
+# Copyright 1999-2006 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/eclass/pax-utils.eclass,v 1.1 2006/01/22 14:18:48 kevquinn Exp $
+
+# Author:
+# Kevin F. Quinn <kevquinn@gentoo.org>
+#
+# This eclass provides support for manipulating PaX markings on ELF
+# binaries, wrapping the use of the chpax and paxctl utilities.
+
+inherit eutils
+
+##### pax-mark ####
+# Mark a file for PaX with the given flags.
+# Tries chpax (EI_FLAGS) and paxctl (PT_FLAGS) if they are installed.
+# If neither are installed, returns 0 (i.e. has no effect on non-PaX
+# systems unless the owner has installed chpax and/or paxctl).
+# Deliberately does _not_ check whether the build system is PaX or not.
+#
+# Syntax:
+# pax-mark [-q] {<flags>} [{<files>}]
+#
+# -q: do things quietly (no einfo/ewarn)
+#
+# There must be at least one <flags>, and can include:
+# -execstack equivalent to -E
+# -execheap equivalent to -m
+# -unrestricted equivalent to -psmxer
+# -{[pPsSmMxXeErR]} as used direcly by chpax/paxctl
+#
+# Where more than one flag is given they are concatenated.
+#
+# {<files>} may be empty, so it's safe to use for example the results
+# of a find that may not return any results.
+#
+# Return codes:
+# 0: for all files, all installed utilities succeed.
+# 1: No flags specified
+# >1: bit 2 => chpax failed, bit 3 => paxctl failed
+
+pax-mark() {
+ local flags ret quiet
+ # Fail if no parameters at all (especially no flags)
+ [[ -z $1 ]] && return 1
+ flags=
+ ret=0
+ quiet=
+ while [[ ${1:0:1} == "-" ]]; do
+ case ${1} in
+ -execstack)
+ flags="${flags}E"
+ ;;
+ -execheap)
+ flags="${flags}m"
+ ;;
+ -unrestricted)
+ flags="${flags}psmxer"
+ ;;
+ -q)
+ quiet="/bin/false "
+ ;;
+ *)
+ flags="${flags}${1:1}"
+ ;;
+ esac
+ shift
+ done
+ # Fail if no flags given
+ [[ -z ${flags} ]] && return 1
+ # Quietly exit if no files given
+ [[ -z $1 ]] && return 0
+ if [[ -x /sbin/chpax ]]; then
+ if /sbin/chpax -${flags} $*; then
+ ${quiet} einfo "PaX EI flags set to ${flags} on $*"
+ else
+ ${quiet} ewarn "Failed to set EI flags to ${flags} on $*"
+ (( ret=${ret}|2 ))
+ fi
+ fi
+ if [[ -x /sbin/paxctl ]]; then
+ # Steal PT_GNU_STACK if paxctl supports it
+ /sbin/paxctl -v 2>&1 | grep PT_GNU_STACK > /dev/null && \
+ flags="c${flags}"
+ if /sbin/paxctl -${flags} $*; then
+ ${quiet} einfo "PaX PT flags set to ${flags} on $*"
+ else
+ ${quiet} ewarn "Failed to set PT flags to ${flags} on $*"
+ (( ret=${ret}|4))
+ fi
+ fi
+ return ${ret}
+}