2  *  drivers/s390/net/iucv.h
 
   6  *    Copyright (C) 2000 IBM Corporation
 
   7  *    Author(s):Alan Altmark (Alan_Altmark@us.ibm.com)
 
   8  *              Xenia Tkatschow (xenia@us.ibm.com)
 
  12  * To explore any of the IUCV functions, one must first register
 
  13  * their program using iucv_register_program(). Once your program has
 
  14  * successfully completed a register, it can exploit the other functions.
 
  15  * For furthur reference on all IUCV functionality, refer to the
 
  16  * CP Programming Services book, also available on the web
 
  17  * thru www.ibm.com/s390/vm/pubs, manual # SC24-5760
 
  19  *      Definition of Return Codes
 
  20  *      -All positive return codes including zero are reflected back
 
  21  *       from CP except for iucv_register_program. The definition of each
 
  22  *       return code can be found in CP Programming Services book.
 
  23  *       Also available on the web thru www.ibm.com/s390/vm/pubs, manual # SC24-5760
 
  25  *             (-EINVAL) Invalid value
 
  26  *             (-ENOMEM) storage allocation failed
 
  27  *      pgmask defined in iucv_register_program will be set depending on input
 
  32 #include <linux/types.h>
 
  33 #include <asm/debug.h>
 
  36  * Debug Facility stuff
 
  38 #define IUCV_DBF_SETUP_NAME "iucv_setup"
 
  39 #define IUCV_DBF_SETUP_LEN 32
 
  40 #define IUCV_DBF_SETUP_PAGES 2
 
  41 #define IUCV_DBF_SETUP_NR_AREAS 1
 
  42 #define IUCV_DBF_SETUP_LEVEL 3
 
  44 #define IUCV_DBF_DATA_NAME "iucv_data"
 
  45 #define IUCV_DBF_DATA_LEN 128
 
  46 #define IUCV_DBF_DATA_PAGES 2
 
  47 #define IUCV_DBF_DATA_NR_AREAS 1
 
  48 #define IUCV_DBF_DATA_LEVEL 2
 
  50 #define IUCV_DBF_TRACE_NAME "iucv_trace"
 
  51 #define IUCV_DBF_TRACE_LEN 16
 
  52 #define IUCV_DBF_TRACE_PAGES 4
 
  53 #define IUCV_DBF_TRACE_NR_AREAS 1
 
  54 #define IUCV_DBF_TRACE_LEVEL 3
 
  56 #define IUCV_DBF_TEXT(name,level,text) \
 
  58                 debug_text_event(iucv_dbf_##name,level,text); \
 
  61 #define IUCV_DBF_HEX(name,level,addr,len) \
 
  63                 debug_event(iucv_dbf_##name,level,(void*)(addr),len); \
 
  66 DECLARE_PER_CPU(char[256], iucv_dbf_txt_buf);
 
  68 #define IUCV_DBF_TEXT_(name,level,text...)                              \
 
  70                 char* iucv_dbf_txt_buf = get_cpu_var(iucv_dbf_txt_buf); \
 
  71                 sprintf(iucv_dbf_txt_buf, text);                        \
 
  72                 debug_text_event(iucv_dbf_##name,level,iucv_dbf_txt_buf); \
 
  73                 put_cpu_var(iucv_dbf_txt_buf);                          \
 
  76 #define IUCV_DBF_SPRINTF(name,level,text...) \
 
  78                 debug_sprintf_event(iucv_dbf_trace, level, ##text ); \
 
  79                 debug_sprintf_event(iucv_dbf_trace, level, text ); \
 
  83  * some more debug stuff
 
  85 #define IUCV_HEXDUMP16(importance,header,ptr) \
 
  86 PRINT_##importance(header "%02x %02x %02x %02x  %02x %02x %02x %02x  " \
 
  87                    "%02x %02x %02x %02x  %02x %02x %02x %02x\n", \
 
  88                    *(((char*)ptr)),*(((char*)ptr)+1),*(((char*)ptr)+2), \
 
  89                    *(((char*)ptr)+3),*(((char*)ptr)+4),*(((char*)ptr)+5), \
 
  90                    *(((char*)ptr)+6),*(((char*)ptr)+7),*(((char*)ptr)+8), \
 
  91                    *(((char*)ptr)+9),*(((char*)ptr)+10),*(((char*)ptr)+11), \
 
  92                    *(((char*)ptr)+12),*(((char*)ptr)+13), \
 
  93                    *(((char*)ptr)+14),*(((char*)ptr)+15)); \
 
  94 PRINT_##importance(header "%02x %02x %02x %02x  %02x %02x %02x %02x  " \
 
  95                    "%02x %02x %02x %02x  %02x %02x %02x %02x\n", \
 
  96                    *(((char*)ptr)+16),*(((char*)ptr)+17), \
 
  97                    *(((char*)ptr)+18),*(((char*)ptr)+19), \
 
  98                    *(((char*)ptr)+20),*(((char*)ptr)+21), \
 
  99                    *(((char*)ptr)+22),*(((char*)ptr)+23), \
 
 100                    *(((char*)ptr)+24),*(((char*)ptr)+25), \
 
 101                    *(((char*)ptr)+26),*(((char*)ptr)+27), \
 
 102                    *(((char*)ptr)+28),*(((char*)ptr)+29), \
 
 103                    *(((char*)ptr)+30),*(((char*)ptr)+31));
 
 106 iucv_hex_dump(unsigned char *buf, size_t len)
 
 110         for (i = 0; i < len; i++) {
 
 113                 printk("%02x ", *(buf + i));
 
 121 #define uchar  unsigned char
 
 122 #define ushort unsigned short
 
 123 #define ulong  unsigned long
 
 124 #define iucv_handle_t void *
 
 127  * All flags are defined in the field IPFLAGS1 of each function
 
 128  * and can be found in CP Programming Services.
 
 129  * IPLOCAL  - Indicates the connect can only be satisfied on the
 
 131  * IPPRTY   - Indicates a priority message
 
 132  * IPQUSCE  - Indicates you do not want to receive messages on a
 
 133  *            path until an iucv_resume is issued
 
 134  * IPRMDATA - Indicates that the message is in the parameter list
 
 139 #define IPRMDATA        0x80
 
 142  * All flags are defined in the output field of IPFLAGS1 for each function
 
 143  * and can be found in CP Programming Services.
 
 144  * IPNORPY - Specifies this is a one-way message and no reply is expected.
 
 145  * IPPRTY   - Indicates a priority message is permitted. Defined in flags1.
 
 149 #define Nonpriority_MessagePendingInterruptsFlag         0x80
 
 150 #define Priority_MessagePendingInterruptsFlag            0x40
 
 151 #define Nonpriority_MessageCompletionInterruptsFlag      0x20
 
 152 #define Priority_MessageCompletionInterruptsFlag         0x10
 
 153 #define IUCVControlInterruptsFlag                        0x08
 
 154 #define AllInterrupts                                    0xf8
 
 156  * Mapping of external interrupt buffers should be used with the corresponding
 
 158  * Names: iucv_ConnectionPending    ->  connection pending
 
 159  *        iucv_ConnectionComplete   ->  connection complete
 
 160  *        iucv_ConnectionSevered    ->  connection severed
 
 161  *        iucv_ConnectionQuiesced   ->  connection quiesced
 
 162  *        iucv_ConnectionResumed    ->  connection resumed
 
 163  *        iucv_MessagePending       ->  message pending
 
 164  *        iucv_MessageComplete      ->  message complete
 
 177 } iucv_ConnectionPending;
 
 190 } iucv_ConnectionComplete;
 
 202 } iucv_ConnectionSevered;
 
 214 } iucv_ConnectionQuiesced;
 
 226 } iucv_ConnectionResumed;
 
 246 } iucv_MessagePending;
 
 261 } iucv_MessageComplete;
 
 264  * iucv_interrupt_ops_t: Is a vector of functions that handle
 
 267  *         eib - is a pointer to a 40-byte area described
 
 268  *               with one of the structures above.
 
 269  *         pgm_data - this data is strictly for the
 
 270  *                    interrupt handler that is passed by
 
 271  *                    the application. This may be an address
 
 275         void (*ConnectionPending) (iucv_ConnectionPending * eib,
 
 277         void (*ConnectionComplete) (iucv_ConnectionComplete * eib,
 
 279         void (*ConnectionSevered) (iucv_ConnectionSevered * eib,
 
 281         void (*ConnectionQuiesced) (iucv_ConnectionQuiesced * eib,
 
 283         void (*ConnectionResumed) (iucv_ConnectionResumed * eib,
 
 285         void (*MessagePending) (iucv_MessagePending * eib, void *pgm_data);
 
 286         void (*MessageComplete) (iucv_MessageComplete * eib, void *pgm_data);
 
 287 } iucv_interrupt_ops_t;
 
 290  *iucv_array_t : Defines buffer array.
 
 291  * Inside the array may be 31- bit addresses and 31-bit lengths.
 
 296 } iucv_array_t __attribute__ ((aligned (8)));
 
 298 extern struct bus_type iucv_bus;
 
 299 extern struct device *iucv_root;
 
 303  * Name: iucv_register_program
 
 304  * Purpose: Registers an application with IUCV
 
 305  * Input: prmname - user identification
 
 306  *        userid  - machine identification
 
 307  *        pgmmask - indicates which bits in the prmname and userid combined will be
 
 308  *                  used to determine who is given control
 
 309  *        ops     - address of vector of interrupt handlers
 
 310  *        pgm_data- application data passed to interrupt handlers
 
 312  * Return: address of handler
 
 313  *         (0) - Error occurred, registration not completed.
 
 314  * NOTE: Exact cause of failure will be recorded in syslog.
 
 316 iucv_handle_t iucv_register_program (uchar pgmname[16],
 
 319                                      iucv_interrupt_ops_t * ops,
 
 323  * Name: iucv_unregister_program
 
 324  * Purpose: Unregister application with IUCV
 
 325  * Input: address of handler
 
 327  * Return: (0) - Normal return
 
 328  *         (-EINVAL) - Internal error, wild pointer
 
 330 int iucv_unregister_program (iucv_handle_t handle);
 
 334  * Purpose: This function is issued after the user receives a Connection Pending external
 
 335  *          interrupt and now wishes to complete the IUCV communication path.
 
 336  * Input:  pathid - u16 , Path identification number
 
 337  *         msglim_reqstd - u16, The number of outstanding messages requested.
 
 338  *         user_data - uchar[16], Data specified by the iucv_connect function.
 
 339  *         flags1 - int, Contains options for this path.
 
 340  *           -IPPRTY   - 0x20- Specifies if you want to send priority message.
 
 341  *           -IPRMDATA - 0x80, Specifies whether your program can handle a message
 
 342  *              in  the parameter list.
 
 343  *           -IPQUSCE  - 0x40, Specifies whether you want to quiesce the path being
 
 345  *         handle - iucv_handle_t, Address of handler.
 
 346  *         pgm_data - void *, Application data passed to interrupt handlers.
 
 347  *         flags1_out - int * Contains information about the path
 
 348  *           - IPPRTY - 0x20, Indicates you may send priority messages.
 
 349  *         msglim - *u16, Number of outstanding messages.
 
 350  * Output: return code from CP IUCV call.
 
 353 int iucv_accept (u16 pathid,
 
 357                  iucv_handle_t handle,
 
 358                  void *pgm_data, int *flags1_out, u16 * msglim);
 
 362  * Purpose: This function establishes an IUCV path. Although the connect may complete
 
 363  *          successfully, you are not able to use the path until you receive an IUCV
 
 364  *          Connection Complete external interrupt.
 
 365  * Input: pathid - u16 *, Path identification number
 
 366  *        msglim_reqstd - u16, Number of outstanding messages requested
 
 367  *        user_data - uchar[16], 16-byte user data
 
 368  *        userid - uchar[8], User identification
 
 369  *        system_name - uchar[8], 8-byte identifying the system name
 
 370  *        flags1 - int, Contains options for this path.
 
 371  *          -IPPRTY -   0x20, Specifies if you want to send priority message.
 
 372  *          -IPRMDATA - 0x80, Specifies whether your program can handle a message
 
 373  *               in  the parameter list.
 
 374  *          -IPQUSCE -  0x40, Specifies whether you want to quiesce the path being
 
 376  *          -IPLOCAL -  0X01, Allows an application to force the partner to be on
 
 377  *              the local system. If local is specified then target class cannot be
 
 379  *        flags1_out - int * Contains information about the path
 
 380  *           - IPPRTY - 0x20, Indicates you may send priority messages.
 
 381  *        msglim - * u16, Number of outstanding messages
 
 382  *        handle - iucv_handle_t, Address of handler
 
 383  *        pgm_data - void *, Application data passed to interrupt handlers
 
 384  * Output: return code from CP IUCV call
 
 385  *         rc - return code from iucv_declare_buffer
 
 386  *         -EINVAL - Invalid handle passed by application
 
 387  *         -EINVAL - Pathid address is NULL
 
 388  *         add_pathid_result - Return code from internal function add_pathid
 
 391     iucv_connect (u16 * pathid,
 
 395                   uchar system_name[8],
 
 398                   u16 * msglim, iucv_handle_t handle, void *pgm_data);
 
 402  * Purpose: This function cancels a message that you have sent.
 
 403  * Input: pathid - Path identification number.
 
 404  *        msgid - Specifies the message ID of the message to be purged.
 
 405  *        srccls - Specifies the source message class.
 
 406  * Output: audit - Contains information about asynchronous error
 
 407  *                 that may have affected the normal completion
 
 409  * Return: Return code from CP IUCV call.
 
 411 int iucv_purge (u16 pathid, u32 msgid, u32 srccls, __u32 *audit);
 
 413  * Name: iucv_query_maxconn
 
 414  * Purpose: This function determines the maximum number of communication paths you
 
 416  * Return:  maxconn - ulong, Maximum number of connection the virtual machine may
 
 419 ulong iucv_query_maxconn (void);
 
 422  * Name: iucv_query_bufsize
 
 423  * Purpose: This function determines how large an external interrupt
 
 424  *          buffer IUCV requires to store information.
 
 425  * Return:  bufsize - ulong, Size of external interrupt buffer.
 
 427 ulong iucv_query_bufsize (void);
 
 431  * Purpose: This function temporarily suspends incoming messages on an
 
 432  *          IUCV path. You can later reactivate the path by invoking
 
 433  *          the iucv_resume function.
 
 434  * Input: pathid - Path identification number
 
 435  *        user_data  - 16-bytes of user data
 
 437  * Return: Return code from CP IUCV call.
 
 439 int iucv_quiesce (u16 pathid, uchar user_data[16]);
 
 443  * Purpose: This function receives messages that are being sent to you
 
 444  *          over established paths. Data will be returned in buffer for length of
 
 447  *       pathid - Path identification number.
 
 448  *       buffer - Address of buffer to receive.
 
 449  *       buflen - Length of buffer to receive.
 
 450  *       msgid - Specifies the message ID.
 
 451  *       trgcls - Specifies target class.
 
 453  *       flags1_out: int *, Contains information about this path.
 
 454  *         IPNORPY - 0x10 Specifies this is a one-way message and no reply is
 
 456  *         IPPRTY  - 0x20 Specifies if you want to send priority message.
 
 457  *         IPRMDATA - 0x80 specifies the data is contained in the parameter list
 
 458  *       residual_buffer - address of buffer updated by the number
 
 459  *                         of bytes you have received.
 
 461  *              Contains one of the following values, if the receive buffer is:
 
 462  *               The same length as the message, this field is zero.
 
 463  *               Longer than the message, this field contains the number of
 
 464  *                bytes remaining in the buffer.
 
 465  *               Shorter than the message, this field contains the residual
 
 466  *                count (that is, the number of bytes remaining in the
 
 467  *                message that does not fit into the buffer. In this
 
 468  *                case b2f0_result = 5.
 
 469  * Return: Return code from CP IUCV call.
 
 470  *         (-EINVAL) - buffer address is pointing to NULL
 
 472 int iucv_receive (u16 pathid,
 
 478                   ulong * residual_buffer, ulong * residual_length);
 
 481   * Name: iucv_receive_array
 
 482   * Purpose: This function receives messages that are being sent to you
 
 483   *          over established paths. Data will be returned in first buffer for
 
 484   *          length of first buffer.
 
 485   * Input: pathid - Path identification number.
 
 486   *        msgid - specifies the message ID.
 
 487   *        trgcls - Specifies target class.
 
 488   *        buffer - Address of array of buffers.
 
 489   *        buflen - Total length of buffers.
 
 491   *        flags1_out: int *, Contains information about this path.
 
 492   *          IPNORPY - 0x10 Specifies this is a one-way message and no reply is
 
 494   *          IPPRTY  - 0x20 Specifies if you want to send priority message.
 
 495   *          IPRMDATA - 0x80 specifies the data is contained in the parameter list
 
 496   *       residual_buffer - address points to the current list entry IUCV
 
 499   *              Contains one of the following values, if the receive buffer is:
 
 500   *               The same length as the message, this field is zero.
 
 501   *               Longer than the message, this field contains the number of
 
 502   *                bytes remaining in the buffer.
 
 503   *               Shorter than the message, this field contains the residual
 
 504   *                count (that is, the number of bytes remaining in the
 
 505   *                message that does not fit into the buffer. In this
 
 506   *                case b2f0_result = 5.
 
 507   * Return: Return code from CP IUCV call.
 
 508   *         (-EINVAL) - Buffer address is NULL.
 
 510 int iucv_receive_array (u16 pathid,
 
 513                         iucv_array_t * buffer,
 
 516                         ulong * residual_buffer, ulong * residual_length);
 
 520  * Purpose: The reject function refuses a specified message. Between the
 
 521  *          time you are notified of a message and the time that you
 
 522  *          complete the message, the message may be rejected.
 
 523  * Input: pathid - Path identification number.
 
 524  *        msgid - Specifies the message ID.
 
 525  *        trgcls - Specifies target class.
 
 527  * Return: Return code from CP IUCV call.
 
 529 int iucv_reject (u16 pathid, u32 msgid, u32 trgcls);
 
 533  * Purpose: This function responds to the two-way messages that you
 
 534  *          receive. You must identify completely the message to
 
 535  *          which you wish to reply. ie, pathid, msgid, and trgcls.
 
 536  * Input: pathid - Path identification number.
 
 537  *        msgid - Specifies the message ID.
 
 538  *        trgcls - Specifies target class.
 
 539  *        flags1 - Option for path.
 
 540  *          IPPRTY- 0x20, Specifies if you want to send priority message.
 
 541  *        buffer - Address of reply buffer.
 
 542  *        buflen - Length of reply buffer.
 
 543  * Output: residual_buffer - Address of buffer updated by the number
 
 544  *                    of bytes you have moved.
 
 545  *         residual_length - Contains one of the following values:
 
 546  *              If the answer buffer is the same length as the reply, this field
 
 548  *              If the answer buffer is longer than the reply, this field contains
 
 549  *               the number of bytes remaining in the buffer.
 
 550  *              If the answer buffer is shorter than the reply, this field contains
 
 551  *               a residual count (that is, the number of bytes remianing in the
 
 552  *               reply that does not fit into the buffer. In this
 
 553  *               case b2f0_result = 5.
 
 554  * Return: Return code from CP IUCV call.
 
 555  *         (-EINVAL) - Buffer address is NULL.
 
 557 int iucv_reply (u16 pathid,
 
 561                 void *buffer, ulong buflen, ulong * residual_buffer,
 
 562                 ulong * residual_length);
 
 565  * Name: iucv_reply_array
 
 566  * Purpose: This function responds to the two-way messages that you
 
 567  *          receive. You must identify completely the message to
 
 568  *          which you wish to reply. ie, pathid, msgid, and trgcls.
 
 569  *          The array identifies a list of addresses and lengths of
 
 570  *          discontiguous buffers that contains the reply data.
 
 571  * Input: pathid - Path identification number
 
 572  *        msgid - Specifies the message ID.
 
 573  *        trgcls - Specifies target class.
 
 574  *        flags1 - Option for path.
 
 575  *          IPPRTY- 0x20, Specifies if you want to send priority message.
 
 576  *        buffer - Address of array of reply buffers.
 
 577  *        buflen - Total length of reply buffers.
 
 578  * Output: residual_buffer - Address of buffer which IUCV is currently working on.
 
 579  *         residual_length - Contains one of the following values:
 
 580  *              If the answer buffer is the same length as the reply, this field
 
 582  *              If the answer buffer is longer than the reply, this field contains
 
 583  *               the number of bytes remaining in the buffer.
 
 584  *              If the answer buffer is shorter than the reply, this field contains
 
 585  *               a residual count (that is, the number of bytes remianing in the
 
 586  *               reply that does not fit into the buffer. In this
 
 587  *               case b2f0_result = 5.
 
 588  * Return: Return code from CP IUCV call.
 
 589  *         (-EINVAL) - Buffer address is NULL.
 
 591 int iucv_reply_array (u16 pathid,
 
 595                       iucv_array_t * buffer,
 
 596                       ulong buflen, ulong * residual_address,
 
 597                       ulong * residual_length);
 
 600  * Name: iucv_reply_prmmsg
 
 601  * Purpose: This function responds to the two-way messages that you
 
 602  *          receive. You must identify completely the message to
 
 603  *          which you wish to reply. ie, pathid, msgid, and trgcls.
 
 604  *          Prmmsg signifies the data is moved into the
 
 606  * Input: pathid - Path identification number.
 
 607  *        msgid - Specifies the message ID.
 
 608  *        trgcls - Specifies target class.
 
 609  *        flags1 - Option for path.
 
 610  *          IPPRTY- 0x20 Specifies if you want to send priority message.
 
 611  *        prmmsg - 8-bytes of data to be placed into the parameter.
 
 614  * Return: Return code from CP IUCV call.
 
 616 int iucv_reply_prmmsg (u16 pathid,
 
 617                        u32 msgid, u32 trgcls, int flags1, uchar prmmsg[8]);
 
 621  * Purpose: This function restores communications over a quiesced path
 
 622  * Input: pathid - Path identification number.
 
 623  *        user_data  - 16-bytes of user data.
 
 625  * Return: Return code from CP IUCV call.
 
 627 int iucv_resume (u16 pathid, uchar user_data[16]);
 
 631  * Purpose: This function transmits data to another application.
 
 632  *          Data to be transmitted is in a buffer and this is a
 
 633  *          one-way message and the receiver will not reply to the
 
 635  * Input: pathid - Path identification number.
 
 636  *        trgcls - Specifies target class.
 
 637  *        srccls - Specifies the source message class.
 
 638  *        msgtag - Specifies a tag to be associated with the message.
 
 639  *        flags1 - Option for path.
 
 640  *          IPPRTY- 0x20 Specifies if you want to send priority message.
 
 641  *        buffer - Address of send buffer.
 
 642  *        buflen - Length of send buffer.
 
 643  * Output: msgid - Specifies the message ID.
 
 644  * Return: Return code from CP IUCV call.
 
 645  *         (-EINVAL) - Buffer address is NULL.
 
 647 int iucv_send (u16 pathid,
 
 650                u32 srccls, u32 msgtag, int flags1, void *buffer, ulong buflen);
 
 653  * Name: iucv_send_array
 
 654  * Purpose: This function transmits data to another application.
 
 655  *          The contents of buffer is the address of the array of
 
 656  *          addresses and lengths of discontiguous buffers that hold
 
 657  *          the message text. This is a one-way message and the
 
 658  *          receiver will not reply to the message.
 
 659  * Input: pathid - Path identification number.
 
 660  *        trgcls - Specifies target class.
 
 661  *        srccls - Specifies the source message class.
 
 662  *        msgtag - Specifies a tag to be associated witht the message.
 
 663  *        flags1 - Option for path.
 
 664  *          IPPRTY- specifies if you want to send priority message.
 
 665  *        buffer - Address of array of send buffers.
 
 666  *        buflen - Total length of send buffers.
 
 667  * Output: msgid - Specifies the message ID.
 
 668  * Return: Return code from CP IUCV call.
 
 669  *         (-EINVAL) - Buffer address is NULL.
 
 671 int iucv_send_array (u16 pathid,
 
 676                      int flags1, iucv_array_t * buffer, ulong buflen);
 
 679  * Name: iucv_send_prmmsg
 
 680  * Purpose: This function transmits data to another application.
 
 681  *          Prmmsg specifies that the 8-bytes of data are to be moved
 
 682  *          into the parameter list. This is a one-way message and the
 
 683  *          receiver will not reply to the message.
 
 684  * Input: pathid - Path identification number.
 
 685  *        trgcls - Specifies target class.
 
 686  *        srccls - Specifies the source message class.
 
 687  *        msgtag - Specifies a tag to be associated with the message.
 
 688  *        flags1 - Option for path.
 
 689  *          IPPRTY- 0x20 specifies if you want to send priority message.
 
 690  *        prmmsg - 8-bytes of data to be placed into parameter list.
 
 691  * Output: msgid - Specifies the message ID.
 
 692  * Return: Return code from CP IUCV call.
 
 694 int iucv_send_prmmsg (u16 pathid,
 
 697                       u32 srccls, u32 msgtag, int flags1, uchar prmmsg[8]);
 
 700  * Name: iucv_send2way
 
 701  * Purpose: This function transmits data to another application.
 
 702  *          Data to be transmitted is in a buffer. The receiver
 
 703  *          of the send is expected to reply to the message and
 
 704  *          a buffer is provided into which IUCV moves the reply
 
 706  * Input: pathid - Path identification number.
 
 707  *        trgcls - Specifies target class.
 
 708  *        srccls - Specifies the source message class.
 
 709  *        msgtag - Specifies a tag associated with the message.
 
 710  *        flags1 - Option for path.
 
 711  *          IPPRTY- 0x20 Specifies if you want to send priority message.
 
 712  *        buffer - Address of send buffer.
 
 713  *        buflen - Length of send buffer.
 
 714  *        ansbuf - Address of buffer into which IUCV moves the reply of
 
 716  *        anslen - Address of length of buffer.
 
 717  * Output: msgid - Specifies the message ID.
 
 718  * Return: Return code from CP IUCV call.
 
 719  *         (-EINVAL) - Buffer or ansbuf address is NULL.
 
 721 int iucv_send2way (u16 pathid,
 
 727                    void *buffer, ulong buflen, void *ansbuf, ulong anslen);
 
 730  * Name: iucv_send2way_array
 
 731  * Purpose: This function transmits data to another application.
 
 732  *          The contents of buffer is the address of the array of
 
 733  *          addresses and lengths of discontiguous buffers that hold
 
 734  *          the message text. The receiver of the send is expected to
 
 735  *          reply to the message and a buffer is provided into which
 
 736  *          IUCV moves the reply to this message.
 
 737  * Input: pathid - Path identification number.
 
 738  *        trgcls - Specifies target class.
 
 739  *        srccls - Specifies the source message class.
 
 740  *        msgtag - Specifies a tag to be associated with the message.
 
 741  *        flags1 - Option for path.
 
 742  *          IPPRTY- 0x20 Specifies if you want to send priority message.
 
 743  *        buffer - Sddress of array of send buffers.
 
 744  *        buflen - Total length of send buffers.
 
 745  *        ansbuf - Address of array of buffer into which IUCV moves the reply
 
 747  *        anslen - Address of length reply buffers.
 
 748  * Output: msgid - Specifies the message ID.
 
 749  * Return: Return code from CP IUCV call.
 
 750  *         (-EINVAL) - Buffer address is NULL.
 
 752 int iucv_send2way_array (u16 pathid,
 
 758                          iucv_array_t * buffer,
 
 759                          ulong buflen, iucv_array_t * ansbuf, ulong anslen);
 
 762  * Name: iucv_send2way_prmmsg
 
 763  * Purpose: This function transmits data to another application.
 
 764  *          Prmmsg specifies that the 8-bytes of data are to be moved
 
 765  *          into the parameter list. This is a two-way message and the
 
 766  *          receiver of the message is expected to reply. A buffer
 
 767  *          is provided into which IUCV moves the reply to this
 
 769  * Input: pathid - Rath identification number.
 
 770  *        trgcls - Specifies target class.
 
 771  *        srccls - Specifies the source message class.
 
 772  *        msgtag - Specifies a tag to be associated with the message.
 
 773  *        flags1 - Option for path.
 
 774  *          IPPRTY- 0x20 Specifies if you want to send priority message.
 
 775  *        prmmsg - 8-bytes of data to be placed in parameter list.
 
 776  *        ansbuf - Address of buffer into which IUCV moves the reply of
 
 778  *        anslen - Address of length of buffer.
 
 779  * Output: msgid - Specifies the message ID.
 
 780  * Return: Return code from CP IUCV call.
 
 781  *         (-EINVAL) - Buffer address is NULL.
 
 783 int iucv_send2way_prmmsg (u16 pathid,
 
 789                           uchar prmmsg[8], void *ansbuf, ulong anslen);
 
 792  * Name: iucv_send2way_prmmsg_array
 
 793  * Purpose: This function transmits data to another application.
 
 794  *          Prmmsg specifies that the 8-bytes of data are to be moved
 
 795  *          into the parameter list. This is a two-way message and the
 
 796  *          receiver of the message is expected to reply. A buffer
 
 797  *          is provided into which IUCV moves the reply to this
 
 798  *          message. The contents of ansbuf is the address of the
 
 799  *          array of addresses and lengths of discontiguous buffers
 
 800  *          that contain the reply.
 
 801  * Input: pathid - Path identification number.
 
 802  *        trgcls - Specifies target class.
 
 803  *        srccls - Specifies the source message class.
 
 804  *        msgtag - Specifies a tag to be associated with the message.
 
 805  *        flags1 - Option for path.
 
 806  *          IPPRTY- 0x20 specifies if you want to send priority message.
 
 807  *        prmmsg - 8-bytes of data to be placed into the parameter list.
 
 808  *        ansbuf - Address of array of buffer into which IUCV moves the reply
 
 810  *        anslen - Address of length of reply buffers.
 
 811  * Output: msgid - Specifies the message ID.
 
 812  * Return: Return code from CP IUCV call.
 
 813  *         (-EINVAL) - Ansbuf address is NULL.
 
 815 int iucv_send2way_prmmsg_array (u16 pathid,
 
 822                                 iucv_array_t * ansbuf, ulong anslen);
 
 826  * Purpose: This function enables or disables the following IUCV
 
 827  *          external interruptions: Nonpriority and priority message
 
 828  *          interrupts, nonpriority and priority reply interrupts.
 
 829  * Input: SetMaskFlag - options for interrupts
 
 830  *           0x80 - Nonpriority_MessagePendingInterruptsFlag
 
 831  *           0x40 - Priority_MessagePendingInterruptsFlag
 
 832  *           0x20 - Nonpriority_MessageCompletionInterruptsFlag
 
 833  *           0x10 - Priority_MessageCompletionInterruptsFlag
 
 834  *           0x08 - IUCVControlInterruptsFlag
 
 836  * Return: Return code from CP IUCV call.
 
 838 int iucv_setmask (int SetMaskFlag);
 
 842  * Purpose: This function terminates an IUCV path.
 
 843  * Input: pathid - Path identification number.
 
 844  *        user_data - 16-bytes of user data.
 
 846  * Return: Return code from CP IUCV call.
 
 847  *         (-EINVAL) - Interal error, wild pointer.
 
 849 int iucv_sever (u16 pathid, uchar user_data[16]);