2010-12-03 05:34:57 +01:00
|
|
|
/* go-defer.h -- the defer stack.
|
|
|
|
|
|
|
|
Copyright 2010 The Go Authors. All rights reserved.
|
|
|
|
Use of this source code is governed by a BSD-style
|
|
|
|
license that can be found in the LICENSE file. */
|
|
|
|
|
|
|
|
struct __go_panic_stack;
|
|
|
|
|
|
|
|
/* The defer stack is a list of these structures. */
|
|
|
|
|
|
|
|
struct __go_defer_stack
|
|
|
|
{
|
|
|
|
/* The next entry in the stack. */
|
|
|
|
struct __go_defer_stack *__next;
|
|
|
|
|
2011-09-16 07:47:20 +02:00
|
|
|
/* The stack variable for the function which called this defer
|
|
|
|
statement. This is set to 1 if we are returning from that
|
|
|
|
function, 0 if we are panicing through it. */
|
|
|
|
_Bool *__frame;
|
2010-12-03 05:34:57 +01:00
|
|
|
|
|
|
|
/* The value of the panic stack when this function is deferred.
|
|
|
|
This function can not recover this value from the panic stack.
|
2014-06-07 00:37:27 +02:00
|
|
|
This can happen if a deferred function has a defer statement
|
|
|
|
itself. */
|
2010-12-03 05:34:57 +01:00
|
|
|
struct __go_panic_stack *__panic;
|
|
|
|
|
|
|
|
/* The function to call. */
|
|
|
|
void (*__pfn) (void *);
|
|
|
|
|
|
|
|
/* The argument to pass to the function. */
|
|
|
|
void *__arg;
|
|
|
|
|
|
|
|
/* The return address that a recover thunk matches against. This is
|
|
|
|
set by __go_set_defer_retaddr which is called by the thunks
|
|
|
|
created by defer statements. */
|
|
|
|
const void *__retaddr;
|
2013-12-12 00:43:16 +01:00
|
|
|
|
|
|
|
/* Set to true if a function created by reflect.MakeFunc is
|
|
|
|
permitted to recover. The return address of such a function
|
|
|
|
function will be somewhere in libffi, so __retaddr is not
|
|
|
|
useful. */
|
|
|
|
_Bool __makefunc_can_recover;
|
2013-12-12 21:13:58 +01:00
|
|
|
|
2014-06-07 00:37:27 +02:00
|
|
|
/* Set to true if this defer stack entry is not part of the defer
|
|
|
|
pool. */
|
|
|
|
_Bool __special;
|
2010-12-03 05:34:57 +01:00
|
|
|
};
|