|
NAMEpvm_pack - Pack the active message buffer with arrays of prescribed data type.SYNOPSISC PARAMETERS
DESCRIPTIONEach of the pvm_pk* routines packs an array of the given data type into the active send buffer. The arguments for each of the routines are a pointer to the first item to be packed, nitem which is the total number of items to pack from this array, and stride which is the stride to use when packing.An exception is pvm_pkstr() which by definition packs a NULL terminated character string and thus does not need nitem or stride arguments. The Fortran routine pvmfpack( STRING, ... ) expects nitem to be the number of characters in the string and stride to be 1. A null string ("") can be packed; this is just a string with no characters before the terminating '\0'. However, packing a null string pointer, (char *)0, is not allowed. If the packing is successful, info will be 0. If some error occurs then info will be < 0. A single variable (not an array) can be packed by setting nitem = 1 and stride = 1. The routine pvm_packf() uses a printf-like format expression to specify what and how to pack data into the send buffer. All variables are passed as addresses if count and stride are specified otherwise, variables are assumed to be values. A BNF-like description of the format syntax is: format : null | init | format fmt init : null | '%' '+' fmt : '%' count stride modifiers fchar fchar : 'c' | 'd' | 'f' | 'x' | 's' count : null | [0-9]+ | '*' stride : null | '.' ( [0-9]+ | '*' ) modifiers : null | modifiers mchar mchar : 'h' | 'l' | 'u' Formats: + means initsend - must match an int (how) in the param list. c pack/unpack bytes d integers f float x complex float s string Modifiers: h short (int) l long (int, float, complex float) u unsigned (int) Future extensions to the what argument in pvmfpack will include 64 bit types when XDR encoding of these types is available. Meanwhile users should be aware that precision can be lost when passing data from a 64 bit machine like a Cray to a 32 bit machine like a SPARCstation. As a mnemonic the what argument name includes the number of bytes of precision to expect. By setting encoding to PVMRAW (see pvmfinitsend) data can be transferred between two 64 bit machines with full precision even if the PVM configuration is heterogeneous. Messages should be unpacked exactly like they were packed to insure data integrity. Packing integers and unpacking them as floats will often fail because a type encoding will have occurred transferring the data between heterogeneous hosts. Packing 10 integers and 100 floats then trying to unpack only 3 integers and the 100 floats will also fail. EXAMPLESC: info = pvm_initsend( PvmDataDefault ); info = pvm_pkstr( "initial data" ); info = pvm_pkint( &size, 1, 1 ); info = pvm_pkint( array, size, 1 ); info = pvm_pkdouble( matrix, size*size, 1 ); msgtag = 3 ; info = pvm_send( tid, msgtag ); int count, *iarry; double darry[4]; pvm_packf("%+ %d %*d %4lf", PvmDataRaw, count, count, iarry, darry); Fortran: CALL PVMFINITSEND(PVMRAW, INFO) CALL PVMFPACK( INTEGER4, NSIZE, 1, 1, INFO ) CALL PVMFPACK( STRING, 'row 5 of NXN matrix', 19, 1, INFO ) CALL PVMFPACK( REAL8, A(5,1), NSIZE, NSIZE , INFO ) CALL PVMFSEND( TID, MSGTAG, INFO ) WARNINGSStrings cannot be packed when using the PvmDataInPlace encoding, due to limitations in the implementation. Attempting to pack a string using pvm_pkstr or pvm_packf will cause error code PvmNotImpl to be returned.ERRORS
SEE ALSOpvm_initsend(3PVM), pvm_unpack(3PVM), pvm_send(3PVM), pvm_recv(3PVM), pvm_pkmesg(3PVM)
Visit the GSP FreeBSD Man Page Interface. |