[BACK]Return to ox_asir.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / io

Diff for /OpenXM_contrib2/asir2000/io/ox_asir.c between version 1.12 and 1.18

version 1.12, 2000/03/16 08:23:16 version 1.18, 2000/09/07 23:59:55
Line 1 
Line 1 
 /* $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.11 2000/03/16 04:55:21 noro Exp $ */  /*
    * Copyright (c) 1994-2000 FUJITSU LABORATORIES LIMITED
    * All rights reserved.
    *
    * FUJITSU LABORATORIES LIMITED ("FLL") hereby grants you a limited,
    * non-exclusive and royalty-free license to use, copy, modify and
    * redistribute, solely for non-commercial and non-profit purposes, the
    * computer program, "Risa/Asir" ("SOFTWARE"), subject to the terms and
    * conditions of this Agreement. For the avoidance of doubt, you acquire
    * only a limited right to use the SOFTWARE hereunder, and FLL or any
    * third party developer retains all rights, including but not limited to
    * copyrights, in and to the SOFTWARE.
    *
    * (1) FLL does not grant you a license in any way for commercial
    * purposes. You may use the SOFTWARE only for non-commercial and
    * non-profit purposes only, such as academic, research and internal
    * business use.
    * (2) The SOFTWARE is protected by the Copyright Law of Japan and
    * international copyright treaties. If you make copies of the SOFTWARE,
    * with or without modification, as permitted hereunder, you shall affix
    * to all such copies of the SOFTWARE the above copyright notice.
    * (3) An explicit reference to this SOFTWARE and its copyright owner
    * shall be made on your publication or presentation in any form of the
    * results obtained by use of the SOFTWARE.
    * (4) In the event that you modify the SOFTWARE, you shall notify FLL by
    * e-mail at risa-admin@sec.flab.fujitsu.co.jp of the detailed specification
    * for such modification or the source code of the modified part of the
    * SOFTWARE.
    *
    * THE SOFTWARE IS PROVIDED AS IS WITHOUT ANY WARRANTY OF ANY KIND. FLL
    * MAKES ABSOLUTELY NO WARRANTIES, EXPRESSED, IMPLIED OR STATUTORY, AND
    * EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS
    * FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT OF THIRD PARTIES'
    * RIGHTS. NO FLL DEALER, AGENT, EMPLOYEES IS AUTHORIZED TO MAKE ANY
    * MODIFICATIONS, EXTENSIONS, OR ADDITIONS TO THIS WARRANTY.
    * UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, TORT, CONTRACT,
    * OR OTHERWISE, SHALL FLL BE LIABLE TO YOU OR ANY OTHER PERSON FOR ANY
    * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE OR CONSEQUENTIAL
    * DAMAGES OF ANY CHARACTER, INCLUDING, WITHOUT LIMITATION, DAMAGES
    * ARISING OUT OF OR RELATING TO THE SOFTWARE OR THIS AGREEMENT, DAMAGES
    * FOR LOSS OF GOODWILL, WORK STOPPAGE, OR LOSS OF DATA, OR FOR ANY
    * DAMAGES, EVEN IF FLL SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF
    * SUCH DAMAGES, OR FOR ANY CLAIM BY ANY OTHER PARTY. EVEN IF A PART
    * 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.17 2000/08/29 04:03:06 noro Exp $
   */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
 #include "signal.h"  #include "signal.h"
Line 9 
Line 56 
 #endif  #endif
   
 void ox_usr1_handler();  void ox_usr1_handler();
 void asir_ox_init();  int asir_ox_init();
   
 extern jmp_buf environnement;  extern jmp_buf environnement;
   
Line 31  static void create_error(ERR *,unsigned int ,char *);
Line 78  static void create_error(ERR *,unsigned int ,char *);
 static void ox_io_init();  static void ox_io_init();
 static void ox_asir_init(int,char **);  static void ox_asir_init(int,char **);
 static Obj asir_pop_one();  static Obj asir_pop_one();
   static Obj asir_peek_one();
 static void asir_push_one(Obj);  static void asir_push_one(Obj);
 static void asir_end_flush();  static void asir_end_flush();
 static void asir_executeFunction(int);  static void asir_executeFunction(int);
Line 41  static void asir_pops();
Line 89  static void asir_pops();
 static void asir_popString();  static void asir_popString();
 static void asir_popCMO(unsigned int);  static void asir_popCMO(unsigned int);
 static void asir_popSerializedLocalObject();  static void asir_popSerializedLocalObject();
   static void asir_pushCMOtag(unsigned int);
 static LIST asir_GetErrorList();  static LIST asir_GetErrorList();
 static char *name_of_cmd(unsigned int);  static char *name_of_cmd(int);
 static char *name_of_id(int);  static char *name_of_id(int);
 static void asir_do_cmd(unsigned int,unsigned int);  static void asir_do_cmd(int,unsigned int);
   
 #if MPI  #if MPI
   /* XXX : currently MPI version supports only a homogeneous cluster. */
   
 extern int mpi_nprocs,mpi_myid;  extern int mpi_nprocs,mpi_myid;
   
 void ox_mpi_master_init() {  void ox_mpi_master_init() {
         int i,idx,ret;          int i,idx;
   
         for ( i = 1; i < mpi_nprocs; i++ ) {          for ( i = 0; i < mpi_nprocs; i++ ) {
                 /* client mode */                  /* ordering information is not exchanged */
                   /* idx should be equal to i */
                 idx = get_iofp(i,0,0);                  idx = get_iofp(i,0,0);
                 ret = register_server(0,idx,idx);                  register_server(0,idx,idx);
         }          }
 }  }
   
 void ox_mpi_slave_init() {  void ox_mpi_slave_init() {
           int i,idx;
   
         endian_init();          endian_init();
         /* server mode */  
         get_iofp(0,0,1);  
         fclose(stdin);          fclose(stdin);
           for ( i = 0; i < mpi_nprocs; i++ ) {
                   /* ordering information is not exchanged */
                   /* idx should be equal to i */
                   idx = get_iofp(i,0,0);
                   register_server(0,idx,idx);
           }
         asir_OperandStackSize = BUFSIZ;          asir_OperandStackSize = BUFSIZ;
         asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));          asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));
         asir_OperandStackPtr = -1;          asir_OperandStackPtr = -1;
Line 90  static void create_error(ERR *err,unsigned int serial,
Line 148  static void create_error(ERR *err,unsigned int serial,
   
 void ox_main(int argc,char **argv) {  void ox_main(int argc,char **argv) {
         int id;          int id;
         unsigned int cmd;          int cmd;
         Obj obj;          Obj obj;
         USINT ui;          USINT ui;
         ERR err;          ERR err;
Line 160  void ox_main(int argc,char **argv) {
Line 218  void ox_main(int argc,char **argv) {
         }          }
 }  }
   
 static void asir_do_cmd(unsigned int cmd,unsigned int serial)  static void asir_do_cmd(int cmd,unsigned int serial)
 {  {
         MATHCAP client_mathcap;          MATHCAP client_mathcap;
         Q q;          Q q;
Line 215  static void asir_do_cmd(unsigned int cmd,unsigned int 
Line 273  static void asir_do_cmd(unsigned int cmd,unsigned int 
                         client_mathcap = (MATHCAP)asir_pop_one();                          client_mathcap = (MATHCAP)asir_pop_one();
                         store_remote_mathcap(0,client_mathcap);                          store_remote_mathcap(0,client_mathcap);
                         break;                          break;
                   case SM_pushCMOtag:
                           asir_pushCMOtag(serial);
                           break;
                 case SM_nop:                  case SM_nop:
                 default:                  default:
                         break;                          break;
Line 242  static char *name_of_id(int id)
Line 303  static char *name_of_id(int id)
         }          }
 }  }
   
 static char *name_of_cmd(unsigned cmd)  static char *name_of_cmd(int cmd)
 {  {
         switch ( cmd ) {          switch ( cmd ) {
                 case SM_popSerializedLocalObject:                  case SM_popSerializedLocalObject:
Line 292  static char *name_of_cmd(unsigned cmd)
Line 353  static char *name_of_cmd(unsigned cmd)
                         break;                          break;
                 case SM_nop:                  case SM_nop:
                         return "SM_nop";                          return "SM_nop";
                   case SM_pushCMOtag:
                           return "SM_pushCMOtag";
                 default:                  default:
                         return "Unknown cmd";                          return "Unknown cmd";
                         break;                          break;
Line 346  static void asir_popCMO(unsigned int serial)
Line 409  static void asir_popCMO(unsigned int serial)
         }          }
 }  }
   
   static void asir_pushCMOtag(unsigned int serial)
   {
           Obj obj;
           ERR err;
           USINT ui;
           int tag;
   
           obj = asir_peek_one();
           if ( cmo_tag(obj,&tag) ) {
                   MKUSINT(ui,tag);
                   asir_push_one((Obj)ui);
           } else {
                   create_error(&err,serial,"cannot convert to CMO object");
                   asir_push_one((Obj)err);
           }
   }
   
 static void asir_popString()  static void asir_popString()
 {  {
         Obj val;          Obj val;
Line 563  static Obj asir_pop_one() {
Line 643  static Obj asir_pop_one() {
         }          }
 }  }
   
   static Obj asir_peek_one() {
           if ( asir_OperandStackPtr < 0 ) {
                   if ( do_message )
                           fprintf(stderr,"OperandStack underflow");
                   return 0;
           } else {
                   if ( do_message )
                           fprintf(stderr,"peek at %d\n",asir_OperandStackPtr);
                   return asir_OperandStack[asir_OperandStackPtr];
           }
   }
   
 static void ox_asir_init(int argc,char **argv)  static void ox_asir_init(int argc,char **argv)
 {  {
         int tmp;          int tmp;
Line 675  static void ox_io_init() {
Line 767  static void ox_io_init() {
         write_char(iofp[0].out,&c); ox_flush_stream_force(0);          write_char(iofp[0].out,&c); ox_flush_stream_force(0);
         read_char(iofp[0].in,&rc);          read_char(iofp[0].in,&rc);
         iofp[0].conv = c == rc ? 0 : 1;          iofp[0].conv = c == rc ? 0 : 1;
           /* XXX; for raw I/O */
           register_server(0,0,0);
 }  }
   
   #if !defined(VISUAL)
 /*  /*
  * Library mode functions   * Library mode functions
  */   */
Line 725  int asir_ox_pop_cmo(void *cmo, int limit)
Line 820  int asir_ox_pop_cmo(void *cmo, int limit)
  * Executes an SM command.   * Executes an SM command.
  */   */
   
 void asir_ox_push_cmd(unsigned int cmd)  void asir_ox_push_cmd(int cmd)
 {  {
         int ret;          int ret;
         ERR err;          ERR err;
Line 798  int asir_ox_peek_cmo_size()
Line 893  int asir_ox_peek_cmo_size()
  *          =1 => network byte order   *          =1 => network byte order
  */   */
   
 void asir_ox_init(int byteorder)  int asir_ox_init(int byteorder)
 {  {
         int tmp;          int tmp;
         char ifname[BUFSIZ];          char ifname[BUFSIZ];
Line 873  void asir_ox_init(int byteorder)
Line 968  void asir_ox_init(int byteorder)
         do_message = 0;          do_message = 0;
         create_my_mathcap("ox_asir");          create_my_mathcap("ox_asir");
         asir_reset_handler();          asir_reset_handler();
           return 0;
 }  }
   #endif

Legend:
Removed from v.1.12  
changed lines
  Added in v.1.18

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>