850 lines
37 KiB
C
850 lines
37 KiB
C
/*
|
|
* drivers/s390/net/iucv.h
|
|
* IUCV base support.
|
|
*
|
|
* S390 version
|
|
* Copyright (C) 2000 IBM Corporation
|
|
* Author(s):Alan Altmark (Alan_Altmark@us.ibm.com)
|
|
* Xenia Tkatschow (xenia@us.ibm.com)
|
|
*
|
|
*
|
|
* Functionality:
|
|
* To explore any of the IUCV functions, one must first register
|
|
* their program using iucv_register_program(). Once your program has
|
|
* successfully completed a register, it can exploit the other functions.
|
|
* For furthur reference on all IUCV functionality, refer to the
|
|
* CP Programming Services book, also available on the web
|
|
* thru www.ibm.com/s390/vm/pubs, manual # SC24-5760
|
|
*
|
|
* Definition of Return Codes
|
|
* -All positive return codes including zero are reflected back
|
|
* from CP except for iucv_register_program. The definition of each
|
|
* return code can be found in CP Programming Services book.
|
|
* Also available on the web thru www.ibm.com/s390/vm/pubs, manual # SC24-5760
|
|
* - Return Code of:
|
|
* (-EINVAL) Invalid value
|
|
* (-ENOMEM) storage allocation failed
|
|
* pgmask defined in iucv_register_program will be set depending on input
|
|
* paramters.
|
|
*
|
|
*/
|
|
|
|
#include <linux/types.h>
|
|
#include <asm/debug.h>
|
|
|
|
/**
|
|
* Debug Facility stuff
|
|
*/
|
|
#define IUCV_DBF_SETUP_NAME "iucv_setup"
|
|
#define IUCV_DBF_SETUP_LEN 32
|
|
#define IUCV_DBF_SETUP_PAGES 2
|
|
#define IUCV_DBF_SETUP_NR_AREAS 1
|
|
#define IUCV_DBF_SETUP_LEVEL 3
|
|
|
|
#define IUCV_DBF_DATA_NAME "iucv_data"
|
|
#define IUCV_DBF_DATA_LEN 128
|
|
#define IUCV_DBF_DATA_PAGES 2
|
|
#define IUCV_DBF_DATA_NR_AREAS 1
|
|
#define IUCV_DBF_DATA_LEVEL 2
|
|
|
|
#define IUCV_DBF_TRACE_NAME "iucv_trace"
|
|
#define IUCV_DBF_TRACE_LEN 16
|
|
#define IUCV_DBF_TRACE_PAGES 4
|
|
#define IUCV_DBF_TRACE_NR_AREAS 1
|
|
#define IUCV_DBF_TRACE_LEVEL 3
|
|
|
|
#define IUCV_DBF_TEXT(name,level,text) \
|
|
do { \
|
|
debug_text_event(iucv_dbf_##name,level,text); \
|
|
} while (0)
|
|
|
|
#define IUCV_DBF_HEX(name,level,addr,len) \
|
|
do { \
|
|
debug_event(iucv_dbf_##name,level,(void*)(addr),len); \
|
|
} while (0)
|
|
|
|
DECLARE_PER_CPU(char[256], iucv_dbf_txt_buf);
|
|
|
|
#define IUCV_DBF_TEXT_(name,level,text...) \
|
|
do { \
|
|
char* iucv_dbf_txt_buf = get_cpu_var(iucv_dbf_txt_buf); \
|
|
sprintf(iucv_dbf_txt_buf, text); \
|
|
debug_text_event(iucv_dbf_##name,level,iucv_dbf_txt_buf); \
|
|
put_cpu_var(iucv_dbf_txt_buf); \
|
|
} while (0)
|
|
|
|
#define IUCV_DBF_SPRINTF(name,level,text...) \
|
|
do { \
|
|
debug_sprintf_event(iucv_dbf_trace, level, ##text ); \
|
|
debug_sprintf_event(iucv_dbf_trace, level, text ); \
|
|
} while (0)
|
|
|
|
/**
|
|
* some more debug stuff
|
|
*/
|
|
#define IUCV_HEXDUMP16(importance,header,ptr) \
|
|
PRINT_##importance(header "%02x %02x %02x %02x %02x %02x %02x %02x " \
|
|
"%02x %02x %02x %02x %02x %02x %02x %02x\n", \
|
|
*(((char*)ptr)),*(((char*)ptr)+1),*(((char*)ptr)+2), \
|
|
*(((char*)ptr)+3),*(((char*)ptr)+4),*(((char*)ptr)+5), \
|
|
*(((char*)ptr)+6),*(((char*)ptr)+7),*(((char*)ptr)+8), \
|
|
*(((char*)ptr)+9),*(((char*)ptr)+10),*(((char*)ptr)+11), \
|
|
*(((char*)ptr)+12),*(((char*)ptr)+13), \
|
|
*(((char*)ptr)+14),*(((char*)ptr)+15)); \
|
|
PRINT_##importance(header "%02x %02x %02x %02x %02x %02x %02x %02x " \
|
|
"%02x %02x %02x %02x %02x %02x %02x %02x\n", \
|
|
*(((char*)ptr)+16),*(((char*)ptr)+17), \
|
|
*(((char*)ptr)+18),*(((char*)ptr)+19), \
|
|
*(((char*)ptr)+20),*(((char*)ptr)+21), \
|
|
*(((char*)ptr)+22),*(((char*)ptr)+23), \
|
|
*(((char*)ptr)+24),*(((char*)ptr)+25), \
|
|
*(((char*)ptr)+26),*(((char*)ptr)+27), \
|
|
*(((char*)ptr)+28),*(((char*)ptr)+29), \
|
|
*(((char*)ptr)+30),*(((char*)ptr)+31));
|
|
|
|
static inline void
|
|
iucv_hex_dump(unsigned char *buf, size_t len)
|
|
{
|
|
size_t i;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
if (i && !(i % 16))
|
|
printk("\n");
|
|
printk("%02x ", *(buf + i));
|
|
}
|
|
printk("\n");
|
|
}
|
|
/**
|
|
* end of debug stuff
|
|
*/
|
|
|
|
#define uchar unsigned char
|
|
#define ushort unsigned short
|
|
#define ulong unsigned long
|
|
#define iucv_handle_t void *
|
|
|
|
/* flags1:
|
|
* All flags are defined in the field IPFLAGS1 of each function
|
|
* and can be found in CP Programming Services.
|
|
* IPLOCAL - Indicates the connect can only be satisfied on the
|
|
* local system
|
|
* IPPRTY - Indicates a priority message
|
|
* IPQUSCE - Indicates you do not want to receive messages on a
|
|
* path until an iucv_resume is issued
|
|
* IPRMDATA - Indicates that the message is in the parameter list
|
|
*/
|
|
#define IPLOCAL 0x01
|
|
#define IPPRTY 0x20
|
|
#define IPQUSCE 0x40
|
|
#define IPRMDATA 0x80
|
|
|
|
/* flags1_out:
|
|
* All flags are defined in the output field of IPFLAGS1 for each function
|
|
* and can be found in CP Programming Services.
|
|
* IPNORPY - Specifies this is a one-way message and no reply is expected.
|
|
* IPPRTY - Indicates a priority message is permitted. Defined in flags1.
|
|
*/
|
|
#define IPNORPY 0x10
|
|
|
|
#define Nonpriority_MessagePendingInterruptsFlag 0x80
|
|
#define Priority_MessagePendingInterruptsFlag 0x40
|
|
#define Nonpriority_MessageCompletionInterruptsFlag 0x20
|
|
#define Priority_MessageCompletionInterruptsFlag 0x10
|
|
#define IUCVControlInterruptsFlag 0x08
|
|
#define AllInterrupts 0xf8
|
|
/*
|
|
* Mapping of external interrupt buffers should be used with the corresponding
|
|
* interrupt types.
|
|
* Names: iucv_ConnectionPending -> connection pending
|
|
* iucv_ConnectionComplete -> connection complete
|
|
* iucv_ConnectionSevered -> connection severed
|
|
* iucv_ConnectionQuiesced -> connection quiesced
|
|
* iucv_ConnectionResumed -> connection resumed
|
|
* iucv_MessagePending -> message pending
|
|
* iucv_MessageComplete -> message complete
|
|
*/
|
|
typedef struct {
|
|
u16 ippathid;
|
|
uchar ipflags1;
|
|
uchar iptype;
|
|
u16 ipmsglim;
|
|
u16 res1;
|
|
uchar ipvmid[8];
|
|
uchar ipuser[16];
|
|
u32 res3;
|
|
uchar ippollfg;
|
|
uchar res4[3];
|
|
} iucv_ConnectionPending;
|
|
|
|
typedef struct {
|
|
u16 ippathid;
|
|
uchar ipflags1;
|
|
uchar iptype;
|
|
u16 ipmsglim;
|
|
u16 res1;
|
|
uchar res2[8];
|
|
uchar ipuser[16];
|
|
u32 res3;
|
|
uchar ippollfg;
|
|
uchar res4[3];
|
|
} iucv_ConnectionComplete;
|
|
|
|
typedef struct {
|
|
u16 ippathid;
|
|
uchar res1;
|
|
uchar iptype;
|
|
u32 res2;
|
|
uchar res3[8];
|
|
uchar ipuser[16];
|
|
u32 res4;
|
|
uchar ippollfg;
|
|
uchar res5[3];
|
|
} iucv_ConnectionSevered;
|
|
|
|
typedef struct {
|
|
u16 ippathid;
|
|
uchar res1;
|
|
uchar iptype;
|
|
u32 res2;
|
|
uchar res3[8];
|
|
uchar ipuser[16];
|
|
u32 res4;
|
|
uchar ippollfg;
|
|
uchar res5[3];
|
|
} iucv_ConnectionQuiesced;
|
|
|
|
typedef struct {
|
|
u16 ippathid;
|
|
uchar res1;
|
|
uchar iptype;
|
|
u32 res2;
|
|
uchar res3[8];
|
|
uchar ipuser[16];
|
|
u32 res4;
|
|
uchar ippollfg;
|
|
uchar res5[3];
|
|
} iucv_ConnectionResumed;
|
|
|
|
typedef struct {
|
|
u16 ippathid;
|
|
uchar ipflags1;
|
|
uchar iptype;
|
|
u32 ipmsgid;
|
|
u32 iptrgcls;
|
|
union u2 {
|
|
u32 iprmmsg1_u32;
|
|
uchar iprmmsg1[4];
|
|
} ln1msg1;
|
|
union u1 {
|
|
u32 ipbfln1f;
|
|
uchar iprmmsg2[4];
|
|
} ln1msg2;
|
|
u32 res1[3];
|
|
u32 ipbfln2f;
|
|
uchar ippollfg;
|
|
uchar res2[3];
|
|
} iucv_MessagePending;
|
|
|
|
typedef struct {
|
|
u16 ippathid;
|
|
uchar ipflags1;
|
|
uchar iptype;
|
|
u32 ipmsgid;
|
|
u32 ipaudit;
|
|
uchar iprmmsg[8];
|
|
u32 ipsrccls;
|
|
u32 ipmsgtag;
|
|
u32 res;
|
|
u32 ipbfln2f;
|
|
uchar ippollfg;
|
|
uchar res2[3];
|
|
} iucv_MessageComplete;
|
|
|
|
/*
|
|
* iucv_interrupt_ops_t: Is a vector of functions that handle
|
|
* IUCV interrupts.
|
|
* Parameter list:
|
|
* eib - is a pointer to a 40-byte area described
|
|
* with one of the structures above.
|
|
* pgm_data - this data is strictly for the
|
|
* interrupt handler that is passed by
|
|
* the application. This may be an address
|
|
* or token.
|
|
*/
|
|
typedef struct {
|
|
void (*ConnectionPending) (iucv_ConnectionPending * eib,
|
|
void *pgm_data);
|
|
void (*ConnectionComplete) (iucv_ConnectionComplete * eib,
|
|
void *pgm_data);
|
|
void (*ConnectionSevered) (iucv_ConnectionSevered * eib,
|
|
void *pgm_data);
|
|
void (*ConnectionQuiesced) (iucv_ConnectionQuiesced * eib,
|
|
void *pgm_data);
|
|
void (*ConnectionResumed) (iucv_ConnectionResumed * eib,
|
|
void *pgm_data);
|
|
void (*MessagePending) (iucv_MessagePending * eib, void *pgm_data);
|
|
void (*MessageComplete) (iucv_MessageComplete * eib, void *pgm_data);
|
|
} iucv_interrupt_ops_t;
|
|
|
|
/*
|
|
*iucv_array_t : Defines buffer array.
|
|
* Inside the array may be 31- bit addresses and 31-bit lengths.
|
|
*/
|
|
typedef struct {
|
|
u32 address;
|
|
u32 length;
|
|
} iucv_array_t __attribute__ ((aligned (8)));
|
|
|
|
extern struct bus_type iucv_bus;
|
|
extern struct device *iucv_root;
|
|
|
|
/* -prototypes- */
|
|
/*
|
|
* Name: iucv_register_program
|
|
* Purpose: Registers an application with IUCV
|
|
* Input: prmname - user identification
|
|
* userid - machine identification
|
|
* pgmmask - indicates which bits in the prmname and userid combined will be
|
|
* used to determine who is given control
|
|
* ops - address of vector of interrupt handlers
|
|
* pgm_data- application data passed to interrupt handlers
|
|
* Output: NA
|
|
* Return: address of handler
|
|
* (0) - Error occurred, registration not completed.
|
|
* NOTE: Exact cause of failure will be recorded in syslog.
|
|
*/
|
|
iucv_handle_t iucv_register_program (uchar pgmname[16],
|
|
uchar userid[8],
|
|
uchar pgmmask[24],
|
|
iucv_interrupt_ops_t * ops,
|
|
void *pgm_data);
|
|
|
|
/*
|
|
* Name: iucv_unregister_program
|
|
* Purpose: Unregister application with IUCV
|
|
* Input: address of handler
|
|
* Output: NA
|
|
* Return: (0) - Normal return
|
|
* (-EINVAL) - Internal error, wild pointer
|
|
*/
|
|
int iucv_unregister_program (iucv_handle_t handle);
|
|
|
|
/*
|
|
* Name: iucv_accept
|
|
* Purpose: This function is issued after the user receives a Connection Pending external
|
|
* interrupt and now wishes to complete the IUCV communication path.
|
|
* Input: pathid - u16 , Path identification number
|
|
* msglim_reqstd - u16, The number of outstanding messages requested.
|
|
* user_data - uchar[16], Data specified by the iucv_connect function.
|
|
* flags1 - int, Contains options for this path.
|
|
* -IPPRTY - 0x20- Specifies if you want to send priority message.
|
|
* -IPRMDATA - 0x80, Specifies whether your program can handle a message
|
|
* in the parameter list.
|
|
* -IPQUSCE - 0x40, Specifies whether you want to quiesce the path being
|
|
* established.
|
|
* handle - iucv_handle_t, Address of handler.
|
|
* pgm_data - void *, Application data passed to interrupt handlers.
|
|
* flags1_out - int * Contains information about the path
|
|
* - IPPRTY - 0x20, Indicates you may send priority messages.
|
|
* msglim - *u16, Number of outstanding messages.
|
|
* Output: return code from CP IUCV call.
|
|
*/
|
|
|
|
int iucv_accept (u16 pathid,
|
|
u16 msglim_reqstd,
|
|
uchar user_data[16],
|
|
int flags1,
|
|
iucv_handle_t handle,
|
|
void *pgm_data, int *flags1_out, u16 * msglim);
|
|
|
|
/*
|
|
* Name: iucv_connect
|
|
* Purpose: This function establishes an IUCV path. Although the connect may complete
|
|
* successfully, you are not able to use the path until you receive an IUCV
|
|
* Connection Complete external interrupt.
|
|
* Input: pathid - u16 *, Path identification number
|
|
* msglim_reqstd - u16, Number of outstanding messages requested
|
|
* user_data - uchar[16], 16-byte user data
|
|
* userid - uchar[8], User identification
|
|
* system_name - uchar[8], 8-byte identifying the system name
|
|
* flags1 - int, Contains options for this path.
|
|
* -IPPRTY - 0x20, Specifies if you want to send priority message.
|
|
* -IPRMDATA - 0x80, Specifies whether your program can handle a message
|
|
* in the parameter list.
|
|
* -IPQUSCE - 0x40, Specifies whether you want to quiesce the path being
|
|
* established.
|
|
* -IPLOCAL - 0X01, Allows an application to force the partner to be on
|
|
* the local system. If local is specified then target class cannot be
|
|
* specified.
|
|
* flags1_out - int * Contains information about the path
|
|
* - IPPRTY - 0x20, Indicates you may send priority messages.
|
|
* msglim - * u16, Number of outstanding messages
|
|
* handle - iucv_handle_t, Address of handler
|
|
* pgm_data - void *, Application data passed to interrupt handlers
|
|
* Output: return code from CP IUCV call
|
|
* rc - return code from iucv_declare_buffer
|
|
* -EINVAL - Invalid handle passed by application
|
|
* -EINVAL - Pathid address is NULL
|
|
* add_pathid_result - Return code from internal function add_pathid
|
|
*/
|
|
int
|
|
iucv_connect (u16 * pathid,
|
|
u16 msglim_reqstd,
|
|
uchar user_data[16],
|
|
uchar userid[8],
|
|
uchar system_name[8],
|
|
int flags1,
|
|
int *flags1_out,
|
|
u16 * msglim, iucv_handle_t handle, void *pgm_data);
|
|
|
|
/*
|
|
* Name: iucv_purge
|
|
* Purpose: This function cancels a message that you have sent.
|
|
* Input: pathid - Path identification number.
|
|
* msgid - Specifies the message ID of the message to be purged.
|
|
* srccls - Specifies the source message class.
|
|
* Output: audit - Contains information about asynchronous error
|
|
* that may have affected the normal completion
|
|
* of this message.
|
|
* Return: Return code from CP IUCV call.
|
|
*/
|
|
int iucv_purge (u16 pathid, u32 msgid, u32 srccls, __u32 *audit);
|
|
/*
|
|
* Name: iucv_query_maxconn
|
|
* Purpose: This function determines the maximum number of communication paths you
|
|
* may establish.
|
|
* Return: maxconn - ulong, Maximum number of connection the virtual machine may
|
|
* establish.
|
|
*/
|
|
ulong iucv_query_maxconn (void);
|
|
|
|
/*
|
|
* Name: iucv_query_bufsize
|
|
* Purpose: This function determines how large an external interrupt
|
|
* buffer IUCV requires to store information.
|
|
* Return: bufsize - ulong, Size of external interrupt buffer.
|
|
*/
|
|
ulong iucv_query_bufsize (void);
|
|
|
|
/*
|
|
* Name: iucv_quiesce
|
|
* Purpose: This function temporarily suspends incoming messages on an
|
|
* IUCV path. You can later reactivate the path by invoking
|
|
* the iucv_resume function.
|
|
* Input: pathid - Path identification number
|
|
* user_data - 16-bytes of user data
|
|
* Output: NA
|
|
* Return: Return code from CP IUCV call.
|
|
*/
|
|
int iucv_quiesce (u16 pathid, uchar user_data[16]);
|
|
|
|
/*
|
|
* Name: iucv_receive
|
|
* Purpose: This function receives messages that are being sent to you
|
|
* over established paths. Data will be returned in buffer for length of
|
|
* buflen.
|
|
* Input:
|
|
* pathid - Path identification number.
|
|
* buffer - Address of buffer to receive.
|
|
* buflen - Length of buffer to receive.
|
|
* msgid - Specifies the message ID.
|
|
* trgcls - Specifies target class.
|
|
* Output:
|
|
* flags1_out: int *, Contains information about this path.
|
|
* IPNORPY - 0x10 Specifies this is a one-way message and no reply is
|
|
* expected.
|
|
* IPPRTY - 0x20 Specifies if you want to send priority message.
|
|
* IPRMDATA - 0x80 specifies the data is contained in the parameter list
|
|
* residual_buffer - address of buffer updated by the number
|
|
* of bytes you have received.
|
|
* residual_length -
|
|
* Contains one of the following values, if the receive buffer is:
|
|
* The same length as the message, this field is zero.
|
|
* Longer than the message, this field contains the number of
|
|
* bytes remaining in the buffer.
|
|
* Shorter than the message, this field contains the residual
|
|
* count (that is, the number of bytes remaining in the
|
|
* message that does not fit into the buffer. In this
|
|
* case b2f0_result = 5.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - buffer address is pointing to NULL
|
|
*/
|
|
int iucv_receive (u16 pathid,
|
|
u32 msgid,
|
|
u32 trgcls,
|
|
void *buffer,
|
|
ulong buflen,
|
|
int *flags1_out,
|
|
ulong * residual_buffer, ulong * residual_length);
|
|
|
|
/*
|
|
* Name: iucv_receive_array
|
|
* Purpose: This function receives messages that are being sent to you
|
|
* over established paths. Data will be returned in first buffer for
|
|
* length of first buffer.
|
|
* Input: pathid - Path identification number.
|
|
* msgid - specifies the message ID.
|
|
* trgcls - Specifies target class.
|
|
* buffer - Address of array of buffers.
|
|
* buflen - Total length of buffers.
|
|
* Output:
|
|
* flags1_out: int *, Contains information about this path.
|
|
* IPNORPY - 0x10 Specifies this is a one-way message and no reply is
|
|
* expected.
|
|
* IPPRTY - 0x20 Specifies if you want to send priority message.
|
|
* IPRMDATA - 0x80 specifies the data is contained in the parameter list
|
|
* residual_buffer - address points to the current list entry IUCV
|
|
* is working on.
|
|
* residual_length -
|
|
* Contains one of the following values, if the receive buffer is:
|
|
* The same length as the message, this field is zero.
|
|
* Longer than the message, this field contains the number of
|
|
* bytes remaining in the buffer.
|
|
* Shorter than the message, this field contains the residual
|
|
* count (that is, the number of bytes remaining in the
|
|
* message that does not fit into the buffer. In this
|
|
* case b2f0_result = 5.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer address is NULL.
|
|
*/
|
|
int iucv_receive_array (u16 pathid,
|
|
u32 msgid,
|
|
u32 trgcls,
|
|
iucv_array_t * buffer,
|
|
ulong buflen,
|
|
int *flags1_out,
|
|
ulong * residual_buffer, ulong * residual_length);
|
|
|
|
/*
|
|
* Name: iucv_reject
|
|
* Purpose: The reject function refuses a specified message. Between the
|
|
* time you are notified of a message and the time that you
|
|
* complete the message, the message may be rejected.
|
|
* Input: pathid - Path identification number.
|
|
* msgid - Specifies the message ID.
|
|
* trgcls - Specifies target class.
|
|
* Output: NA
|
|
* Return: Return code from CP IUCV call.
|
|
*/
|
|
int iucv_reject (u16 pathid, u32 msgid, u32 trgcls);
|
|
|
|
/*
|
|
* Name: iucv_reply
|
|
* Purpose: This function responds to the two-way messages that you
|
|
* receive. You must identify completely the message to
|
|
* which you wish to reply. ie, pathid, msgid, and trgcls.
|
|
* Input: pathid - Path identification number.
|
|
* msgid - Specifies the message ID.
|
|
* trgcls - Specifies target class.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20, Specifies if you want to send priority message.
|
|
* buffer - Address of reply buffer.
|
|
* buflen - Length of reply buffer.
|
|
* Output: residual_buffer - Address of buffer updated by the number
|
|
* of bytes you have moved.
|
|
* residual_length - Contains one of the following values:
|
|
* If the answer buffer is the same length as the reply, this field
|
|
* contains zero.
|
|
* If the answer buffer is longer than the reply, this field contains
|
|
* the number of bytes remaining in the buffer.
|
|
* If the answer buffer is shorter than the reply, this field contains
|
|
* a residual count (that is, the number of bytes remianing in the
|
|
* reply that does not fit into the buffer. In this
|
|
* case b2f0_result = 5.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer address is NULL.
|
|
*/
|
|
int iucv_reply (u16 pathid,
|
|
u32 msgid,
|
|
u32 trgcls,
|
|
int flags1,
|
|
void *buffer, ulong buflen, ulong * residual_buffer,
|
|
ulong * residual_length);
|
|
|
|
/*
|
|
* Name: iucv_reply_array
|
|
* Purpose: This function responds to the two-way messages that you
|
|
* receive. You must identify completely the message to
|
|
* which you wish to reply. ie, pathid, msgid, and trgcls.
|
|
* The array identifies a list of addresses and lengths of
|
|
* discontiguous buffers that contains the reply data.
|
|
* Input: pathid - Path identification number
|
|
* msgid - Specifies the message ID.
|
|
* trgcls - Specifies target class.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20, Specifies if you want to send priority message.
|
|
* buffer - Address of array of reply buffers.
|
|
* buflen - Total length of reply buffers.
|
|
* Output: residual_buffer - Address of buffer which IUCV is currently working on.
|
|
* residual_length - Contains one of the following values:
|
|
* If the answer buffer is the same length as the reply, this field
|
|
* contains zero.
|
|
* If the answer buffer is longer than the reply, this field contains
|
|
* the number of bytes remaining in the buffer.
|
|
* If the answer buffer is shorter than the reply, this field contains
|
|
* a residual count (that is, the number of bytes remianing in the
|
|
* reply that does not fit into the buffer. In this
|
|
* case b2f0_result = 5.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer address is NULL.
|
|
*/
|
|
int iucv_reply_array (u16 pathid,
|
|
u32 msgid,
|
|
u32 trgcls,
|
|
int flags1,
|
|
iucv_array_t * buffer,
|
|
ulong buflen, ulong * residual_address,
|
|
ulong * residual_length);
|
|
|
|
/*
|
|
* Name: iucv_reply_prmmsg
|
|
* Purpose: This function responds to the two-way messages that you
|
|
* receive. You must identify completely the message to
|
|
* which you wish to reply. ie, pathid, msgid, and trgcls.
|
|
* Prmmsg signifies the data is moved into the
|
|
* parameter list.
|
|
* Input: pathid - Path identification number.
|
|
* msgid - Specifies the message ID.
|
|
* trgcls - Specifies target class.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20 Specifies if you want to send priority message.
|
|
* prmmsg - 8-bytes of data to be placed into the parameter.
|
|
* list.
|
|
* Output: NA
|
|
* Return: Return code from CP IUCV call.
|
|
*/
|
|
int iucv_reply_prmmsg (u16 pathid,
|
|
u32 msgid, u32 trgcls, int flags1, uchar prmmsg[8]);
|
|
|
|
/*
|
|
* Name: iucv_resume
|
|
* Purpose: This function restores communications over a quiesced path
|
|
* Input: pathid - Path identification number.
|
|
* user_data - 16-bytes of user data.
|
|
* Output: NA
|
|
* Return: Return code from CP IUCV call.
|
|
*/
|
|
int iucv_resume (u16 pathid, uchar user_data[16]);
|
|
|
|
/*
|
|
* Name: iucv_send
|
|
* Purpose: This function transmits data to another application.
|
|
* Data to be transmitted is in a buffer and this is a
|
|
* one-way message and the receiver will not reply to the
|
|
* message.
|
|
* Input: pathid - Path identification number.
|
|
* trgcls - Specifies target class.
|
|
* srccls - Specifies the source message class.
|
|
* msgtag - Specifies a tag to be associated with the message.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20 Specifies if you want to send priority message.
|
|
* buffer - Address of send buffer.
|
|
* buflen - Length of send buffer.
|
|
* Output: msgid - Specifies the message ID.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer address is NULL.
|
|
*/
|
|
int iucv_send (u16 pathid,
|
|
u32 * msgid,
|
|
u32 trgcls,
|
|
u32 srccls, u32 msgtag, int flags1, void *buffer, ulong buflen);
|
|
|
|
/*
|
|
* Name: iucv_send_array
|
|
* Purpose: This function transmits data to another application.
|
|
* The contents of buffer is the address of the array of
|
|
* addresses and lengths of discontiguous buffers that hold
|
|
* the message text. This is a one-way message and the
|
|
* receiver will not reply to the message.
|
|
* Input: pathid - Path identification number.
|
|
* trgcls - Specifies target class.
|
|
* srccls - Specifies the source message class.
|
|
* msgtag - Specifies a tag to be associated witht the message.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- specifies if you want to send priority message.
|
|
* buffer - Address of array of send buffers.
|
|
* buflen - Total length of send buffers.
|
|
* Output: msgid - Specifies the message ID.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer address is NULL.
|
|
*/
|
|
int iucv_send_array (u16 pathid,
|
|
u32 * msgid,
|
|
u32 trgcls,
|
|
u32 srccls,
|
|
u32 msgtag,
|
|
int flags1, iucv_array_t * buffer, ulong buflen);
|
|
|
|
/*
|
|
* Name: iucv_send_prmmsg
|
|
* Purpose: This function transmits data to another application.
|
|
* Prmmsg specifies that the 8-bytes of data are to be moved
|
|
* into the parameter list. This is a one-way message and the
|
|
* receiver will not reply to the message.
|
|
* Input: pathid - Path identification number.
|
|
* trgcls - Specifies target class.
|
|
* srccls - Specifies the source message class.
|
|
* msgtag - Specifies a tag to be associated with the message.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20 specifies if you want to send priority message.
|
|
* prmmsg - 8-bytes of data to be placed into parameter list.
|
|
* Output: msgid - Specifies the message ID.
|
|
* Return: Return code from CP IUCV call.
|
|
*/
|
|
int iucv_send_prmmsg (u16 pathid,
|
|
u32 * msgid,
|
|
u32 trgcls,
|
|
u32 srccls, u32 msgtag, int flags1, uchar prmmsg[8]);
|
|
|
|
/*
|
|
* Name: iucv_send2way
|
|
* Purpose: This function transmits data to another application.
|
|
* Data to be transmitted is in a buffer. The receiver
|
|
* of the send is expected to reply to the message and
|
|
* a buffer is provided into which IUCV moves the reply
|
|
* to this message.
|
|
* Input: pathid - Path identification number.
|
|
* trgcls - Specifies target class.
|
|
* srccls - Specifies the source message class.
|
|
* msgtag - Specifies a tag associated with the message.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20 Specifies if you want to send priority message.
|
|
* buffer - Address of send buffer.
|
|
* buflen - Length of send buffer.
|
|
* ansbuf - Address of buffer into which IUCV moves the reply of
|
|
* this message.
|
|
* anslen - Address of length of buffer.
|
|
* Output: msgid - Specifies the message ID.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer or ansbuf address is NULL.
|
|
*/
|
|
int iucv_send2way (u16 pathid,
|
|
u32 * msgid,
|
|
u32 trgcls,
|
|
u32 srccls,
|
|
u32 msgtag,
|
|
int flags1,
|
|
void *buffer, ulong buflen, void *ansbuf, ulong anslen);
|
|
|
|
/*
|
|
* Name: iucv_send2way_array
|
|
* Purpose: This function transmits data to another application.
|
|
* The contents of buffer is the address of the array of
|
|
* addresses and lengths of discontiguous buffers that hold
|
|
* the message text. The receiver of the send is expected to
|
|
* reply to the message and a buffer is provided into which
|
|
* IUCV moves the reply to this message.
|
|
* Input: pathid - Path identification number.
|
|
* trgcls - Specifies target class.
|
|
* srccls - Specifies the source message class.
|
|
* msgtag - Specifies a tag to be associated with the message.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20 Specifies if you want to send priority message.
|
|
* buffer - Sddress of array of send buffers.
|
|
* buflen - Total length of send buffers.
|
|
* ansbuf - Address of array of buffer into which IUCV moves the reply
|
|
* of this message.
|
|
* anslen - Address of length reply buffers.
|
|
* Output: msgid - Specifies the message ID.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer address is NULL.
|
|
*/
|
|
int iucv_send2way_array (u16 pathid,
|
|
u32 * msgid,
|
|
u32 trgcls,
|
|
u32 srccls,
|
|
u32 msgtag,
|
|
int flags1,
|
|
iucv_array_t * buffer,
|
|
ulong buflen, iucv_array_t * ansbuf, ulong anslen);
|
|
|
|
/*
|
|
* Name: iucv_send2way_prmmsg
|
|
* Purpose: This function transmits data to another application.
|
|
* Prmmsg specifies that the 8-bytes of data are to be moved
|
|
* into the parameter list. This is a two-way message and the
|
|
* receiver of the message is expected to reply. A buffer
|
|
* is provided into which IUCV moves the reply to this
|
|
* message.
|
|
* Input: pathid - Rath identification number.
|
|
* trgcls - Specifies target class.
|
|
* srccls - Specifies the source message class.
|
|
* msgtag - Specifies a tag to be associated with the message.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20 Specifies if you want to send priority message.
|
|
* prmmsg - 8-bytes of data to be placed in parameter list.
|
|
* ansbuf - Address of buffer into which IUCV moves the reply of
|
|
* this message.
|
|
* anslen - Address of length of buffer.
|
|
* Output: msgid - Specifies the message ID.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Buffer address is NULL.
|
|
*/
|
|
int iucv_send2way_prmmsg (u16 pathid,
|
|
u32 * msgid,
|
|
u32 trgcls,
|
|
u32 srccls,
|
|
u32 msgtag,
|
|
ulong flags1,
|
|
uchar prmmsg[8], void *ansbuf, ulong anslen);
|
|
|
|
/*
|
|
* Name: iucv_send2way_prmmsg_array
|
|
* Purpose: This function transmits data to another application.
|
|
* Prmmsg specifies that the 8-bytes of data are to be moved
|
|
* into the parameter list. This is a two-way message and the
|
|
* receiver of the message is expected to reply. A buffer
|
|
* is provided into which IUCV moves the reply to this
|
|
* message. The contents of ansbuf is the address of the
|
|
* array of addresses and lengths of discontiguous buffers
|
|
* that contain the reply.
|
|
* Input: pathid - Path identification number.
|
|
* trgcls - Specifies target class.
|
|
* srccls - Specifies the source message class.
|
|
* msgtag - Specifies a tag to be associated with the message.
|
|
* flags1 - Option for path.
|
|
* IPPRTY- 0x20 specifies if you want to send priority message.
|
|
* prmmsg - 8-bytes of data to be placed into the parameter list.
|
|
* ansbuf - Address of array of buffer into which IUCV moves the reply
|
|
* of this message.
|
|
* anslen - Address of length of reply buffers.
|
|
* Output: msgid - Specifies the message ID.
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Ansbuf address is NULL.
|
|
*/
|
|
int iucv_send2way_prmmsg_array (u16 pathid,
|
|
u32 * msgid,
|
|
u32 trgcls,
|
|
u32 srccls,
|
|
u32 msgtag,
|
|
int flags1,
|
|
uchar prmmsg[8],
|
|
iucv_array_t * ansbuf, ulong anslen);
|
|
|
|
/*
|
|
* Name: iucv_setmask
|
|
* Purpose: This function enables or disables the following IUCV
|
|
* external interruptions: Nonpriority and priority message
|
|
* interrupts, nonpriority and priority reply interrupts.
|
|
* Input: SetMaskFlag - options for interrupts
|
|
* 0x80 - Nonpriority_MessagePendingInterruptsFlag
|
|
* 0x40 - Priority_MessagePendingInterruptsFlag
|
|
* 0x20 - Nonpriority_MessageCompletionInterruptsFlag
|
|
* 0x10 - Priority_MessageCompletionInterruptsFlag
|
|
* 0x08 - IUCVControlInterruptsFlag
|
|
* Output: NA
|
|
* Return: Return code from CP IUCV call.
|
|
*/
|
|
int iucv_setmask (int SetMaskFlag);
|
|
|
|
/*
|
|
* Name: iucv_sever
|
|
* Purpose: This function terminates an IUCV path.
|
|
* Input: pathid - Path identification number.
|
|
* user_data - 16-bytes of user data.
|
|
* Output: NA
|
|
* Return: Return code from CP IUCV call.
|
|
* (-EINVAL) - Interal error, wild pointer.
|
|
*/
|
|
int iucv_sever (u16 pathid, uchar user_data[16]);
|