diff options
-rw-r--r-- | sys-cluster/torque/ChangeLog | 8 | ||||
-rw-r--r-- | sys-cluster/torque/Manifest | 15 | ||||
-rw-r--r-- | sys-cluster/torque/files/torque-2.3-fixes-r2221-2227.patch | 372 | ||||
-rw-r--r-- | sys-cluster/torque/torque-2.3.1.ebuild | 233 |
4 files changed, 626 insertions, 2 deletions
diff --git a/sys-cluster/torque/ChangeLog b/sys-cluster/torque/ChangeLog index 593bb2c88bfe..449e11ecf213 100644 --- a/sys-cluster/torque/ChangeLog +++ b/sys-cluster/torque/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for sys-cluster/torque # Copyright 2000-2008 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-cluster/torque/ChangeLog,v 1.69 2008/06/18 13:04:11 fmccor Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-cluster/torque/ChangeLog,v 1.70 2008/07/10 03:28:56 jsbronder Exp $ + +*torque-2.3.1 (10 Jul 2008) + + 10 Jul 2008; Justin Bronder <jsbronder@gentoo.org> + +files/torque-2.3-fixes-r2221-2227.patch, +torque-2.3.1.ebuild: + Bump torque to 2.3.1, add some fixes from svn for newer gcc's. 18 Jun 2008; Ferris McCormick <fmccor@gentoo.org> torque-2.3.0-r1.ebuild: Sparc stable, required for bug #224099. diff --git a/sys-cluster/torque/Manifest b/sys-cluster/torque/Manifest index c43e90c4ccf0..920cd92fe8e4 100644 --- a/sys-cluster/torque/Manifest +++ b/sys-cluster/torque/Manifest @@ -1,3 +1,6 @@ +-----BEGIN PGP SIGNED MESSAGE----- +Hash: SHA1 + AUX 2.3.0-fixes_r2031.patch 8484 RMD160 58429355795ed3304c986b7b667d86486bb1c8cf SHA1 2a47b277277fcfc97a26ccad7c967c9f8bf72932 SHA256 9f847cc8273b2b227d7163299ea856830c4d333527e1566b13e989d980866398 AUX pbs_mom-init.d-2.2.1 1003 RMD160 97be9b485fabd022ff209c910ae3974a73ebbc30 SHA1 cf50bac5a12a07535104ff7f7dcdfd054c995b2b SHA256 ef010854efc7a5c310c34bc53d1d927b7928bfa0d48bb5d8ae76bd3453f37a25 AUX pbs_mom-init.d-2.2.1-r1 1093 RMD160 ade6389bcda7974fd17c56c5f6f7a1c5b19c7fda SHA1 051455da4526b908ddb2346c912b68ba22245209 SHA256 ce5dfb1db62de8611974dcf15698dce75ef289f2a13d6a95039aec724748e64d @@ -5,6 +8,7 @@ AUX pbs_sched-init.d-2.2.1 1084 RMD160 a4f8b42dc5e004cbd9f8168cc39520d8bc1168d6 AUX pbs_sched-init.d-2.2.1-r1 1174 RMD160 d39789a7675487065094083c1ebb6da6e8246818 SHA1 c550cd7606da18a74e736c7f0d26d04deea3d34b SHA256 b1edba8149cc3962e147d8e16148113ad629c5c7ab54ea629d5c106aea337afe AUX pbs_server-init.d-2.2.1 1576 RMD160 f57eeea595c8d609346c0d0d4645decfab76cb5c SHA1 90ad4ff42cac937929bde4cbcf7f69460c2f630e SHA256 43a1ea111ca161d8bd496291a28fe3201e9080b97d3c746a29d820ec2cfbd9d7 AUX pbs_server-init.d-2.2.1-r1 1666 RMD160 e757d58142dd2abc10cee6e016744336788bca5c SHA1 f1f0a3181265e7a0c0e59cfb51c53dfaf4f93dd8 SHA256 a7e05fa7b544b46d8e8a6fc2ed4fc843dd63496597fcd32a70f45c4ddcec18d3 +AUX torque-2.3-fixes-r2221-2227.patch 11583 RMD160 c9034c6ac160565837ce1d6a7ae847f9d5db7565 SHA1 d5b8cccefb50e1cbee4c57df86b78e569767bb3a SHA256 46907789798266695efbcb584bcae898be6f76554f68c42d9a3974b4c4ac6f5d AUX torque-conf.d-2.2.1 816 RMD160 8bd7fd0c6566445c761da96859d86fbdb11d40f9 SHA1 da49ef33b73cab88c37bea20d26361c7a69cfb12 SHA256 ed982717cb8334a0a43e8807166bc10b5cbf39848e5729b321e946b31fa1c0c1 AUX torque-conf.d-2.2.1-r1 649 RMD160 d8a8cec80a86fdea54545d64df9276db0386d688 SHA1 115fc52661a003b69be2dfb716e29f8d86461ca3 SHA256 4139da44a55dbcb4a8227fd0aedede8e091971fd63c0e08644712f4a91e7b174 AUX torque-env.d-2.2.1 337 RMD160 bb5341d647e6c4545077783dd2aa4135662276f8 SHA1 10910a42d419e552c42a098010d8360b496f7f72 SHA256 0c5abf36209d684e7c4f82749f6c06ad976f7c1f3f0e94731b42c1d1331c5bed @@ -14,8 +18,17 @@ AUX torque-setuid-safety.patch 1020 RMD160 199a8d543c6f0de0934211ca248b637f61f1a DIST torque-2.1.6.tar.gz 2708793 RMD160 6802c2d49a36624d34fce7b96b29551da3ff1106 SHA1 f0437e3f429c5cecb44a7f991f2b7bd58baa7a0a SHA256 e5ac494859df9951ca34149ae56b93fbfc83d7d4ba015bc8b67514b190e51c36 DIST torque-2.2.1.tar.gz 5370260 RMD160 219e5a4234a1bbf0241c15f568a720752e48587c SHA1 fafa9d66aa8bf8daa9e8f660903aa1105ff14bda SHA256 6d2674d471e300df6ebda56ef80c2a7be0de33fc619f98ee78eee69af1d179b8 DIST torque-2.3.0.tar.gz 5419629 RMD160 7dd4885cda583aa8ba16dce7b9001c009f264881 SHA1 e600b121aa6dae8e872935907311913cf8631d75 SHA256 eb5e694b6acdfe84249dfdf71552cb38d26e29fcda7ba09574b041e06290ec57 +DIST torque-2.3.1.tar.gz 5447820 RMD160 c4152ff383940965cd77274e4f94a0350f8fb87e SHA1 0fa5729f55fd309dde6b8163375e8968ca9cae89 SHA256 5f628c19155c2c5d2bb3cc45276637b80652304ea8c918c20b0d8591c02ac970 EBUILD torque-2.1.6.ebuild 4038 RMD160 b6c85175b08ec7fc389ad4503e7844c7aebf6402 SHA1 51784cd28f3dd838d52b502b123cb81cacdf4c1a SHA256 1d2fbc09c5ee0a7658f10c813d8f0015656930887ab28f2109a57da7a11e67d0 EBUILD torque-2.2.1-r2.ebuild 7202 RMD160 1bf67f7e5a7d2bd813ceca38739a873ac36c35d4 SHA1 37e2c5bd0c6bb3fcc90f8869a6eae0b299448dd5 SHA256 113a0e6629f1e7208b55edb7760f3ae8127f5ca4f3d8dea24cd10188a222e363 EBUILD torque-2.3.0-r1.ebuild 7304 RMD160 b7efed57577bf9f1ed063d743b083d1f5bfb3c3f SHA1 1301f8bdbd6144303e744e0768016da80c9ff141 SHA256 5d3b1df074eea6db5bb5f259f988b9530908e8be2a0371c88a60f23c3f0b317a -MISC ChangeLog 12239 RMD160 cc50cdafa0ec71e6de5cba3c7c46feef6b315a08 SHA1 414c6e881a7aba53dd3c01717b7b545500aed942 SHA256 8684863d657ae1f360fa0002c76417154945b51d344ec1b339a645b344e2dd72 +EBUILD torque-2.3.1.ebuild 7370 RMD160 888d9285336ee85a45c8c7ede2c9874ac5771696 SHA1 4ecdbd43c994d7e7d2d8f16ab48038ffb1d6c30c SHA256 01813f8c39a0c1cddc388009d1c38ae6297f93a5137aac0efa7ab330308e0c4a +MISC ChangeLog 12456 RMD160 ec580ebef159dccb43b85cb9696a0445c8e3aa33 SHA1 f2ff20017f2c2f569ad8f3d43bf77c3a1d54cdd2 SHA256 987759d0883509d988a97e69a69c701c3f47003dd42724a38a3fe0682e0c12b8 MISC metadata.xml 231 RMD160 37dd476ccaceaa37796cf29fd01af8fcfa2b4c61 SHA1 87cab1ccad4db7724c4292e4f32dd19accdcf2fa SHA256 b5305a12d2e3e9f9fdf645e98b0108c1bd8f5b5da32589a25bf7b0f0d74f1213 +-----BEGIN PGP SIGNATURE----- +Version: GnuPG v2.0.9 (GNU/Linux) + +iEYEARECAAYFAkh1gJ4ACgkQ4MrvBE1wQ8ktJwCaAhU1YsGgVS8a/MKdcpbXPNR5 +xQkAn3VoRIHsu1XYBpSvBagQXEAfOQqs +=Md7k +-----END PGP SIGNATURE----- diff --git a/sys-cluster/torque/files/torque-2.3-fixes-r2221-2227.patch b/sys-cluster/torque/files/torque-2.3-fixes-r2221-2227.patch new file mode 100644 index 000000000000..81af4a5e790c --- /dev/null +++ b/sys-cluster/torque/files/torque-2.3-fixes-r2221-2227.patch @@ -0,0 +1,372 @@ +Index: src/include/qmgr.h +=================================================================== +--- src/include/qmgr.h (revision 2221) ++++ src/include/qmgr.h (revision 2227) +@@ -166,30 +166,30 @@ + + + /* prototypes */ +-struct objname *commalist2objname(); +-struct server *find_server(); ++struct objname *commalist2objname(char *, int); ++struct server *find_server(char *); + struct server *make_connection(); + struct server *new_server(); + struct objname *new_objname(); +-struct objname *strings2objname( ); ++struct objname *strings2objname(char **, int, int); + struct objname *default_server_name(); +-struct objname *temp_objname(); +-int parse_request( ); +-void clean_up_and_exit(); +-void freeattrl(); +-void freeattropl(); +-void pstderr_big(); +-void free_objname_list(); +-void free_server(); +-void free_objname(); ++struct objname *temp_objname(char *, char *, struct server *); ++int parse_request(char *, char [][MAX_REQ_WORD_LEN]); ++void clean_up_and_exit(int); ++void freeattrl(struct attrl *); ++void freeattropl(struct attropl *); ++void pstderr_big(char *, char*, char *); ++void free_objname_list(struct objname *); ++void free_server(struct server *); ++void free_objname(struct objname *); + void close_non_ref_servers(); +-int connect_servers(); +-int set_active(); +-int get_request(); +-int parse(); +-int execute(); +-int is_attr(); +-int is_valid_object(); ++int connect_servers(struct objname *, int); ++int set_active(int, struct objname *); ++int get_request(char *); ++int parse(char *, int *, int *, char **, struct attropl **); ++int execute(int, int, int, char *, struct attropl *); ++int is_attr(int, char *, int); ++int is_valid_object(struct objname *, int); + void disconnect_from_server(); + + +Index: src/include/md5.h +=================================================================== +--- src/include/md5.h (revision 2221) ++++ src/include/md5.h (revision 2227) +@@ -55,9 +55,9 @@ + unsigned char digest[16]; /* actual digest after MD5Final call */ + } MD5_CTX; + +-void MD5Init (); +-void MD5Update (); +-void MD5Final (); ++void MD5Init (MD5_CTX *); ++void MD5Update (MD5_CTX *, unsigned char *, unsigned int); ++void MD5Final (MD5_CTX *); + + #define __MD5_INCLUDE__ + #endif /* __MD5_INCLUDE__ */ +Index: src/include/mom_func.h +=================================================================== +--- src/include/mom_func.h (revision 2221) ++++ src/include/mom_func.h (revision 2227) +@@ -149,7 +149,7 @@ + extern int set_mach_vars A_((job *, struct var_table *)); + extern char *set_shell A_((job *, struct passwd *)); + extern void start_exec A_((job *)); +-extern int open_master(); ++extern int open_master(char **); + extern int open_slave(); + extern char *rcvttype A_((int)); + extern int rcvwinsize A_((int)); +Index: src/include/pbs_config.h.in +=================================================================== +--- src/include/pbs_config.h.in (revision 2221) ++++ src/include/pbs_config.h.in (revision 2227) +@@ -316,6 +316,9 @@ + /* use nodemask-based scheduling on O2k */ + #undef NODEMASK + ++/* Define to disable posix memlock */ ++#undef NOPOSIXMEMLOCK ++ + /* Define to disable privileged ports */ + #undef NOPRIVPORTS + +Index: src/cmds/qstop.c +=================================================================== +--- src/cmds/qstop.c (revision 2221) ++++ src/cmds/qstop.c (revision 2227) +@@ -108,7 +108,7 @@ + + + int exitstatus = 0; /* Exit Status */ +-static void execute (); ++static void execute (char *, char *); + + + int main ( argc, argv ) +Index: src/cmds/qenable.c +=================================================================== +--- src/cmds/qenable.c (revision 2221) ++++ src/cmds/qenable.c (revision 2227) +@@ -109,7 +109,7 @@ + + + int exitstatus = 0; /* Exit Status */ +-static void execute (); ++static void execute (char *, char *); + + + int main( +Index: src/cmds/qsub.c +=================================================================== +--- src/cmds/qsub.c (revision 2221) ++++ src/cmds/qsub.c (revision 2227) +@@ -3823,7 +3823,7 @@ + { + strcat(submit_args_str,argv[argi]); + +- if (argi != optind - 1) ++ if (argi != argc - 1) + { + strcat(submit_args_str," "); + } +Index: src/cmds/qstart.c +=================================================================== +--- src/cmds/qstart.c (revision 2221) ++++ src/cmds/qstart.c (revision 2227) +@@ -108,7 +108,7 @@ + + + int exitstatus = 0; /* Exit Status */ +-static void execute (); ++static void execute (char *, char *); + + + int main ( +Index: src/cmds/qdisable.c +=================================================================== +--- src/cmds/qdisable.c (revision 2221) ++++ src/cmds/qdisable.c (revision 2227) +@@ -110,7 +110,7 @@ + + int exitstatus = 0; /* Exit Status */ + +-static void execute (); ++static void execute (char *, char *); + + int main ( argc, argv ) + int argc; +Index: src/cmds/qrun.c +=================================================================== +--- src/cmds/qrun.c (revision 2221) ++++ src/cmds/qrun.c (revision 2227) +@@ -101,7 +101,7 @@ + #include <pbs_config.h> /* the master config generated by configure */ + + int exitstatus = 0; /* Exit Status */ +-static void execute(); ++static void execute(char *, char *, char *, int); + + + +Index: src/cmds/qterm.c +=================================================================== +--- src/cmds/qterm.c (revision 2221) ++++ src/cmds/qterm.c (revision 2227) +@@ -113,7 +113,7 @@ + + int exitstatus = 0; /* Exit Status */ + +-static void execute(); ++static void execute(int, char *); + + int main( + +Index: src/resmom/start_exec.c +=================================================================== +--- src/resmom/start_exec.c (revision 2221) ++++ src/resmom/start_exec.c (revision 2227) +@@ -133,6 +133,10 @@ + #include "pbs_cpuset.h" + #endif + ++#ifdef NOPOSIXMEMLOCK ++#undef _POSIX_MEMLOCK ++#endif /* NOPOSIXMEMLOCK */ ++ + #define EXTRA_VARIABLE_SPACE 2000 + #define EXTRA_ENV_PTRS 32 + +@@ -4678,9 +4682,9 @@ + + MD5Init(&c); + +- MD5Update(&c,(caddr_t)&loopcnt,sizeof(loopcnt)); ++ MD5Update(&c,(unsigned char *)&loopcnt,sizeof(loopcnt)); + +- MD5Update(&c,(caddr_t)pjob,sizeof(job)); ++ MD5Update(&c,(unsigned char *)pjob,sizeof(job)); + + MD5Final(&c); + +@@ -5286,7 +5290,7 @@ + + /* don't do for checkpoint file names, only StdErr and StdOut */ + +- if (suffix != JOB_CKPT_SUFFIX) ++ if (strcmp(suffix, JOB_CKPT_SUFFIX) != 0) + { + pt = strstr(jobpath,"$HOME"); + +Index: src/resmom/mom_server.c +=================================================================== +--- src/resmom/mom_server.c (revision 2221) ++++ src/resmom/mom_server.c (revision 2227) +@@ -2533,7 +2533,7 @@ + { + int sindex; + +- for (sindex = 0; sindex < PBS_MAXSERVER || down_svraddrs[sindex] == 0; sindex++) ++ for (sindex = 0; sindex < PBS_MAXSERVER && down_svraddrs[sindex] != 0; sindex++) + { + if (down_svraddrs[sindex] == server_address) + { +Index: src/resmom/mom_main.c +=================================================================== +--- src/resmom/mom_main.c (revision 2221) ++++ src/resmom/mom_main.c (revision 2227) +@@ -146,6 +146,9 @@ + + #include "mcom.h" + ++#ifdef NOPOSIXMEMLOCK ++#undef _POSIX_MEMLOCK ++#endif /* NOPOSIXMEMLOCK */ + + #ifdef _POSIX_MEMLOCK + #include <sys/mman.h> +Index: src/server/req_stat.c +=================================================================== +--- src/server/req_stat.c (revision 2221) ++++ src/server/req_stat.c (revision 2227) +@@ -119,7 +119,7 @@ + extern int pbs_mom_port; + extern time_t time_now; + extern char *msg_init_norerun; +-extern struct pbsnode *tfind_addr(); ++extern struct pbsnode *tfind_addr(const u_long); + extern int LOGLEVEL; + + /* Extern Functions */ +Index: src/lib/Libnet/md5.c +=================================================================== +--- src/lib/Libnet/md5.c (revision 2221) ++++ src/lib/Libnet/md5.c (revision 2227) +@@ -49,7 +49,7 @@ + */ + + /* forward declaration */ +-static void Transform (); ++static void Transform (UINT4 *, UINT4 *); + + static unsigned char PADDING[64] = { + 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, +Index: src/lib/Libnet/net_server.c +=================================================================== +--- src/lib/Libnet/net_server.c (revision 2221) ++++ src/lib/Libnet/net_server.c (revision 2227) +@@ -115,7 +115,7 @@ + + extern void process_request A_((int)); + +-extern time_t time(); ++extern time_t time(time_t *); + + /* Global Data (I wish I could make it private to the library, sigh, but + * C don't support that scope of control.) +Index: configure.ac +=================================================================== +--- configure.ac (revision 2221) ++++ configure.ac (revision 2227) +@@ -79,7 +79,7 @@ + dnl + AC_MSG_CHECKING([whether to turn on the AUTORUN_JOBS flag]) + AC_ARG_ENABLE(autorun, +- [ --enable-autorun turn on the AUTORUN_JOBS flag], ++ [ --enable-autorun turn on the AUTORUN_JOBS flag], + enable_autorun=$enableval, enable_autorun=no) + AC_MSG_RESULT($enable_autorun) + if test "x$enable_autorun" = "xyes" ; then +@@ -94,7 +94,7 @@ + dnl + AC_MSG_CHECKING([whether to turn on the RESOURCEMAXNOTDEFAULT flag]) + AC_ARG_ENABLE(maxnotdefault, +- [ --enable-maxnotdefault turn on the RESOURCEMAXNOTDEFAULT flag], ++ [ --enable-maxnotdefault turn on the RESOURCEMAXNOTDEFAULT flag], + enable_maxnotdefault=$enableval, enable_maxnotdefault=no) + AC_MSG_RESULT($enable_maxnotdefault) + if test "x$enable_maxnotdefault" = "xyes" ; then +@@ -108,7 +108,7 @@ + dnl + AC_MSG_CHECKING([whether to turn on the QUICKCOMMIT flag]) + AC_ARG_ENABLE(quickcommit, +- [ --enable-quickcommit turn on the QUICKCOMMIT flag], ++ [ --enable-quickcommit turn on the QUICKCOMMIT flag], + enable_quickcommit=$enableval, enable_quickcommit=no) + AC_MSG_RESULT($enable_quickcommit) + if test "x$enable_quickcommit" = "xyes" ; then +@@ -122,7 +122,7 @@ + dnl + AC_MSG_CHECKING([whether to turn on the NO_SIGCHLD flag]) + AC_ARG_ENABLE(nochildsignal, +- [ --enable-nochildsignal turn on the NO_SIGCHLD flag], ++ [ --enable-nochildsignal turn on the NO_SIGCHLD flag], + enable_nochildsignal=$enableval, enable_nochildsignal=no) + AC_MSG_RESULT($enable_nochildsignal) + if test "x$enable_nochildsignal" = "xyes" ; then +@@ -709,6 +709,18 @@ + AC_DEFINE_UNQUOTED(SHELL_USE_ARGV, ${SHELL_USE_ARGV}, [job script name passed as the shell's arg]) + + ++ ++AC_ARG_ENABLE(posixmemlock, [ ++ --disable-posixmemlock disable the moms use of mlockall. ++ Some versions of OSs seem to have buggy POSIX MEMLOCK.], ++[case "${enableval}" in ++ yes) ;; ++ no) NOPOSIXMEMLOCK=1; AC_DEFINE(NOPOSIXMEMLOCK, 1, [Define to disable mlockall]) ;; ++ *) AC_MSG_ERROR(--enable-posixmemlock cannot take a value) ;; ++esac])dnl ++ ++ ++ + AC_ARG_ENABLE(privports, [ + --disable-privports disable the use of privileged ports for authentication. + Some versions of OSX have a buggy bind() and cannot +@@ -726,7 +738,7 @@ + [case "${enableval}" in + yes) MOMCHECKLOCALSPOOL=1 ;; + no) MOMCHECKLOCALSPOOL=0;; +- *) AC_MSG_ERROR(--enable-privports cannot take a value) ;; ++ *) AC_MSG_ERROR(--enable-mom-checkspool cannot take a value) ;; + esac],[MOMCHECKLOCALSPOOL=1])dnl + AC_DEFINE_UNQUOTED(MOMCHECKLOCALSPOOL, ${MOMCHECKLOCALSPOOL}, [Define to error if spool is full on MOM]) + +Index: doc/soelim.c +=================================================================== +--- doc/soelim.c (revision 2221) ++++ doc/soelim.c (revision 2227) +@@ -102,7 +102,7 @@ + int argc; + char *argv[]; + { +- int dofile(); ++ int dofile(FILE *); + int dirct = 0; + FILE *filein; + int i; diff --git a/sys-cluster/torque/torque-2.3.1.ebuild b/sys-cluster/torque/torque-2.3.1.ebuild new file mode 100644 index 000000000000..2a1a7c6bf5a7 --- /dev/null +++ b/sys-cluster/torque/torque-2.3.1.ebuild @@ -0,0 +1,233 @@ +# Copyright 1999-2008 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-cluster/torque/torque-2.3.1.ebuild,v 1.1 2008/07/10 03:28:56 jsbronder Exp $ + +inherit autotools flag-o-matic eutils linux-info + +DESCRIPTION="Resource manager and queuing system based on OpenPBS" +HOMEPAGE="http://www.clusterresources.com/products/torque/" +SRC_URI="http://www.clusterresources.com/downloads/${PN}/${P}.tar.gz" + +LICENSE="openpbs" + +SLOT="0" +KEYWORDS="~alpha ~amd64 ~hppa ~ia64 ~ppc ~ppc64 ~sparc ~x86" +IUSE="tk crypt server syslog doc cpusets kernel_linux" +PROVIDE="virtual/pbs" + +# ed is used by makedepend-sh +DEPEND_COMMON="virtual/libc + sys-libs/ncurses + sys-libs/readline + tk? ( dev-lang/tk ) + syslog? ( virtual/logger ) + !virtual/pbs + !sys-cluster/openpbs-common + !games-util/qstat" + +DEPEND="${DEPEND_COMMON} + sys-apps/ed" + +RDEPEND="${DEPEND_COMMON} + crypt? ( net-misc/openssh ) + !crypt? ( net-misc/netkit-rsh )" + +[ -n "${PBS_SERVER_HOME}" ] || PBS_SERVER_HOME="/var/spool/torque" + +pkg_setup() { + linux-info_pkg_setup + USE_CPUSETS="--disable-cpusets" + if use cpusets; then + if ! use kernel_linux; then + einfo + elog " Torque currently only has support for cpusets in linux." + elog "Assuming you didn't really want this USE flag." + einfo + else + einfo + elog " Torque support for cpusets is still in development, you may" + elog "wish to disable it for production use." + einfo + if ! linux_chkconfig_present CPUSETS; then + einfo + elog " Torque support for cpusets will require that you recompile" + elog "your kernel with CONFIG_CPUSETS enabled." + einfo + fi + USE_CPUSETS="--enable-cpusets" + fi + fi +} + +src_unpack() { + unpack ${A} + cd "${S}" + + # Fixes gcc-4.2 compile errors. Changes to configure and CHANGELOG had to + # be removed to get the patch to apply cleanly. + # TODO: Will not be required in 2.3.2 + epatch "${FILESDIR}"/torque-2.3-fixes-r2221-2227.patch +} + +src_compile() { + local myconf="--with-rcp=mom_rcp" + + use crypt && myconf="--with-rcp=scp" + + [ -n "${PBS_SERVER_NAME}" ] || PBS_SERVER_NAME=$(hostname -f) + + econf \ + $(use_enable tk gui) \ + $(use_enable syslog) \ + $(use_enable server) \ + --with-server-home=${PBS_SERVER_HOME} \ + --with-environ=/etc/pbs_environment \ + --with-default-server=${PBS_SERVER_NAME} \ + --disable-gcc-warnings \ + ${USE_CPUSETS} \ + ${myconf} \ + || die "econf failed" + emake || die "emake failed" +} + +# WARNING +# OpenPBS is extremely stubborn about directory permissions. Sometimes it will +# just fall over with the error message, but in some spots it will just ignore +# you and fail strangely. Likewise it also barfs on our .keep files! +pbs_createspool() { + local root="$1" + local s="$(dirname "${PBS_SERVER_HOME}")" + local h="${PBS_SERVER_HOME}" + local sp="${h}/server_priv" + einfo "Building spool directory under ${D}${h}" + local a d m + local dir_spec=" + 0755:${h}/aux 0700:${h}/checkpoint + 0755:${h}/mom_logs 0751:${h}/mom_priv 0751:${h}/mom_priv/jobs + 1777:${h}/spool 1777:${h}/undelivered" + + if use server; then + dir_spec="${dir_spec} 0755:${h}/sched_logs + 0755:${h}/sched_priv/accounting 0755:${h}/server_logs + 0750:${h}/server_priv 0755:${h}/server_priv/accounting + 0750:${h}/server_priv/acl_groups 0750:${h}/server_priv/acl_hosts + 0750:${h}/server_priv/acl_svr 0750:${h}/server_priv/acl_users + 0750:${h}/server_priv/jobs 0750:${h}/server_priv/queues" + fi + + for a in ${dir_spec}; do + d="${a/*:}" + m="${a/:*}" + if [[ ! -d "${root}${d}" ]]; then + install -d -m${m} "${root}${d}" + else + chmod ${m} "${root}${d}" + fi + # (#149226) If we're running in src_*, then keepdir + if [[ "${root}" = "${D}" ]]; then + keepdir ${d} + fi + done +} + +src_install() { + # Make directories first + pbs_createspool "${D}" + + make DESTDIR="${D}" install || die "make install failed" + + dodoc CHANGELOG DEVELOPMENT README.* Release_Notes || die "dodoc failed" + if use doc; then + dodoc doc/admin_guide.ps doc/*.pdf || die "dodoc failed" + fi + + # The build script isn't alternative install location friendly, + # So we have to fix some hard-coded paths in tclIndex for xpbs* to work + for file in `find "${D}" -iname tclIndex`; do + sed -e "s/${D//\// }/ /" "${file}" > "${file}.new" + mv "${file}.new" "${file}" + done + + if use server; then + newinitd "${FILESDIR}"/pbs_server-init.d-2.2.1-r1 pbs_server + newinitd "${FILESDIR}"/pbs_sched-init.d-2.2.1-r1 pbs_sched + fi + newinitd "${FILESDIR}"/pbs_mom-init.d-2.2.1-r1 pbs_mom + newconfd "${FILESDIR}"/torque-conf.d-2.2.1-r1 torque + newenvd "${FILESDIR}"/torque-env.d-2.2.1-r1 25torque +} + +pkg_preinst() { + if [[ -f "${ROOT}etc/pbs_environment" ]]; then + cp "${ROOT}etc/pbs_environment" "${D}"/etc/pbs_environment + fi + + if [ -n "${PBS_SERVER_NAME}" ]; then + echo "${PBS_SERVER_NAME}" > "${D}${PBS_SERVER_HOME}/server_name" + elif [[ -f "${ROOT}${PBS_SERVER_HOME}/server_name" ]]; then + cp "${ROOT}${PBS_SERVER_HOME}/server_name" "${D}${PBS_SERVER_HOME}/server_name" + fi + + # Fix up the env.d file to use our set server home. + sed -i "s:/var/spool/torque:${PBS_SERVER_HOME}:g" "${D}"/etc/env.d/25torque +} + +pkg_postinst() { + pbs_createspool "${ROOT}" + elog " If this is the first time torque has been installed, then you are not" + elog "ready to start the server. Please refer to the documentation located at:" + elog "http://www.clusterresources.com/wiki/doku.php?id=torque:torque_wiki" + + elog " For a basic setup, you may use emerge --config ${PN}" +} + +# Either the correct PBS_SERVER_HOME and PBS_SERVER_NAME are set +# or we use the default HOME and the localhost as the server. +# root will be setup as the primary operator/manager, the local machine +# will be added as a node and we'll create a simple queue, batch. +pkg_config() { + local h="${ROOT}/${PBS_SERVER_HOME}" + local rc=0 + + ebegin "Configuring Torque" + [ -n "${PBS_SERVER_NAME}" ] || PBS_SERVER_NAME=$(hostname -f) + einfo "Using ${PBS_SERVER_HOME} as the pbs homedir" + einfo "Using ${PBS_SERVER_NAME} as the pbs_server" + + # Check for previous configuration and bail if found. + if [ -e "${h}/server_priv/acl_svr/operators" ] \ + || [ -e "${h}/server_priv/nodes" ] \ + || [ -e "${h}/mom_priv/config" ]; then + ewarn "Previous Torque configuration detected. Press any key to" + ewarn "continue or press Control-C to abort now" + read + fi + + # pbs_mom configuration. + echo "\$pbsserver ${PBS_SERVER_NAME}" > "${h}/mom_priv/config" + echo "\$logevent 255" >> "${h}/mom_priv/config" + + if use server; then + local qmgr="${ROOT}/usr/bin/qmgr -c" + if ! echo "y" | "${ROOT}"/usr/sbin/pbs_server \ + -d "${ROOT}${PBS_SERVER_HOME}" -t create &>/dev/null; then + eerror "Failed to start pbs_server" + rc=1 + else + ${qmgr} "set server operators = root@$(hostname -f)" ${PBS_SERVER_NAME} + ${qmgr} "create queue batch" ${PBS_SERVER_NAME} + ${qmgr} "set queue batch queue_type = Execution" ${PBS_SERVER_NAME} + ${qmgr} "set queue batch started = True" ${PBS_SERVER_NAME} + ${qmgr} "set queue batch enabled = True" ${PBS_SERVER_NAME} + ${qmgr} "set server default_queue = batch" ${PBS_SERVER_NAME} + ${qmgr} "set server resources_default.nodes = 1" ${PBS_SERVER_NAME} + ${qmgr} "set server scheduling = True" ${PBS_SERVER_NAME} + + "${ROOT}"/usr/bin/qterm -t quick ${PBS_SERVER_NAME} || rc=1 + + # Add the local machine as a node. + echo "$(hostname -f) np=1" > "${h}/server_priv/nodes" + fi + fi + eend ${rc} +} |