Merge branch 'master' of git://git.savannah.gnu.org/guile into elisp
authorDaniel Kraft <d@domob.eu>
Thu, 27 Aug 2009 17:26:04 +0000 (19:26 +0200)
committerDaniel Kraft <d@domob.eu>
Thu, 27 Aug 2009 17:26:04 +0000 (19:26 +0200)
1  2 
doc/ref/vm.texi
lib/iconv_open-aix.h
libguile/vm-i-system.c
module/language/assembly.scm

diff --cc doc/ref/vm.texi
Simple merge
@@@ -229,7 -229,7 +229,7 @@@ static const struct mapping mappings[] 
  
  #ifdef __GNUC__
  __inline
--#ifdef __GNUC_STDC_INLINE__
++#if defined __GNUC_STDC_INLINE__ || defined __GNUC_GNU_INLINE__
  __attribute__ ((__gnu_inline__))
  #endif
  #endif
@@@ -107,13 -101,7 +101,13 @@@ VM_DEFINE_INSTRUCTION (7, make_false, "
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (57, make_nil, "make-nil", 0, 0, 1)
 -VM_DEFINE_INSTRUCTION (8, make_eol, "make-eol", 0, 0, 1)
++VM_DEFINE_INSTRUCTION (8, make_nil, "make-nil", 0, 0, 1)
 +{
 +  PUSH (SCM_ELISP_NIL);
 +  NEXT;
 +}
 +
 +VM_DEFINE_INSTRUCTION (9, make_eol, "make-eol", 0, 0, 1)
  {
    PUSH (SCM_EOL);
    NEXT;
@@@ -187,7 -175,7 +181,7 @@@ VM_DEFINE_INSTRUCTION (16, make_char8, 
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (42, make_char32, "make-char32", 4, 0, 1)
 -VM_DEFINE_INSTRUCTION (16, make_char32, "make-char32", 4, 0, 1)
++VM_DEFINE_INSTRUCTION (17, make_char32, "make-char32", 4, 0, 1)
  {
    scm_t_wchar v = 0;
    v += FETCH ();
  
  
  
--VM_DEFINE_INSTRUCTION (17, list, "list", 2, -1, 1)
++VM_DEFINE_INSTRUCTION (18, list, "list", 2, -1, 1)
  {
    unsigned h = FETCH ();
    unsigned l = FETCH ();
    NEXT;
  }
  
--VM_DEFINE_INSTRUCTION (18, vector, "vector", 2, -1, 1)
++VM_DEFINE_INSTRUCTION (19, vector, "vector", 2, -1, 1)
  {
    unsigned h = FETCH ();
    unsigned l = FETCH ();
  
  /* ref */
  
- VM_DEFINE_INSTRUCTION (23, object_ref, "object-ref", 1, 0, 1)
 -VM_DEFINE_INSTRUCTION (19, object_ref, "object-ref", 1, 0, 1)
++VM_DEFINE_INSTRUCTION (20, object_ref, "object-ref", 1, 0, 1)
  {
    register unsigned objnum = FETCH ();
    CHECK_OBJECT (objnum);
  }
  
  /* FIXME: necessary? elt 255 of the vector could be a vector... */
- VM_DEFINE_INSTRUCTION (24, long_object_ref, "long-object-ref", 2, 0, 1)
 -VM_DEFINE_INSTRUCTION (20, long_object_ref, "long-object-ref", 2, 0, 1)
++VM_DEFINE_INSTRUCTION (21, long_object_ref, "long-object-ref", 2, 0, 1)
  {
    unsigned int objnum = FETCH ();
    objnum <<= 8;
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (25, local_ref, "local-ref", 1, 0, 1)
 -VM_DEFINE_INSTRUCTION (21, local_ref, "local-ref", 1, 0, 1)
++VM_DEFINE_INSTRUCTION (22, local_ref, "local-ref", 1, 0, 1)
  {
    PUSH (LOCAL_REF (FETCH ()));
    ASSERT_BOUND (*sp);
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (26, long_local_ref, "long-local-ref", 2, 0, 1)
 -VM_DEFINE_INSTRUCTION (22, long_local_ref, "long-local-ref", 2, 0, 1)
++VM_DEFINE_INSTRUCTION (23, long_local_ref, "long-local-ref", 2, 0, 1)
  {
    unsigned int i = FETCH ();
    i <<= 8;
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (27, variable_ref, "variable-ref", 0, 0, 1)
 -VM_DEFINE_INSTRUCTION (23, variable_ref, "variable-ref", 0, 0, 1)
++VM_DEFINE_INSTRUCTION (24, variable_ref, "variable-ref", 0, 0, 1)
  {
    SCM x = *sp;
  
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (28, toplevel_ref, "toplevel-ref", 1, 0, 1)
 -VM_DEFINE_INSTRUCTION (24, toplevel_ref, "toplevel-ref", 1, 0, 1)
++VM_DEFINE_INSTRUCTION (25, toplevel_ref, "toplevel-ref", 1, 0, 1)
  {
    unsigned objnum = FETCH ();
    SCM what;
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (29, long_toplevel_ref, "long-toplevel-ref", 2, 0, 1)
 -VM_DEFINE_INSTRUCTION (25, long_toplevel_ref, "long-toplevel-ref", 2, 0, 1)
++VM_DEFINE_INSTRUCTION (26, long_toplevel_ref, "long-toplevel-ref", 2, 0, 1)
  {
    SCM what;
    unsigned int objnum = FETCH ();
  
  /* set */
  
- VM_DEFINE_INSTRUCTION (30, local_set, "local-set", 1, 1, 0)
 -VM_DEFINE_INSTRUCTION (26, local_set, "local-set", 1, 1, 0)
++VM_DEFINE_INSTRUCTION (27, local_set, "local-set", 1, 1, 0)
  {
    LOCAL_SET (FETCH (), *sp);
    DROP ();
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (31, long_local_set, "long-local-set", 2, 1, 0)
 -VM_DEFINE_INSTRUCTION (27, long_local_set, "long-local-set", 2, 1, 0)
++VM_DEFINE_INSTRUCTION (28, long_local_set, "long-local-set", 2, 1, 0)
  {
    unsigned int i = FETCH ();
    i <<= 8;
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (32, variable_set, "variable-set", 0, 1, 0)
 -VM_DEFINE_INSTRUCTION (28, variable_set, "variable-set", 0, 1, 0)
++VM_DEFINE_INSTRUCTION (29, variable_set, "variable-set", 0, 1, 0)
  {
    VARIABLE_SET (sp[0], sp[-1]);
    DROPN (2);
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (33, toplevel_set, "toplevel-set", 1, 1, 0)
 -VM_DEFINE_INSTRUCTION (29, toplevel_set, "toplevel-set", 1, 1, 0)
++VM_DEFINE_INSTRUCTION (30, toplevel_set, "toplevel-set", 1, 1, 0)
  {
    unsigned objnum = FETCH ();
    SCM what;
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (34, long_toplevel_set, "long-toplevel-set", 2, 1, 0)
 -VM_DEFINE_INSTRUCTION (30, long_toplevel_set, "long-toplevel-set", 2, 1, 0)
++VM_DEFINE_INSTRUCTION (31, long_toplevel_set, "long-toplevel-set", 2, 1, 0)
  {
    SCM what;
    unsigned int objnum = FETCH ();
    NEXT;                                               \
  }
  
- VM_DEFINE_INSTRUCTION (35, br, "br", 2, 0, 0)
 -VM_DEFINE_INSTRUCTION (31, br, "br", 2, 0, 0)
++VM_DEFINE_INSTRUCTION (32, br, "br", 2, 0, 0)
  {
    scm_t_int16 offset;
    FETCH_OFFSET (offset);
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (36, br_if, "br-if", 2, 0, 0)
 -VM_DEFINE_INSTRUCTION (32, br_if, "br-if", 2, 0, 0)
++VM_DEFINE_INSTRUCTION (33, br_if, "br-if", 2, 0, 0)
  {
    BR (!SCM_FALSEP (*sp));
  }
  
- VM_DEFINE_INSTRUCTION (37, br_if_not, "br-if-not", 2, 0, 0)
 -VM_DEFINE_INSTRUCTION (33, br_if_not, "br-if-not", 2, 0, 0)
++VM_DEFINE_INSTRUCTION (34, br_if_not, "br-if-not", 2, 0, 0)
  {
    BR (SCM_FALSEP (*sp));
  }
  
- VM_DEFINE_INSTRUCTION (38, br_if_eq, "br-if-eq", 2, 0, 0)
 -VM_DEFINE_INSTRUCTION (34, br_if_eq, "br-if-eq", 2, 0, 0)
++VM_DEFINE_INSTRUCTION (35, br_if_eq, "br-if-eq", 2, 0, 0)
  {
    sp--; /* underflow? */
    BR (SCM_EQ_P (sp[0], sp[1]));
  }
  
- VM_DEFINE_INSTRUCTION (39, br_if_not_eq, "br-if-not-eq", 2, 0, 0)
 -VM_DEFINE_INSTRUCTION (35, br_if_not_eq, "br-if-not-eq", 2, 0, 0)
++VM_DEFINE_INSTRUCTION (36, br_if_not_eq, "br-if-not-eq", 2, 0, 0)
  {
    sp--; /* underflow? */
    BR (!SCM_EQ_P (sp[0], sp[1]));
  }
  
- VM_DEFINE_INSTRUCTION (40, br_if_null, "br-if-null", 2, 0, 0)
 -VM_DEFINE_INSTRUCTION (36, br_if_null, "br-if-null", 2, 0, 0)
++VM_DEFINE_INSTRUCTION (37, br_if_null, "br-if-null", 2, 0, 0)
  {
    BR (SCM_NULLP (*sp));
  }
  
- VM_DEFINE_INSTRUCTION (41, br_if_not_null, "br-if-not-null", 2, 0, 0)
 -VM_DEFINE_INSTRUCTION (37, br_if_not_null, "br-if-not-null", 2, 0, 0)
++VM_DEFINE_INSTRUCTION (38, br_if_not_null, "br-if-not-null", 2, 0, 0)
  {
    BR (!SCM_NULLP (*sp));
  }
   * Subprogram call
   */
  
- VM_DEFINE_INSTRUCTION (43, call, "call", 1, -1, 1)
 -VM_DEFINE_INSTRUCTION (38, new_frame, "new-frame", 0, 0, 3)
++VM_DEFINE_INSTRUCTION (39, new_frame, "new-frame", 0, 0, 3)
+ {
+   PUSH ((SCM)fp); /* dynamic link */
+   PUSH (0);  /* mvra */
+   PUSH (0);  /* ra */
+   NEXT;
+ }
 -VM_DEFINE_INSTRUCTION (39, call, "call", 1, -1, 1)
++VM_DEFINE_INSTRUCTION (40, call, "call", 1, -1, 1)
  {
    SCM x;
    nargs = FETCH ();
    goto vm_error_wrong_type_apply;
  }
  
- VM_DEFINE_INSTRUCTION (44, goto_args, "goto/args", 1, -1, 1)
 -VM_DEFINE_INSTRUCTION (40, goto_args, "goto/args", 1, -1, 1)
++VM_DEFINE_INSTRUCTION (41, goto_args, "goto/args", 1, -1, 1)
  {
    register SCM x;
    nargs = FETCH ();
    goto vm_error_wrong_type_apply;
  }
  
- VM_DEFINE_INSTRUCTION (45, goto_nargs, "goto/nargs", 0, 0, 1)
 -VM_DEFINE_INSTRUCTION (41, goto_nargs, "goto/nargs", 0, 0, 1)
++VM_DEFINE_INSTRUCTION (42, goto_nargs, "goto/nargs", 0, 0, 1)
  {
    SCM x;
    POP (x);
    goto vm_goto_args;
  }
  
- VM_DEFINE_INSTRUCTION (46, call_nargs, "call/nargs", 0, 0, 1)
 -VM_DEFINE_INSTRUCTION (42, call_nargs, "call/nargs", 0, 0, 1)
++VM_DEFINE_INSTRUCTION (43, call_nargs, "call/nargs", 0, 0, 1)
  {
    SCM x;
    POP (x);
    goto vm_call;
  }
  
- VM_DEFINE_INSTRUCTION (47, mv_call, "mv-call", 3, -1, 1)
 -VM_DEFINE_INSTRUCTION (43, mv_call, "mv-call", 3, -1, 1)
++VM_DEFINE_INSTRUCTION (44, mv_call, "mv-call", 3, -1, 1)
  {
    SCM x;
    scm_t_int16 offset;
    goto vm_error_wrong_type_apply;
  }
  
- VM_DEFINE_INSTRUCTION (48, apply, "apply", 1, -1, 1)
 -VM_DEFINE_INSTRUCTION (44, apply, "apply", 1, -1, 1)
++VM_DEFINE_INSTRUCTION (45, apply, "apply", 1, -1, 1)
  {
    int len;
    SCM ls;
    goto vm_call;
  }
  
- VM_DEFINE_INSTRUCTION (49, goto_apply, "goto/apply", 1, -1, 1)
 -VM_DEFINE_INSTRUCTION (45, goto_apply, "goto/apply", 1, -1, 1)
++VM_DEFINE_INSTRUCTION (46, goto_apply, "goto/apply", 1, -1, 1)
  {
    int len;
    SCM ls;
    goto vm_goto_args;
  }
  
- VM_DEFINE_INSTRUCTION (50, call_cc, "call/cc", 0, 1, 1)
 -VM_DEFINE_INSTRUCTION (46, call_cc, "call/cc", 0, 1, 1)
++VM_DEFINE_INSTRUCTION (47, call_cc, "call/cc", 0, 1, 1)
  {
    int first;
    SCM proc, cont;
      }
  }
  
- VM_DEFINE_INSTRUCTION (51, goto_cc, "goto/cc", 0, 1, 1)
 -VM_DEFINE_INSTRUCTION (47, goto_cc, "goto/cc", 0, 1, 1)
++VM_DEFINE_INSTRUCTION (48, goto_cc, "goto/cc", 0, 1, 1)
  {
    int first;
    SCM proc, cont;
      }
  }
  
- VM_DEFINE_INSTRUCTION (52, return, "return", 0, 1, 1)
 -VM_DEFINE_INSTRUCTION (48, return, "return", 0, 1, 1)
++VM_DEFINE_INSTRUCTION (49, return, "return", 0, 1, 1)
  {
   vm_return:
    EXIT_HOOK ();
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (53, return_values, "return/values", 1, -1, -1)
 -VM_DEFINE_INSTRUCTION (49, return_values, "return/values", 1, -1, -1)
++VM_DEFINE_INSTRUCTION (50, return_values, "return/values", 1, -1, -1)
  {
    /* nvalues declared at top level, because for some reason gcc seems to think
       that perhaps it might be used without declaration. Fooey to that, I say. */
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (54, return_values_star, "return/values*", 1, -1, -1)
 -VM_DEFINE_INSTRUCTION (50, return_values_star, "return/values*", 1, -1, -1)
++VM_DEFINE_INSTRUCTION (51, return_values_star, "return/values*", 1, -1, -1)
  {
    SCM l;
  
    goto vm_return_values;
  }
  
- VM_DEFINE_INSTRUCTION (55, truncate_values, "truncate-values", 2, -1, -1)
 -VM_DEFINE_INSTRUCTION (51, truncate_values, "truncate-values", 2, -1, -1)
++VM_DEFINE_INSTRUCTION (52, truncate_values, "truncate-values", 2, -1, -1)
  {
    SCM x;
    int nbinds, rest;
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (56, box, "box", 1, 1, 0)
 -VM_DEFINE_INSTRUCTION (52, box, "box", 1, 1, 0)
++VM_DEFINE_INSTRUCTION (53, box, "box", 1, 1, 0)
  {
    SCM val;
    POP (val);
       (set! a (lambda () (b ...)))
       ...)
   */
- VM_DEFINE_INSTRUCTION (57, empty_box, "empty-box", 1, 0, 0)
 -VM_DEFINE_INSTRUCTION (53, empty_box, "empty-box", 1, 0, 0)
++VM_DEFINE_INSTRUCTION (54, empty_box, "empty-box", 1, 0, 0)
  {
    SYNC_BEFORE_GC ();
    LOCAL_SET (FETCH (),
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (58, local_boxed_ref, "local-boxed-ref", 1, 0, 1)
 -VM_DEFINE_INSTRUCTION (54, local_boxed_ref, "local-boxed-ref", 1, 0, 1)
++VM_DEFINE_INSTRUCTION (55, local_boxed_ref, "local-boxed-ref", 1, 0, 1)
  {
    SCM v = LOCAL_REF (FETCH ());
    ASSERT_BOUND_VARIABLE (v);
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (59, local_boxed_set, "local-boxed-set", 1, 1, 0)
 -VM_DEFINE_INSTRUCTION (55, local_boxed_set, "local-boxed-set", 1, 1, 0)
++VM_DEFINE_INSTRUCTION (56, local_boxed_set, "local-boxed-set", 1, 1, 0)
  {
    SCM v, val;
    v = LOCAL_REF (FETCH ());
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (60, free_ref, "free-ref", 1, 0, 1)
 -VM_DEFINE_INSTRUCTION (56, free_ref, "free-ref", 1, 0, 1)
++VM_DEFINE_INSTRUCTION (57, free_ref, "free-ref", 1, 0, 1)
  {
    scm_t_uint8 idx = FETCH ();
    
  
  /* no free-set -- if a var is assigned, it should be in a box */
  
- VM_DEFINE_INSTRUCTION (61, free_boxed_ref, "free-boxed-ref", 1, 0, 1)
 -VM_DEFINE_INSTRUCTION (57, free_boxed_ref, "free-boxed-ref", 1, 0, 1)
++VM_DEFINE_INSTRUCTION (58, free_boxed_ref, "free-boxed-ref", 1, 0, 1)
  {
    SCM v;
    scm_t_uint8 idx = FETCH ();
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (62, free_boxed_set, "free-boxed-set", 1, 1, 0)
 -VM_DEFINE_INSTRUCTION (58, free_boxed_set, "free-boxed-set", 1, 1, 0)
++VM_DEFINE_INSTRUCTION (59, free_boxed_set, "free-boxed-set", 1, 1, 0)
  {
    SCM v, val;
    scm_t_uint8 idx = FETCH ();
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (63, make_closure, "make-closure", 0, 2, 1)
 -VM_DEFINE_INSTRUCTION (59, make_closure, "make-closure", 0, 2, 1)
++VM_DEFINE_INSTRUCTION (60, make_closure, "make-closure", 0, 2, 1)
  {
    SCM vect;
    POP (vect);
    NEXT;
  }
  
- VM_DEFINE_INSTRUCTION (64, make_variable, "make-variable", 0, 0, 1)
 -VM_DEFINE_INSTRUCTION (60, make_variable, "make-variable", 0, 0, 1)
++VM_DEFINE_INSTRUCTION (61, make_variable, "make-variable", 0, 0, 1)
  {
    SYNC_BEFORE_GC ();
    /* fixme underflow */
    NEXT;
  }
  
 -VM_DEFINE_INSTRUCTION (61, fix_closure, "fix-closure", 2, 0, 1)
++VM_DEFINE_INSTRUCTION (62, fix_closure, "fix-closure", 2, 0, 1)
+ {
+   SCM x, vect;
+   unsigned int i = FETCH ();
+   i <<= 8;
+   i += FETCH ();
+   POP (vect);
+   /* FIXME CHECK_LOCAL (i) */ 
+   x = LOCAL_REF (i);
+   /* FIXME ASSERT_PROGRAM (x); */
+   SCM_SET_CELL_WORD_3 (x, vect);
+   NEXT;
+ }
 -VM_DEFINE_INSTRUCTION (62, define, "define", 0, 0, 2)
++VM_DEFINE_INSTRUCTION (63, define, "define", 0, 0, 2)
+ {
+   SCM sym, val;
+   POP (sym);
+   POP (val);
+   SYNC_REGISTER ();
+   VARIABLE_SET (scm_sym2var (sym, scm_current_module_lookup_closure (),
+                              SCM_BOOL_T),
+                 val);
+   NEXT;
+ }
 -VM_DEFINE_INSTRUCTION (63, make_keyword, "make-keyword", 0, 1, 1)
++VM_DEFINE_INSTRUCTION (64, make_keyword, "make-keyword", 0, 1, 1)
+ {
+   CHECK_UNDERFLOW ();
+   SYNC_REGISTER ();
+   *sp = scm_symbol_to_keyword (*sp);
+   NEXT;
+ }
 -VM_DEFINE_INSTRUCTION (64, make_symbol, "make-symbol", 0, 1, 1)
++VM_DEFINE_INSTRUCTION (65, make_symbol, "make-symbol", 0, 1, 1)
+ {
+   CHECK_UNDERFLOW ();
+   SYNC_REGISTER ();
+   *sp = scm_string_to_symbol (*sp);
+   NEXT;
+ }
  
  /*
  (defun renumber-ops ()
          (replace-match
           (number-to-string (setq counter (1+ counter)))
            t t nil 1)))))
++(renumber-ops)
  */
  /*
    Local Variables:
Simple merge