Mercurial > emacs
annotate src/sheap.c @ 81938:26330ef1aa46
* net/tramp.el (tramp-handle-file-remote-p): Handle optional
parameter IDENTIFICATION.
(tramp-handle-set-file-times): New defun. Replaces `tramp-touch'.
(tramp-file-name-handler-alist, tramp-file-name-for-operation):
Add entry for `set-file-times'.
(tramp-do-copy-or-rename-file-via-buffer)
(tramp-do-copy-or-rename-file-out-of-band): Use `set-file-times'.
(tramp-handle-unhandled-file-name-directory): Rewrite.
(tramp-convert-file-attributes): Add error handling when inode is
extraordinary big.
(tramp-get-inode): Change parameter from FILE to VEC.
(tramp-handle-start-file-process ): Use (current-buffer) if BUFFER
is NIL. This is according to the specification. Goto (point-max)
when ready.
(tramp-handle-shell-command): Rewrite completely, using
`process-file' and `start-file-process'.
(tramp-methods, tramp-find-shell)
(tramp-open-connection-setup-interactive-shell)
(tramp-maybe-open-connection): Guard against $PROMPT_COMMAND shell
var. Reported by Steve Youngs <steve@sxemacs.org>.
* net/tramp-fish.el (tramp-fish-file-name-handler-alist): Add
entry for `set-file-times'. Rename `start-process' into
`start-file-process'. Remove `call-process' entry.
(tramp-fish-handle-set-file-times): New defun.
(tramp-fish-handle-executable-find): Use `process-file'.
(tramp-fish-handle-process-file): New defun. Replaces
`tramp-fish-handle-call-process'.
(tramp-fish-do-copy-or-rename-file-directly): Use
`set-file-times'.
(tramp-fish-get-file-entries): Change `tramp-get-inode' parameter.
* net/tramp-smb.el (tramp-smb-handle-file-attributes): Change
`tramp-get-inode' parameter.
author | Michael Albinus <michael.albinus@gmx.de> |
---|---|
date | Tue, 17 Jul 2007 21:10:07 +0000 |
parents | 3d45362f1d38 |
children | 922696f363b0 95d0cdf160ea |
rev | line source |
---|---|
66663
d74deb025f5a
(STATIC_HEAP_SIZE): Increment both definitions.
Richard M. Stallman <rms@gnu.org>
parents:
64770
diff
changeset
|
1 /* simulate `sbrk' with an array in .bss, for `unexec' support for Cygwin; |
d74deb025f5a
(STATIC_HEAP_SIZE): Increment both definitions.
Richard M. Stallman <rms@gnu.org>
parents:
64770
diff
changeset
|
2 complete rewrite of xemacs Cygwin `unexec' code |
54844 | 3 |
75348 | 4 Copyright (C) 2004, 2005, 2006, 2007 Free Software Foundation, Inc. |
54844 | 5 |
6 This file is part of GNU Emacs. | |
7 | |
8 GNU Emacs is free software; you can redistribute it and/or modify | |
9 it under the terms of the GNU General Public License as published by | |
10 the Free Software Foundation; either version 2, or (at your option) | |
11 any later version. | |
12 | |
13 GNU Emacs is distributed in the hope that it will be useful, | |
14 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 GNU General Public License for more details. | |
17 | |
18 You should have received a copy of the GNU General Public License | |
19 along with GNU Emacs; see the file COPYING. If not, write to | |
64084 | 20 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
21 Boston, MA 02110-1301, USA. */ | |
54844 | 22 |
23 #include <config.h> | |
24 #include <stdio.h> | |
25 #include "lisp.h" | |
26 | |
27 #include <unistd.h> | |
28 | |
69554
e6104b603d86
(STATIC_HEAP_SIZE): Enlarge STATIC_HEAP_SIZE to 12MB.
Eli Zaretskii <eliz@gnu.org>
parents:
68651
diff
changeset
|
29 #define STATIC_HEAP_SIZE (12 * 1024 * 1024) |
54844 | 30 |
31 int debug_sheap = 0; | |
32 | |
33 #define BLOCKSIZE 4096 | |
34 | |
35 char bss_sbrk_buffer[STATIC_HEAP_SIZE]; | |
36 char *bss_sbrk_ptr; | |
37 int bss_sbrk_did_unexec; | |
38 | |
39 void * | |
40 bss_sbrk (ptrdiff_t request_size) | |
41 { | |
42 if (!bss_sbrk_ptr) | |
43 { | |
44 bss_sbrk_ptr = bss_sbrk_buffer; | |
45 #ifdef CYGWIN | |
46 sbrk (BLOCKSIZE); /* force space for fork to work */ | |
47 #endif | |
48 } | |
49 | |
50 if (!(int) request_size) | |
51 { | |
52 return (bss_sbrk_ptr); | |
53 } | |
54 else if (bss_sbrk_ptr + (int) request_size < bss_sbrk_buffer) | |
55 { | |
56 printf | |
57 ("attempt to free too much: avail %d used %d failed request %d\n", | |
58 STATIC_HEAP_SIZE, bss_sbrk_ptr - bss_sbrk_buffer, | |
59 (int) request_size); | |
60 exit (-1); | |
61 return 0; | |
62 } | |
63 else if (bss_sbrk_ptr + (int) request_size > | |
64 bss_sbrk_buffer + STATIC_HEAP_SIZE) | |
65 { | |
66 printf ("static heap exhausted: avail %d used %d failed request %d\n", | |
67 STATIC_HEAP_SIZE, | |
68 bss_sbrk_ptr - bss_sbrk_buffer, (int) request_size); | |
69 exit (-1); | |
70 return 0; | |
71 } | |
72 else if ((int) request_size < 0) | |
73 { | |
74 bss_sbrk_ptr += (int) request_size; | |
75 if (debug_sheap) | |
76 printf ("freed size %d\n", request_size); | |
77 return bss_sbrk_ptr; | |
78 } | |
79 else | |
80 { | |
81 char *ret = bss_sbrk_ptr; | |
82 if (debug_sheap) | |
83 printf ("allocated 0x%08x size %d\n", ret, request_size); | |
84 bss_sbrk_ptr += (int) request_size; | |
85 return ret; | |
86 } | |
87 } | |
88 | |
89 void | |
90 report_sheap_usage (int die_if_pure_storage_exceeded) | |
91 { | |
92 char buf[200]; | |
93 sprintf (buf, "Static heap usage: %d of %d bytes", | |
94 bss_sbrk_ptr - bss_sbrk_buffer, STATIC_HEAP_SIZE); | |
95 message ("%s", buf); | |
96 } | |
54858
44a3fff23885
Changes from arch/CVS synchronization
Miles Bader <miles@gnu.org>
parents:
54844
diff
changeset
|
97 |
44a3fff23885
Changes from arch/CVS synchronization
Miles Bader <miles@gnu.org>
parents:
54844
diff
changeset
|
98 /* arch-tag: 1bc386e8-71c2-4da4-b8b5-c1674a9cf926 |
44a3fff23885
Changes from arch/CVS synchronization
Miles Bader <miles@gnu.org>
parents:
54844
diff
changeset
|
99 (do not change this comment) */ |