/* Round to page size */
new_size = (new_size + (LISP_PAGESIZE-1))/LISP_PAGESIZE * new_size;
- if (top > new_size) {
+ if (ecl_unlikely(top > new_size)) {
FEerror("Internal error: cannot shrink stack below stack top.",0);
}
void
ecl_stack_pop_values(cl_env_ptr env, cl_index n) {
cl_object *p = env->stack_top - n;
- if (p < env->stack)
+ if (ecl_unlikely(p < env->stack))
FEstack_underflow();
env->nvalues = n;
env->stack_top = p;
reg0 = ecl_apply_from_stack_frame((cl_object)&frame, fun); \
the_env->stack_top -= __n; }
-static void
-undefined_function(cl_object fname)
-{
- cl_error(3, @'undefined-function', @':name', fname);
-}
-
-static void
-invalid_function(cl_object obj)
-{
- FEwrong_type_argument(@'function', obj);
-}
-
-
-
/* -------------------- THE INTERPRETER -------------------- */
cl_object
cl_object var_name;
GET_DATA(var_name, vector, data);
reg0 = ECL_SYM_VAL(the_env, var_name);
- if (reg0 == OBJNULL)
+ if (ecl_unlikely(reg0 == OBJNULL))
FEunbound_variable(var_name);
THREAD_NEXT;
}
}
CASE(OP_CAR); {
- if (!LISTP(reg0)) FEtype_error_cons(reg0);
+ if (ecl_unlikely(!LISTP(reg0))) FEtype_error_cons(reg0);
reg0 = CAR(reg0);
THREAD_NEXT;
}
CASE(OP_CDR); {
- if (!LISTP(reg0)) FEtype_error_cons(reg0);
+ if (ecl_unlikely(!LISTP(reg0))) FEtype_error_cons(reg0);
reg0 = CDR(reg0);
THREAD_NEXT;
}
cl_object var_name, value;
GET_DATA(var_name, vector, data);
value = ECL_SYM_VAL(the_env, var_name);
- if (value == OBJNULL) FEunbound_variable(var_name);
+ if (ecl_unlikely(value == OBJNULL))
+ FEunbound_variable(var_name);
ECL_STACK_PUSH(the_env, value);
THREAD_NEXT;
}
frame_aux.base = the_env->stack_top - narg;
SETUP_ENV(the_env);
AGAIN:
- if (reg0 == OBJNULL || reg0 == Cnil) {
- undefined_function(x);
- }
+ if (ecl_unlikely(reg0 == OBJNULL || reg0 == Cnil))
+ FEundefined_function(x);
switch (type_of(reg0)) {
case t_cfunfixed:
- if (narg != (cl_index)reg0->cfunfixed.narg)
+ if (ecl_unlikely(narg != (cl_index)reg0->cfunfixed.narg))
FEwrong_num_arguments(reg0);
reg0 = APPLY_fixed(narg, reg0->cfunfixed.entry_fixed,
frame_aux.base);
reg0 = reg0->instance.slots[reg0->instance.length - 1];
goto AGAIN;
default:
- invalid_function(reg0);
+ FEinvalid_function(reg0);
}
break;
#endif
case t_symbol:
- if (reg0->symbol.stype & stp_macro)
- undefined_function(x);
+ if (ecl_unlikely(reg0->symbol.stype & stp_macro))
+ FEundefined_function(x);
reg0 = SYM_FUN(reg0);
goto AGAIN;
case t_bytecodes:
reg0 = ecl_interpret(frame, reg0->bclosure.lex, reg0->bclosure.code);
break;
default:
- invalid_function(reg0);
+ FEinvalid_function(reg0);
}
ECL_STACK_POP_N_UNSAFE(the_env, narg);
THREAD_NEXT;
REG0 = T and the value is on the stack, otherwise REG0 = NIL.
*/
CASE(OP_POPREQ); {
- if (frame_index >= frame->frame.size) {
+ if (ecl_unlikely(frame_index >= frame->frame.size)) {
FEwrong_num_arguments(bytecodes->bytecodes.name);
}
reg0 = frame->frame.base[frame_index++];
No more arguments.
*/
CASE(OP_NOMORE); {
- if (frame_index < frame->frame.size)
+ if (ecl_unlikely(frame_index < frame->frame.size))
FEprogram_error("Too many arguments passed to "
"function ~A~&Argument list: ~S",
2, bytecodes, cl_apply(2, @'list', frame));
first = frame->frame.base + frame_index;
count = frame->frame.size - frame_index;
last = first + count;
- if (count & 1) {
+ if (ecl_unlikely(count & 1)) {
FEprogram_error("Function ~A called with odd number "
"of keyword arguments.",
1, bytecodes);
count -= 2;
}
}
- if (count && (aok & 1) == 0) {
+ if (ecl_unlikely(count && (aok & 1) == 0)) {
FEprogram_error("Unknown keyword argument "
"passed to function ~S.~&"
"Argument list: ~S",
}
CASE(OP_ENDP);
- if (!LISTP(reg0)) FEtype_error_list(reg0);
-
+ if (ecl_unlikely(!LISTP(reg0)))
+ FEtype_error_list(reg0);
CASE(OP_NOT); {
reg0 = (reg0 == Cnil)? Ct : Cnil;
THREAD_NEXT;
cl_object var;
GET_DATA(var, vector, data);
/* INV: Not NIL, and of type t_symbol */
- if (var->symbol.stype & stp_constant)
+ if (ecl_unlikely(var->symbol.stype & stp_constant))
FEassignment_to_constant(var);
ECL_SETQ(the_env, var, reg0);
THREAD_NEXT;
CASE(OP_PSETQ); {
int lex_env_index;
GET_OPARG(lex_env_index, vector);
- ecl_lex_env_set_var(lex_env, lex_env_index, ECL_STACK_POP_UNSAFE(the_env));
+ ecl_lex_env_set_var(lex_env, lex_env_index,
+ ECL_STACK_POP_UNSAFE(the_env));
THREAD_NEXT;
}
CASE(OP_PSETQS); {
*/
CASE(OP_NTHVAL); {
cl_fixnum n = fix(ECL_STACK_POP_UNSAFE(the_env));
- if (n < 0) {
+ if (ecl_unlikely(n < 0)) {
FEerror("Wrong index passed to NTH-VAL", 1, MAKE_FIXNUM(n));
} else if ((cl_index)n >= the_env->nvalues) {
reg0 = Cnil;
#define _ARGS(x) x
-#if defined(__cplusplus) || (defined(__GNUC__) && !defined(__STRICT_ANSI__))
-#define ECL_INLINE inline
-#else
-#define ECL_INLINE
-#endif
-#if !defined(__GNUC__)
-# define ecl_likely(form) (form)
-# define ecl_unlikely(form) (form)
-#else
-# if (__GNUC__ < 3)
-# define ecl_likely(form) (form)
-# define ecl_unlikely(form) (form)
-# else
-# define ecl_likely(form) __builtin_expect(form,1)
-# define ecl_unlikely(form) __builtin_expect(form,0)
-# endif
-#endif
-
/*
* Per-thread data.
*/
extern ECL_API cl_object si_make_pure_array(cl_object etype, cl_object dims, cl_object adj, cl_object fillp, cl_object displ, cl_object disploff);
extern ECL_API cl_object si_fill_array_with_elt(cl_object array, cl_object elt, cl_object start, cl_object end);
-extern ECL_API void FEwrong_dimensions(cl_object a, cl_index rank);
-extern ECL_API void FEwrong_index(cl_object a, cl_index ndx, cl_index upper);
+extern ECL_API void FEwrong_dimensions(cl_object a, cl_index rank) ecl_attr_noreturn;
+extern ECL_API void FEwrong_index(cl_object a, cl_index ndx, cl_index upper) ecl_attr_noreturn;
extern ECL_API cl_index ecl_to_index(cl_object n);
extern ECL_API cl_index ecl_array_dimension(cl_object x, cl_index n);
extern ECL_API cl_object ecl_aref_unsafe(cl_object x, cl_index index);
extern ECL_API double ecl_to_double(cl_object x);
extern ECL_API int ecl_aref_bv(cl_object x, cl_index index);
extern ECL_API int ecl_aset_bv(cl_object x, cl_index index, int value);
-extern ECL_API void cl_throw(cl_object tag) /*__attribute__((noreturn))*/;
-extern ECL_API void cl_return_from(cl_object block_id, cl_object block_name) /*__attribute__((noreturn))*/;
-extern ECL_API void cl_go(cl_object tag_id, cl_object label) /*__attribute__((noreturn))*/;
+extern ECL_API void cl_throw(cl_object tag) /*ecl_attr_noreturn*/;
+extern ECL_API void cl_return_from(cl_object block_id, cl_object block_name) /*ecl_attr_noreturn*/;
+extern ECL_API void cl_go(cl_object tag_id, cl_object label) /*ecl_attr_noreturn*/;
extern ECL_API void cl_parse_key(cl_va_list args, int nkey, cl_object *keys, cl_object *vars, cl_object *rest, bool allow_other_keys);
extern ECL_API cl_object cl_grab_rest_args(cl_va_list args);
extern ECL_API void ecl_stack_frame_close(cl_object f);
#define si_apply_from_stack_frame ecl_apply_from_stack_frame
-extern ECL_API void FEstack_underflow(void);
-extern ECL_API void FEstack_advance(void);
+extern ECL_API void FEstack_underflow(void) ecl_attr_noreturn;
+extern ECL_API void FEstack_advance(void) ecl_attr_noreturn;
extern ECL_API cl_object *ecl_stack_grow(cl_env_ptr env);
extern ECL_API cl_object *ecl_stack_set_size(cl_env_ptr env, cl_index new_size);
extern ECL_API cl_index ecl_stack_push_values(cl_env_ptr env);
/* error.c */
-extern ECL_API cl_object cl_error _ARGS((cl_narg narg, cl_object eformat, ...)) /*__attribute__((noreturn))*/;
+extern ECL_API cl_object cl_error _ARGS((cl_narg narg, cl_object eformat, ...)) ecl_attr_noreturn;
extern ECL_API cl_object cl_cerror _ARGS((cl_narg narg, cl_object cformat, cl_object eformat, ...));
-extern ECL_API void ecl_internal_error(const char *s) /*__attribute__((noreturn))*/;
-extern ECL_API void ecl_cs_overflow(void) /*__attribute__((noreturn))*/;
-extern ECL_API void FEprogram_error(const char *s, int narg, ...) /*__attribute__((noreturn))*/;
-extern ECL_API void FEprogram_error_noreturn(const char *s, int narg, ...) __attribute__((noreturn));
-extern ECL_API void FEcontrol_error(const char *s, int narg, ...) /*__attribute__((noreturn))*/;
-extern ECL_API void FEreader_error(const char *s, cl_object stream, int narg, ...) /*__attribute__((noreturn))*/;
+extern ECL_API void ecl_internal_error(const char *s) /*ecl_attr_noreturn*/;
+extern ECL_API void ecl_cs_overflow(void) /*ecl_attr_noreturn*/;
+extern ECL_API void FEprogram_error(const char *s, int narg, ...) ecl_attr_noreturn;
+extern ECL_API void FEprogram_error_noreturn(const char *s, int narg, ...) ecl_attr_noreturn;
+extern ECL_API void FEcontrol_error(const char *s, int narg, ...) ecl_attr_noreturn;
+extern ECL_API void FEreader_error(const char *s, cl_object stream, int narg, ...) ecl_attr_noreturn;
#define FEparse_error FEreader_error
-extern ECL_API void FEerror(const char *s, int narg, ...) /*__attribute__((noreturn))*/;
-extern ECL_API void FEcannot_open(cl_object fn) /*__attribute__((noreturn))*/;
-extern ECL_API void FEend_of_file(cl_object strm) /*__attribute__((noreturn))*/;
-extern ECL_API void FEclosed_stream(cl_object strm) /*__attribute__ ((noreturn))*/;
-extern ECL_API void FEwrong_type_argument(cl_object type, cl_object value) /*__attribute__((noreturn))*/;
-extern ECL_API void FEwrong_num_arguments(cl_object fun) __attribute__((noreturn));
-extern ECL_API void FEwrong_num_arguments_anonym(void) __attribute__((noreturn));
-extern ECL_API void FEunbound_variable(cl_object sym) /*__attribute__((noreturn))*/;
-extern ECL_API void FEinvalid_macro_call(cl_object obj) /*__attribute__((noreturn))*/;
-extern ECL_API void FEinvalid_variable(const char *s, cl_object obj) /*__attribute__((noreturn))*/;
-extern ECL_API void FEassignment_to_constant(cl_object v) /*__attribute__((noreturn))*/;
-extern ECL_API void FEundefined_function(cl_object fname) __attribute__((noreturn));
-extern ECL_API void FEinvalid_function(cl_object obj) __attribute__((noreturn));
-extern ECL_API void FEinvalid_function_name(cl_object obj) /*__attribute__((noreturn))*/;
+extern ECL_API void FEerror(const char *s, int narg, ...) ecl_attr_noreturn;
+extern ECL_API void FEcannot_open(cl_object fn) ecl_attr_noreturn;
+extern ECL_API void FEend_of_file(cl_object strm) ecl_attr_noreturn;
+extern ECL_API void FEclosed_stream(cl_object strm) ecl_attr_noreturn;
+extern ECL_API void FEwrong_type_argument(cl_object type, cl_object value) ecl_attr_noreturn;
+extern ECL_API void FEwrong_num_arguments(cl_object fun) ecl_attr_noreturn;
+extern ECL_API void FEwrong_num_arguments_anonym(void) ecl_attr_noreturn;
+extern ECL_API void FEunbound_variable(cl_object sym) ecl_attr_noreturn;
+extern ECL_API void FEinvalid_macro_call(cl_object obj) ecl_attr_noreturn;
+extern ECL_API void FEinvalid_variable(const char *s, cl_object obj) ecl_attr_noreturn;
+extern ECL_API void FEassignment_to_constant(cl_object v) ecl_attr_noreturn;
+extern ECL_API void FEundefined_function(cl_object fname) ecl_attr_noreturn;
+extern ECL_API void FEinvalid_function(cl_object obj) ecl_attr_noreturn;
+extern ECL_API void FEinvalid_function_name(cl_object obj) ecl_attr_noreturn;
extern ECL_API cl_object CEerror(cl_object c, const char *err_str, int narg, ...);
-extern ECL_API void FEillegal_index(cl_object x, cl_object i);
-extern ECL_API void FEtype_error_symbol(cl_object obj) /*__attribute__((noreturn))*/;
-extern ECL_API void FElibc_error(const char *msg, int narg, ...) /*__attribute__((noreturn))*/;
+extern ECL_API void FEillegal_index(cl_object x, cl_object i) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_symbol(cl_object obj) ecl_attr_noreturn;
+extern ECL_API void FElibc_error(const char *msg, int narg, ...) ecl_attr_noreturn;
#if defined(mingw32) || defined(_MSC_VER) || defined(cygwin)
-extern ECL_API void FEwin32_error(const char *msg, int narg, ...) /*__attribute__((noreturn))*/;
+extern ECL_API void FEwin32_error(const char *msg, int narg, ...) ecl_attr_noreturn;
#endif
/* eval.c */
extern ECL_API cl_object si_setenv(cl_object var, cl_object value);
extern ECL_API cl_object si_environ(void);
extern ECL_API cl_object si_pointer(cl_object x);
-extern ECL_API cl_object si_quit _ARGS((cl_narg narg, ...)) /*__attribute__((noreturn))*/;
-extern ECL_API cl_object si_exit _ARGS((cl_narg narg, ...)) /*__attribute__((noreturn))*/;
+extern ECL_API cl_object si_quit _ARGS((cl_narg narg, ...)) /*ecl_attr_noreturn*/;
+extern ECL_API cl_object si_exit _ARGS((cl_narg narg, ...)) /*ecl_attr_noreturn*/;
typedef enum {
ECL_OPT_INCREMENTAL_GC = 0,
extern ECL_API cl_index ecl_progv(cl_env_ptr env, cl_object vars, cl_object values);
extern ECL_API void ecl_bds_unwind(cl_env_ptr env, cl_index new_bds_top_index);
-extern ECL_API void ecl_unwind(cl_env_ptr env, struct ecl_frame *fr) /*__attribute__((noreturn))*/;
+extern ECL_API void ecl_unwind(cl_env_ptr env, struct ecl_frame *fr) /*ecl_attr_noreturn*/;
extern ECL_API struct ecl_frame *frs_sch(cl_object frame_id);
/* string.c */
#ifdef ECL_THREADS
extern ECL_API cl_object mp_own_process(void) __attribute__((const));
extern ECL_API cl_object mp_all_processes(void);
-extern ECL_API cl_object mp_exit_process(void) /*__attribute__((noreturn))*/;
+extern ECL_API cl_object mp_exit_process(void) /*ecl_attr_noreturn*/;
extern ECL_API cl_object mp_interrupt_process(cl_object process, cl_object function);
extern ECL_API cl_object mp_make_process _ARGS((cl_narg narg, ...));
extern ECL_API cl_object mp_process_active_p(cl_object process);
extern ECL_API void assert_type_proper_list(cl_object p);
extern ECL_API cl_object cl_type_of(cl_object x);
-extern ECL_API void FEtype_error_character(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_cons(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_number(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_real(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_float(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_integer(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_list(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_proper_list(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_alist(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_stream(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_sequence(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_instance(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEcircular_list(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_index(cl_object seq, cl_object ndx) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_array(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_vector(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEtype_error_string(cl_object x) /*__attribute__((noreturn))*/;
-extern ECL_API void FEdivision_by_zero(cl_object x, cl_object y) /*__attribute__((noreturn))*/;
+extern ECL_API void FEtype_error_character(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_cons(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_number(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_real(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_float(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_integer(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_list(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_proper_list(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_alist(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_stream(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_sequence(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_instance(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEcircular_list(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_index(cl_object seq, cl_object ndx) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_array(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_vector(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEtype_error_string(cl_object x) ecl_attr_noreturn;
+extern ECL_API void FEdivision_by_zero(cl_object x, cl_object y) ecl_attr_noreturn;
extern ECL_API cl_object ecl_type_error(cl_object function, const char *place, cl_object o, cl_object type);
extern ECL_API cl_object ecl_check_cl_type(cl_object fun, cl_object p, cl_type t);
extern ECL_API cl_object ecl_check_type_string(cl_object fun, cl_object p);
extern ECL_API cl_object cl_encode_universal_time _ARGS((cl_narg narg, cl_object V1, cl_object V2, cl_object V3, cl_object V4, cl_object V5, cl_object V6, ...));
extern ECL_API cl_object cl_get_decoded_time();
extern ECL_API cl_object cl_ensure_directories_exist _ARGS((cl_narg narg, cl_object V1, ...));
-extern ECL_API cl_object si_simple_program_error _ARGS((cl_narg narg, cl_object format, ...)) /*__attribute__((noreturn))*/;
-extern ECL_API cl_object si_signal_simple_error _ARGS((cl_narg narg, cl_object condition, cl_object continuable, cl_object format, cl_object args, ...)) /*__attribute__((noreturn))*/;
+extern ECL_API cl_object si_simple_program_error _ARGS((cl_narg narg, cl_object format, ...)) ecl_attr_noreturn;
+extern ECL_API cl_object si_signal_simple_error _ARGS((cl_narg narg, cl_object condition, cl_object continuable, cl_object format, cl_object args, ...)) ecl_attr_noreturn;
/* module.lsp */