次の方法で共有


MC_RECEIVE_AND_WAIT

MC_RECEIVE_AND_WAIT動詞は、パートナー トランザクション プログラム (TP) から現在使用できるデータを受け取ります。 現在使用可能なデータがない場合、ローカル TP はデータの到着を待機します。

非同期サポートを完全に使用できるようにするために、非同期的に発行 されたMC_RECEIVE_AND_WAIT 動詞は 、MC_RECEIVE_AND_POST 動詞のように動作するように変更されています。 具体的には、非同期 MC_RECEIVE_AND_WAIT は未処理ですが、同じ会話で次の動詞を発行できます。

  • GET_TYPE

  • MC_GET_ATTRIBUTES

  • MC_REQUEST_TO_SEND

  • MC_SEND_ERROR

  • MC_TEST_RTS

  • TP_ENDED

    これにより、アプリケーション、特に 5250 エミュレーターで非同期 MC_RECEIVE_AND_WAIT を使用してデータを受信できます。 MC_RECEIVE_AND_WAITは未処理ですが、MC_SEND_ERRORMC_REQUEST_TO_SENDを引き続き使用できます。 完全な非同期サポートには、この機能を使用することをお勧めします。

    次の構造体では、 MC_RECEIVE_AND_WAIT 動詞で使用される動詞制御ブロック (VCB) について説明します。

構文

  
struct mc_receive_and_wait {  
    unsigned short      opcode;  
    unsigned char       opext;  
    unsigned char       reserv2;  
    unsigned short      primary_rc;  
    unsigned long       secondary_rc;  
    unsigned char       tp_id[8];  
    unsigned long       conv_id;  
    unsigned short      what_rcvd;  
    unsigned char       rtn_status;  
    unsigned char       reserv4;  
    unsigned char       rts_rcvd;  
    unsigned char       reserv5;  
    unsigned short      max_len;  
    unsigned short      dlen;  
    unsigned char FAR * dptr;  
    unsigned char       reserv6[5];  
};   

メンバー

opcode
指定されたパラメーター。 動詞操作コード (AP_M_RECEIVE_AND_WAIT) を指定します。

opext
指定されたパラメーター。 動詞操作拡張機能をAP_MAPPED_CONVERSATION指定します。

reserv2
予約済みフィールド。

primary_rc
返されたパラメーター。 動詞の完了時に APPC によって設定されるプライマリ リターン コードを指定します。 有効なリターン コードは、発行された APPC 動詞によって異なります。 この動詞の有効なエラーコードについては、「リターン コード」を参照してください。

secondary_rc
返されたパラメーター。 動詞の完了時に APPC によって設定されるセカンダリ リターン コードを指定します。 有効なリターン コードは、発行された APPC 動詞によって異なります。 この動詞の有効なエラーコードについては、「リターン コード」を参照してください。

tp_id
指定されたパラメーター。 ローカル TP を識別します。

このパラメーターの値は、呼び出し元の TP の TP_STARTED または呼び出された TP の RECEIVE_ALLOCATE によって返されます。

conv_id
指定されたパラメーター。 会話識別子を指定します。

このパラメーターの値は、呼び出し元の TP で MC_ALLOCATE するか、呼び出された TP で RECEIVE_ALLOCATE することによって返されます。

what_rcvd
返されたパラメーター。 データまたは会話の状態が受信されたかどうかを示します。

  • AP_CONFIRM_DEALLOCATEは、パートナー TP が AP_SYNC_LEVEL に設定dealloc_typeMC_DEALLOCATEを発行し、MC_ALLOCATEによって確立された会話の同期レベルがAP_CONFIRM_SYNC_LEVELされることを示します。 この値を受け取ると、ローカル TP は通常 、MC_CONFIRMEDを発行します。

  • AP_CONFIRM_SENDは、パートナー TP が AP_SYNC_LEVEL に設定ptr_typeMC_PREPARE_TO_RECEIVEを発行し、MC_ALLOCATEによって確立された会話の同期レベルがAP_CONFIRM_SYNC_LEVELされていることを示します。 この値を受け取ると、ローカル TP は通常 、MC_CONFIRMED を発行し、データの送信を開始します。

  • AP_CONFIRM_WHAT_RECEIVEDは、パートナー TP が MC_CONFIRMを発行したことを示します。 この値を受け取ると、ローカル TP は通常 、MC_CONFIRMEDを発行します。

  • AP_DATA_COMPLETEは、 MC_RECEIVE_AND_WAITに対して、ローカル TP が完全なデータ レコードまたはデータ レコードの最後の部分を受信したことを示します。 この値を受け取ると、ローカル TP は通常、 MC_RECEIVE_AND_WAIT を再発行するか、別の受信動詞を発行します。 パートナー TP がより多くのデータを送信した場合、ローカル TP は新しいデータユニットの受信を開始します。

    それ以外の場合、primary_rc にAP_OK が含まれており、what_rcvdにAP_SEND、AP_CONFIRM_SEND、AP_CONFIRM_DEALLOCATE、またはAP_CONFIRM_WHAT_RECEIVED が含まれている 場合、ローカル TP は状態情報を調べます。

    ローカル TP が通常実行する次のアクションについては、このトピックの「リターン コード」を参照してください。

    primary_rcにAP_DEALLOC_NORMALが含まれている場合、パートナー TP によって発行された MC_DEALLOCATE に応じて、会話の割り当てが解除されます。

  • AP_DATA_INCOMPLETEは、ローカル TP が不完全なデータ レコードを受信したことを示します。 max_len パラメーターは、データ レコードの長さより小さい値を指定しました (レコードを読み取る最初の受信動詞でない場合は、データ レコードの残りの部分より小さい値)。 この値を受け取ると、ローカル TP は通常 、レコードの次の部分を 受信するためにMC_RECEIVE_AND_WAITを再発行 (または別の受信動詞を発行) します。

  • AP_NONEは、TP がデータまたは会話の状態インジケーターを受信しなかったことを示します。

  • AP_SENDは、パートナー TP に対して、会話が RECEIVE 状態に入っていることを示します。 ローカル TP の場合、会話は SEND 状態になりました。 この値を受け取ると、ローカル TP は通常 、MC_SEND_DATA を使用してデータの送信を開始します。

    rtn_status
    指定されたパラメーター。 データと会話の状態インジケーターの両方を 1 つの API 呼び出し内で返す必要があるかどうかを示します。

  • AP_NOは、動詞の個別の呼び出しでインジケーターを個別に返す必要があることを指定します。

  • AP_YESは、両方が使用可能な場合に、インジケーターを一緒に返す必要があることを指定します。 どちらも、次の場合に返すことができます。

    受信バッファーは、状態インジケーターの前にあるすべてのデータを保持するのに十分な大きさです。

    データは、状態インジケーターの前の最後のデータ レコードです。

    rts_rcvd
    返されたパラメーター。 送信要求インジケーターを含みます。

  • AP_YESは、パートナー TP が MC_REQUEST_TO_SENDを発行したことを示します。これにより、ローカル TP が会話を RECEIVE 状態に変更するように要求されます。

  • AP_NOは、パートナー TP が MC_REQUEST_TO_SENDを発行していないことを示します。

    max_len
    指定されたパラメーター。 ローカル TP が受信できるデータの最大バイト数を示します。 範囲は 0 ~ 65535 です。

    Microsoft Windows オペレーティング システムと Windows グラフィカル環境の場合、この値は、受信したデータを格納するバッファーの長さを超えてはなりません。

    OS/2 オペレーティング・システムの場合、 dptr のオフセットと max_len の値は、データ・セグメントのサイズを超えてはなりません。

    max_lenを 0 に設定してMC_RECEIVE_AND_WAITを発行すると、ローカル TP は、パートナー TP が送信するデータを持っているか、確認をシークするか、会話の状態を変更したかを判断できます。

    dlen
    返されたパラメーター。 受信したデータのバイト数を示します。 データは dptr で指定されたバッファーに格納されます。 長さが 0 の場合は、データが受信されなかったことを示します。

    dptr
    指定されたパラメーター。 ローカル TP によって受信されたデータを格納するバッファーのアドレスを提供します。

    Windows オペレーティング システムと Windows グラフィカル環境の場合、データ バッファーは静的データ領域またはグローバルに割り当てられた領域に存在できます。 データ バッファーは、この領域内に完全に収まる必要があります。

    OS/2 オペレーティング システムの場合、データ バッファーは、フラグが 1 に等しい DosAllocSeg 関数によって割り当てられる、名前のない共有セグメント上に存在する必要があります。 データ バッファーは、データ セグメントに完全に収まる必要があります。

    Windows 環境の場合、データ バッファーは静的データ領域またはグローバルに割り当てられた領域に存在できます。 データ バッファーは、この領域内に完全に収まる必要があります。

リターン コード

AP_OK
プライマリ リターン コード。動詞は正常に実行されました。

rtn_statusがAP_YESされると、上記の戻りコードまたは次のいずれかの戻りコードを返すことができます。

AP_DATA_COMPLETE_SEND

プライマリ リターン コード。これは、AP_DATA_COMPLETEとAP_SENDの組み合わせです。

AP_DATA_COMPLETE_CONFIRM_SEND

プライマリ リターン コード。これは、AP_DATA_COMPLETEとAP_CONFIRM_SENDの組み合わせです。

AP_DATA_COMPLETE_CONFIRM

プライマリ リターン コード。これは、AP_DATA_COMPLETEとAP_CONFIRM_WHAT_RECEIVEDの組み合わせです。

AP_DATA_COMPLETE_CONFIRM_DEALL

プライマリ リターン コード。これは、AP_DATA_COMPLETEとAP_CONFIRM_DEALLOCATEの組み合わせです。

AP_DEALLOC_NORMAL
プライマリ リターン コード。パートナー TP は、確認を要求せずに会話の割り当てを解除し、 dealloc_type 次のいずれかに設定 されたMC_DEALLOCATE を発行しました。

  • AP_CONFIRM_SYNC_LEVEL

  • AP_FLUSH

  • AP_NONEとして指定された会話の同期レベルを使用してAP_SYNC_LEVEL

    rtn_statusがAP_YES場合は、what_rcvdも調べます。

    AP_PARAMETER_CHECK
    プライマリ リターン コード。パラメーター エラーのため、動詞は実行されませんでした。

    AP_BAD_CONV_ID

    セカンダリ リターン コード。 conv_id の値が、APPC によって割り当てられた会話識別子と一致しませんでした。

    AP_BAD_TP_ID

    セカンダリ リターン コード。 tp_id の値が、APPC によって割り当てられた TP 識別子と一致しませんでした。

    AP_BAD_RETURN_STATUS_WITH_DATA

    セカンダリ リターン コード。指定した rtn_status 値が APPC によって認識されませんでした。

    AP_INVALID_DATA_SEGMENT

    セカンダリ リターン コード。データ バッファーに指定された長さが、バッファーを格納するために割り当てられたセグメントよりも長かった。

    AP_STATE_CHECK
    プライマリ リターン コード。動詞は無効な状態で発行されたため、実行されませんでした。

    AP_RCV_AND_WAIT_BAD_STATE

    セカンダリ リターン コード。TP がこの動詞を発行したときに、会話が RECEIVE または SEND 状態ではなかった。

    AP_ALLOCATION_ERROR
    プライマリ リターン コード。APPC で会話の割り当てに失敗しました。 会話の状態は RESET に設定されます。

    このコードは、 MC_ALLOCATE後に発行された動詞を介して返される場合があります。

    AP_ALLOCATION_FAILURE_NO_RETRY

    セカンダリ リターン コード。構成エラーやセッション プロトコル エラーなどの永続的な条件のため、会話を割り当てることができません。 エラーを特定するには、システム管理者がエラー ログ ファイルを調べる必要があります。 エラーが修正されるまで、割り当てを再試行しないでください。

    AP_ALLOCATION_FAILURE_RETRY

    セカンダリ リターン コード。リンクエラーなどの一時的な状態のため、会話を割り当てませんでした。 エラーの理由は、システム エラー ログに記録されます。 割り当てを再試行してください。

    AP_CONVERSATION_TYPE_MISMATCH

    セカンダリ リターン コード。パートナー論理ユニット (LU) または TP は、割り当て要求で指定された会話の種類 (基本またはマップ) をサポートしていません。

    AP_PIP_NOT_ALLOWED

    セカンダリ リターン コード。割り当て要求で PIP データが指定されましたが、パートナー TP がこのデータを必要としないか、パートナー LU でサポートされていません。

    AP_PIP_NOT_SPECIFIED_CORRECTLY

    セカンダリ リターン コード。パートナー TP には PIP データが必要ですが、割り当て要求で PIP データが指定されていないか、パラメーターの数が正しくありません。

    AP_SECURITY_NOT_VALID

    セカンダリ リターン コード。割り当て要求で指定されたユーザー ID またはパスワードが、パートナー LU によって受け入れられなかった。

    AP_SYNC_LEVEL_NOT_SUPPORTED

    セカンダリ リターン コード。パートナー TP は、割り当て要求で指定された sync_level (AP_NONEまたはAP_CONFIRM_SYNC_LEVEL) をサポートしていないか、 sync_level が認識されませんでした。

    AP_TP_NAME_NOT_RECOGNIZED

    セカンダリ リターン コード。パートナー LU は、割り当て要求で指定された TP 名を認識しません。

    AP_TRANS_PGM_NOT_AVAIL_NO_RETRY

    セカンダリ リターン コード。リモート LU は、要求されたパートナー TP を開始できなかったため、割り当て要求を拒否しました。 条件は永続的です。 エラーの理由が、リモート ノードでログに記録されている可能性があります。 エラーが修正されるまで、割り当てを再試行しないでください。

    AP_TRANS_PGM_NOT_AVAIL_RETRY

    セカンダリ リターン コード。リモート LU は、要求されたパートナー TP を開始できなかったため、割り当て要求を拒否しました。 状態は一時的 (タイム アウトなど) である可能性があります。エラーの理由が、リモート ノードでログに記録されている可能性があります。 割り当てを再試行してください。

    AP_COMM_SUBSYSTEM_ABENDED
    プライマリ リターン コード。次のいずれかの条件を示します。

  • このメッセージ交換で使用されているノードで、ABEND が発生しました。

  • TP と PU 2.1 ノードの間の接続が切断されました (LAN エラー)。

  • TP のコンピューターの SnaBase で ABEND が発生しました。

    ABEND の理由を特定するには、システム管理者がエラー ログを調べる必要があります。

    AP_CONV_FAILURE_NO_RETRY
    プライマリ リターン コード。セッション プロトコル エラーなどの永続的な条件が原因で、会話が終了しました。 システム管理者は、システム エラー ログを調べて、エラーの原因を特定する必要があります。 エラーが修正されるまで、会話を再試行しないでください。

    AP_CONV_FAILURE_RETRY
    プライマリ リターン コード。一時的なエラーが発生したため、会話が終了しました。 TP を再起動して、問題が再度発生するかどうかを確認します。 その場合、システム管理者はエラー ログを調べて、エラーの原因を特定する必要があります。

    AP_CONVERSATION_TYPE_MIXED
    プライマリ リターン コード。TP は、基本的な会話動詞とマップされた会話動詞の両方を発行しました。 1 つの会話で発行できる型は 1 つだけです。

    AP_INVALID_VERB_SEGMENT
    プライマリ リターン コード。VCB がデータ セグメントの終わりを越えています。

    AP_PROG_ERROR_NO_TRUNC
    プライマリ リターン コード。会話が SEND 状態の間にパートナー TP が MC_SEND_ERROR を発行しました。 データは切り捨てられませんでした。

    AP_PROG_ERROR_PURGING
    プライマリ リターン コード。RECEIVE、PENDING、PENDING_POST、CONFIRM、CONFIRM_SEND、またはCONFIRM_DEALLOCATEの状態では、パートナー TP は MC_SEND_ERRORを発行します。 送信されたデータがまだ受信されていないデータは消去されます。

    AP_STACK_TOO_SMALL
    プライマリ リターン コード。アプリケーションのスタック サイズが小さすぎて動詞を実行できません。 アプリケーションのスタック サイズを増やしてください。

    AP_CONV_BUSY
    プライマリ リターン コード。どの会話にも、一度に 1 つの未処理の会話動詞しか存在できません。 これは、ローカル TP に複数のスレッドがあり、複数のスレッドが同じ conv_idを使用して APPC 呼び出しを発行している場合に発生する可能性があります。

    AP_THREAD_BLOCKING
    プライマリ リターン コード。呼び出し元のスレッドは、既にブロック呼び出しにあります。

    AP_UNEXPECTED_DOS_ERROR
    プライマリ リターン コード。ローカル TP からの APPC 呼び出しの処理中に、オペレーティング システムから APPC にエラーが返されました。 オペレーティング システムのリターン コードは、secondary_rc 経由で返されます。 これは、Intel バイトスワップ順で表示されます。 問題が解決しない場合は、システム管理者に問い合わせてください。

    AP_DEALLOC_ABEND
    プライマリ リターン コード。次のいずれかの理由で、会話の割り当てが解除されました。

  • dealloc_type が AP_ABEND に設定された MC_DEALLOCATE 発行されたパートナー TP。

  • パートナー TP で異常終了が発生し、パートナー LU から MC_DEALLOCATE 要求が送信されました。

注釈

ローカル TP は、次のプロセスを通じてデータを受信します。

  1. ローカル TP は、データの完全な単位の受信が完了するまで、受信動詞を発行します。 受信したデータは 1 つのデータ レコードです。

    ローカル TP は、データの完全な単位を受信するために、受信動詞を複数回発行する必要がある場合があります。 データの完全な単位を受信した後、ローカル TP はそれを操作できます。

    受信動詞は 、MC_RECEIVE_AND_POSTMC_RECEIVE_AND_WAITおよびMC_RECEIVE_IMMEDIATEです。

  2. ローカル TP は、受信動詞を再度発行します。 これには、次のいずれかの効果があります。

    • パートナー TP がより多くのデータを送信した場合、ローカル TP は新しいデータユニットの受信を開始します。

    • パートナー TP がデータの送信を完了した場合、または確認を待機している場合、状態情報 ( what_rcvd パラメーターを使用して使用可能) は、ローカル TP が通常実行する次のアクションを示します。

    TP がこの動詞を発行する場合、会話は RECEIVE または SEND 状態である必要があります。

    SEND 状態で動詞を発行する

    メッセージ交換が SEND 状態の間に MC_RECEIVE_AND_WAIT を発行すると、次の効果があります。

  • ローカル LU は、送信バッファー内の情報と SEND インジケーターをパートナー TP に送信します。

  • 会話が RECEIVE 状態に変わります。ローカル TP は、パートナー TP がデータを送信するのを待機します。

    状態の変更

    新しい会話の状態は、次の要因によって決まります。

  • TP が動詞を発行したときの会話の状態。

  • primary_rc パラメーター。

  • primary_rcにAP_OKが含まれている場合、what_rcvd パラメーター。

    SEND 状態で発行された動詞

    次の表では、SEND 状態で MC_RECEIVE_AND_WAIT が発行され、 primary_rcがAP_OK された場合の状態の変更について詳しく説明します。

what_rcvd 新しい状態
AP_CONFIRM_DEALLOCATE CONFIRM_DEALLOCATE
AP_DATA_COMPLETE_CONFIRM_DEALL CONFIRM_DEALLOCATE
AP_DATA_CONFIRM_DEALLOCATE CONFIRM_DEALLOCATE
AP_CONFIRM_SEND CONFIRM_SEND
AP_DATA_COMPLETE_CONFIRM_SEND CONFIRM_SEND
AP_DATA_CONFIRM_SEND CONFIRM_SEND
AP_CONFIRM_WHAT_RECEIVED CONFIRM
AP_DATA_COMPLETE_CONFIRM CONFIRM
AP_DATA_CONFIRM CONFIRM
AP_DATA RECEIVE
AP_DATA_COMPLETE RECEIVE
AP_DATA_INCOMPLETE RECEIVE
AP_SEND 変更なし
AP_DATA_COMPLETE_SEND SEND_PENDING

次の表では、 MC_RECEIVE_AND_WAIT が SEND 状態で発行され、 primary_rcがAP_OK されていない場合の状態の変更について詳しく説明します。

primary_rc 新しい状態
AP_ALLOCATION_ERROR RESET
AP_CONV_FAILURE_RETRY RESET
AP_CONV_FAILURE_NO_RETRY RESET
AP_DEALLOC_ABEND RESET
AP_DEALLOC_ABEND_PROG RESET
AP_DEALLOC_ABEND_SVC RESET
AP_DEALLOC_ABEND_TIMER RESET
AP_DEALLOC_NORMAL RESET
AP_PROG_ERROR_PURGING RECEIVE
AP_PROG_ERROR_NO_TRUNC RECEIVE
AP_SVC_ERROR_PURGING RECEIVE
AP_SVC_ERROR_NO_TRUNC RECEIVE

RECEIVE 状態で発行された動詞

次の表では、RECEIVE 状態で MC_RECEIVE_AND_WAIT が発行され、 primary_rcがAP_OK された場合の状態の変更について詳しく説明します。

what_rcvd 新しい状態
AP_CONFIRM_DEALLOCATE CONFIRM_DEALLOCATE
AP_DATA_COMPLETE_CONFIRM_DEALL CONFIRM_DEALLOCATE
AP_DATA_CONFIRM_DEALLOCATE CONFIRM_DEALLOCATE
AP_CONFIRM_SEND CONFIRM_SEND
AP_DATA_COMPLETE_CONFIRM_SEND CONFIRM_SEND
AP_DATA_CONFIRM_SEND CONFIRM_SEND
AP_CONFIRM_WHAT_RECEIVED CONFIRM
AP_DATA_COMPLETE_CONFIRM CONFIRM
AP_DATA_CONFIRM CONFIRM
AP_DATA 変更なし
AP_DATA_COMPLETE 変更なし
AP_DATA_INCOMPLETE 変更なし
AP_SEND SEND
AP_DATA_COMPLETE_SEND SEND_PENDING

次の表では、MC_RECEIVE_AND_WAITが RECEIVE 状態で発行され、 primary_rcAP_OK されていない場合の状態の変更について詳しく説明します。

primary_rc 新しい状態
AP_ALLOCATION_ERROR RESET
AP_CONV_FAILURE_RETRY RESET
AP_CONV_FAILURE_NO_RETRY RESET
AP_DEALLOC_ABEND RESET
AP_DEALLOC_ABEND_PROG RESET
AP_DEALLOC_ABEND_SVC RESET
AP_DEALLOC_ABEND_TIMER RESET
AP_DEALLOC_NORMAL RESET
AP_PROG_ERROR_PURGING 変更なし
AP_PROG_ERROR_NO_TRUNC 変更なし
AP_SVC_ERROR_PURGING 変更なし
AP_SVC_ERROR_NO_TRUNC 変更なし
AP_PROG_ERROR_TRUNC 変更なし
AP_SVC_ERROR_TRUNC 変更なし