annotate etc/ulimit.hack @ 90787:91bf6e05918b

Merge from emacs--devo--0 Patches applied: * emacs--devo--0 (patch 662-669) - Update from CVS - Fix read-only prompt problem in isearch - Merge from gnus--rel--5.10 * gnus--rel--5.10 (patch 207-208) - Merge from emacs--devo--0 - Update from CVS Revision: emacs@sv.gnu.org/emacs--unicode--0--patch-184
author Miles Bader <miles@gnu.org>
date Sun, 18 Mar 2007 14:11:08 +0000
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
90787
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
1 #!/bin/sh
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
2 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
3 # ulimit.hack: Create an intermediate program for use in
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
4 # between kernel initialization and init startup.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
5 # This is needed on a 3b system if the standard CDLIMIT is
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
6 # so small that the dumped Emacs file cannot be written.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
7 # This program causes everyone to get a bigger CDLIMIT value
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
8 # so that the dumped Emacs can be written out.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
9 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
10 # Users of V.3.1 and later should not use this; see etc/MACHINES
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
11 # and reconfig your kernel's CDLIMIT parameter instead.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
12 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
13 # Caveat: Heaven help you if you screw this up. This puts
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
14 # a new program in as /etc/init, which then execs the real init.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
15 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
16 cat > ulimit.init.c << \EOF
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
17 main(argc, argv)
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
18 int argc;
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
19 char *argv[];
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
20 {
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
21 ulimit(2, 262144L); /* "2" is the "set" command. */
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
22 /* 262,144 allows for 128Mb files to be written. */
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
23 /* If that value isn't suitable, roll your own. */
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
24 execv("/etc/real.init", argv);
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
25 }
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
26 EOF
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
27 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
28 # Compile it and put it in place of the usual init program.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
29 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
30 cc ulimit.init.c -o ulimit.init
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
31 mv /etc/init /etc/real.init
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
32 mv ulimit.init /etc/ulimit.init
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
33 ln /etc/ulimit.init /etc/init
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
34 mv ulimit.init.c /etc/ulimit.init.c # to keep src for this hack nearby.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
35 chmod 0754 /etc/init
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
36 exit 0
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
37 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
38 # Upon system reboot, all processes will inherit the new large ulimit.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
39
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
40 # Copyright (C) 1999, 2001, 2002, 2003, 2004, 2005, 2006, 2007
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
41 # Free Software Foundation, Inc.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
42
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
43 # COPYING PERMISSIONS:
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
44 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
45 # This document is free software; you can redistribute it and/or modify
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
46 # it under the terms of the GNU General Public License as published by
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
47 # the Free Software Foundation; either version 2 of the License, or
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
48 # (at your option) any later version.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
49 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
50 # This program is distributed in the hope that it will be useful,
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
51 # but WITHOUT ANY WARRANTY; without even the implied warranty of
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
52 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
53 # GNU General Public License for more details.
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
54 #
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
55 # You should have received a copy of the GNU General Public License
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
56 # along with this program; if not, write to the Free Software
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
57 # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
58
91bf6e05918b Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents:
diff changeset
59 # arch-tag: 6f9a7072-9d07-4431-b0bb-e867648ad0b4