1 /* Copyright (C) 1995,1996,1997, 2000, 2001, 2006, 2008, 2010, 2011 Free Software Foundation, Inc.
3 * This library is free software; you can redistribute it and/or
4 * modify it under the terms of the GNU Lesser General Public License
5 * as published by the Free Software Foundation; either version 3 of
6 * the License, or (at your option) any later version.
8 * This library is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * Lesser General Public License for more details.
13 * You should have received a copy of the GNU Lesser General Public
14 * License along with this library; if not, write to the Free Software
15 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
25 #include "libguile/_scm.h"
26 #include "libguile/ports.h"
27 #include "libguile/root.h"
28 #include "libguile/threads.h"
29 #include "libguile/dynwind.h"
31 #include "libguile/stackchk.h"
37 int scm_stack_checking_enabled_p
;
39 SCM_SYMBOL (scm_stack_overflow_key
, "stack-overflow");
42 reset_scm_stack_checking_enabled_p (void *arg
)
44 scm_stack_checking_enabled_p
= (int)(scm_t_bits
)arg
;
48 scm_report_stack_overflow ()
50 scm_dynwind_begin (0); /* non-rewindable frame */
51 scm_dynwind_unwind_handler (reset_scm_stack_checking_enabled_p
,
52 (void*)(scm_t_bits
)scm_stack_checking_enabled_p
,
53 SCM_F_WIND_EXPLICITLY
);
55 scm_stack_checking_enabled_p
= 0;
57 scm_error (scm_stack_overflow_key
,
68 scm_stack_size (SCM_STACKITEM
*start
)
71 #if SCM_STACK_GROWS_UP
72 return &stack
- start
;
74 return start
- &stack
;
75 #endif /* SCM_STACK_GROWS_UP */
82 SCM port
= scm_current_error_port ();
84 scm_i_thread
*thread
= SCM_I_CURRENT_THREAD
;
86 scm_uintprint ((scm_stack_size (thread
->continuation_base
)
87 * sizeof (SCM_STACKITEM
)),
89 scm_puts_unlocked (" of stack: 0x", port
);
90 scm_uintprint ((scm_t_bits
) thread
->continuation_base
, 16, port
);
91 scm_puts_unlocked (" - 0x", port
);
92 scm_uintprint ((scm_t_bits
) &stack
, 16, port
);
93 scm_puts_unlocked ("\n", port
);
97 SCM_DEFINE (scm_sys_get_stack_size
, "%get-stack-size", 0, 0, 0,
99 "Return the current thread's C stack size (in Scheme objects).")
100 #define FUNC_NAME s_scm_sys_get_stack_size
102 return scm_from_long (scm_stack_size (SCM_I_CURRENT_THREAD
->base
));
110 #include "libguile/stackchk.x"