2007-10-25 16:27:34 -04:00
|
|
|
/*
|
|
|
|
* Ikarus Scheme -- A compiler for R6RS Scheme.
|
2008-01-29 00:34:34 -05:00
|
|
|
* Copyright (C) 2006,2007,2008 Abdulaziz Ghuloum
|
2007-10-25 16:27:34 -04:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 3 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program 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
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2007-10-17 09:22:47 -04:00
|
|
|
|
|
|
|
#ifndef IKARUS_H
|
|
|
|
#define IKARUS_H
|
2007-12-26 22:28:48 -05:00
|
|
|
#include "ikarus-getaddrinfo.h"
|
2007-10-17 09:22:47 -04:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <sys/resource.h>
|
|
|
|
|
|
|
|
extern int total_allocated_pages;
|
|
|
|
extern int total_malloced;
|
|
|
|
extern int hash_table_count;
|
|
|
|
|
|
|
|
#define cardsize 512
|
|
|
|
#define cards_per_page 8
|
|
|
|
|
|
|
|
#define most_bytes_in_minor 0x10000000
|
|
|
|
|
|
|
|
#define old_gen_mask 0x00000007
|
|
|
|
#define new_gen_mask 0x00000008
|
|
|
|
#define gen_mask 0x0000000F
|
|
|
|
#define new_gen_tag 0x00000008
|
|
|
|
#define meta_dirty_mask 0x000000F0
|
|
|
|
#define type_mask 0x00000F00
|
|
|
|
#define scannable_mask 0x0000F000
|
|
|
|
#define dealloc_mask 0x000F0000
|
|
|
|
#define large_object_mask 0x00100000
|
|
|
|
#define meta_dirty_shift 4
|
|
|
|
|
|
|
|
#define hole_type 0x00000000
|
|
|
|
#define mainheap_type 0x00000100
|
|
|
|
#define mainstack_type 0x00000200
|
|
|
|
#define pointers_type 0x00000300
|
|
|
|
#define dat_type 0x00000400
|
|
|
|
#define code_type 0x00000500
|
|
|
|
#define weak_pairs_type 0x00000600
|
|
|
|
#define symbols_type 0x00000700
|
|
|
|
|
|
|
|
#define scannable_tag 0x00001000
|
|
|
|
#define unscannable_tag 0x00000000
|
|
|
|
|
|
|
|
#define dealloc_tag_un 0x00010000
|
|
|
|
#define dealloc_tag_at 0x00020000
|
|
|
|
#define retain_tag 0x00000000
|
|
|
|
|
|
|
|
#define large_object_tag 0x00100000
|
|
|
|
|
|
|
|
#define hole_mt (hole_type | unscannable_tag | retain_tag)
|
|
|
|
#define mainheap_mt (mainheap_type | unscannable_tag | retain_tag)
|
|
|
|
#define mainstack_mt (mainstack_type | unscannable_tag | retain_tag)
|
|
|
|
#define pointers_mt (pointers_type | scannable_tag | dealloc_tag_un)
|
|
|
|
#define symbols_mt (symbols_type | scannable_tag | dealloc_tag_un)
|
|
|
|
#define data_mt (dat_type | unscannable_tag | dealloc_tag_un)
|
|
|
|
#define code_mt (code_type | scannable_tag | dealloc_tag_un)
|
|
|
|
#define weak_pairs_mt (weak_pairs_type | scannable_tag | dealloc_tag_un)
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
inthash(int key) {
|
|
|
|
key += ~(key << 15);
|
|
|
|
key ^= (key >> 10);
|
|
|
|
key += (key << 3);
|
|
|
|
key ^= (key >> 6);
|
|
|
|
key += ~(key << 11);
|
|
|
|
key ^= (key >> 16);
|
|
|
|
return key;
|
|
|
|
return inthash(key);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define pagesize 4096
|
|
|
|
#define generation_count 5 /* generations 0 (nursery), 1, 2, 3, 4 */
|
|
|
|
|
2008-01-01 23:07:41 -05:00
|
|
|
typedef unsigned long int ikptr;
|
2008-01-01 21:08:07 -05:00
|
|
|
|
2008-01-01 04:24:36 -05:00
|
|
|
typedef int ikchar;
|
2007-12-23 13:37:48 -05:00
|
|
|
|
|
|
|
void ik_error(ikptr args);
|
2007-10-17 09:22:47 -04:00
|
|
|
|
|
|
|
typedef struct ikpage{
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr base;
|
2007-10-17 09:22:47 -04:00
|
|
|
struct ikpage* next;
|
|
|
|
} ikpage;
|
|
|
|
|
|
|
|
typedef struct ikpages{
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr base;
|
2007-10-17 09:22:47 -04:00
|
|
|
int size;
|
|
|
|
struct ikpages* next;
|
|
|
|
} ikpages;
|
|
|
|
|
|
|
|
typedef struct ikdl{ /* double-link */
|
|
|
|
struct ikdl* prev;
|
|
|
|
struct ikdl* next;
|
|
|
|
} ikdl;
|
|
|
|
|
|
|
|
|
|
|
|
#define ik_ptr_page_size \
|
2008-01-02 20:58:48 -05:00
|
|
|
((pagesize - sizeof(long int) - sizeof(struct ik_ptr_page*))/sizeof(ikptr))
|
2007-10-17 09:22:47 -04:00
|
|
|
|
|
|
|
typedef struct ik_ptr_page{
|
2008-01-02 20:58:48 -05:00
|
|
|
long int count;
|
2007-10-17 09:22:47 -04:00
|
|
|
struct ik_ptr_page* next;
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr ptr[ik_ptr_page_size];
|
2007-10-17 09:22:47 -04:00
|
|
|
} ik_ptr_page;
|
2008-01-02 20:58:48 -05:00
|
|
|
|
2007-10-17 09:22:47 -04:00
|
|
|
|
|
|
|
typedef struct ikpcb{
|
|
|
|
/* the first locations may be accessed by some */
|
|
|
|
/* compiled code to perform overflow/underflow ops */
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr allocation_pointer; /* offset = 0 */
|
|
|
|
ikptr allocation_redline; /* offset = 4 */
|
|
|
|
ikptr frame_pointer; /* offset = 8 */
|
|
|
|
ikptr frame_base; /* offset = 12 */
|
|
|
|
ikptr frame_redline; /* offset = 16 */
|
|
|
|
ikptr next_k; /* offset = 20 */
|
2008-01-01 21:08:07 -05:00
|
|
|
ikptr system_stack; /* offset = 24 */
|
|
|
|
ikptr dirty_vector; /* offset = 28 */
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr arg_list; /* offset = 32 */
|
2008-01-01 23:07:41 -05:00
|
|
|
ikptr engine_counter; /* offset = 36 */
|
|
|
|
ikptr interrupted; /* offset = 40 */
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr base_rtd; /* offset = 44 */
|
|
|
|
ikptr collect_key; /* offset = 48 */
|
2007-10-17 09:22:47 -04:00
|
|
|
/* the rest are not used by any scheme code */
|
|
|
|
/* they only support the runtime system (gc, etc.) */
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr* root0;
|
|
|
|
ikptr* root1;
|
2007-10-17 09:22:47 -04:00
|
|
|
unsigned int* segment_vector;
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr weak_pairs_ap;
|
|
|
|
ikptr weak_pairs_ep;
|
|
|
|
ikptr heap_base;
|
2008-06-04 03:54:53 -04:00
|
|
|
unsigned long int heap_size;
|
2007-10-17 09:22:47 -04:00
|
|
|
ikpages* heap_pages;
|
|
|
|
ikpage* cached_pages; /* pages cached so that we don't map/unmap */
|
|
|
|
ikpage* uncached_pages; /* ikpages cached so that we don't malloc/free */
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr cached_pages_base;
|
2007-10-17 09:22:47 -04:00
|
|
|
int cached_pages_size;
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr stack_base;
|
2008-06-04 03:54:53 -04:00
|
|
|
unsigned long int stack_size;
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr symbol_table;
|
|
|
|
ikptr gensym_table;
|
2008-01-12 17:32:43 -05:00
|
|
|
ik_ptr_page* protected_list[generation_count];
|
2007-10-17 09:22:47 -04:00
|
|
|
unsigned int* dirty_vector_base;
|
|
|
|
unsigned int* segment_vector_base;
|
2008-01-01 21:08:07 -05:00
|
|
|
ikptr memory_base;
|
|
|
|
ikptr memory_end;
|
2007-10-17 09:22:47 -04:00
|
|
|
int collection_id;
|
|
|
|
int allocation_count_minor;
|
|
|
|
int allocation_count_major;
|
|
|
|
struct timeval collect_utime;
|
|
|
|
struct timeval collect_stime;
|
|
|
|
struct timeval collect_rtime;
|
|
|
|
} ikpcb;
|
|
|
|
|
2008-06-04 03:54:53 -04:00
|
|
|
ikpcb* ik_collect(unsigned long int, ikpcb*);
|
2007-10-17 09:22:47 -04:00
|
|
|
void ikarus_usage_short(void);
|
|
|
|
|
|
|
|
void* ik_malloc(int);
|
|
|
|
void ik_free(void*, int);
|
|
|
|
|
2008-01-01 21:08:07 -05:00
|
|
|
ikptr ik_mmap(int);
|
|
|
|
ikptr ik_mmap_typed(int size, unsigned int type, ikpcb*);
|
|
|
|
ikptr ik_mmap_ptr(int size, int gen, ikpcb*);
|
|
|
|
ikptr ik_mmap_data(int size, int gen, ikpcb*);
|
|
|
|
ikptr ik_mmap_code(int size, int gen, ikpcb*);
|
|
|
|
ikptr ik_mmap_mixed(int size, ikpcb*);
|
|
|
|
void ik_munmap(ikptr, int);
|
2008-06-04 03:54:53 -04:00
|
|
|
void ik_munmap_from_segment(ikptr, unsigned long int, ikpcb*);
|
2007-10-17 09:22:47 -04:00
|
|
|
ikpcb* ik_make_pcb();
|
|
|
|
void ik_delete_pcb(ikpcb*);
|
|
|
|
void ik_free_symbol_table(ikpcb* pcb);
|
|
|
|
|
|
|
|
void ik_fasl_load(ikpcb* pcb, char* filename);
|
2007-12-23 13:37:48 -05:00
|
|
|
void ik_relocate_code(ikptr);
|
2007-10-17 09:22:47 -04:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr ik_exec_code(ikpcb* pcb, ikptr code_ptr);
|
|
|
|
void ik_print(ikptr x);
|
|
|
|
void ik_fprint(FILE*, ikptr x);
|
2007-10-17 09:22:47 -04:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr ikrt_string_to_symbol(ikptr, ikpcb*);
|
|
|
|
ikptr ikrt_strings_to_gensym(ikptr, ikptr, ikpcb*);
|
2007-10-17 09:22:47 -04:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr ik_cstring_to_symbol(char*, ikpcb*);
|
2007-10-17 09:22:47 -04:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
ikptr ik_asm_enter(ikpcb*, ikptr code_object, ikptr arg);
|
|
|
|
ikptr ik_asm_reenter(ikpcb*, ikptr code_object, ikptr val);
|
|
|
|
ikptr ik_underflow_handler(ikpcb*);
|
|
|
|
ikptr ik_unsafe_alloc(ikpcb* pcb, int size);
|
|
|
|
ikptr ik_safe_alloc(ikpcb* pcb, int size);
|
2007-10-17 09:22:47 -04:00
|
|
|
|
2008-01-02 20:58:48 -05:00
|
|
|
#define IK_HEAP_EXT_SIZE (32 * 4096)
|
2008-04-12 15:06:55 -04:00
|
|
|
#define IK_HEAPSIZE (1024 * ((wordsize==4)?1:2) * 4096) /* 4/8 MB */
|
2008-01-02 20:58:48 -05:00
|
|
|
|
2008-06-04 03:54:53 -04:00
|
|
|
#define wordsize ((int)(sizeof(ikptr)))
|
2008-01-02 20:58:48 -05:00
|
|
|
#define wordshift ((wordsize == 4)?2:3)
|
|
|
|
#define align_shift (wordshift + 1)
|
|
|
|
#define align_size (2 * wordsize)
|
|
|
|
#define fx_shift wordshift
|
|
|
|
#define fx_mask (wordsize - 1)
|
|
|
|
|
|
|
|
#define align(n) \
|
|
|
|
((((n) + align_size - 1) >> align_shift) << align_shift)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
2008-01-03 02:07:17 -05:00
|
|
|
#define IK_FASL_HEADER \
|
|
|
|
((sizeof(ikptr) == 4) ? "#@IK01" : "#@IK02")
|
2006-11-23 19:38:26 -05:00
|
|
|
#define IK_FASL_HEADER_LEN (strlen(IK_FASL_HEADER))
|
|
|
|
|
|
|
|
#define code_pri_tag vector_tag
|
2008-01-02 20:58:48 -05:00
|
|
|
#define code_tag ((ikptr)0x2F)
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_code_code_size (1 * wordsize)
|
|
|
|
#define disp_code_reloc_vector (2 * wordsize)
|
|
|
|
#define disp_code_freevars (3 * wordsize)
|
|
|
|
#define disp_code_annotation (4 * wordsize)
|
|
|
|
#define disp_code_unused (5 * wordsize)
|
|
|
|
#define disp_code_data (6 * wordsize)
|
2007-09-04 19:59:14 -04:00
|
|
|
#define off_code_annotation (disp_code_annotation - code_pri_tag)
|
2006-11-23 19:38:26 -05:00
|
|
|
#define off_code_data (disp_code_data - code_pri_tag)
|
2006-11-23 19:44:29 -05:00
|
|
|
#define off_code_reloc_vector (disp_code_reloc_vector - code_pri_tag)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
2008-01-01 04:24:36 -05:00
|
|
|
#define unfix(x) (((long int)(x)) >> fx_shift)
|
|
|
|
#define fix(x) ((ikptr)(((long int)(x)) << fx_shift))
|
2008-01-01 21:08:07 -05:00
|
|
|
#define is_fixnum(x) ((((unsigned long)(x)) & fx_mask) == 0)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
|
|
|
#define ref(x,n) \
|
2008-01-01 21:08:07 -05:00
|
|
|
(((ikptr*)(((char*)(long int)(x)) + ((long int)(n))))[0])
|
2006-11-23 19:38:26 -05:00
|
|
|
|
2008-01-01 21:08:07 -05:00
|
|
|
#define tagof(x) (((int)(x)) & 7)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
|
|
|
#define immediate_tag 7
|
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
#define false_object ((ikptr)0x2F)
|
|
|
|
#define true_object ((ikptr)0x3F)
|
|
|
|
#define null_object ((ikptr)0x4F)
|
|
|
|
#define void_object ((ikptr)0x7F)
|
|
|
|
#define bwp_object ((ikptr)0x8F)
|
2006-11-23 19:42:39 -05:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
#define unbound_object ((ikptr)0x6F)
|
2008-01-02 20:58:48 -05:00
|
|
|
#define char_tag 0x0F
|
|
|
|
#define char_mask 0xFF
|
|
|
|
#define char_shift 8
|
2008-01-01 04:24:36 -05:00
|
|
|
#define int_to_scheme_char(x) \
|
2008-01-02 20:58:48 -05:00
|
|
|
((ikptr)((((unsigned long int)(x)) << char_shift) | char_tag))
|
|
|
|
#define pair_size (2 * wordsize)
|
2008-01-01 04:24:36 -05:00
|
|
|
#define pair_mask 7
|
2006-11-23 19:38:26 -05:00
|
|
|
#define pair_tag 1
|
2008-01-02 20:58:48 -05:00
|
|
|
#define disp_car 0
|
|
|
|
#define disp_cdr wordsize
|
2006-11-23 19:38:26 -05:00
|
|
|
#define off_car (disp_car - pair_tag)
|
|
|
|
#define off_cdr (disp_cdr - pair_tag)
|
2008-01-02 20:58:48 -05:00
|
|
|
#define is_char(x) ((char_mask & (int)(x)) == char_tag)
|
2006-11-23 19:38:26 -05:00
|
|
|
#define string_tag 6
|
|
|
|
#define disp_string_length 0
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_string_data wordsize
|
2006-11-23 19:38:26 -05:00
|
|
|
#define off_string_length (disp_string_length - string_tag)
|
|
|
|
#define off_string_data (disp_string_data - string_tag)
|
|
|
|
|
2007-05-19 13:54:13 -04:00
|
|
|
#define string_set(x,i,c) \
|
2008-01-01 21:42:52 -05:00
|
|
|
(((ikchar*)(((long)(x)) + off_string_data))[i] = ((ikchar)(c)))
|
2008-01-01 04:24:36 -05:00
|
|
|
#define integer_to_char(x) \
|
2008-01-02 20:58:48 -05:00
|
|
|
((ikchar)((((int)(x)) << char_shift) + char_tag))
|
2007-05-19 14:38:45 -04:00
|
|
|
#define string_char_size 4
|
2006-11-23 19:38:26 -05:00
|
|
|
|
|
|
|
#define vector_tag 5
|
|
|
|
#define disp_vector_length 0
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_vector_data wordsize
|
2008-01-02 20:58:48 -05:00
|
|
|
#define off_vector_data (disp_vector_data - vector_tag)
|
2006-11-23 19:38:26 -05:00
|
|
|
#define off_vector_length (disp_vector_length - vector_tag)
|
|
|
|
|
2007-05-17 04:34:52 -04:00
|
|
|
#define bytevector_tag 2
|
|
|
|
#define disp_bytevector_length 0
|
2008-01-02 20:58:48 -05:00
|
|
|
#define disp_bytevector_data 8 /* not f(wordsize) */
|
2007-05-17 04:34:52 -04:00
|
|
|
#define off_bytevector_length (disp_bytevector_length - bytevector_tag)
|
2008-01-02 20:58:48 -05:00
|
|
|
#define off_bytevector_data (disp_bytevector_data - bytevector_tag)
|
2007-05-17 04:34:52 -04:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
#define symbol_record_tag ((ikptr) 0x5F)
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_symbol_record_string (1 * wordsize)
|
|
|
|
#define disp_symbol_record_ustring (2 * wordsize)
|
|
|
|
#define disp_symbol_record_value (3 * wordsize)
|
|
|
|
#define disp_symbol_record_proc (4 * wordsize)
|
|
|
|
#define disp_symbol_record_plist (5 * wordsize)
|
|
|
|
#define symbol_record_size (6 * wordsize)
|
2007-05-15 08:56:22 -04:00
|
|
|
#define off_symbol_record_string (disp_symbol_record_string - record_tag)
|
|
|
|
#define off_symbol_record_ustring (disp_symbol_record_ustring - record_tag)
|
|
|
|
#define off_symbol_record_value (disp_symbol_record_value - record_tag)
|
|
|
|
#define off_symbol_record_proc (disp_symbol_record_proc - record_tag)
|
|
|
|
#define off_symbol_record_plist (disp_symbol_record_plist - record_tag)
|
|
|
|
|
2006-11-23 19:38:26 -05:00
|
|
|
#define closure_tag 3
|
|
|
|
#define closure_mask 7
|
|
|
|
#define disp_closure_code 0
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_closure_data wordsize
|
2006-11-23 19:38:26 -05:00
|
|
|
#define off_closure_code (disp_closure_code - closure_tag)
|
|
|
|
#define off_closure_data (disp_closure_data - closure_tag)
|
|
|
|
|
2008-01-01 04:24:36 -05:00
|
|
|
#define is_closure(x) ((((long int)(x)) & closure_mask) == closure_tag)
|
|
|
|
#define is_pair(x) ((((long int)(x)) & pair_mask) == pair_tag)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
|
|
|
#define record_tag vector_tag
|
|
|
|
#define disp_record_rtd 0
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_record_data wordsize
|
2006-11-23 19:38:26 -05:00
|
|
|
#define off_record_rtd (disp_record_rtd - record_tag)
|
|
|
|
#define off_record_data (disp_record_data - record_tag)
|
|
|
|
|
|
|
|
#define rtd_tag record_tag
|
2006-11-23 19:40:06 -05:00
|
|
|
#define disp_rtd_rtd 0
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_rtd_name (1 * wordsize)
|
|
|
|
#define disp_rtd_length (2 * wordsize)
|
|
|
|
#define disp_rtd_fields (3 * wordsize)
|
|
|
|
#define disp_rtd_printer (4 * wordsize)
|
|
|
|
#define disp_rtd_symbol (5 * wordsize)
|
|
|
|
#define rtd_size (6 * wordsize)
|
2006-11-23 19:40:06 -05:00
|
|
|
|
|
|
|
#define off_rtd_rtd (disp_rtd_rtd - rtd_tag)
|
|
|
|
#define off_rtd_name (disp_rtd_name - rtd_tag)
|
|
|
|
#define off_rtd_length (disp_rtd_length - rtd_tag)
|
|
|
|
#define off_rtd_fields (disp_rtd_fields - rtd_tag)
|
|
|
|
#define off_rtd_printer (disp_rtd_printer - rtd_tag)
|
2006-11-23 19:44:29 -05:00
|
|
|
#define off_rtd_symbol (disp_rtd_symbol - rtd_tag)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
#define continuation_tag ((ikptr)0x1F)
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_continuation_top (1 * wordsize)
|
|
|
|
#define disp_continuation_size (2 * wordsize)
|
|
|
|
#define disp_continuation_next (3 * wordsize)
|
|
|
|
#define continuation_size (4 * wordsize)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
|
|
|
#define off_continuation_top (disp_continuation_top - vector_tag)
|
|
|
|
#define off_continuation_size (disp_continuation_size - vector_tag)
|
|
|
|
#define off_continuation_next (disp_continuation_next - vector_tag)
|
|
|
|
|
|
|
|
#define pagesize 4096
|
|
|
|
#define pageshift 12
|
|
|
|
#define align_to_next_page(x) \
|
2008-01-01 04:24:36 -05:00
|
|
|
(((pagesize - 1 + (unsigned long int)(x)) >> pageshift) << pageshift)
|
2006-11-23 19:38:26 -05:00
|
|
|
#define align_to_prev_page(x) \
|
2008-01-01 04:24:36 -05:00
|
|
|
((((unsigned long int)(x)) >> pageshift) << pageshift)
|
2006-11-23 19:38:26 -05:00
|
|
|
|
2008-01-03 02:07:17 -05:00
|
|
|
#define call_instruction_size \
|
|
|
|
((wordsize == 4) ? 5 : 10)
|
2008-01-02 20:58:48 -05:00
|
|
|
#define disp_frame_size (- (call_instruction_size + 3 * wordsize))
|
|
|
|
#define disp_frame_offset (- (call_instruction_size + 2 * wordsize))
|
|
|
|
#define disp_multivale_rp (- (call_instruction_size + 1 * wordsize))
|
2006-11-23 19:38:26 -05:00
|
|
|
|
2006-11-23 19:48:14 -05:00
|
|
|
#define port_tag 0x3F
|
|
|
|
#define port_mask 0x3F
|
2008-01-02 20:58:48 -05:00
|
|
|
#define port_size (14 * wordsize)
|
2006-11-23 19:48:14 -05:00
|
|
|
|
2008-01-02 18:05:32 -05:00
|
|
|
#define disp_tcbucket_tconc (0 * wordsize)
|
|
|
|
#define disp_tcbucket_key (1 * wordsize)
|
|
|
|
#define disp_tcbucket_val (2 * wordsize)
|
|
|
|
#define disp_tcbucket_next (3 * wordsize)
|
|
|
|
#define tcbucket_size (4 * wordsize)
|
2006-11-23 19:48:14 -05:00
|
|
|
#define off_tcbucket_tconc (disp_tcbucket_tconc - vector_tag)
|
|
|
|
#define off_tcbucket_key (disp_tcbucket_key - vector_tag)
|
|
|
|
#define off_tcbucket_val (disp_tcbucket_val - vector_tag)
|
|
|
|
#define off_tcbucket_next (disp_tcbucket_next - vector_tag)
|
|
|
|
|
|
|
|
#define bignum_mask 0x7
|
2007-01-21 20:36:22 -05:00
|
|
|
#define bignum_tag 0x3
|
2006-11-23 19:48:14 -05:00
|
|
|
#define bignum_sign_mask 0x8
|
|
|
|
#define bignum_sign_shift 3
|
|
|
|
#define bignum_length_shift 4
|
|
|
|
#define disp_bignum_data wordsize
|
2006-12-06 20:53:54 -05:00
|
|
|
#define off_bignum_data (disp_bignum_data - vector_tag)
|
2006-11-23 19:42:39 -05:00
|
|
|
|
2007-12-23 13:37:48 -05:00
|
|
|
#define flonum_tag ((ikptr)0x17)
|
2007-01-20 17:49:25 -05:00
|
|
|
#define flonum_size 16
|
2008-01-02 20:58:48 -05:00
|
|
|
#define disp_flonum_data 8 /* not f(wordsize) */
|
2007-01-20 17:49:25 -05:00
|
|
|
#define off_flonum_data (disp_flonum_data - vector_tag)
|
2008-01-01 21:08:07 -05:00
|
|
|
#define flonum_data(x) (*((double*)(((char*)(long)(x))+off_flonum_data)))
|
2007-01-20 17:49:25 -05:00
|
|
|
|
2008-01-02 18:05:32 -05:00
|
|
|
#define ratnum_tag ((ikptr) 0x27)
|
|
|
|
#define disp_ratnum_num (1 * wordsize)
|
|
|
|
#define disp_ratnum_den (2 * wordsize)
|
|
|
|
#define disp_ratnum_unused (3 * wordsize)
|
|
|
|
#define ratnum_size (4 * wordsize)
|
2007-06-10 00:32:19 -04:00
|
|
|
|
2008-05-18 23:39:41 -04:00
|
|
|
#define compnum_tag ((ikptr) 0x37)
|
|
|
|
#define disp_compnum_real (1 * wordsize)
|
|
|
|
#define disp_compnum_imag (2 * wordsize)
|
|
|
|
#define disp_compnum_unused (3 * wordsize)
|
|
|
|
#define compnum_size (4 * wordsize)
|
|
|
|
|
2008-05-24 13:13:01 -04:00
|
|
|
#define cflonum_tag ((ikptr) 0x47)
|
|
|
|
#define disp_cflonum_real (1 * wordsize)
|
|
|
|
#define disp_cflonum_imag (2 * wordsize)
|
|
|
|
#define disp_cflonum_unused (3 * wordsize)
|
|
|
|
#define cflonum_size (4 * wordsize)
|
|
|
|
|
2007-10-17 09:22:47 -04:00
|
|
|
#define ik_eof_p(x) ((x) == ik_eof_object)
|
2008-01-01 04:24:36 -05:00
|
|
|
#define page_index(x) (((unsigned long int)(x)) >> pageshift)
|
2007-10-17 09:22:47 -04:00
|
|
|
|
2006-11-23 19:38:26 -05:00
|
|
|
#endif
|