mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-29 19:30:36 +02:00
* libguile/scm.h (struct scm_thread, scm_thread): Rename from scm_i_thread. * libguile/deprecated.h (scm_i_thread): Add deprecated typedef. * libguile/threads.h: Adapt to renaming. * libguile/intrinsics.h: * libguile/scmsigs.h: * libguile/cache-internal.h: Remove threads.h includes; unnecessary with the forward decl. * libguile/continuations.h: * libguile/gc-inline.h: * libguile/async.h: Adapt scm_thread type name change. * libguile/async.c: * libguile/continuations.c: * libguile/control.c: * libguile/dynstack.c: * libguile/dynwind.c: * libguile/eval.c: * libguile/finalizers.c: * libguile/fluids.c: * libguile/gc.c: * libguile/intrinsics.c: * libguile/load.c: * libguile/memoize.c: * libguile/print.c: * libguile/read.c: * libguile/scmsigs.c: * libguile/script.c: * libguile/stackchk.c: * libguile/stacks.c: * libguile/symbols.c: * libguile/threads.c: * libguile/throw.c: * libguile/vm-engine.c: * libguile/vm.c: Adapt to type name change, and add additional includes as needed.
128 lines
6.1 KiB
C
128 lines
6.1 KiB
C
/* Copyright 2018
|
|
Free Software Foundation, Inc.
|
|
|
|
This file is part of Guile.
|
|
|
|
Guile is free software: you can redistribute it and/or modify it
|
|
under the terms of the GNU Lesser General Public License as published
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
Guile is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with Guile. If not, see
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef _SCM_INTRINSICS_H_
|
|
#define _SCM_INTRINSICS_H_
|
|
|
|
#ifndef BUILDING_LIBGUILE
|
|
#error intrinsics.h is private and uninstalled
|
|
#endif
|
|
|
|
#include <libguile/scm.h>
|
|
|
|
|
|
typedef SCM (*scm_t_scm_from_scm_scm_intrinsic) (SCM, SCM);
|
|
typedef SCM (*scm_t_scm_from_scm_uimm_intrinsic) (SCM, uint8_t);
|
|
typedef void (*scm_t_scm_u64_u64_intrinsic) (SCM, uint64_t, uint64_t);
|
|
typedef SCM (*scm_t_scm_from_scm_intrinsic) (SCM);
|
|
typedef double (*scm_t_f64_from_scm_intrinsic) (SCM);
|
|
typedef uint64_t (*scm_t_u64_from_scm_intrinsic) (SCM);
|
|
typedef int64_t (*scm_t_s64_from_scm_intrinsic) (SCM);
|
|
typedef SCM (*scm_t_scm_from_u64_intrinsic) (uint64_t);
|
|
typedef SCM (*scm_t_scm_from_s64_intrinsic) (int64_t);
|
|
typedef void (*scm_t_thread_intrinsic) (scm_thread*);
|
|
typedef void (*scm_t_thread_scm_intrinsic) (scm_thread*, SCM);
|
|
typedef void (*scm_t_thread_scm_scm_intrinsic) (scm_thread*, SCM, SCM);
|
|
typedef SCM (*scm_t_scm_from_thread_scm_intrinsic) (scm_thread*, SCM);
|
|
typedef SCM (*scm_t_scm_from_scm_u64_intrinsic) (SCM, uint64_t);
|
|
typedef int (*scm_t_bool_from_scm_scm_intrinsic) (SCM, SCM);
|
|
typedef enum scm_compare (*scm_t_compare_from_scm_scm_intrinsic) (SCM, SCM);
|
|
typedef void (*scm_t_thread_sp_intrinsic) (scm_thread*, union scm_vm_stack_element*);
|
|
typedef SCM (*scm_t_scm_from_thread_u32_intrinsic) (scm_thread*, uint32_t);
|
|
typedef uint32_t (*scm_t_u32_from_thread_u32_u32_intrinsic) (scm_thread*, uint32_t, uint32_t);
|
|
typedef void (*scm_t_thread_u32_u32_scm_u8_u8_intrinsic) (scm_thread*, uint32_t,
|
|
uint32_t, SCM, uint8_t,
|
|
uint8_t);
|
|
typedef SCM (*scm_t_scm_from_scm_scm_scmp_sp_intrinsic) (SCM, SCM, SCM*,
|
|
const union scm_vm_stack_element*);
|
|
typedef void (*scm_t_thread_scm_noreturn_intrinsic) (scm_thread*, SCM) SCM_NORETURN;
|
|
|
|
#define SCM_FOR_ALL_VM_INTRINSICS(M) \
|
|
M(scm_from_scm_scm, add, "add", ADD) \
|
|
M(scm_from_scm_uimm, add_immediate, "add/immediate", ADD_IMMEDIATE) \
|
|
M(scm_from_scm_scm, sub, "sub", SUB) \
|
|
M(scm_from_scm_uimm, sub_immediate, "sub/immediate", SUB_IMMEDIATE) \
|
|
M(scm_from_scm_scm, mul, "mul", MUL) \
|
|
M(scm_from_scm_scm, div, "div", DIV) \
|
|
M(scm_from_scm_scm, quo, "quo", QUO) \
|
|
M(scm_from_scm_scm, rem, "rem", REM) \
|
|
M(scm_from_scm_scm, mod, "mod", MOD) \
|
|
M(scm_from_scm_scm, logand, "logand", LOGAND) \
|
|
M(scm_from_scm_scm, logior, "logior", LOGIOR) \
|
|
M(scm_from_scm_scm, logxor, "logxor", LOGXOR) \
|
|
M(scm_u64_u64, string_set_x, "string-set!", STRING_SET_X) \
|
|
M(scm_from_scm, string_to_number, "string->number", STRING_TO_NUMBER) \
|
|
M(scm_from_scm, string_to_symbol, "string->symbol", STRING_TO_SYMBOL) \
|
|
M(scm_from_scm, symbol_to_keyword, "symbol->keyword", SYMBOL_TO_KEYWORD) \
|
|
M(scm_from_scm, class_of, "class-of", CLASS_OF) \
|
|
M(f64_from_scm, scm_to_f64, "scm->f64", SCM_TO_F64) \
|
|
M(u64_from_scm, scm_to_u64, "scm->u64", SCM_TO_U64) \
|
|
M(u64_from_scm, scm_to_u64_truncate, "scm->u64/truncate", SCM_TO_U64_TRUNCATE) \
|
|
M(s64_from_scm, scm_to_s64, "scm->s64", SCM_TO_S64) \
|
|
M(scm_from_u64, u64_to_scm, "u64->scm", U64_TO_SCM) \
|
|
M(scm_from_s64, s64_to_scm, "s64->scm", S64_TO_SCM) \
|
|
M(scm_from_scm_scm, logsub, "logsub", LOGSUB) \
|
|
M(thread_scm_scm, wind, "wind", WIND) \
|
|
M(thread, unwind, "unwind", UNWIND) \
|
|
M(thread_scm_scm, push_fluid, "push-fluid", PUSH_FLUID) \
|
|
M(thread, pop_fluid, "pop-fluid", POP_FLUID) \
|
|
M(scm_from_thread_scm, fluid_ref, "fluid-ref", FLUID_REF) \
|
|
M(thread_scm_scm, fluid_set_x, "fluid-set!", FLUID_SET_X) \
|
|
M(thread_scm, push_dynamic_state, "push-dynamic-state", PUSH_DYNAMIC_STATE) \
|
|
M(thread, pop_dynamic_state, "pop-dynamic-state", POP_DYNAMIC_STATE) \
|
|
M(scm_from_scm_u64, lsh, "lsh", LSH) \
|
|
M(scm_from_scm_u64, rsh, "rsh", RSH) \
|
|
M(scm_from_scm_uimm, lsh_immediate, "lsh/immediate", LSH_IMMEDIATE) \
|
|
M(scm_from_scm_uimm, rsh_immediate, "rsh/immediate", RSH_IMMEDIATE) \
|
|
M(bool_from_scm_scm, heap_numbers_equal_p, "heap-numbers-equal?", HEAP_NUMBERS_EQUAL_P) \
|
|
M(compare_from_scm_scm, less_p, "<?", LESS_P) \
|
|
M(bool_from_scm_scm, numerically_equal_p, "=?", NUMERICALLY_EQUAL_P) \
|
|
M(scm_from_scm_uimm, resolve_module, "resolve-module", RESOLVE_MODULE) \
|
|
M(scm_from_scm_scm, lookup, "lookup", LOOKUP) \
|
|
M(scm_from_scm_scm, define_x, "define!", DEFINE_X) \
|
|
M(thread_sp, expand_stack, "expand-stack", EXPAND_STACK) \
|
|
M(scm_from_thread_u32, cons_rest, "cons-rest", CONS_REST) \
|
|
M(u32_from_thread_u32_u32, compute_kwargs_npositional, "compute-kwargs-npositional", COMPUTE_KWARGS_NPOSITIONAL) \
|
|
M(thread_u32_u32_scm_u8_u8, bind_kwargs, "bind-kwargs", BIND_KWARGS) \
|
|
M(thread, push_interrupt_frame, "push-interrupt-frame", PUSH_INTERRUPT_FRAME) \
|
|
M(scm_from_scm_scm_scmp_sp, foreign_call, "foreign-call", FOREIGN_CALL) \
|
|
M(thread_scm_noreturn, reinstate_continuation_x, "reinstate-continuation!", REINSTATE_CONTINUATION_X) \
|
|
/* Add new intrinsics here; also update scm_bootstrap_intrinsics. */
|
|
|
|
enum scm_vm_intrinsic
|
|
{
|
|
#define DEFINE_ENUM(type, id, name, ID) SCM_VM_INTRINSIC_##ID,
|
|
SCM_FOR_ALL_VM_INTRINSICS(DEFINE_ENUM)
|
|
#undef DEFINE_ENUM
|
|
SCM_VM_INTRINSIC_COUNT
|
|
};
|
|
|
|
SCM_INTERNAL struct scm_vm_intrinsics
|
|
{
|
|
#define DEFINE_MEMBER(type, id, name, ID) scm_t_##type##_intrinsic id;
|
|
SCM_FOR_ALL_VM_INTRINSICS(DEFINE_MEMBER)
|
|
#undef DEFINE_MEMBER
|
|
} scm_vm_intrinsics;
|
|
|
|
SCM_INTERNAL SCM scm_intrinsic_list (void);
|
|
|
|
SCM_INTERNAL void scm_bootstrap_intrinsics (void);
|
|
SCM_INTERNAL void scm_init_intrinsics (void);
|
|
|
|
#endif /* _SCM_INTRINSICS_H_ */
|