mirror of
https://github.com/flatcar/scripts.git
synced 2025-09-28 09:01:55 +02:00
procps: sync latest stable from upstream Gentoo
We're seeing some HZ warnings on ARM platforms due to a bug in the internal procps init sequence. This has already been fixed in the upstream Gentoo ebuild, so pull down the latest stable from there. BUG=chromium-os:20777 TEST=`emerge procps` works TEST=`emerge-amd64-generic procps` works TEST=`emerge-arm-generic procps` works TEST=`emerge-x86-generic procps` works TEST=`cbuildbot arm-generic-full` works TEST=`cbuildbot x86-generic-full` works Change-Id: If635416e7e28ede1b60cf8067aa4f77aabb4a4d8 Reviewed-on: https://gerrit.chromium.org/gerrit/12000 Reviewed-by: David James <davidjames@chromium.org> Tested-by: Mike Frysinger <vapier@chromium.org> Commit-Ready: Mike Frysinger <vapier@chromium.org>
This commit is contained in:
parent
c8ba560e58
commit
2374aa31e0
15
sdk_container/src/third_party/portage-stable/sys-process/procps/files/procps-3.2.3-noproc.patch
vendored
Normal file
15
sdk_container/src/third_party/portage-stable/sys-process/procps/files/procps-3.2.3-noproc.patch
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
If /proc isnt mounted, `top` will cause screen corruption ...
|
||||
|
||||
--- procps-3.2.3/top.c
|
||||
+++ procps-3.2.3/top.c
|
||||
@@ -3201,6 +3201,10 @@
|
||||
{
|
||||
(void)dont_care_argc;
|
||||
before(*argv);
|
||||
+
|
||||
+ if (access("/proc/stat", F_OK))
|
||||
+ std_err("/proc is not mounted, required for output data");
|
||||
+
|
||||
// +-------------+
|
||||
windows_stage1(); // top (sic) slice
|
||||
configs_read(); // > spread etc, <
|
@ -0,0 +1,18 @@
|
||||
Slightly prettier error message
|
||||
|
||||
--- proc/readproc.c
|
||||
+++ proc/readproc.c
|
||||
@@ -907,3 +907,3 @@
|
||||
if(file2str("/proc/self", "stat", sbuf, sizeof sbuf) == -1){
|
||||
- fprintf(stderr, "Error, do this: mount -t proc none /proc\n");
|
||||
+ fprintf(stderr, "Error, do this: mount -t proc proc /proc\n");
|
||||
_exit(47);
|
||||
--- proc/sysinfo.c
|
||||
+++ proc/sysinfo.c
|
||||
@@ -31,4 +31,4 @@
|
||||
" To mount /proc at boot you need an /etc/fstab line like:\n" \
|
||||
-" /proc /proc proc defaults\n" \
|
||||
-" In the meantime, run \"mount /proc /proc -t proc\"\n"
|
||||
+" proc /proc proc defaults\n" \
|
||||
+" In the meantime, run \"mount proc /proc -t proc\"\n"
|
||||
|
@ -0,0 +1,42 @@
|
||||
avoid gcc warnings like:
|
||||
|
||||
ps/output.c:341:6: warning: the address of ‘forest_prefix’ will always evaluate as ‘true’
|
||||
|
||||
--- a/ps/output.c
|
||||
+++ b/ps/output.c
|
||||
@@ -338,7 +338,7 @@ static int pr_args(char *restrict const
|
||||
unsigned flags;
|
||||
int rightward=max_rightward;
|
||||
|
||||
- if(forest_prefix){
|
||||
+ if(/*forest_prefix*/1){
|
||||
int fh = forest_helper(outbuf);
|
||||
endp += fh;
|
||||
rightward -= fh;
|
||||
@@ -405,7 +405,7 @@ static int pr_cgroup(char *restrict cons
|
||||
if(pp->cgroup && *pp->cgroup) {
|
||||
char *endp = outbuf;
|
||||
int rightward=max_rightward;
|
||||
- if(forest_prefix){
|
||||
+ if(/*forest_prefix*/1){
|
||||
int fh = forest_helper(outbuf);
|
||||
endp += fh;
|
||||
rightward -= fh;
|
||||
@@ -365,7 +365,7 @@ static int pr_comm(char *restrict const
|
||||
unsigned flags;
|
||||
int rightward=max_rightward;
|
||||
|
||||
- if(forest_prefix){
|
||||
+ if(/*forest_prefix*/1){
|
||||
int fh = forest_helper(outbuf);
|
||||
endp += fh;
|
||||
rightward -= fh;
|
||||
@@ -390,7 +390,7 @@ static int pr_fname(char *restrict const
|
||||
char *endp = outbuf;
|
||||
int rightward = max_rightward;
|
||||
|
||||
- if(forest_prefix){
|
||||
+ if(/*forest_prefix*/1){
|
||||
int fh = forest_helper(outbuf);
|
||||
endp += fh;
|
||||
rightward -= fh;
|
@ -0,0 +1,16 @@
|
||||
X-Gentoo-Bug: 279819
|
||||
Upstream-Patch: http://procps.cvs.sourceforge.net/viewvc/procps/procps/top.c?r1=1.132&r2=1.134
|
||||
--- top.c 2008/03/24 04:41:26 1.132
|
||||
+++ top.c 2009/12/10 11:37:48 1.134
|
||||
@@ -2190,7 +2190,10 @@
|
||||
// Value a window's name and make the associated group name.
|
||||
static void win_names (WIN_t *q, const char *name)
|
||||
{
|
||||
- sprintf(q->rc.winname, "%.*s", WINNAMSIZ -1, name);
|
||||
+ // Note that src==dst is illegal in sprintf.
|
||||
+ // Failure: amd64, glibc 2.9-20081201, gcc 4.3.4
|
||||
+ if(q->rc.winname != name)
|
||||
+ sprintf(q->rc.winname, "%.*s", WINNAMSIZ -1, name);
|
||||
sprintf(q->grpname, "%d:%.*s", q->winnum, WINNAMSIZ -1, name);
|
||||
}
|
||||
|
@ -0,0 +1,29 @@
|
||||
diff -Naurp procps-3.2.3.orig/minimal.c procps-3.2.3/minimal.c
|
||||
--- procps-3.2.3.orig/minimal.c 2004-05-04 20:26:14.000000000 -0400
|
||||
+++ procps-3.2.3/minimal.c 2004-08-20 02:01:35.868100752 -0400
|
||||
@@ -68,8 +68,8 @@
|
||||
///////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef PAGE_SIZE
|
||||
-#warning PAGE_SIZE not defined, assuming it is 4096
|
||||
-#define PAGE_SIZE 4096
|
||||
+#warning PAGE_SIZE not defined, using sysconf() to determine correct value
|
||||
+#define PAGE_SIZE (sysconf(_SC_PAGESIZE))
|
||||
#endif
|
||||
|
||||
|
||||
diff -Naurp procps-3.2.3.orig/ps/common.h procps-3.2.3/ps/common.h
|
||||
--- procps-3.2.3.orig/ps/common.h 2004-04-25 17:03:18.000000000 -0400
|
||||
+++ procps-3.2.3/ps/common.h 2004-08-20 02:00:59.228670792 -0400
|
||||
@@ -16,6 +16,11 @@
|
||||
#include "../proc/readproc.h"
|
||||
#include <asm/page.h> /* looks safe for glibc, we need PAGE_SIZE */
|
||||
|
||||
+#ifndef PAGE_SIZE
|
||||
+#warning PAGE_SIZE not defined, using sysconf() to determine correct value
|
||||
+#define PAGE_SIZE (sysconf(_SC_PAGESIZE))
|
||||
+#endif
|
||||
+
|
||||
#if 0
|
||||
#define trace(args...) printf(## args)
|
||||
#else
|
90
sdk_container/src/third_party/portage-stable/sys-process/procps/procps-3.2.8_p11.ebuild
vendored
Normal file
90
sdk_container/src/third_party/portage-stable/sys-process/procps/procps-3.2.8_p11.ebuild
vendored
Normal file
@ -0,0 +1,90 @@
|
||||
# Copyright 1999-2011 Gentoo Foundation
|
||||
# Distributed under the terms of the GNU General Public License v2
|
||||
# $Header: /var/cvsroot/gentoo-x86/sys-process/procps/procps-3.2.8_p11.ebuild,v 1.5 2011/11/13 21:09:29 maekke Exp $
|
||||
|
||||
EAPI="2"
|
||||
|
||||
inherit flag-o-matic eutils toolchain-funcs multilib
|
||||
|
||||
DEB_VER=${PV#*_p}
|
||||
MY_PV=${PV%_p*}
|
||||
MY_P="${PN}-${MY_PV}"
|
||||
DESCRIPTION="Standard informational utilities and process-handling tools"
|
||||
HOMEPAGE="http://procps.sourceforge.net/"
|
||||
SRC_URI="http://procps.sourceforge.net/${MY_P}.tar.gz
|
||||
mirror://debian/pool/main/p/procps/${PN}_${MY_PV}-${DEB_VER}.debian.tar.gz"
|
||||
|
||||
LICENSE="GPL-2"
|
||||
SLOT="0"
|
||||
KEYWORDS="~alpha amd64 arm hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc x86"
|
||||
IUSE="unicode"
|
||||
|
||||
RDEPEND=">=sys-libs/ncurses-5.2-r2[unicode?]"
|
||||
|
||||
S=${WORKDIR}/${MY_P}
|
||||
|
||||
src_prepare() {
|
||||
local p d="${WORKDIR}"/debian/patches
|
||||
pushd "${d}" >/dev/null
|
||||
# makefile_dev_null: this bug is actually in gcc and is already fixed
|
||||
for p in $(use unicode || echo watch_{unicode,ansi_colour}) makefile_dev_null ; do
|
||||
rm ${p}.patch || die
|
||||
sed -i "/^${p}/d" series || die
|
||||
done
|
||||
popd >/dev/null
|
||||
EPATCH_SOURCE="${d}" \
|
||||
epatch $(<"${d}"/series)
|
||||
# fixup debian watch_exec_beep.patch
|
||||
sed -i '1i#include <sys/wait.h>' watch.c || die
|
||||
|
||||
epatch "${FILESDIR}"/${PN}-3.2.7-proc-mount.patch
|
||||
epatch "${FILESDIR}"/${PN}-3.2.3-noproc.patch
|
||||
epatch "${FILESDIR}"/${PN}-3.2.8-toprc-fixup.patch
|
||||
epatch "${FILESDIR}"/${PN}-3.2.8-r1-forest-prefix.patch
|
||||
|
||||
# Clean up the makefile
|
||||
# - we do stripping ourselves
|
||||
# - punt fugly gcc flags
|
||||
sed -i \
|
||||
-e '/install/s: --strip : :' \
|
||||
-e '/ALL_CFLAGS += $(call check_gcc,-fweb,)/d' \
|
||||
-e '/ALL_CFLAGS += $(call check_gcc,-Wstrict-aliasing=2,)/s,=2,,' \
|
||||
-e "/^lib64/s:=.*:=$(get_libdir):" \
|
||||
-e 's:-m64::g' \
|
||||
Makefile || die "sed Makefile"
|
||||
|
||||
# mips 2.4.23 headers (and 2.6.x) don't allow PAGE_SIZE to be defined in
|
||||
# userspace anymore, so this patch instructs procps to get the
|
||||
# value from sysconf().
|
||||
epatch "${FILESDIR}"/${PN}-mips-define-pagesize.patch
|
||||
|
||||
# lame unicode stuff checks glibc defines
|
||||
sed -i "s:__GNU_LIBRARY__ >= 6:0 == $(use unicode; echo $?):" proc/escape.c || die
|
||||
}
|
||||
|
||||
src_compile() {
|
||||
replace-flags -O3 -O2
|
||||
emake \
|
||||
CC="$(tc-getCC)" \
|
||||
CPPFLAGS="${CPPFLAGS}" \
|
||||
CFLAGS="${CFLAGS}" \
|
||||
LDFLAGS="${LDFLAGS}" \
|
||||
|| die "make failed"
|
||||
}
|
||||
|
||||
src_install() {
|
||||
emake \
|
||||
ln_f="ln -sf" \
|
||||
ldconfig="true" \
|
||||
DESTDIR="${D}" \
|
||||
install \
|
||||
|| die "install failed"
|
||||
|
||||
insinto /usr/include/proc
|
||||
doins proc/*.h || die
|
||||
|
||||
dodoc sysctl.conf BUGS NEWS TODO ps/HACKING
|
||||
|
||||
# compat symlink so people who shouldnt be using libproc can #170077
|
||||
dosym libproc-${MY_PV}.so /$(get_libdir)/libproc.so || die
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user