=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/io/ox_asir.c,v retrieving revision 1.42 retrieving revision 1.63 diff -u -p -r1.42 -r1.63 --- OpenXM_contrib2/asir2000/io/ox_asir.c 2003/03/07 03:12:28 1.42 +++ OpenXM_contrib2/asir2000/io/ox_asir.c 2006/06/21 09:46:06 1.63 @@ -44,7 +44,7 @@ * OF THE SOFTWARE HAS BEEN DEVELOPED BY A THIRD PARTY, THE THIRD PARTY * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. - * $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.41 2003/02/14 22:29:15 ohara Exp $ + * $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.62 2006/02/25 06:33:31 noro Exp $ */ #include "ca.h" #include "parse.h" @@ -59,7 +59,10 @@ void ox_usr1_handler(); int asir_ox_init(); /* environement is defined in libpari.a */ +# if !( PARI_VERSION_CODE > 131588) extern jmp_buf environnement; +# endif +extern int myrank_102,nserver_102; extern int do_message; extern int ox_flushing; @@ -67,11 +70,13 @@ extern JMP_BUF ox_env; extern MATHCAP my_mathcap; extern int little_endian,ox_sock_id; +extern char LastError[]; +extern LIST LastStackTrace; int ox_sock_id; int lib_ox_need_conv; -void create_error(ERR *,unsigned int ,char *); +void create_error(ERR *,unsigned int ,char *,LIST trace); int asir_OperandStackSize; Obj *asir_OperandStack; @@ -91,6 +96,12 @@ void asir_popString(); void asir_popCMO(unsigned int); void asir_popSerializedLocalObject(); void asir_pushCMOtag(unsigned int); +void asir_set_rank_102(unsigned int); +void asir_tcp_accept_102(unsigned int); +void asir_tcp_connect_102(unsigned int); +void asir_reset_102(unsigned int serial); +void asir_bcast_102(unsigned int serial); +void asir_reduce_102(unsigned int serial); LIST asir_GetErrorList(); char *name_of_cmd(int); char *name_of_id(int); @@ -98,7 +109,7 @@ char *name_of_id(int); static void asir_do_cmd(int,unsigned int); static void asir_executeFunction(int); -#if MPI +#if defined(MPI) /* XXX : currently MPI version supports only a homogeneous cluster. */ extern int mpi_nprocs,mpi_myid; @@ -138,7 +149,6 @@ void ox_main(int argc,char **argv) { ERR err; unsigned int serial; int ret; - extern char LastError[]; ox_asir_init(argc,argv,"ox_asir"); if ( do_message ) @@ -146,6 +156,9 @@ void ox_main(int argc,char **argv) { if ( SETJMP(ox_env) ) { while ( NEXT(asir_infile) ) closecurrentinput(); + resetpvs(); + reset_engine(); + reset_io(); ox_send_sync(0); } while ( 1 ) { @@ -174,8 +187,11 @@ void ox_main(int argc,char **argv) { fprintf(stderr," %s\n",name_of_cmd(cmd)); if ( ret = SETJMP(main_env) ) { if ( ret == 1 ) { - create_error(&err,serial,LastError); + create_error(&err,serial,LastError,LastStackTrace); asir_push_one((Obj)err); + while ( NEXT(asir_infile) ) + closecurrentinput(); + resetpvs(); } break; } @@ -258,6 +274,24 @@ static void asir_do_cmd(int cmd,unsigned int serial) case SM_pushCMOtag: asir_pushCMOtag(serial); break; + case SM_set_rank_102: + asir_set_rank_102(serial); + break; + case SM_tcp_accept_102: + asir_tcp_accept_102(serial); + break; + case SM_tcp_connect_102: + asir_tcp_connect_102(serial); + break; + case SM_reset_102: + asir_reset_102(serial); + break; + case SM_bcast_102: + asir_bcast_102(serial); + break; + case SM_reduce_102: + asir_reduce_102(serial); + break; case SM_nop: default: break; @@ -337,6 +371,23 @@ char *name_of_cmd(int cmd) return "SM_nop"; case SM_pushCMOtag: return "SM_pushCMOtag"; + case SM_set_rank_102: + return "SM_set_rank_102"; + break; + case SM_tcp_accept_102: + return "SM_tcp_accept_102"; + break; + case SM_tcp_connect_102: + return "SM_tcp_connect_102"; + case SM_reset_102: + return "SM_reset_102"; + break; + case SM_bcast_102: + return "SM_bcast_102"; + break; + case SM_reduce_102: + return "SM_reduce_102"; + break; default: return "Unknown cmd"; break; @@ -385,12 +436,150 @@ void asir_popCMO(unsigned int serial) if ( valid_as_cmo(obj) ) ox_send_data(0,obj); else { - create_error(&err,serial,"cannot convert to CMO object"); + create_error(&err,serial,"cannot convert to CMO object",0); ox_send_data(0,err); asir_push_one(obj); } } +void asir_reduce_102(unsigned int serial) +{ + Q r; + int root; + Obj data,obj; + ERR err; + STRING op; + char *opname; + void (*func)(); + + func = 0; + op = (STRING)asir_pop_one(); + opname = BDY(op); + r = (Q)asir_pop_one(); + root = QTOS(r); + if ( !strcmp(opname,"+") ) + func = arf_add; + else if ( !strcmp(opname,"*") ) + func = arf_mul; + if ( !func ) { + create_error(&err,serial,"Invalid opration in ox_reduce_102",0); + asir_push_one(obj); + } else + ox_reduce_102(root,func); +} + +void asir_bcast_102(unsigned int serial) +{ + Q r; + int root; + Obj data; + + r = (Q)asir_pop_one(); + root = QTOS(r); + ox_bcast_102(root); +} + +void asir_reset_102(unsigned int serial) +{ + int i,j,id; + Obj obj; + + for ( i = 0; i < myrank_102; i++ ) + do { + ox_recv_102(i,&id,&obj); + } while ( id != OX_SYNC_BALL ); + for ( i = myrank_102+1; i < nserver_102; i++ ) + ox_send_sync_102(i); +} + +void asir_set_rank_102(unsigned int serial) +{ + Obj obj; + Q rank,nserver; + int n,r,stat; + NODE arg; + ERR err; + + rank = (Q)asir_pop_one(); + nserver = (Q)asir_pop_one(); + stat = 0; + if ( !nserver || !INT(nserver) || !INT(rank) ) { + stat = -1; + } else { + n = QTOS(nserver); r = QTOS(rank); + if ( n <= 0 || r < 0 || r >= n ) { + stat = -1; + } + myrank_102 = r; + nserver_102 = n; + } + if ( !stat ) return; + else { + create_error(&err,serial,"Invalid argument(s) in ox_set_rank_102",0); + asir_push_one(obj); + } +} + +void asir_tcp_accept_102(unsigned int serial) +{ + Obj obj; + Q r,p; + ERR err; + char port_str[BUFSIZ]; + int port,s,use_unix,rank; + + r = (Q)asir_pop_one(); + p = (Q)asir_pop_one(); + if ( IS_CYGWIN || !p || NUM(p) ) { + port = QTOS(p); + sprintf(port_str,"%d",port); + use_unix = 0; + } else { + strcpy(port_str,BDY((STRING)p)); + use_unix = 1; + } + s = try_bind_listen(use_unix,port_str); + s = try_accept(use_unix,s); + rank = QTOS((Q)r); + if ( register_102(s,rank,1) < 0 ) { + create_error(&err,serial, + "failed to bind or accept in ox_tcp_accept_102",0); + asir_push_one((Obj)err); + } +} + +void asir_tcp_connect_102(unsigned int serial) +{ + Obj obj; + Q r,p; + STRING h; + ERR err; + char *host; + char port_str[BUFSIZ]; + int port,s,use_unix,rank; + + r = (Q)asir_pop_one(); + p = (Q)asir_pop_one(); + h = (STRING)asir_pop_one(); + if ( IS_CYGWIN || !p || NUM(p) ) { + port = QTOS(p); + sprintf(port_str,"%d",port); + use_unix = 0; + host = BDY((STRING)h); + } else { + strcpy(port_str,BDY((STRING)p)); + use_unix = 1; + host = 0; + } + s = try_connect(use_unix,host,port_str); + rank = QTOS((Q)r); + if ( register_102(s,rank,1) < 0 ) { + create_error(&err,serial, + "failed to connect in ox_tcp_connect_102",0); + asir_push_one((Obj)err); + } +} + void asir_pushCMOtag(unsigned int serial) { Obj obj; @@ -403,7 +592,7 @@ void asir_pushCMOtag(unsigned int serial) MKUSINT(ui,tag); asir_push_one((Obj)ui); } else { - create_error(&err,serial,"cannot convert to CMO object"); + create_error(&err,serial,"cannot convert to CMO object",0); asir_push_one((Obj)err); } } @@ -411,23 +600,20 @@ void asir_pushCMOtag(unsigned int serial) void asir_popString() { Obj val; - char *buf,*obuf; + char *buf; int l; STRING str; val = asir_pop_one(); if ( !val ) - obuf = "0"; + buf = "0"; else { l = estimate_length(CO,val); buf = (char *)ALLOCA(l+1); soutput_init(buf); sprintexpr(CO,val); - l = strlen(buf); - obuf = (char *)MALLOC(l+1); - strcpy(obuf,buf); } - MKSTR(str,obuf); + MKSTR(str,buf); ox_send_data(0,str); } @@ -453,7 +639,7 @@ void asir_setName(unsigned int serial) parse_strp = (char *)ALLOCA(n); sprintf(parse_strp,"%s%s",name,dummy); if ( mainparse(&snode) ) { - create_error(&err,serial,"cannot set to variable"); + create_error(&err,serial,"cannot set to variable",0); asir_push_one((Obj)err); } else { FA1((FNODE)FA0(snode)) = (pointer)mkfnode(1,I_FORMULA,asir_pop_one()); @@ -475,13 +661,27 @@ void asir_evalName(unsigned int serial) parse_strp = (char *)ALLOCA(n); sprintf(parse_strp,"%s;",name); if ( mainparse(&snode) ) { - create_error(&err,serial,"no such variable"); + create_error(&err,serial,"no such variable",0); val = (pointer)err; } else val = evalstat(snode); asir_push_one(val); } +char *augment_backslash(char *s) +{ + char *p,*r; + int i; + + for ( i = 0, p = s; *p; p++, i++ ) if ( *p == '\\' ) i++; + r = (char *)MALLOC_ATOMIC((i+1)*sizeof(char)); + for ( i = 0, p = s; *p; p++, i++ ) { + if ( *p == '\\' ) r[i++] = '\\'; + r[i] = *p; + } + return r; +} + int asir_executeString() { SNODE snode; @@ -490,13 +690,21 @@ int asir_executeString() #if defined(PARI) recover(0); /* environement is defined in libpari.a */ +# if !(PARI_VERSION_CODE > 131588 ) if ( setjmp(environnement) ) { avma = top; recover(1); resetenv(""); } +# endif #endif cmd = ((STRING)asir_pop_one())->body; +/* XXX : probably this is useless */ +#if 0 + parse_strp = augment_backslash(cmd); +#else parse_strp = cmd; +#endif + asir_infile->ln = 1; if ( mainparse(&snode) ) { return -1; } @@ -549,6 +757,7 @@ static void asir_executeFunction(int serial) if ( n ) NEXT(n1) = 0; +#if 0 if ( !strcmp(func,"load") ) { fname = (STRING)BDY(n); if ( OID(fname) == O_STR ) { @@ -563,6 +772,7 @@ static void asir_executeFunction(int serial) } result = 0; } else { +#endif searchf(noargsysf,func,&f); if ( !f ) searchf(sysf,func,&f); @@ -576,12 +786,14 @@ static void asir_executeFunction(int serial) } else { result = (Obj)bevalf(f,n); } +#if 0 } +#endif asir_push_one(result); return; error: - create_error(&err,serial,buf); + create_error(&err,serial,buf,0); result = (Obj)err; asir_push_one(result); } @@ -640,7 +852,6 @@ void ox_asir_init(int argc,char **argv,char *servernam { char ifname[BUFSIZ]; extern int GC_dont_gc; - extern int read_exec_file; extern int do_asirrc; extern int do_server_in_X11; extern char displayname[]; @@ -649,11 +860,13 @@ void ox_asir_init(int argc,char **argv,char *servernam FILE *ifp; char *homedir; char *ptr; + int do_server_sav; #if !defined(VISUAL) int tmp; #endif -#if !defined(VISUAL) && !MPI + GC_init(); +#if !defined(VISUAL) && !defined(MPI) do_server_in_X11 = 1; /* XXX */ #endif asir_save_handler(); @@ -665,7 +878,7 @@ void ox_asir_init(int argc,char **argv,char *servernam rtime_init(); env_init(); endian_init(); - GC_init(); + cppname_init(); process_args(--argc,++argv); #if defined(__CYGWIN__) if ( !displayname[0] ) @@ -700,16 +913,19 @@ void ox_asir_init(int argc,char **argv,char *servernam } sprintf(ifname,"%s/.asirrc",homedir); } + + /* the bottom of the input stack */ + input_init(0,"string"); + if ( do_asirrc && (ifp = fopen(ifname,"r")) ) { - input_init(ifp,ifname); - if ( !SETJMP(main_env) ) { - read_exec_file = 1; - read_eval_loop(); - read_exec_file = 0; - } fclose(ifp); + do_server_sav = do_server_in_X11; + do_server_in_X11 = 0; + if ( !SETJMP(main_env) ) + execasirfile(ifname); + do_server_in_X11 = do_server_sav; } - input_init(0,"string"); + /* XXX Windows compatibility */ ox_io_init(); create_my_mathcap(servername); @@ -803,7 +1019,7 @@ int asir_ox_pop_cmo(void *cmo, int limit) obj = asir_pop_one(); if ( !valid_as_cmo(obj) ) { asir_push_one(obj); - create_error(&err,0,"The object at the stack top is invalid as a CMO."); + create_error(&err,0,"The object at the stack top is invalid as a CMO.",0); obj = (Obj)err; } len = count_as_cmo(obj); @@ -852,7 +1068,7 @@ void asir_ox_push_cmd(int cmd) if ( ret = SETJMP(main_env) ) { asir_reset_handler(); if ( ret == 1 ) { - create_error(&err,0,LastError); /* XXX */ + create_error(&err,0,LastError,LastStackTrace); /* XXX */ asir_push_one((Obj)err); } } else { @@ -879,7 +1095,7 @@ void asir_ox_execute_string(char *s) if ( ret = SETJMP(main_env) ) { asir_reset_handler(); if ( ret == 1 ) { - create_error(&err,0,LastError); /* XXX */ + create_error(&err,0,LastError,LastStackTrace); /* XXX */ asir_push_one((Obj)err); } } else { @@ -934,14 +1150,14 @@ int asir_ox_init(int byteorder) int tmp; char ifname[BUFSIZ]; extern int GC_dont_gc; - extern int read_exec_file; extern int do_asirrc; extern int do_server_in_X11; char *getenv(); static ox_asir_initialized = 0; FILE *ifp; -#if !defined(VISUAL) && !MPI + GC_init(); +#if !defined(VISUAL) && !defined(MPI) do_server_in_X11 = 0; /* XXX */ #endif asir_save_handler(); @@ -953,7 +1169,6 @@ int asir_ox_init(int byteorder) rtime_init(); env_init(); endian_init(); - GC_init(); /* process_args(argc,argv); */ output_init(); arf_init(); @@ -971,17 +1186,13 @@ int asir_ox_init(int byteorder) #if defined(UINIT) reg_sysf(); #endif + input_init(0,"string"); sprintf(ifname,"%s/.asirrc",getenv("HOME")); if ( do_asirrc && (ifp = fopen(ifname,"r")) ) { - input_init(ifp,ifname); - if ( !SETJMP(main_env) ) { - read_exec_file = 1; - read_eval_loop(); - read_exec_file = 0; - } fclose(ifp); + if ( !SETJMP(main_env) ) + execasirfile(ifname); } - input_init(0,"string"); asir_OperandStackSize = BUFSIZ; asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));