mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-01 20:30:28 +02:00
* libguile/foreign.c: Convert to using RTL stubs. Because RTL code has different GC characteristics than objcode -- it's mostly assumed that RTL code will never go away -- we go ahead and pre-generate code for 100 arguments. This is actually less memory than the stack VM code, and doesn't require any relocations at load-time: bonus! We'll cross the >=100 args bridge if we ever come to it. (get_foreign_stub_code) New function. (scm_i_foreign_arity): New helper, like scm_i_primitive_arity. (cif_to_procedure): Rework to make RTL programs. * libguile/foreign.h: Declare scm_pointer_to_scm and scm_scm_to_pointer. Declare new internal helpers. * libguile/gsubr.c (create_subr): Refactor to set the flags when the object is allocated. * libguile/instructions.h: Define SCM_PACK_RTL_12_12. * libguile/programs.c (scm_i_rtl_program_minimum_arity): Dispatch to scm_i_foreign_arity if the procedure has the FOREIGN flag. * libguile/programs.h (SCM_F_PROGRAM_IS_FOREIGN) (SCM_PROGRAM_IS_FOREIGN): New interfaces. * test-suite/tests/foreign.test ("procedure->pointer"): Add a test for foreign arities.
109 lines
3.6 KiB
C
109 lines
3.6 KiB
C
/* Copyright (C) 2001, 2009, 2012, 2013 Free Software Foundation, Inc.
|
|
*
|
|
* This library 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.
|
|
*
|
|
* This library 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 this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef _SCM_INSTRUCTIONS_H_
|
|
#define _SCM_INSTRUCTIONS_H_
|
|
|
|
#include <libguile.h>
|
|
#include <libguile/vm-operations.h>
|
|
|
|
enum scm_rtl_opcode
|
|
{
|
|
#define ENUM(opcode, tag, name, meta) scm_rtl_op_##tag = opcode,
|
|
FOR_EACH_VM_OPERATION(ENUM)
|
|
#undef ENUM
|
|
};
|
|
|
|
#define SCM_PACK_RTL_8_8_8(op,a,b,c) ((op) | ((a) << 8) | ((b) << 16) | ((c) << 24))
|
|
#define SCM_PACK_RTL_8_16(op,a,b) ((op) | ((a) << 8) | ((b) << 16))
|
|
#define SCM_PACK_RTL_16_8(op,a,b) ((op) | ((a) << 8) | ((b) << 24))
|
|
#define SCM_PACK_RTL_12_12(op,a,b) ((op) | ((a) << 8) | ((b) << 20))
|
|
#define SCM_PACK_RTL_24(op,a) ((op) | ((a) << 8))
|
|
|
|
#define SCM_UNPACK_RTL_8_8_8(op,a,b,c) \
|
|
do \
|
|
{ \
|
|
a = (op >> 8) & 0xff; \
|
|
b = (op >> 16) & 0xff; \
|
|
c = op >> 24; \
|
|
} \
|
|
while (0)
|
|
|
|
#define SCM_UNPACK_RTL_8_16(op,a,b) \
|
|
do \
|
|
{ \
|
|
a = (op >> 8) & 0xff; \
|
|
b = op >> 16; \
|
|
} \
|
|
while (0)
|
|
|
|
#define SCM_UNPACK_RTL_16_8(op,a,b) \
|
|
do \
|
|
{ \
|
|
a = (op >> 8) & 0xffff; \
|
|
b = op >> 24; \
|
|
} \
|
|
while (0)
|
|
|
|
#define SCM_UNPACK_RTL_12_12(op,a,b) \
|
|
do \
|
|
{ \
|
|
a = (op >> 8) & 0xfff; \
|
|
b = op >> 20; \
|
|
} \
|
|
while (0)
|
|
|
|
#define SCM_UNPACK_RTL_24(op,a) \
|
|
do \
|
|
{ \
|
|
a = op >> 8; \
|
|
} \
|
|
while (0)
|
|
|
|
#define SCM_VM_NUM_INSTRUCTIONS (1<<8)
|
|
#define SCM_VM_INSTRUCTION_MASK (SCM_VM_NUM_INSTRUCTIONS-1)
|
|
|
|
enum scm_opcode {
|
|
#define VM_INSTRUCTION_TO_OPCODE 1
|
|
#include <libguile/vm-expand.h>
|
|
#include <libguile/vm-i-system.i>
|
|
#include <libguile/vm-i-scheme.i>
|
|
#include <libguile/vm-i-loader.i>
|
|
#undef VM_INSTRUCTION_TO_OPCODE
|
|
};
|
|
|
|
SCM_INTERNAL SCM scm_rtl_instruction_list (void);
|
|
|
|
SCM_API SCM scm_instruction_list (void);
|
|
SCM_API SCM scm_instruction_p (SCM obj);
|
|
SCM_API SCM scm_instruction_length (SCM inst);
|
|
SCM_API SCM scm_instruction_pops (SCM inst);
|
|
SCM_API SCM scm_instruction_pushes (SCM inst);
|
|
SCM_API SCM scm_instruction_to_opcode (SCM inst);
|
|
SCM_API SCM scm_opcode_to_instruction (SCM op);
|
|
|
|
SCM_INTERNAL void scm_bootstrap_instructions (void);
|
|
SCM_INTERNAL void scm_init_instructions (void);
|
|
|
|
#endif /* _SCM_INSTRUCTIONS_H_ */
|
|
|
|
/*
|
|
Local Variables:
|
|
c-file-style: "gnu"
|
|
End:
|
|
*/
|