version 1.7, 2009/02/06 08:58:28 |
version 1.18, 2018/03/12 02:37:08 |
|
|
/* $OpenXM: OpenXM_contrib2/asir2000/parse/gc_risa.c,v 1.6 2009/02/05 11:25:59 ohara Exp $ */ |
/* $OpenXM: OpenXM_contrib2/asir2000/parse/gc_risa.c,v 1.17 2017/08/30 09:40:30 ohara Exp $ */ |
|
|
|
#if defined(VISUAL) || defined(__MINGW32__) |
|
#include "private/gcconfig.h" |
|
#endif |
#include "gc.h" |
#include "gc.h" |
#include <time.h> |
#include <time.h> |
|
#include <signal.h> |
|
|
void error(char *); |
void error(char *); |
|
void int_handler(); |
|
|
int *StackBottom; |
int *StackBottom; |
|
int in_gc, caught_intr; |
|
|
|
void check_caught_intr() |
|
{ |
|
if ( caught_intr == 1 ) { |
|
caught_intr = 0; |
|
int_handler(SIGINT); |
|
} else if ( caught_intr == 2 ) { |
|
caught_intr = 0; |
|
ox_usr1_handler(SIGUSR1); |
|
} |
|
} |
|
|
void *Risa_GC_malloc(size_t d) |
void *Risa_GC_malloc(size_t d) |
{ |
{ |
void *ret; |
void *ret; |
|
|
|
in_gc = 1; |
ret = (void *)GC_malloc(d); |
ret = (void *)GC_malloc(d); |
|
in_gc = 0; |
|
check_caught_intr(); |
if ( !ret ) |
if ( !ret ) |
error("GC_malloc : failed to allocate memory"); |
error("GC_malloc : failed to allocate memory"); |
return ret; |
return ret; |
Line 21 void *Risa_GC_malloc_atomic(size_t d) |
|
Line 41 void *Risa_GC_malloc_atomic(size_t d) |
|
{ |
{ |
void *ret; |
void *ret; |
|
|
|
in_gc = 1; |
ret = (void *)GC_malloc_atomic(d); |
ret = (void *)GC_malloc_atomic(d); |
|
in_gc = 0; |
|
check_caught_intr(); |
if ( !ret ) |
if ( !ret ) |
error("GC_malloc_atomic : failed to allocate memory"); |
error("GC_malloc_atomic : failed to allocate memory"); |
return ret; |
return ret; |
} |
} |
|
|
|
void *Risa_GC_malloc_atomic_ignore_off_page(size_t d) |
|
{ |
|
void *ret; |
|
|
|
in_gc = 1; |
|
ret = (void *)GC_malloc_atomic_ignore_off_page(d); |
|
in_gc = 0; |
|
check_caught_intr(); |
|
if ( !ret ) |
|
error("GC_malloc_atomic_ignore_off_page : failed to allocate memory"); |
|
return ret; |
|
} |
|
|
void *Risa_GC_realloc(void *p,size_t d) |
void *Risa_GC_realloc(void *p,size_t d) |
{ |
{ |
void *ret; |
void *ret; |
|
|
|
in_gc = 1; |
ret = (void *)GC_realloc(p,d); |
ret = (void *)GC_realloc(p,d); |
|
in_gc = 0; |
|
check_caught_intr(); |
if ( !ret ) |
if ( !ret ) |
error("GC_realloc : failed to reallocate memory"); |
error("GC_realloc : failed to reallocate memory"); |
return ret; |
return ret; |
} |
} |
|
|
int get_heapsize() |
void Risa_GC_free(void *p) |
{ |
{ |
|
in_gc = 1; |
|
GC_free(p); |
|
in_gc = 0; |
|
check_caught_intr(); |
|
} |
|
|
|
size_t get_heapsize() |
|
{ |
return GC_get_heap_size(); |
return GC_get_heap_size(); |
} |
} |
|
|
Line 46 int get_heapsize() |
|
Line 93 int get_heapsize() |
|
#define BYTES_TO_WORDS(x) ((x)>>2) |
#define BYTES_TO_WORDS(x) ((x)>>2) |
#endif |
#endif |
|
|
long get_allocwords() |
size_t get_allocwords() |
{ |
{ |
size_t n = GC_get_total_bytes(); |
size_t n = GC_get_total_bytes(); |
return (long)BYTES_TO_WORDS(n); /* bytes to words */ |
return BYTES_TO_WORDS(n); /* bytes to words */ |
} |
} |
|
|
static double asir_start_time; |
static double asir_start_time; |
Line 73 double get_rtime() |
|
Line 120 double get_rtime() |
|
return get_current_time() - asir_start_time; |
return get_current_time() - asir_start_time; |
} |
} |
|
|
#if defined(VISUAL) |
#if defined(VISUAL) || defined(__MINGW32__) |
#include <windows.h> |
#include <windows.h> |
|
|
extern int recv_intr,doing_batch; |
extern int recv_intr,doing_batch; |
Line 81 void send_intr(); |
|
Line 128 void send_intr(); |
|
|
|
BOOL set_ctrlc_flag(DWORD type) |
BOOL set_ctrlc_flag(DWORD type) |
{ |
{ |
if ( doing_batch ) |
enter_signal_cs(); |
|
if ( doing_batch ) { |
send_intr(); |
send_intr(); |
else |
}else { |
recv_intr = 1; |
recv_intr = 1; |
|
} |
|
leave_signal_cs(); |
return TRUE; |
return TRUE; |
} |
} |
|
|
Line 182 double get_clock() |
|
Line 232 double get_clock() |
|
#endif |
#endif |
#endif |
#endif |
|
|
#if 1 |
#if !defined(NO_ASIR_GC) |
extern int GC_free_space_numerator; |
extern int GC_free_space_numerator; |
|
|
void Risa_GC_get_adj(int *nm, int *dn) { |
void Risa_GC_get_adj(int *nm, int *dn) { |
Line 209 double GC_get_gctime() { |
|
Line 259 double GC_get_gctime() { |
|
} |
} |
#endif |
#endif |
|
|
#if defined(MSWIN32) && !defined(VISUAL) |
#if defined(MSWIN32) && !defined(VISUAL) && !defined(__MINGW32__) |
#include <signal.h> |
#include <signal.h> |
void process_events() { |
void process_events() { |
if ( check_break() ) |
if ( check_break() ) |
Line 242 void process_events() { |
|
Line 292 void process_events() { |
|
} |
} |
#endif |
#endif |
|
|
#if defined(VISUAL) && !defined(MSWIN32) |
#if (defined(VISUAL) || defined(__MINGW32__)) && !defined(MSWIN32) |
int sigsetmask(mask) int mask; { return 0; } |
int sigsetmask(mask) int mask; { return 0; } |
|
|
void process_events() { |
void process_events() { |
|
|
#else |
#else |
if ( c == ('c' & 037 ) ) |
if ( c == ('c' & 037 ) ) |
#endif |
#endif |
int_handler(); |
int_handler(SIGINT); |
} |
} |
#endif |
#endif |